## Bipolar Microprocessor logic and Interface

## BIPOLAR



## $\square$

## Advanced Micro Devices

## Bipolar <br> Microprocessor Logic and Interface Data Book


(c) 1985 Advanced Micro Devices, Inc.

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry.

For specific testing details contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

901 Thompson Place, P.O. Box 3453, Sunnyvale, California 94088
(408) 732-2400 TWX: 910-339-9280 TELEX: 34-6306

Printed in U.S.A.


| Am2900 | BIT-SLICE PROCESSORS |
| :--- | :--- |
| PROCESSORS | MICROCDE SEQUENCERS |
| AND PERIPHERALS | LSI PERIPHERELS |


Am29500
ARRAY ANB DICITAL
SICNAL PROCESSIIUG

## $16 \times 16$ PARALLEL MULTIPLIERS MULTIPORT PIPELINED PROCESSORS

 FFT ADDRESS SEQUENCERS```
Am29800
HIGH PERFORMANCE BUS INTERFACE
```


## 8, 9, AND 10-BIT IMOX BUS INTERFACE

## DIAGNOSTIC REGISTERS




## Index Section

Numeric Device Index ..... 1-1
Functional Index ..... 1-5

Am25LS07
Am25LS08
Am25LS09
Am25LS14A
Am25LS15
Am25LS22
Am25LS23
Am25LS2513
Am25LS2517
Am25LS2518
Am25LS2519
Am25LS2520
Am25LS2521
Am25LS2535
Am25LS2536
Am25LS2537
Am25LS2538
Am25LS2539
Am25LS2548
Am25LS2568
Am25LS2569
Am25LS381
Am25S05
Am25S07
Am25S08
Am25S09
Am25S10
Am25S18
Am25S557
Am25S558
Am26LS27
Am26LS28
Am26LS29
Am26LS30
Am26LS31
Am26LS32
Am26LS32B
Am26LS33
Am26LS34
Am26LS38
Am26S02
Am26S10
Hex/Quad Parallel D Registers with Register Enable ..... 9-8
Hex/Quad Parallel D Registers with Register Enable ..... 9-8
Quad Two-Input, High-Speed Register ..... 9-20
8-Bit Serial/Parallel Two's Complement Multiplier ..... 9-38
Quad Serial Adder/Subtractor ..... 9-45
8-Bit Serial/Parallel Register with Sign Extend ..... 9-57
8-Bit Shift/Storage Register with Synchronous Clear ..... 9-64
Three-State Priority Encoder ..... 9-69
Arithmetic Logic Unit/Function Generator Low-Power Schottky Integrated Circuits ..... 9-77
Quad D Register with Standard and Three-State Outputs ..... 9-89
Quad Register with Two Independently Controlled Three-State Outputs ..... 9-95
Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control ..... 9-101
Eight-Bit Equal-to Comparator ..... 9-108
Eight-Input Multiplexer with Control Register ..... 9-113
Eight-Bit Decoder with Control Storage ..... 9-120
One-of-Ten Decoder with Three-State Outputs and Polarity Control ..... 9-125
One-of-Eight Decoder with Three-State Outputs and Polarity Control ..... 9-131
Dual One-of-Four Decoder with Three-State Outputs and Polarity Control ..... 9-138
Chip Select Address Decoder with Acknowledge ..... 9-144
Four-Bit Up/Down Counters with Three-State Outputs ..... 9-157
Four-Bit Up/Down Counters with Three-State Outputs ..... 9-157
Arithmetic Logic Unit/Function Generator Low-Power Schottky Integrated Circuits ..... 9-77
Four-Bit by Two-Bit Two's Complement Multiplier ..... 9-1
Hex/Quad Parallel D Register with Register Enable ..... 9-13
Hex/Quad Parallel D Register with Register Enable. ..... 9-13
Quad Two-Input, High-Speed Register ..... 9-26
Four-Bit Shifter with Three-State Outputs ..... 9-32
Quad D Register with Standard and Three-State Outputs ..... 9-51
Eight-Bit by Eight-Bit Combinatorial Multiplier ..... 9-150
Eight-Bit by Eight-Bit Combinatorial Multiplier ..... 9-150
Dual EIA RS-485 Party Line Transceivers ..... 10-19
Dual EIA RS-485 Party Line Transceivers ..... 10-19
Quad Three-State Single Ended RS-423 Line Driver ..... 10-20
Dual Differential RS-422 Party Line/Quad
Single Ended RS-423 Line Driver ..... 10-26
Quad High Speed Differential Line Driver ..... 10-34
Quad Differential Line Receivers ..... 10-40
Quad Differential Line Receiver ..... 10-42
Quad Differential Line Receivers ..... 10-40
Quad Differential Line Receiver ..... 10-46
Quad Differential Backplane Transceiver ..... 10-50
Schottky Dual Retriggerable, Resettable Monostable Multivibrator ..... 10-1
Quad Bus Transceivers ..... 10-7

## NUMERICAL DEVICE INDEX (Cont.)

Am26S11 Quad Bus Transceivers ..... 10-7
Quad Bus Transceivers ..... 10-15
Quad Bus Transceivers ..... 10-15
Quad D Register with Standard and Three-State Outputs ..... 5-160
A High-Performance 16-Bit Bipolar Microprocessor ..... 6-50
$12 \times 12$ Multiplier Accumulator ..... 7-15
$16 \times 16$ Multiplier Accumulator ..... 7-26
Fuse Programmable Controller (FPC) ..... 6-59
Four-Bit Bipolar Microprocessor Slice ..... 5-1
Four-Bit Bipolar Microprocessor Slice ..... 5-1
High-Speed Look-Ahead Carry Generator ..... 5-19
Four-Bit Bipolar Microprocessor Slice ..... 5-25
Status and Shift Control Unit ..... 5-48
Quad Two-Input OC Bus Transceiver with Three-State Receiver ..... 5-65
Quad Two-Input OC Transceiver with Parity ..... 5-73
Quad Bus Transceivers with Interface Logic ..... 5-81
Quad Bus Transceivers with Interface Logic ..... 5-81
Microprogram Sequencers ..... 5-93
Microprogram Controller ..... 5-166
High-Performance Controller Products, Application Note ..... 6-1
Microprogram Sequencers ..... 5-93
A High-Performance 8-Bit Slice Microprogram Sequencer ..... 6-2
Real-Time Interrupt Controller ..... 6-18
A High-Performance 16-Bit Bipolar Microprocessor ..... 6-19
A High-Performance 16-Bit Bipolar Microprocessor ..... 6-50
A High-Performance 16-Bit Bipolar Microprocessor ..... 6-51
Eight-Bit Am29116 I/O Support ..... 6-52
Quad Bus Transceiver ..... 5-109
Priority Interrupt Expander ..... 5-115
Vectored Priority Interrupt Controller ..... 5-122
Quad Three-State Bus Transceiver with Interface Logic ..... 5-131
Quad Three-State Bus Transceiver with Interface Logic ..... 5-138
Quad Three-State Bus Transceiver with Interface Logic ..... 5-146
Quad D Register with Standard and Three-State Outputs ..... 5-154
Quad Register ..... 5-184
Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control ..... 5-191
Four-Bit Bipolar Microprocessor Slice ..... 5-336
One-of-Eight Decoder with Three-State Outputs and Polarity Control ..... 5-197
Eight-Input Multiplexer with Control Register ..... 5-203
Eight-Input Multiplexer ..... 5-45
Three-Line to Eight-Line Decoder/Demuliplexer ..... 5-210
Clock Generator and Microcycle Length Controller ..... 5-220
Quad Three-State Bus Transceivers With Clock Enable ..... 5-236
Quad Three-State Bus Transceivers With Clock Enable ..... 5-236
Program Control Unit ..... 5-245
Program Control Unit/Push-Pop Stack ..... 5-257
32-Bit Parallel Multiplier ..... 3-1
32-Bit Floating Point Processor ..... 3-2

## NUMERICAL DEVICE INDEX (Cont.)

Am29331Am29332Am29334Am29360Am29368Am2940Am2942Am2946Am2947Am2948Am2949Am2950Am2950AAm29501Am29509Am2951Am2951AAm29510Am29516Am 29517Am2952Am2952AAm29520Am 29521Am 29526Am29527Am29528Am29529Am29.53Am2953AAm 2954Am 29540Am2955Am2956Am2957Am2960Am2960AAm2961Am2962Am2964BAm2964CAm2965Am2966Am2968Am2969
16-Bit Microprogram Sequencer ..... 3-50
32-Bit Arithmetic Logic Unit ..... 3-52
Four-Port, Dual-Access Register File ..... 3-54
32-Bit Error Detection and Correction Unit ..... 3-55
1M-Bit Dynamic Memory Controller (DMC) ..... 3-56
DMA Address Generator ..... 5-268
Programmable Timer/Counter DMA Address Generator ..... 5-279
Octal Three-State Bidirectional Bus Transceivers ..... 5-291
Octal Three-State Bidirectional Bus Transceivers ..... 5-291
Octal Three-State Bidirectional Bus Transceivers ..... 5-300
Octal Three-State Bidirectional Bus Transceivers ..... 5-300
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-309
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-309
Multi-Port Pipelined Processor (Byte-Slice ${ }^{T M}$ ) ..... 7-3
$12 \times 12$ Multiplier Accumulator ..... 7-15
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-309
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-309
$16 \times 16$ Multiplier Accumulator ..... 7-26
$16 \times 16$-Bit Parallel Multipliers ..... 7-38
$16 \times 16$-Bit Parallel Multipliers ..... 7-38
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-319
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-319
Multilevel Pipeline Registers ..... 7-54
Multilevel Pipeline Registers ..... 7-54
High Speed Sine, Cosine Generators ..... 7-64
High Speed Sine, Cosine Generators ..... 7-64
High Speed Sine, Cosine Generators ..... 7-64
High Speed Sine, Cosine Generators ..... 7-64
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-319
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-319
Octal Registers with Three-State Outputs ..... 5-326
Programmable FFT Address Sequencer. ..... 7-69
Octal Registers with Three-State Outputs ..... 5-326
Octal Latches with Three-State Outputs ..... 5-331
Octal Latches with Three-State Outputs ..... 5-331
Cascadable 16-Bit Error ..... 4-5
Cascadable 16-Bit Error ..... 4-5
4-Bit Error Correction Multiple Bus Buffers ..... 4-44
4-Bit Error Correction Multiple Bus Buffers ..... 4-44
Dynamic Memory Controller ..... 4-52
Dynamic Memory Controller ..... 4-52
Octal Dynamic Memory Drivers with Three-State Outputs ..... 4-66
Octal Dynamic Memory Drivers with Three-State Outputs ..... 4-66
Dynamic Memory Controller (DMC) ..... 4-72
Dynamic Memory Timing Controller ..... 4-89
Dynamic Memory Timing Controller ..... 4-95
Programmable Event Generator (PEG) ..... 4-99
16-Way Branch Control Unit ..... 5-355
6-Bit Chip Select Decoder/9-Bit Equal-to-Comparator ..... 8-4
6-Bit Chip Select Decoder/9-Bit Equal-to-Comparator ..... 8-4
SSR ${ }^{\text {TM }}$ Diagnostics/WCS Pipeline Register ..... 8-13

## NUMERICAL DEVICE INDEX (Cont.)

Am29821
Am29822
Am29823
Am29824
Am29825
Am29826
Am29827
Am29828
Am29833
Am 29834
Am29841
Am29842
Am 29843
Am 29844
Am 29845
Am29846
Am29853
Am 29854
Am29861
Am29862
Am29863
Am 29864
Am54LS381
Am74LS381
Am7960
Am7990
Am7991A
Am7992A
Am8120

Am8127
Am8152A
Am8153A
Am8163
Am8167
8284A
8284A-1
8286
8287
8288
High Performance Bus Interface Registers ..... 8-23
High Performance Bus Interface Registers ..... 8-23
High Performance Bus Interface Registers ..... 8-23
High Performance Bus Interface Registers ..... 8-23
High Performance Bus Interface Registers ..... 8-23
High Performance Bus Interface Registers ..... 8-23
High Performance Buffers ..... 8-32
High Performance Buffers ..... 8-32
Parity Bus Transceivers ..... 8-38
Parity Bus Transceivers ..... 8-38
High Performance Bus Interface Latches ..... 8-48
High Performance Bus Interface Latches ..... 8-48
High Performance Bus Interface Latches ..... 8-48
High Performance Bus Interface Latches ..... 8-48
High Performance Bus Interface Latches ..... 8-48
High Performance Bus Interface Latches ..... 8-48
Parity Bus Transceivers ..... 8-38
Parity Bus Transceivers ..... 8-38
High Performance Bus Transceivers ..... 8-57
High Performance Bus Transceivers ..... 8-57
High Performance Bus Transceivers ..... 8-57
High Performance Bus Transceivers ..... 8-57
Arithmetic Logic Unit/Function Generator Low-Power Schottky Integrated Circuits ..... 9-77
Arithmetic Logic Unit/Function Generator Low-Power Schottky Integrated Circuits ..... 9-77
Coded Data Transceiver ..... 11-1
Local Area Network Controller for Ethernet (Lance) ..... 11-12
Serial Interface Adapter (SIA) ..... 11-37
Serial Interface Adapter (SIA) ..... 11-37
Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control ..... 11-50
AmZ8000 Clock Generator ..... 11-56
Video System Controller (VSC) ..... 11-67
Video System Controller (VSC) ..... 11-67
Dynamic Memory Timing, Refresh and EDC Controllers ..... 4-100
Dynamic Memory Timing, Refresh and EDC Controllers ..... 4-100
Clock Generator and Driver for 8086, 8088 Processors ..... 11-83
Clock Generator and Driver for 8086, 8088 Processors ..... 11-83
Octal Bus Transceivers ..... 11-92
Octal Bus Transceivers ..... 11-92
Bus Controller ..... 11-98

|  | FUNCTIONAL INDEX |
| :---: | :---: |
| Part Number | Description |
| High Speed | mable Registered ALUs |
| Am2901B | 4-Bit Slice, 16 Registers |
| Am2901C | Higher Speed 4-bit Slice, 16 Registers |
| Am2903 | Expanded Function 4-Bit Slice, 16 Registers |
| Am2903A | Higher Speed Version of Am2903 |
| Am29203 | Enhancement of Am2903A, Including BCD Arithmetic |
| Am29116 | 16-Bit Microprocessor Optimized for High Speed Control |
| Am29501 | Multiport, Pipelined Processor, 8-Bit Slice |
| ALU Auxiliary |  |
| Am2902A | Carry Lookahead |
| Am2904 | Status and Shift Control Unit for 2901, 2903, 29203 |
| Register File | or ALUs |
| Am29705 | 16-Word by 4-Bit Two-Port Register File, for 2903 |
| Am29705A | Higher Speed Version of 29705, for 2903A |
| Am29707 | 16-Word by 4-Bit Two-Port Register File, for 29203 |
| Multipliers |  |
| Am29510 | $16 \times 16$ Parallel Multiplier, with Accumulator |
| Am29L510 | $16 \times 16$ Parallel Multiplier, with Accumulator |
| Am29510A | Higher Speed Version of Am29510 |
| Am29516 | $16 \times 16$ Parallel Multiplier |
| Am29516A | Fastest Version of Am29516 |
| Am29L516 | Low-Power Version of Am29518, < 100 ns |
| Am29517 | $16 \times 16$ Parallel Multiplier with Clock Enables |
| Am29517A | Fastest Version of Am29517 |
| Am29L517 | Low-Power Version of Am29517, < 100ns |
| Am25LS14A | 8 -Bit Serial/Parallel Multiplier |
| Am25S557 | $8 \times 8$ Parallel Multiplier, with Latchable Outputs |
| Am25S558 | $8 \times 8$ Parallel Multiplier |
| Microprogram |  |
| Am2909A | 4-Bit Sequencer Slice |
| Am2910 | 12-Bit Single-Chip Sequencer for up to 4K Microwords |
| Am2910A | Fastest (IMOX) Version of Am2910, Plus Deeper Stack |
| Am2911A | 4-Bit Sequencer Slice, Compact Version of Am2909A |
| Am2930 | 4-Bit Program Control Slice |
| Am2932 | 4-Bit Program Control Slice, Compact Version of 2930 |
| Am29112 | Interruptible Sequencer, 31-Deep Stack, 8-Bit Slice |
| Am29803A | 16-Way Branch Control Unit, for 2909A and 2911A |
| Am29811A | Next Address Control Unit, for 2909A and 2911A |
| Microprogrammable Controller |  |
| Am29PL141 | Fuse Programmable Controller |
| Clocks |  |
| Am2925 | Single-Chip Clock, Microprogrammable Cycle Lengths |
|  |  |




| Part Number | Description |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Data Communications and Networking |  |  |  |  |  |
| Am26LS27 | Dual Party-Line Transceivers, Serial |  |  |  |  |
| Am26LS28 | Dual Party-Line Transceivers, Parallel |  |  |  |  |
| Am26LS29 | Quad Driver RS423, Three-State |  |  |  |  |
| Am26LS30 | Quad Driver RS422/423 |  |  |  |  |
| Am26LS31 | Quad Driver RS422, High-Speed |  |  |  |  |
| Am26LS32 | Quad Differential Line Receivers |  |  |  |  |
| Am26LS32B | Quad Differential Line Receiver RS422/423 |  |  |  |  |
| Am26LS33 | Quad Differential Line Receiver, High Common Mode |  |  |  |  |
| Am26LS38 | Quad Differential Backplane Transceiver |  |  |  |  |
| Am7960 | Coded Data Transceiver |  |  |  |  |
| Am7990 | Local Area Network Controller for Ethernet |  |  |  |  |
| Am7991 | Serial Interface Adapter |  |  |  |  |
| Description |  | 4 Bits | 8 Bits | 9 Bits | 10 Bits |
| Bus Drivers |  | 2912 | $\begin{aligned} & 2958 \\ & 2959 \\ & 2965 \\ & 2966 \end{aligned}$ |  | $\begin{aligned} & 29827 \\ & 29828 \end{aligned}$ |
| Bus Transceivers (Bidirectional) |  | 2926 2929 $26 S 10$ $26 S 11$ $26 S 12 A$ | $\begin{aligned} & 2946 \\ & 2947 \\ & 2948 \\ & 2949 \end{aligned}$ | $\begin{aligned} & 29833 \\ & 29834 \\ & 29863 \\ & 29864 \\ & 29853 \\ & 29854 \end{aligned}$ | $\begin{aligned} & 29861 \\ & 29862 \end{aligned}$ |
| Registered Bus Drivers and Latched Receivers |  | $\begin{aligned} & 2905 \\ & 2906 \\ & 2907 \\ & 2908 \\ & 2915 \mathrm{~A} \\ & 2916 \mathrm{~A} \\ & 2917 \mathrm{~A} \\ & 2927 \\ & 2928 \end{aligned}$ |  | - |  |
| Latches |  |  | $\begin{aligned} & 2956 \\ & 2957 \\ & 29845 \\ & 29846 \end{aligned}$ | $\begin{aligned} & 29843 \\ & 29844 \end{aligned}$ | $\begin{aligned} & 29841 \\ & 29842 \end{aligned}$ |
| Registers |  | $\begin{aligned} & 2918 \\ & \text { 29LS18 } \\ & 2919 \end{aligned}$ | $\begin{aligned} & 2920 \\ & 2954 \\ & 2955 \\ & 29825 \\ & 29826 \\ & 8120 \end{aligned}$ | $\begin{aligned} & 29823 \\ & 29824 \end{aligned}$ | $\begin{aligned} & 29821 \\ & 29822 \end{aligned}$ |
| Multilevel Pipeline Register |  |  | $\begin{aligned} & 29520 \\ & 29521 \end{aligned}$ |  |  |
| Diagnostics Register |  |  | 29618 |  |  |
| Bidirectional, Double-Registered Bus Transceivers |  |  | $\begin{aligned} & \hline \text { 2950/A } \\ & \text { 2951/A } \\ & \text { 2952/A } \\ & \text { 2953/A } \\ & \text { 29118 } \\ & \hline \end{aligned}$ |  |  |



## Systems Design Considerations and Training

Bipolar Technologies ..... 2-1
DESIGNER'S GUIDE TO HIGH PERFORMANCE LOW-POWER SCHOTTKY LOGIC ..... 2-3
Am2900 Components Continuously Become Faster and Faster ..... 2-16
Am29100 High-Performance Controller Products ..... 2-20
The Am29500 Family A High-Performance Architecture for Digital Signal/Array Processing ..... 2-21
Am2960-70 Memory Support Family System Overview ..... 2-23
Am2900 Family Applications Literature ..... 2-27
School of Advanced Engineering ..... 2-28
Macro Meta Assembler from Microtec* ..... 2-29
Meta Assembler Program from Microtec* ..... 2-30
Videotape Seminar Kits ..... 2-31

# Bipolar Technologies 

Advanced Micro Devices emphasizes Research and Development expenditures for developing the most advanced technologies for Bipolar processing, circuit design, and Very Large Scale Integration (VLSI).
Today, Advanced Micro Devices' bipolar products combine ECL-internal circuitry, the super high performance IMOX ${ }^{\text {TM }}$ process, and VLSI integration to offer the system designer the most compact high performance integrated circuits. This, plus AMD's systems solution approach to design problems, makes the Am2900 Family the best choice for fastest applications.

## IMOX

First introduced in 1980, IMOX is the name of Advanced Micro Devices' proprietary bipolar process. IMOX is an acronym which means: 1) lon-IMplantation of dopants for tighter parameter control and lower power consumption; and, 2) OXide-isolation of transistor structures which results in faster transistor switching and tighter packing. Older, LStype processes used diffused isolation for isolating transistor structures; this had the disadvantage of a large die area and high parasitic capacitance.
AMD is also applying IMOX to bring out higher-speed versions of earlier Am2900 devices. Figure 1 shows the evolution of the Am2901 Four-bit Microprocessor Slice. First introduced in 1975, the Am2901 has been repeatedly redesigned and is now available in the IMOX Am2901C version, which is less than half the size and more than twice the speed of the original Am2901 - and costs less. The current generation IMOX process has an 8 micron pitch (pitch equals the total of the width of metal lines plus the spacings between metal lines). In 1983, AMD brought into
full scale production a completely new Fabrication Facility in San Antonio, Texas which will feature the state-of-the-art in process and masking equipment, and allow products which feature the IMOX process but with a pitch of only 4 microns, by late 1983. This version of IMOX is termed IMOX-S2. The $50 \%$ reduction in metal pitch will dramatically increase the level of integration of new products and also provides $>30 \%$ increase in device speed.

## ECL-INTERNAL CIRCUITRY

All Am2900 devices today are TTL-compatible on inputs and outputs and use standard +5 V and ground for supply voltages. TTL is a good interface standard for systems design today, but TTL gates are slow, and ECL gates are much faster. To offer TTL-compatibility but near-ECL speeds to our customers, AMD has adopted a circuit design approach which features all ECL-circuitry for the internal circuitry of all LSI and VLSI devices (see Figure 2).

This approach, ECL-internal circuitry, provides near-ECL speeds to TTL-I/O designers. Of course the ECL gate structures inside the device are completely transparent to system designers because of the $100 \%$ adherence to TTL standards for I/O specs. Also, these chips only require +5 V and ground because internal gates are not the same type of ECL gates as those used with 10 K or 100 K logic. The final point to note is that ECL has a reputation for being very power intensive. While the Am2900 Family are not lowpower devices, they do significantly reduce the total power usage in a high performance systems design because of the large number of SSI/MSI devices they replace. These ECL gates are not run at the very high power levels of traditional ECL circuits.

Figure 1. Bipolar Speed/Density Improvements
Am2901 FOUR-BIT MICROPROCESSOR SLICE


| DIE <br> SIZE | $\begin{gathered} \text { Am2901 } \\ 33,000 \text { MILS }^{2} \end{gathered}$ | $\begin{gathered} \text { Am2901A } \\ \text { 20,000 MILS }{ }^{2} \end{gathered}$ | $\begin{aligned} & \text { Am2901B } \\ & 15,000 \text { MILS }^{2} \end{aligned}$ | $\begin{gathered} \text { Am2901C } \\ 15,000 \text { MILS }^{2} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| SPEED $\mathbf{A}, \mathbf{B} \rightarrow \mathbf{G}, \mathbf{P}$ | 80ns | 65ns | 50ns | 37ns |
| TECHNOLOGY | LOW-POWER SCHOTTKY | DUAL LAYER METAL IONIMPLANTATION | PROJECTION PRINTING | ECL INTERNAL TTL I/O IMOX |
|  | 1975 | 1977 | 1978 | 1981 |

IMOX is a trademark of Advanced Micro Devices, Inc.

Using internal ECL with TTL-1/O does involve paying a translation speed penalty at the inputs and outputs of the device, but because these devices ane LSI and VLSI with many levels of internal gating between input and output, the translation penalty is more than compensated for by the extra performance gained by the multiple layers of high speed ECL gates. Figure 3 shows an approximate comparison of the IMOX- with-internal-ECL approach to other process/circuit offerings available to designers utilizing high speed TTL compatible ICs. IMOX offers an excellent combination of high speed and relatively low power. The speed comes not only from the IMOX process but also from the use of ECL gates for internal circuitry. The FAST and AS/ALS Families are populated primarily with MSI devices where ECL-internal gating is not feasible due to the few layers of internal gating relative to the TTL/ECL translation delay penalty. Note also that Am2900/

IMOX devices use an order of magnitude less power per gate than traditional ECL 10 K and 100 K devices.

## BIPOLAR VLSI

Advanced Micro Devices is the leader in high integration, high performance integrated circuits. Our largest device to date, the Am29116, is a 2500-gate device measuring 68,000 square mils in area, and currently in development are devices of four times that complexity using our new IMOX-S2 process. AMD's emphasis on Very Large Scale Integration bipolar is best illustrated in Figure 4 below.

Figure 4 demonstrates AMD's commitment and leadership in large scale integration bipolar since the introduction of the original Am2901 in 1975. Another graphic demonstration of the growing complexity of our devices is the relative die sizes of successively complex arithmetic processors, as shown in Figure 5.

Figure 2. Am2900 Circuit Design for Maximum Speed

Figure 3.


SOURCE: MOTOROLA AND ELECTRONICS

- All ECL would be only $7-15 \%$ faster
- Practical approach for LSI/VLSI

Figure 4. Am2900 Bipolar LSI/VLSI


AF001590

Figure 5.


## DESIGNER'S GUIDE TO HIGH PERFORMANCE LOW-POWER SCHOTTKY LOGIC

By David A. Laws and Roy J. Levy.

## INTRODUCTION

Advanced Micro Devices is a leading supplier of low-power Schottky MSI and LSI devices. Two basic families of product are offered:

Am54/74LS Series

- Typical tpd $10 \mathrm{~ns} /$ gate at 2 mW
- Typical Register fmax $=40 \mathrm{MHz}$

Pin for pin and electrical alternate source devices to the standard performance LS logic family.

## Am25LS Series

- Typical tpd $5 \mathrm{~ns} /$ gate at 2 mW
- Typical Register fmax $=65 \mathrm{MHz}$

Advanced Micro Devices' proprietary high performance LS logic family. This includes both original designs and enhanced specification versions of the Am54/74LS devices. Improvements include twice the fan-out over the military temperature range, higher noise margin and faster switching speeds.

## THE SCHOTTKY DIODE STRUCTURE

The major components of switching delays in digital integrated circuits are listed in Figure 1. One of the most significant of these is the storage time constant of a transistor driven into saturation Ts. Older TTL circuits minimized this parameter with process technique known as gold doping. This increased the rate of recombination of charge stored in the base region.

The desired result of improved speed was achieved. Unfortunately it also reduced available design $\beta$ at low temperatures and was marginally effective when hot. This resulted in lowered performance over the full military temperature range.

The development of the Schottky diode provides a more effective solution. A feature of the Schottky diode is its lower forward voltage at a given current level compared to a diffused ( $\mathrm{P}-\mathrm{N}$ ) diode of the same area, Figure 2. Connecting a Schottky diode between the base and collector of a transistor, Figure 3, will shunt excess base current drive from the base to the collector, once the collector drops to a low enough voltage to forward bias the Schottky. This prevents the build up of stored charge and eliminates the Ts component of the delay.

A Schottky diode is formed at a metal to semiconductor junction when the semiconductor doping is at the level normally found in the collector region of TTL devices. A Schottky-clamped transistor is constructed by extending the metal contact for the base region over the collector as shown in Figure 4. The same metallization structure forms a simple ohmic contact at the base, collector and emitter contact window because of the higher doping levels in the silicon at these locations.


WF003140

| Parameters | Determining Factors |
| :---: | :--- |
| $T_{d}$ | R,C <br> $\beta, \mathrm{Cob}$, Base Drive, Signal Ampli- <br> $T_{f}$ |
| $\mathrm{~T}_{\mathrm{s}}$ | Storage Time Constant of a Satu- <br> rated Transistor <br> Cob, Signal Amplitude |
| $\mathrm{T}_{\mathrm{r}}$ |  |

Figure 1. Major Causes of Propagation Delay.


Figure 2. Comparison of $V_{F}$ for Schotty and Diffused Diodes.

Figure 3. Schottky Clamped Transistor and its Convential Circuit Symbol
 ,

The selection of the forward voltage drop across the Schottky diode, $V_{S B D}$, is a compromise between a high value to insure a minimum $V_{\mathrm{OL}}$ but low enough to prevent charge storage in the base. Platinum silicide Schottky diodes provide this optimum voltage drop. Platinum is deposited and platinum-silicide is formed by sintering and annealing. As aluminum has a high affinity for silicon, in order to prevent the aluminum interconnect metallization from diffusing through the platinum material, with resulting lower $V_{S B D}$, a barrier of tungsten-titanium is evaporated after the platinum and before the aluminum metallization. This structure has been extensively evaluated and proven to have excellent reliability characteristics. It is now widely employed in the manufacture of Schottky devices. Reliability data is available from Advanced Micro Devices on request.

## CHARACTERISTICS OF SCHOTTKY DEVICES

The primary reason for the development of Schottky devices was to improve AC (switching) performance and the first integrated circuits to employ this technique offered propagation delays as fast as 3 ns . However, their fast rise and fall times and high power requirements have restricted their application to highest performance systems. It was realized that the technique could be used to decrease the charging current required to achieve the 10 ns speed specification of older TTL gates. This insures considerably lower operating power requirements. The resulting family of devices are known as Low-Power Schottky (LS) circuits.

## 2. D.C. Circuit Characteristics

 CIRCUIT CONFIGURATIONSThe basic circuit design configuration of a Low-Power Schottky gate is similar to that of the original standard TTL elements. However, certain refinements have been made to optimize device performance when fabricated with the LS process.

In order to analyze the circuit configuration, Table 1 shows terms used in describing Advanced Micro Devices' LS circuits:

## TABLE 1.

## D.C. CIRCUIT PARAMETER DEFINITIONS

IL The current out of an input at a specified LOW voltage.
$\mathrm{I}_{\mathrm{H}}$. The current into an input at a specified HIGH voltage.
IOL. The current into an output when in the LOW state.
$\mathrm{I}_{\mathrm{OH}} \quad$ The current out of an output when in the HIGH state (pull-up circuit only).
$\mathrm{I}_{\mathrm{SC}} \quad$ The current out of an output in the HIGH state when shorted to ground. (Also called Ios)
$V_{C C} \quad$ The range of supply voltage over which the device is guaranteed to operate.
$V_{\text {IL }} \quad$ The guaranteed maximum input voltage that will be recognized by the device as a logic LOW.
$V_{i H} \quad$ The guaranteed minimum input voltage that will be recognized by the device as a logic HIGH.
$V_{O L} \quad$ The maximum guaranteed logic LOW voltage at the output terminal while sinking the specified load current $\mathrm{I}_{\mathrm{OL}}$.
$V_{\mathrm{OH}} \quad$ The minimum guaranteed logic HIGH voltage at the output terminal when sourcing the specified source current $\mathrm{I}_{\mathrm{OH}}$.
$\mathrm{I}_{\mathrm{OZH}} \quad$ Three-state off-state output current, high level voltage applied.
Iozl Three-state off-state output current, low-level voltage applied.


AF001820
Figure 4. Schottky Diode Clamped Transistor Structure.

Both the input and output structures of the LS devices themselves have evolved through a number of configurations as designers have attempted to optimize circuit performance.

Depending on the function of the device any one of four commonly used inputs may be employed. The significant characteristics of each of these configurations are summarized in Figure 5.

The first LS designs used the familiar multi-emitter TTL input of Figure 5a. However because of low breakdown voltage and slow speed it is now used only where the geometry offers a significant advantage in circuit mask layout.

The second and still most widely used structure is the simple DTL style input of Figure 5b. This is the fastest version and it has good input breakdown voltage. In output functions having
only a single gate delay between input and output, such as a three-state enable input, the low threshold of the DTL configuration causes the output node to be at a sufficiently low voltage to risk leakage problems at high temperature. The input of Figure $5 c$ raises the threshold by one diode to overcome this problem (Figure 6). However because it is
slower and uses more silicon area, its use is limited to special situations. A PNP input, Figure 5d, insures low d.c. loading for devices with common input/output pins such as the Am25LS23. However it is slow and has low breakdown voltage, comparable to the multi-emitter TTL structure.


1C000690
a) TTL


10000700


IC000670
b) DTL

d) PNP

Figure 5. Low-Power Schottky Input Configurations.


OP001510
Figure 6. LS Input Characteristics for DTL and High Threshold Inputs.

Figure 7 compares the early LS output configuration with the design most frequently used today. The change was made to provide clamping of positive ringing and to allow the higher $I_{\mathrm{SC}}$ currents now specified (see section 3). The typical $\mathrm{V}_{\text {OH }}$ versus $\mathrm{l}_{\mathrm{OH}}$ curves of Figure 8 are similar for both versions.

This example displays an $\mathrm{I}_{\mathrm{SC}}$ of approximately 35 mA . Note that both of these designs include the "squaring" network ( $\mathrm{R}_{3}, \mathrm{R}_{4}$ and $Q_{5}$ ) at the base of the output pulldown transistor, $Q_{4}$, which was not included on standard TTL families. The result of this is a sharp transition of $\mathrm{V}_{\text {Out }}$ with $\mathrm{V}_{\text {IN }}$ shown in Figure 9 for a simple gate function.



Figure 7. Low-Power Schottky Output Configurations.


OP001530
Figure 8. Typical $\mathrm{V}_{\mathrm{OH}}$ for Low-Power Schottky.


OP001540
Figure 9. Typical Output Versus Input Voltage Characteristic.

The typical $V_{O L}$ versus $l_{\text {OL }}$ output characteristics of LS devices are shown in Figure 10. Most 74LS functions are specified at $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ at $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ and 0.5 V at 8 mA . Am25LS are specified at 0.45 V for $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$. Some newer designs are being guaranteed at $\mathrm{I}_{\mathrm{OL}}$ of 12 mA and 24 mA . This curve indicates that lack of $\beta$ at low temperature will not permit existing designs to be guaranteed to these higher values without severe yield loss.


OP001520
Figure 10. Typical LS $V_{O L}$ Versus $I_{O L}$ Characteristics.

## INPUT/OUTPUT LEVELS

Table 2 shows the guaranteed D.C. parameters of the Am54LS/74LS and second generation Am25LS families. Input current requirements ( $l_{\mathrm{IH}}, \mathrm{I}_{\mathrm{IL}}$ ) and therefore output drive needs ( $l_{\mathrm{OH}}, l_{\mathrm{OL}}$ ) are significantly reduced over older TTL.
A one unit load input current at logic HIGH, $I_{I H}$, for Am54LS/ 74 LS is $20 \mu \mathrm{~A}$, compared with $40 \mu \mathrm{~A}$ for Am54/74 standard TTL. Similarly at logic LOW, $I_{l}$ is reduced to -0.36 mA from -1.6 mA .
Corresponding reductions in the output drive requirements are $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ vs. 16 mA at $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ and $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ compared to $800 \mu \mathrm{~A}$.

## FAN-OUT CAPABILITY

The fan-out capability of a logic family indicates the number of inputs which can be driven by a single output. It is defined as the maximum output drive current divided by the input current available.

Logic HIGH Fan-out $=I_{\mathrm{OH}} / \mathrm{I}_{\mathrm{IH}}$
Logic LOW fan-out $=I_{\mathrm{OL}} / I_{\mathrm{IL}}$
Table 3 shows the fan-out capabilities of typical functions from the three families. The lower current operating levels of LS devices allow them to be specified at a logic LOW fan-out over the commercial range of more than twice that of standard TTL (22 vs. 10). The Am25LS family allows this advantage to be extended to the military range.

## D.C. NOISE MARGIN

The D.C. noise margins of digital system are defined from Figure 11 as follows:
Logic HIGH Noise Margin $=\mathrm{V}_{\mathrm{OH} 1}-\mathrm{V}_{\mathrm{IH} 2}$
Logic LOW Noise Margin $=V_{1 L 2}-V_{V O L 1}$

These parameters for LS devices are shown in Table 2. LS has a minimum logic HIGH output voltage of $\mathrm{V}_{\mathrm{OH}}=2.5 \mathrm{~V}$ for military and 2.7 V for the commercial temperature range. For standard TTL, $\mathrm{V}_{\mathrm{OH}}$ is 2.4 V . $\mathrm{V}_{\mathrm{IH}}$ is 2.0 V for both families.


Figure 11. Input/Output Voltage Interface Conditions.

TABLE 2
COMPARISON OF TTL DC PARAMETERS

| Parameters | 54LS/74LS LOW-POWER SCHOTTKY |  |  |  |  | 25LS LOW-POWER SCHOTTKY |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Conditions |  | Min | Typ | Max | Conditions |  | Min | Typ | Max |  |
| $V_{O L}$ | $\mathrm{l}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | $\mathrm{l}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | V |
|  | $\mathrm{IOL}^{\text {a }}=8.0 \mathrm{~mA}$ (COM'L Only) |  |  |  | 0.5 | $\mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA} \mathrm{(MIL}, \mathrm{COM'L)}$ |  |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | MIL | 2.5 | 3.4 |  | $\mathrm{I}_{\mathrm{OH}}=-440 \mu \mathrm{~A}$ | MIL | 2.5 | 3.4 |  | V |
|  |  | COM'L | 2.7 | 3.4 |  |  | COM'L | 2.7 | 3.4 |  |  |
| $\mathrm{V}_{\text {IL }}$ | Logic LOW | MIL |  |  | 0.7 | Logic LOW | MIL |  |  | 0.7 | V |
|  |  | COM'L |  |  | 0.8 |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{\text {IH }}$ | Logic HIGH |  | 2.0 |  |  | Logic HIGH |  | 2.0 |  |  | V |
| IIL | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  | -0.36 | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  |  |  | -0.36 | mA |
| $\mathrm{I}_{\mathrm{iH}}$ | $\mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mathrm{V}_{1 \text { IN }}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |  |  |  |  |  |  |
| Parameter | 54S/74S AND 25S SCHOTTKY TTL |  |  |  |  |  | TANDAR |  |  |  |  |
|  | Condition |  | Min | Typ | Max |  |  | Min | Typ | Max | Units |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{l}_{\mathrm{OL}}=20 \mathrm{~mA}$ |  |  | 0.3 | 0.5 | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | , | 0.2 | 0.4 | Volts |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ | MIL | 2.5 | 3.4 |  | $\mathrm{I}_{\mathrm{OH}}=-300 \mu \mathrm{~A}$ |  | , |  |  |  |
|  |  | COM'L | 2.7 | 3.4 |  |  |  | 2.4 | 3.4 |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Logic LOW |  |  |  | 0.8 | Logic LOW |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Logic HIGH |  | 2.0 |  |  | Logic HIGH |  | 2.0 |  |  | Volts |
| $I_{\text {IL }}$ | $\mathrm{V}_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  | -2.0 | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  |  |  | -1.6 | mA |
| IHH | $\mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mathrm{V}_{1 \mathrm{IN}}=2.4 \mathrm{~V}$ |  |  |  | 40 | $\mu \mathrm{A}$ |

Table 3 compares the guaranteed noise margin values for the standard TTL and LS devices．LS devices offer improved margin over standard TTL in the logic HIGH state，which is the most critical with regard to noise generation．At a similar fan－ out， 10 for standard TTL and 11 for LS，noise margins in the LOW state are the same over the commercial range．

Military LS devices have a 100 mV lower noise margin in the LOW state than standard TTL．In most systems，this does not present a problem as the lower power supply currents being switched with LS generally result in lower system noise generation．

The logic levels guaranteed over the operating temperature ranges are of course worst case．Figures 12 and 13 show the typical values to be considerably better than these．

## Am25LS D．C．FEATURES

The D．C．advantages offered by second generation Am25LS over $54 / 74$ LS devices can be seen from Table 3 as：

1．In the logic LOW state at a fan－out of 22 （8mA），Am25LS has 50 mV greater noise margin（ 350 mV vs． 300 mV ）．

2．Am25LS products are guaranteed at a fan－out of 22 （ 8 mA ） over the military range．Am54LS is specified at fan－out of 10 （4mA）only．

3．Am25LS offers a symmetrical fan－out of 22 in both logic HIGH and logic LOW states，allowing full use of the logic LOW drive capability．

TABLE 3
FAN－OUT AND NOISE MARGIN COMPARISON OF TTL AND LS FAMILIES．
a）LOGIC＂HIGH＇STATE

| FAMILY | INPUT CURRENT $I_{1 H}$ | OUTPUT CURRENT $\mathrm{I}_{\mathrm{OH}}$ | FAN－OUT |  | NOISE MARGIN |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MILITARY | COMMERCIAL | MILITARY | COMMERCIAL |
| 54／74 | $40 \mu \mathrm{~A}$ | $-800 \mu \mathrm{~A}$ | 20 | 20 | 400 mV | 400 mV |
| 54LS／74LS | $20 \mu \mathrm{~A}$ | $-400 \mu \mathrm{~A}$ | 20 | 20 | 500 mV | 700 mV |
| 25LS | $20 \mu \mathrm{~A}$ | $-440 \mu \mathrm{~A}$ | 22 | 22 | 500 mV | 700 mV |

b）LOGIC＇LOW＇STATE

| FAMILY | INPUT CURRENT IL | OUTPUT CURRENT lot | FAN－OUT |  | NOISE MARGIN |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Military | COMMERCIAL | MILITARY | COMMERCIAL |
| 54／74 | －1．6mA | 16 mA | 10 | 10 | 400 mV | 400 mV |
| 54LS／74LS | $-0.36 \mathrm{~mA}$ | 4 mA | 11 | 11 | 300 mV | 400 mV |
|  |  | 8 mA | No Spec． | 22 | No Spec． | 300 mV |
| 25LS | $-0.36 \mathrm{~mA}$ | 4 mA | 11 | 11 | 300 mV | 400 mV |
|  |  | 8 mA | 22 | 22 | 250 mV | ． 350 mV |



OP001490
Figure 12．LS Logic＇ $\mathrm{O}^{\prime}$＇Noise Margin．


OP001480

Figure 13．LS Logic＂1＇Noise Margin．

## 3. Switching Characteristics

## INTRODUCTION

Many Low-Power Schottky functions have been designed specifically to replace standard TTL elements in existing system designs. Their A.C. performance characteristics usually meet or exceed the limits of the earlier devices. The switching terms which are used on data sheets to describe the A.C. performance of these designs are summarized in Table 4. The more important parameters are discussed in detail in this section.

## TABLE 4.

## DEFINITION OF SWITCHING TERMS

(All switching times are measured at the 1.3 V logic level unless otherwise noted.)
$\mathrm{f}_{\text {max }}$ The highest operating clock frequency.
$\mathbf{t}_{\text {PLH }}$ The propagation delay time from an input change to an output LOW-to-HIGH transition.
$\mathrm{t}_{\text {PHL }}$ The propagation delay time from an input change to an output HIGH-to-LOW transition.
$t_{\text {Pw }} \quad$ Pulse width. The time between the leading and trailing edges of a pulse, measured at the $50 \%$ points.
$\boldsymbol{t}_{\mathbf{r}}$ Rise time. The time required for a signal to 1. change from $10 \%$ to $90 \%$ of its measured values.
$\mathbf{t}_{\mathrm{f}} \quad$ Fall time. The time required for a signal to change from $90 \%$ to $10 \%$ of its measured values.
$t_{s} \quad$ Set-up time. The time interval for which a signal must be applied and maintained at one input terminal before an active transition occurs at another input terminal.
$t_{h} \quad$ Hold time. The time interval for which a signal must be retained at one input after an active transition occurs at another input terminal.
$t_{\mathrm{HZ}} \quad \mathrm{HIGH}$ to disable. The delay time from a control also input change to the three-state output HIGH-
$\mathrm{t}_{\text {PHz }}$ level to high-impedance transition (measured at 0.5 V change).
$\mathbf{t}_{\mathrm{Lz}} \quad$ LOW to disable. The delay time from a control also input change to the three-state output LOW-
$\mathrm{t}_{\text {PLz }}$ level to high-impedance transition (measured at 0.5 V change).
$\mathrm{t}_{\mathrm{zH}}$ Enable HIGH. The delay time from a control also input change to the three-state output high$\mathbf{t}_{\text {PZH }}$ impedance to HIGH-level transition.
$t_{z L}$ Enable LOW. The delay time from a control also input change to the three-state output high-
$\mathbf{t}_{\text {pzL }}$ impedance to LOW-level transition.

## PROPAGATION DELAYS

The standard designations for delays through combinatorial logic networks are $t_{\text {PHL }}$ and $t_{\text {PLH }}$. A delay from an input change to an output going LOW is called $t_{\text {PHL }}$, while $t_{\text {PLH }}$ is the delay from an input change to an output going HIGH.

Figure 14 shows a typical waveform with the output changing during the interval indicated by the diagonal, sloping line. Note that all switching times shown are measured at the 1.3 volt logic level.


WF003040

Figure 14. Propagation Delay.

Typical values for a single gate propagation delay $t_{P H L}$ in LowPower Schottky functions are $8 \mathbf{- 1 0 n s}$ into a 15 pFF load. Higher performance LS families such as Am25LS, exhibit delays in the $4-6 n s$ range. These propagation delays will increase by 2 -4 ns at an output loading of 50 pF or approximately 0.1 ns per pF .

## EDGE RATES

The rise and fall times of Low-Power Schottky devices are similar to those of standard TTL. Into a 50 pF load fall time, $\mathrm{t}_{\mathrm{f}}$, is typically $6-8 \mathrm{~ns}$, while rise time, $\mathrm{t}_{\mathrm{r}}$, is in the $9-12 \mathrm{~ns}$ range. A.C. parameters are measured at $t_{f} \leqslant 6 \mathrm{~ns}$ and $\mathrm{t}_{\mathrm{r}} \leqslant 15 \mathrm{~ns}$.

As with standard TTL, careful P.C. board layout rules should be employed to avoid problems which can occur at these relatively fast edge rates. In particular, precautions should be taken to insure that transmission line effects do not cause false switching or ringing and oscillation problems on lines longer than 18 inches. See Section 4 for more information.

## SEQUENTIAL DEVICES

Set-up time, $t_{s}$, hold time, $t_{h}$, are the most important parameters for specifying sequential elements such as latches, flipflops and registers.

For these synchronous devices, inputs must be stable for a .certain period of time before the clock or enable pulse. This interval is the region in time during which devices are 'sampling' their inputs. As an example, consider a latch with a D input and an active LOW clock. The latch will store the information present on its input just before the clock goes HIGH. The question is, how long does the input level have to be present and stable before the clock goes HIGH? A particular device will ''sample' its input at some exact instant, but in a group of devices some are slower than others. The result is an interval of some time called set-up time during which all devices, fast or slow, will "'sample" their inputs.

All devices exhibit a hold time. That is a period of time after the clock or enable pulse transition during which the data cannot be changed without loss of input intelligence. This hold time occurs after the clock goes HIGH. Figure 15 shows the input requirements and definitions for data entry.


Notes：1．Diagram shown for HIGH data only．Output transition may be opposite sense．
2．Cross hatched area is don＇t care condition．

Figure 15．Set－up and Hold Time Definitions．

## $f_{\text {MAX }}$

A frequently misunderstood parameter on data sheets is maximum clock frequency $f_{\text {MAX }}$ ．This was defined by the early TTL manufacturers as the maximum toggle frequency which can be attained by the device under ideal conditions with no constraints on $t_{r}, t_{f}$ ，pulse width，or duty cycle．Although $f_{\text {mAX }}$ as specified cannot usually be attained in an operating system，it is a relatively easy parameter to test and provides a conve－ nient measure of comparative performance between different devices．

## EFFECTS OF TEMPERATURE AND POWER SUPPLY VARIATIONS

Standard TTL devices exhibit severe degradation in A．C． performance at the recommended limits of the operating temperature and power supply voltage ranges．

At elevated temperature and／or high $V_{C C}$ levels，charge storage begins to slow down A．C．response．At the other extreme，low temperature and／or low $V_{C C}$ ，the loss of $\beta$ causes a similar problem．These combined effects can cause more than $50 \%$ degradation in performance over the full military temperature and power supply extremes．

Low－Power Schottky technology reduces the impact of both of these effects on performance．$\beta$ degradation at cold tempera－ tures is far less severe and Schottky clamping largely elimi－ nates the effects of charge storage at high temperature．

TABLE 5．GUIDELINES FOR TYPICAL VARIATION OF A．C．PARAMETERS WITH COMBINED TEMPERATURE AND V ${ }_{c c}$ VARIATION

| Temperature Range |  | AC Derating Factor |  |
| :---: | :---: | :---: | :---: |
|  |  | Sys－ tem | Compo－ nent |
| COM＇L， $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | None | 5\％ | 10\％ |
| COM＇L， $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $\pm 0.25 \mathrm{~V}$ | 15\％ | 30\％ |
| MIL， $-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}$ | None | 15\％ | 30\％ |
| MIL， $-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}$ | $\pm 0.5 \mathrm{~V}$ | 25\％ | 50\％ |

The system＇s designer would like a factor which will allow his system to meet specification with minimum design overkill． However，the component engineer often requires maximum delays to be guaranteed．For system design guidelines，the AC derating factors of Table 5 may be useful．
It must be emphasized that the values of Table 5 are typical． However as it is unlikely that any given system will contain all worst case devices they will usually yield a fairly safe prediction of the system performance which can be achieved．
Individual components will of course be slower than these typical numbers．These must be reflected on procurement specifications．A general rule of thumb would be to double the system design guidelines of Table 5．Am25LS specifications are published with worst case parameters guaranteed over the operating power supply and temperature ranges，as well as at a realistic system load condition of 50 pF ．A typical example of this format is shown in Table 6.

## SHORT CIRCUIT OUTPUT CURRENT

To improve performance，in 1975 Tl lowered the short－circuit current limiting resistor value．This increased the $I_{S C}\left(I_{\text {OS }}\right)$ range from -6 to $-42 m A$ up to -30 to -130 mA ．The overall delay when driving very large capacitive loads $(>150 \mathrm{pF})$ was reduced somewhat as a result．However，the inherent circuit performance still dominates in normal applications such that the Am25LS and other high performance families remain faster even when driving large capacitive loads．

TABLE 6
Am25LS2513 THREE-STATE PRIORITY ENCODER A.C. SPECIFICATION FORMAT FOR $\mathrm{V}_{\mathrm{cc}}$ AND TEMPERATURE EXTREMES AND 50pF LOAD CONDITION

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | $\bar{I}_{i}$ to An (In-phase) | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 17 | 25 | ns |
| tPHL |  |  |  | 17 | 25 |  |
| tpLH | $i_{i}$ to An (Out-phase) |  |  | 11 | 17 | ns |
| tPHL |  |  |  | 12 | 18 |  |
| tple | $i_{i}$ to $\overline{E O}$ |  |  | 7.0 | 11 | ns |
| tpHL |  |  |  | 24 | 36 |  |
| tpLH | $\overline{E l}$ to EO |  |  | 11 | 17 | ns |
| tpHL |  |  |  | 23. | 34 |  |
| tplH | El to An |  |  | 12 | 18 | ns |
| tpHL |  |  |  | 14 | 21 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to An |  |  | 23 | 40 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 20 | 37 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}$ to An |  |  | 20 | 30 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 18 | 27 |  |
| $\mathrm{t}_{\mathrm{HZ}}$ | $G_{1}$ or $G_{2}$ to $A n$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 17 | 27 | ns |
| tLZ |  |  |  | 19 | 28 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}$ to An |  |  | 16 | 24 | ns |
| tLz |  |  |  | 18 | 27 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | $\frac{\text { COMMERCIAL }}{\text { Am25LS }}$ |  | $\frac{\text { MILITARY }}{\text { Am25LS }}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| ${ }_{\text {tPLH }}$ | $i_{i}$ to An (In-phase) | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 31 |  | 37 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 30 |  | 34 |  |
| $\mathrm{tpLH}^{\text {chen }}$ | $i_{i}$ to An (Out-phase) |  |  | 22 |  | 27 | ns |
| tpHL |  |  |  | 22 |  | 25 |  |
| tPLH | $i_{i}$ to EO |  |  | 15 |  | 18 | ns |
| tPHL |  |  |  | 48 |  | 60 |  |
| tple | $\overline{E l}$ to EO |  |  | 19 |  | 21 | ns |
| tpHL |  |  |  | 46 |  | 57 |  |
| tPLH | El to An |  |  | 22 |  | 25 | ns |
| tPHL |  |  |  | 27 |  | 32 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to An |  |  | 42 |  | 49 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 43 |  | 49 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\bar{G}_{3}, \bar{G}_{4}, \overline{\mathrm{G}}_{5}$ to An |  |  | 36 |  | 43 | ns |
| t ZL |  |  |  | 35 |  | 43 |  |
| $\mathrm{thz}^{\text {l }}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to An | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 34 |  | 40 | ns |
| tLZ |  |  |  | 34 |  | 40 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to An |  |  | 30 |  | 35 | ns |
| $t_{L Z}$ |  |  |  | 31 |  | 35 |  |

## 4. Design Guidelines

## POWER SUPPLY CONSIDERATIONS

The recommended power supply voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) for all TTL circuits, including $L S$, is +5 V . Commercial temperature range devices, designated 74LS or in the case of Am25LS with the suffix $C$, are specified with a $\pm 5 \%$ supply tolerance ( $\pm 250 \mathrm{mV}$ ) over the ambient range $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. Military range parts, designated 54LS or in the case of Am25LS with the suffix M, are guaranteed with a $\pm 10 \%$ supply tolerance $( \pm 500 \mathrm{mV})$ over an ambient temperature range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$. The power supply should be well regulated with a ripple less than $5 \%$ and with regulation better than 5\%. Even though LS devices generate significantly smaller power supply spikes when switching than standard TTL, on-board regulation is still preferable to isolate this noise to one board.
A low-inductance transmission line power distribution bus with good RF decoupling is necessary for large systems. On all boards, ceramic decoupling capacitors of $0.01 \mu \mathrm{~F}$ to $0.1 \mu \mathrm{~F}$ should be used at least one for every five packages, and one for every one-shot (monostable), line driver and line receiver package. In addition, a larger tantalum capacitor of $20 \mu \mathrm{~F}$ to $100 \mu \mathrm{~F}$ should be included on each card. On boards containing a large number of packages, a low impedance ground system is essential. The ground can either be a bus or a ground which is incorporated with the $\mathrm{V}_{\mathrm{CC}}$ supply to form a transmission line power system. Separate power transmission systems can be attached to the board to provide this same feature without the cost of a multi-layer PC card.

## UNUSED INPUTS

An unused input to an AND or NAND gate should not be left floating as it can act as an antenna for noise. On devices with storage, such as latches, registers and counters, it is particularly important to terminate unused inputs (MR, PE, PL, CP) properly since a noise spike on these inputs might change the contents of the memory. This technique optimizes switching speed as the distributed capacitance associated with the floating input, bond wire and package leads is eliminated. To terminate, the input should be held between 2.4 V and the maximum input voltage. One method of achieving this is to connect the unused input to $V_{C C}$. Most LS inputs have a breakdown voltage $>7 \mathrm{~V}$ and require no series resistor. Devices specified with a maximum 5.5 volt breakdown should use a $1 \mathrm{k} \Omega$ to $10 \mathrm{k} \Omega$ current limiting series resistor to protect against $V_{C C}$ transients. Another method is to connect the unused input to the output of an unused gate that is forced HIGH. Do not connect an unused input to another input of the same NAND or AND function. Although recommended for standard TTL, with LS this increases the input coupting capacitance and reduces A.C. noise immunity.

## TRANSMISSION LINE EFFECTS

The relatively fast rise and fall times of Low-Power Schottky TTL (5 to 15ns) can cause transmission line effects with interconnections as short as 18 inches. With one TTL device driving another and the driver switching from LOW to HIGH, if the propagation delay of the interconnection is long compared to the signal rise time, the arrangement can behave like a transmission line driven by a generator with a non-linear output.
The initial voltage step at the output, just after the driver has switched, propagates down the line and reflects at the end. In the typical case where the line is open ended or terminated in an impedance greater than its characteristics impedance $\left(Z_{O L}\right)$, the reflected wave arrives back at the source and increases $V_{\text {OUT }}$. If the total round-trip delay is longer than the rise time of the driving signal, a staircase response results at the driver output and along the line. If one of the driven
devices is connected close to the driver, the initial output voltage (VOUT) seen by it might not exceed $\mathrm{V}_{\mathrm{IH}}$. The state of the input is undetermined until after the round trip of the transmission line, thus slowing down the response of the system.

The longest interconnection that should be used with LS devices without incurring problems due to line effects is in the 10-12 inch range.

With longer interconnections, transmission line techniques should be used for maximum speed. Good system operation can be obtained by designing around 100 ohm lines. A 0.026 inch $(0.65 \mathrm{~mm})$ trace on a 0.062 inch epoxy-glass board ( $E_{r}=4.7$ ) with a ground plane on the other side represents a $100 \Omega$ line. 28 to 30 gauge wire ( 0.25 to 0.30 mm ) twisted pair line has a characteristic impedance of 100 to $115 \Omega$.

## LINE DRIVING AND RECEIVING

For lines longer than 2 feet, twisted pairs or coaxial cable should be used. The characteristic impedance of the transmission media should be approximately $120 \Omega$ such as twisted pairs of \# 26 wire or $100 \Omega$ coax. A possible choice is cables with a characteristic impedance $R_{0}$ of $100 \Omega$ such as ribbon cable or flat cable with controlled impedance. Resistive pullups at the receiving end can be used to increase noise margin. Where reflection effects are unacceptable, the line must be terminated in its characteristic impedance. A method shown in Figure 16 has the output of the line tied to $V_{C C}$ through a resistor equivalent to the characteristic impedance of the line. As the output impedance of the LS driver is low and must sink the current through it, in addition to the current from the inputs being driven, a useful technique is to terminate the line in a voltage divider with two resistors, each twice the line impedance.


Figure 16. LS Driving Twisted Pair.
This reduces the extra sink current by $50 \%$. Where the line exceeds five feet in length it is preferable to dedicate gates solely to line driving.
For additional noise immunity when driving long lines, a differential line driver and line receiver may be used. These dedicated line interface circuits drive a twisted pair of wires differentially, permit easy termination of lines and provide excellent common mode noise rejection.

The Am26LS31 driver and Am26LS32 and Am26LS33 are quad differential line drivers and receivers satisfying the interface requirements of EIA RS-422 and 423 as well as military applications, Figure 17. They are designed to operate off the standard 5 V power supplies of the LS logic devices. More applications information on line termination techniques is provided on the above mentioned device data sheets.

## CROSS－TALK AND RINGING

These two problems may be experienced with all forms of high speed digital logic．Crosstalk is the coupling of energy from one circuit to another via real or parasitic capacitance and inductance．Ringing is the possible rebound of the signal into the input threshold region（ $0.8-2.0 \mathrm{~V}$ ）following a HIGH－to－ LOW level change．When a driver switches from a HIGH－to－ LOW state the output voltage should fall below the threshold value．However，a line having a very low characteristic impedance does not allow transistor Q5 in the NAND gate example to saturate，and the resulting output voltage may not be low enough to switch an adjacent device until two or more line delay times．The low current levels at which LS devices
operate，coupled with the low output impedance in both HIGH and LOW Logic states，minimize crosstalk effects．Input clamp diodes provided on all LS devices are extremely effective in reducing ringing phenomenon．

Care should be taken to insure that signals with falling edges faster than $2.5-3 \mathrm{~ns} /$ volt are not coupled into the input of an LS function．Even though the signal may not pass into the threshold region，if the pulse edge is fast enough，sufficient energy may be capacitively coupled onto a sequential device to cause it to change state：High speed Schottky elements in a test setup can exceed this limit．However in an active system， the edges will generally be slowed sufficiently to eliminate any problem．


Figure 17．Differential Line Driving and Receiving with the Am26LS31 and Am26LS32．

## DEFINITION OF STANDARD TERMS

## DEFINITION OF A．C．SWITCHING TERMS

（All switching times are measured at the 1.3 V logic level for Low－Power Schottky and the 1.5 V logic level for Schottky unless otherwise noted．）
$f_{\text {MAX }}$ The highest operating clock frequency．
tpLH The propagation delay time from an input change to an output LOW－to－HIGH transition．
$t_{\text {PHL }}$ The propagation delay time from an input change to an output HIGH－to－LOW transition．
tpw Pulse width．The time between the leading and trailing edges of a pulse．
$t_{r} \quad$ Rise time．The time required for a signal to change from $10 \%$ to $90 \%$ of its measured values．
$\mathbf{t f}_{f}$ Fall time．The time required for a signal to change from $90 \%$ to $10 \%$ of its measured values．
$\boldsymbol{t}_{\mathbf{s}}$ Set－up time．The time interval for which a signal must be applied and maintained at one input terminal before an active transition occurs at another input terminal．
$t_{h} \quad H o l d$ time．The time interval for which a signal must be retained at one input after an active transition occurs at another input terminal．
$\mathbf{t}_{\mathbf{H z}} \quad \mathrm{HIGH}$ to disable．The delay time from a control input change to the three－state output HIGH－ level to high－impedance transition（measured at 0.5 V change）．
tLz LOW to disable．The delay time from a control input change to the three－state output LOW－ level to high－impedance transition（measured at 0.5 V change）．
tzH Enable HIGH．The delay time from a control input change to the three－state output high－ impedance to HIGH－level transition．
tzL Enable LOW．The delay time from a control input change to the three－state output high－ impedance to LOW－level transition．

## DEFINITION OF D．C．TERMS

H HIGH，applying to a HIGH voltage level．
L LOW，applying to a LOW voltage level．
1 Input
0
Negative Current flowing out of the device． Current
Positive Current flowing into the device． Current

IIL
$I_{I H} \quad$ HIGH－level input current with a specified HIGH－level voltage applied．
loL LOW－level output current．
IOH HIGH－level output current．
IsC Output short－circuit source current．
Icc The supply current drawn by the device from the $\mathrm{V}_{\mathrm{CC}}$ power supply．
IozH Three－state off－state output current，HIGH－ level voitage applied．
Iozl Three－state off－state output current，LOW－ level voltage applied．
VCC The range of supply voltage over which the device is guaranteed to operate．
$V_{I L} \quad$ The guaranteed maximum input voltage that will be recognized by the device as a logic LOW．
$\mathbf{V}_{\mathbf{I H}} \quad$ The guaranteed minimum input voltage that will be recognized by the device as a logic HIGH．

VOL The maximum guaranteed logic LOW voltage at the output terminal while sinking the specified load current lol．
$V_{\mathrm{OH}} \quad$ The minimum guaranteed logic HIGH voltage at the output terminal when sourcing the specified source current loH．

## PARAMETER MEASUREMENTS

LOAD TEST CIRCUIT FOR THREE－STATE OUTPUTS


SET UP，HOLD，AND RELAESE TIMES


Note：For standard totem－pole outputs， remove $\mathrm{R}_{1} . \mathrm{S}_{1}$ and $\mathrm{S}_{2}$ closed．

Notes：1．Diagram shown for HIGH data only．Output transition may be opposite sense．
2．Cross hatched area is don＇t care condition．


Note: 1. Pulse Generator for All Pulses: Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{O}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$ for Schottky. Rate $\leqslant 1.0 \mathrm{MHz} ; Z_{0}=50 \Omega ; t_{r} \leqslant 15 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 6 \mathrm{~ns}$ for Low-power Schottky.

# Am2900 Components Continuously Become Faster and Faster 

## MORE SPEED: NO MORE POWER

There's a good old tried and proven way to make faster IC's - burn more power. (That's the only real difference between '"LS' and 'S' devices). But that solution isn't satisfactory for LSI devices like the Am2900 Family. Power is constrained to existing levels for reliability reasons.

Am2900 parts are always designed to obtain the maximum speed at a power level which is safe for the package types and operating environment of the part. To increase speeds, new technologies must be used to build faster components at no increase in power.

## NEW CIRCUIT DESIGN TECHNIQUES MAKE FASTER GATES

One way to make faster components is to use new circuit design techniques. The most obvious is internal ECL, which provides very fast gates at similar power levels to LS TTL. The Am29116 reaches microcycle times of 100 ns through the use of internal ECL. Other design techniques, such as low-level logic (with very small logic swings on-chip), can also provide higher speeds without introducing the time penalty of ECL to TTL conversion.

Finally, very low power gates used in non-critical speed paths make more power available for use in critical speed paths. As the 2900 Family develops, all these technologies will be used within a single component to achieve the highest speeds without increasing power. The Am2903A is one of the first products to take advantage of this mixed circuit technology.

## IMPROVED PROCESS CONTROL ALLOWS TIGHTER SPECS

Today's 2900 parts are carefully characterized over a wide range of voltages, temperatures, and process parameters before an AC specification is published. As manufacturing technology improves, the process is subject to smaller run-
to-run variations, so that all of the product is closer to design nominal. This makes it possible to specify parameters more closely to typical without incurring large yield losses. The first product reflecting this is the Am2903.

## WHAT'S GOOD FOR THE GOOSE IS GOOD FOR THE GANDER

Many new tools in production technology are emerging, primarily spurred by the emphasis on high-speed MOS memories. The same tools, such as projection masking, also provide for smaller geometries in bipolar circuits. As MOS gets faster, so does bipolar. The Am2901C obtains its speed improvement over the Am2901B through these tools.

## PROCESS TECHNOLOGY TAKES A QUANTUM LEAP

Current generátion LSI/VLSI bipolar devices call for state-of-the-art processing technologies. IMOX ${ }^{\text {TM }}$ ion-implanted micro-oxide technology gives the Am2901C its performance improvement over the Am2901B. IMOX also generates incredible packing densities - the Am29116 has 2500 gates on a single bipolar chip!

## DESIGN FOR THE FUTURE

Every Am2900 part will undergo an evolution as new technologies become practical for production. Every part type will continuously become faster. The results are easy to observe - increases in performance at no additional cost (see Figure 1).

Most existing 2900 designs can be offered in higher performance versions simply by substitution of the 2901C for the 2901B, the 2909A for the 2909, and 2903A for the 2903, and so forth. Your 2900 design won't run out of speed in a few years. Advanced Micro Devices' 2900 Family will serve tomorrow's needs as well as today's.

Figure 1. Price/Performance Improvements


Figure 2. Bipolar Speed/Density Improvements
Am2901 FOUR-BIT MICROPROCESSOR SLICE


540 GATES 800 mW 40-PIN DIP
$\left.\begin{array}{|lcccc|}\hline \text { DIE } & \text { Am2901 } & \text { Am2901A } & \text { Am2901B } & \text { Am2901C } \\ \text { SIZE } & 33,000 \text { MILS }^{2}\end{array}\right)$

## INTRODUCTION

## THREE GENERATIONS OF TTL

Transistor-transistor logic has been the dominant technology for digital circuits since it was developed in the mid-1960's. It has proven itself to be manufacturable in high volume using an extremely reliable process technology. The processes used for TTL have evolved over the years, making components smaller, faster and less expensive. Relative to a TTL gate manufactured in 1966, a gate on a circuit manufactured today occupies $1 / 5$ the area, consumes $1 / 10$ the power, is twice as fast and costs less than $1 / 100$ the price.

The circuits built using TTL technology have gone through two generations; the Am2900 Family represents the beginning of the third. Each generation consists of circuits which are fundamental building blocks of systems - circuits which can be interconnected in many different ways to build many different systems. Only by producing such universal circuits can manufacturing volumes be high enough to generate the rapid cost reductions characteristic of the integrated circuit industry.

The quality which distinguishes one generation from another is the level of integration used, and, because of the level of integration, the philosophy behind the circuit.

If one draws a curve plotting the cost of an individual gate against the number of gates on a chip, Figure 1 results.


Figure 1.

At the left, cost per gate is inversely proportional to the number of gates on the chip. The chip is small enough that it does not represent a significant portion of the cost of the product - it is virtually free. The cost of the product is composed of labor in assembly and test, the cost of processing an order, shipping and fixed overhead. Doubling the number of gates on the chip doesn't materially affect the cost so the cost per gate halves. As the number of gates per chip increases, the die begins to cost more, reversing the downward trend. As die cost dominates, the cost per gate remains relatively flat until the yield of the die begins to decline markedly. The cost per gate then begins to rise again. The lowest cost per gate is achieved at a level of integration corresponding to the flat region. This is the optimum level of integration.

As technology improves, costs are constantly reduced and the optimum level of integration occurs at more and more gates per chip.

The three curves of Figure 2 are the reason for the three generations of TTL. Each generation has consisted of fundamental system building blocks designed to take advantage of the optimum level of integration at the time.


OP001450
Figure 2.

## GENERATION I - SSI, 1965

In 1965, the optimum level of integration was three-to-six gates per chip. Users were delighted to buy such chips at $\$ 10-20$ each. The circuits were useful in many systems. They consisted of gates - 7400, 7410, 7420 - and, pressing the state of the art, some flip-flops. They were fundamenta building blocks.

## GENERATION II - MSI, 1970

Beginning around 1968, it became economical to put more gates on a chip and the industry was faced with a problem: How does one put 20 gates on a chip and build a universal building block? Clearly, one answer was to bring the inputs and outputs off chip as had been done before. But that was the wrong answer. The right answer was to redefine fundamental building blocks. The new building blocks fell into seven categories:

- Counters
- Decoders
- Multiplexers
- Operators (adders, comparators)
- Encoders
- Registers
- Latches

All systems could be defined in terms of these seven functions, and integrated circuits could be defined at the 20-50 gate/chip level which performed these functions efficiently. This, of course, is MSI. Over the last six or seven years, more and more circuits of this type have been introduced, utilizing standard gold-doped technology, low-power TTL, high-speed TTL, Schottky TTL, and now low-power Schottky TTL technology. Today, there are over 250 different MSI circuits and new ones appear every month. But in today's technology, many of these circuits are not particularly cost effective. They are too small for today's technology and their costs are labor intensive. (Labor costs do not follow traditional semiconductor pricing patterns.) in 1977, the optimum level of integration for bipolar logic was around 500 gates chip.

## GENERATION III - The Am2900 Family, 1976

At a 500-gate-per-chip level of integration, one does not build counters, decoders, and multiplexers. A new definition of fundamental system functions was needed. Advanced Micro Devices has defined these eight categories:

- Data Manipulation
- Microprogram Control
- Macroprogram Control
- Priority Interrupt
- Direct Memory Access
- I/O Control
- Memory Control
- Front Panel Control

The Am2900 Family includes circuits designed to perform those functions efficiently. They are fundamental system building blocks; they contain hundreds of gates per chip; they are fast - utilizing Low-Power Schottky TTL technology and AMD's proprietary IMOX ${ }^{\text {TM }}$ technology; they are expandable; they are flexible - useful in emulation; and they are driven under microprogram control.

## IMOX AND ECL - THE NEXT STEP

Ever increasing complexity placed greater and greater demands on existing process technologies. Advanced Micro Devices responded to this challenge by introducing its revolutionary IMOX ion-implanted micro-oxide technology in 1980. Oxide isolation generated faster transistor switching and tighter packaging. Ion-implantation meant tighter parameter control and lower power consumption. The bottom line - an unequalled combination of speed and density culminating in the Am29116 with a staggering 2500 gates-per-chip. Figure 3 shows this climb in gate density.


## Figure 3. Am2900 Bipolar LSI/VLSI

Future refinements of IMOX and new device technologies will keep AMD on the leading edge in bipolar LSI/VLSI. Designed to take advantage of these improvements in process technology, a new family of microprogrammable 32-bit controller products will set the pace for bipolar VLSI in the mid-1980s.

## THE Am2900 FAMILY

The Am2900 Family consists of a series of LSI building blocks designed for use in microprogrammed computers and controllers. Each device is designed to be expandable and sufficiently flexible to be suitable for emulation of many existing machines. It is the wide variety of machine architectures possible with the Am2900 Family which sets it apart from the fixed-instruction microprocessors such as the Am8086.

While an Am8086 can be used to build a microcomputer with only four or five pac', ages, an Am2900 design will require 30 or 40 or more. The Am8086 design will, therefore, almost always be cheaper. But the Am8086, or any other fixed-instruction processor, can execute only one instruction set, so it is not really suitable for emulation of another machine.

Moreover, a fixed-instruction processor operates only on words of a single length, e.g., sixteen bits. An Am2900 design, on the other hand, can be constructed for any word length which is a multiple of four bits.

Many applications require specialized operations to be performed at relatively high speed. Such functions as multiply and divide and special graphic control operations, can be done in microcode 10-100 times faster than in. fixed-instruction MOS processors.

## MICROPROGRAMMED ARCHITECTURE

Most small processors today are being designed using a technique called microprogramming. In microprogrammed systems, a large portion of the system's control is performed by a read only memory (usually PROM) rather than large arrays of gates and flip-flops. This technique frequently reduces the package count in the controller and provides a highly ordered structure in the controller, not present when random logic is used. Moreover, microprogramming makes changes in the machines' instruction set very simple to perform - reducing the post-production engineering costs for the system substantially.

The Am2900 Family of Bipolar LSI devices has been' designed for use in microprogrammed systems. Each device performs a basic system function and is driven by a set of control lines from a microinstruction.

Figure 4 illustrates a typical system architecture. There are two 'sides" to the system. At the left is the control circuitry and on the right is the data manipulation circuitry. The block labeled "'2901C array" consists of the ALU, scratchpad registers, data steering logic (all internal to the Am2901Cs), plus left/right shift control and carry lookahead circuit. Data is processed by moving it from main memory (not shown) into the 2901C registers, performing the required operations on it and returning the result to main memory. Memory addresses may also be generated in the 2901Cs and sent out to the memory address register (MAR). The four status bits from the 2901Cs ALU are captured in the status register after each operation.

The logic on the left side is the control section of the computer. This is where the Am2909A, 2910A, or 2911A is used. The entire system is controlled by a memory, usually PROM, which contains long words called microinstructions. Each microinstruction contains bits to control each of the data manipulation elements in the system. There are, for example, nine bits for the 2901C instruction lines, eight bits for the A and $B$ register addresses, two or three bits to control the shifting multiplexers at the ends of the 2901C array (see Figure 19, 2901 C data sheet), and bits to control the register enables on the MAR, instruction register, and various bus transceivers. When the bits in a microinstruction are applied to all the data elements and everything is clocked, then one small operation (such as a data transfer or a register-to-register add) will occur.

A 'machine instruction' (such as a minicomputer instruction or an 8086 instruction) is performed by executing several microinstructions in sequence. Each microinstruction therefore contains not only bits to control the data hardware, but also bits to define the location in PROM of the next microinstruction to be executed. The fields are labeled in Figure 4 as I, CC, and BA. The I field controls the sequencer. It indicates where the next address is located - the $\mu \mathrm{PC}$, the stack, or the direct inputs - and whether the stack is to be pushed or popped.

The CC field contains bits indicating the conditions under which the I field applies. These are compared with the condition codes in the status register and may cause modification to the I field. The comparing and modification occurs in the block labeled ''control logic''. Frequently this is a PROM or PLA. In the case of the Am2910, it is built into the chip. The BA field is a branch address or the address of a subroutine.

## PIPELINING

The address for the microinstructions is generated by the sequencer, starting from a clock edge. The address goes from the sequencer to the ROM and, an access time later, the microinstruction is at the ROM outputs.

A pipeline register is a register placed on the output of the microprogram memory to essentially split the system in two.

The pipeline register contains the microinstruction currently being executed (1). (Refer to the circled numbers in Figure 4.) The data manipulation control bits go out to the system elements and a portion of the microinstruction is returned to the sequencer (2) to determine the address of the next microinstruction to be executed. That address (3) is sent to the ROM and the next microinstruction (4) sits at the input of the pipeline register. So while the 2901Cs are executing one instruction, the next instruction is being fetched from ROM.

Note that there is no sequential logic in the sequencer between the select lines and the output. This is important because the loop (1) to (2) to (3) to (4) must occur during a single clock cycle. During the same time, the loop from (1) to (5) must occur in the 2901Cs. These two paths are roughly the same (around 200 ns worst case for a 16 -bit system). The presence of the pipeline register allows the microinstruction fetch to occur in parallel with the data operation rather than serially, allowing the clock frequency to be doubled.

Figure 4.


The system shown in Figure 4 works as follows. A sequence of microinstructions in the PROM is executed to fetch an instruction from main memory. This requires that the program counter, often in a 2901 C working register, be sent to the memory address register and incremented. The data returned from memory is loaded into the instruction register. The contents of the instruction register is passed through a PROM or PLA to generate the address of the first microinstruction which must be executed to perform the required function. A branch to this address occurs through the sequencer. Severa! microinstructions may be executed to fetch data from memory, perform ALU operations, test for overflow, and so forth. Then a branch will be made back to the instruction fetch cycle. At
this point, there may be branches to other sections of microcode. For example, the machine might test for an interrupt here and obtain an interrupt service routine address from another mapping ROM rather than start on the next machine instruction. There are obviously many possibilities. Throughout this data book, in application notes, and within data sheets, some suggested techniques will be found.

Additional application notes are in preparation and are planned for publication. Advanced Micro Devices' Applicalions' staff is available to answer questions and provide technical assistance as well. They may be reached by calling (408) 732-2400, or, outside California (800) 538-8450. Ask for Am2900 Family Applications.

## Am29100 High-Performance Controller Products

## A BETTER WAY IS HERE

A new family of products from Advanced Micro Devices makes high-performance controller design a snap.

## MICROPROGRAMMING; BEST FOR COMPUTERS, BEST FOR CONTROLLERS

Microprogramming, long the preferred approach for computer design, offers lots of advantages in controllers as well. The ease with which the functions of a microprogrammed controller can be enhanced and modified made the original 2900 Family popular for many disk, printer and communications controllers. The high-speed operation of these microprogrammed systems makes it possible to handle higher data rates from newer peripheral devices and to build intelligence into the controller.

But the original 2900 products are architecturally oriented toward computers, with design features optimized for arithmetic functions and short sequences of microinstructions. MOS processors are good choices for many lowspeed applications, but when the demand for speed and intelligence goes up, they cannot keep pace. Controllers need something better: the 29100 Family.
The 29100 Family products have been designed from the ground up with peripheral control applications in mind. They are fast, they are optimized for bit-manipulation, character handling, data communication and long, sophisticated microprograms and they are designed to work together in a system.

## FAST LIKE YOU'VE NEVER HAD

The central element of our new high-speed controller family is the Am29116-a 16-bit bipolar microprocessor. It's not a slice - it's a complete 16 -bit processor, with three-input ALU, 32 scratchpad registers, an accumulator, data latch, barrel shifter, priority encoder and status register with conditional code generation logic. But the Am29116 is far
more than a very fast number cruncher - it's been optimized for controller-oriented applications. It's instruction set has instructions often needed in controllers that are not available in any other processor.

## A WHOLE FAMILY OF FAST LSI CONTROLLER PARTS

There's more to our controller family than just the Am29116. A new sequencer, the Am29112, has been expressly designed for 10 MHz microprogram control, with features like real-time interrupt servicing and deep subroutining. Rapid internal data transfer is handled by the Am2940 DMA Address Generator and by the Am2950 handshaking I/O port. The Am9520 Burst Error Processor will provide a solution for error correction on disk reads. Now, more than ever, the 2900 Family is the better solution for high data rate and highly intelligent control problems.

## TYPICAL CONFIGURATION USING THE 2900 CONTROLLER FAMILY

A typical intelligent controller configuration is shown below. The basic controller consists of the Am29116, a microprogram control unit and a high-speed buffer memory. Each microinstruction includes: a) a 16-bit instruction field to the Am29116, b) next-microinstruction selection bits, c) control for the buffer memory, $d$ and e) control for the interface circuits and f) possibly an 8 or 16 -bit data field.

Interface circuits like the Am2940 and Am2950 are used to provide DMA and to pass data between the controller and the host computer. Other circuits are used to interface to the peripheral. In this example, a disk interface is shown with a serial-parallel converter, a FIFO and a burst error processor. Controllers for other peripherals use identical hardware except for the peripheral interface itself.

HIGH-PERFORMANCE INTELLIGENT CONTROLLER


# The Am29500 Family 

A High-Performance Architecture<br>For Digital Signal/Array Processing

The new system designs of the '80s will continue to press the performance limits of technology. Parallel processing and pipelined architectures will become the standard approach. The new architectures are best implemented with a chip set that has been designed from the ground up with high speed array processing in mind.

The Am29500 Family is designed specifically for these new architectures. Every key product feature supports the system end objective of maximum performance and flexibility. These include:

- Microprogrammable, parallel functions
- Pipeline organization used throughout
- $I M O X^{T M}$ process and ECL internal structures
- TTL I/O for easy interfacing

The first members of the family are targeted for the efficient execution of DSP and array processing algorithms. The most common algorithms include Infinite Impulse Response (IIR) and Finite Impulse Response (FIR) digital filters and Fast Fourier Transform (FFT) processors.

The first major building blocks are designed to support maximum performance signal processing applications.

Included are:

- Am29501 Multi-Port Pipelined Processor

A specialized parallel processor which executes multiple simultaneous data operations. Its Register/ALU structure provides the key functional element for a high performance signal processing system. Eight-bit slice!

- Am29540 FFT Address Sequencer

This algorithm-specific VLSI chip generates data and coefficient addresses for the Fast Fourier Transform. It supports a wide variety of FFT algorithms in either radix-2 or radix-4.

- Am29516/29517 High Speed $16 \times 16$-Bit Parallel Multipliers
Both are $16 \times 16$-bit Parallel Multipliers. The Am29516 is pin and functionally compatible with the MPY-16HJ, but with an added multiplexer to output the LSP at the MSP port. The Am29517 is the same function, but with clock enables for microprogrammed applications.
- Am29520/29521 Multilevel Pipeline Registers Both devices contain four 8-bit registers for dual two-stage (FFT butterfly) or single four-stage (general purpose) data or address pipelining. Combined load-and-shift (Am29520) or separate load-and-shift (Am29521) control options are available.
- Am29526/29527/29528/29529 High-Speed Sine/ Cosine Function Generators
The sine and cosine functions are necessary for Fast Fourier Transforms (FFT). The Am29526/527 generate the most significant and least significant byte of the 16-bit sine function and the Am29528/ 529 generate the most significant and least significant byte of the 16 -bit cosine function. The sine and cosine functions are generated to provide a range of $\theta$ for a half cycle, $0 \leqslant \theta \leqslant \pi$, in increments of $\pi / 2048$. All four units have a 50 ns maximum commercial generation time.

HIGH PERFORMANCE SIGNAL PROCESSOR


A high-performance signal processor may be constructed as shown in the diagram. The processor is built entirely with new Am29500 digital signal processing and Am2900 devices. Such a processor is attached as a slave to the main system bus to perform the multitude of arithmetic operations which prevail in DSP algorithms.

Using this architecture it is possible to implement a radix-2 FFT butterfly in four instruction cycles. This allows a 1024 point complex FFT to be performed in approximately 2 ms .

Fast multiplication is the key to high-speed digital-signal processing and high-speed array processing. In addition to the Am29516 and Am29517, Advanced Micro Devices is developing an extensive family of multipliers. The first addition to the high-performance multiplier group:

- Am29510 High-Performance $16 \times 16$ Bit Multiply Accumulator
The multiply accumulator provides single cycle multiply accumulation or subtraction. The Am29510 is a pinand function-compatible alternate source for the TRW TDC1010J. As illustrated with the Am29516/517, the multiply accumulator will have a speed improvement over existing multiply accumulators.
- Am295XX to be announced.


## -More Multipliers

A proliferation of the existing multiplier architectures will generate a complete family of multipliers and multiplier accumulators.
-Floating Point Processors (FPP)
A 32-bit FPP capable of performing single-cycle dou-ble-precision floating-point addition, subtraction, and multiplication. The FPP performs the arithmetic operations in DEC or IEEE format. Available 1984.

Am29500 ARRAY PROCESSOR


BD002650

# Am2960-70 Memory Support Family System Overview 

Memory system designs are increasingly shaped by three requirements:

1. Higher system performance
2. More memory capacity in less space
3. Increased reliability

The Am2960-70 Memory Support Family is a family of LSI building blocks which excels in satisfying these three requirements and provides a complete systems solution for designs using 64 K or 256 K DRAMS. The family members include:

Am2960 Error Detection and Correction Unit<br>Am2961/62 EDC Bus Buffers<br>Am2964B Dynamic Memory Controller<br>(64K DRAM Version)<br>Am2965/66 Dynamic RAM Drivers<br>Am2968 Dynamic Memory Controller<br>(256K DRAM Version)<br>Am2969 Timing Controller<br>Am2970 Timing Controller<br>Am8163/67 System and Timing Controller for MOS MPUs

These are general purpose products. They will support any suppliers' DRAMs and will work with any processor type: 8086, 80186, 80286, 68000, Z8000, and Am2900 processors. They may also be used to support word widths of any size from 8 bits to 64 bits.

Figure 1 shows the system interconnection for a typical memory system for 256K DRAMs, and Figure 2 shows the system irterconnection for a typical memory system using 64K DRAMs. In both cases, the memory support subsystem interfaces to the System Data Bus, Address Bus, and control signals. Also, in both cases all, or almost all, of the memory support functions are handled by AMD LSI devices. This simplifies the design of the memory system and, more importantly, allows the board space available for DRAMs to be maximized because the LSI solution for control and error correction is very compact.

## ERROR DETECTION AND CORRECTION

It is important that memory systems function reliably. The number of bytes of storage is increasing rapidly in memory systems at the same time that the density of the MOS DRAMs is growing. With 64 K and 256 K DRAMs, alpha particle sensitivity is much greater than that of smaller DRAMs because of the reduced size of the memory cells and the smaller stored charge of the cell. A Technical Report follows the Am2960 data sheet in this section and is entitled "Am2960 Boosts Memory Reliability." This technical report gives some statistics on soft error rates for DRAMs and demonstrates the dramatic increase in memory reliability gained from the use of Hamming Code Error Detection and Correction schemes, such as those used by the Am2960 EDC (Error Detection and Correction) unit.

Data interface between the dynamic memories, the Am2960 EDC chip and the system data bus is accomplished by means of the Am2961/62 bus buffers. Figure 3 depicts the architecture of these devices along with a
simplified block diagram of the Am2960. The Am2961 is inverting between the system data bus and the EDC bus while the Am2962 is noninverting. As shown in Figure 3, the Am2961 and Am2962 contain two internal latches, a multiplexer, and a RAM driver output buffer.

These devices feature 4-bit-wide data paths to and from the RAM, the EDC, and the system data bus. The bus-input (BI) latch is used predominantly in byte WRITE operations, so that an incoming byte from the system data bus can be stored while the memory is being read, and any necessary correction made in the bytes not being changed. The busoutput ( BO ) latch is used predominantly for storing the output data if the processor is in the single-step mode. In the single-step mode it is necessary to hold the output data on the system data bus, but the memory must be released for refresh.

The Am2960 Error Detection and Correction Unit contains all the logic necessary to generate check bits on a 16 -bit data field according to a modified Hamming code and to correct the data word when check bits are supplied. Operating on the data read from memory, the Am2960 will correct any single-bit error and will detect all double- and some triple-bit errors. For 16 -bit words, 6 check bits are used. The Am2960 is expandable to operate on 32-bit words ( 7 check bits) and 64-bit words ( 8 check bits). In all configurations, the device makes the error syndrome bits available on separate outputs for data logging.

The Am2960 also features two diagnostic modes in which diagnostic data can be forced into portions of the device to simplify device testing and to execute system diagnostic functions.

The 16-bit Diagnostic Latch is loadable from the bidirectional data lines under control of the Diagnostic Latch Enable, LE DIAG. It contains check bit information in one byte and control information in the other, and is used for driving the device when in the Internal Control mode, or for supplying check bits when in one of the Diagnostic modes.

The control logic determines the specific operating mode. Normally the control logic is driven by external control inputs; however, in the Internal Control mode, the control signals are instead read from the Diagnostic Latch.

The Am2960 is a very fast EDC device, but even faster versions will soon be available. A speed selected version, the Am2960-1, is described in the Am2960 data sheet, and an $\mathrm{IMOX}^{\text {TM }}$ version, the Am2960A, will be available by early 1985. All speed-improved versions have identical functions and are electrically plug-compatible with the current Am2960.

## MEMORY SYSTEM CONTROL AND TIMING

Two Dynamic Memory Controllers are available for generating address, $\overline{\mathrm{RAS}}$, and $\overline{\text { CAS }}$ signais for memory banks. The Am2964B is designed to work with 64K DRAMs of which each device can handle up to four banks for a total control capacity of 256 K words. The new Am2968 is designed to work with 256K DRAMs and can also handle up to four banks for a total control capacity of 1 Megaword (the words
can be as many bits wide as desired). Also, the Am2968 does not require external driver chips as does the Am2964B - the Am2968 has the memory drivers, with all of the undershoot control and speed features of the Am2965/ 66 , built right into its address, $\overline{R A S}$, and $\overline{\mathrm{CAS}}$ outputs.

For generating the timing and control signals required by the Am2964B/68 and the Am2960/61/62, there are several different devices available, optimized for different system requirements. For MOS Microprocessor systems, use the Am8163 or Am8167. Both of these devices will interface

Figure 1. Am2900 High Performance Memory Subsystem Using 256K DRAMs


BD002660

Figure 2. Am2900 High Performance Memory Subsystem Using 64K DRAMs



Figure 4. Am 2960 Block Diagram

easily to iAPX86/186/286, Z8000, or 68000 microprocessors. The Am8163 and Am8167 provide the control signals and timing signals for the memory controllers, the EDC, and the data bus buffers - in addition, the Am8163/67 decode the memory system control signals directly from the MOS Microprocessor, requiring in most cases only a single PAL ${ }^{\text {TM }}$ for interfacing.
For high-performance Am2900-based processors or other high-speed processor designs, use the Am2969 or Am2970 to generate timing and control signals.
Following is a description of the function of the Am2964B/65/ 66 for Dynamic Memory Control for 64K DRAMs. The Am2968 incorporates these features and more into a single IC for use with 256K DRAMs.
The Am2964B Dynamic Memory Controller is used to provide all address handling, as well as $\overline{R A S}$ and $\overline{\text { CAS }}$ decoding and control. A block diagram of the Am2964B Dynamic Memory Controller is shown in Figure 5. The device contains 18 input latches for capturing an 18-bit address for memory control; the two highest order addresses are decoded in the Am2964B to select one of four banks of RAM by selecting one of the four RAS outputs.
The Am2964B is designed to operate with either 16 K Dynamic RAMs or 64 K Dynamic RAMs. Thus, the designer either uses 14 of the multiplexer address inputs and 7 of the address outputs or all 16 of the multiplexer address inputs and all 8 of the address outputs as needed by the memory. In the case of 16K Dynamic RAMs, 7 address inputs are provided to the RAM during the $\overline{R A S}$ LOW signal, and then the 8-bit multiplexer is switched so that 7 upper address bits are provided to the RAM for the $\overline{C A S}$ LOW part of the cycle. The Am2964B Dynamic Memory Controller contains an 8-bit refresh counter that is used to supply the refresh address to the dynamic
memory during the refresh cycle. This counter can be used in either the 128 or 256 line refresh mode. A CAS buffer is included in the dynamic memory controller so that the $\overline{C A S}$ output can be inhibited during refresh.

Normal operation of the Dynamic Memory Controller is to provide the address, close the input address latches and kick off a normal memory cycle. This is accomplished by bringing the $\overline{R A S I}$ input LOW, which will cause one of the RAS outputs to go LOW. After the required memory timing, the MSEL input will be used to switch the multiplexer to the other address latch, then, the $\overline{\text { CASI input will be driven LOW causing the }}$ $\overline{\text { CASO }}$ output to go LOW and execute the $\overline{C A S}$ part of the memory cycle. The refresh cycle is executed by driving the $\overline{\text { RFSH }}$ input LOW which causes the multiplexer to connect the refresh counter to its address outputs. Then, the $\overline{\text { RASI }}$ input is driven LOW which causes all four $\overline{\text { RAS }}$ outputs to go LOW. This will simultaneously refresh all four banks of dynamic RAMs controlled by the Am2964B Dynamic Memory Controller. When either the $\overline{\text { RFSH }}$ or $\overline{\text { RASI }}$ input is brought HIGH, the refresh counter is advanced so it will be ready for the next refresh cycle.

As can be seen in Figure 1, Dynamic RAM Drivers can be used in large memory systems to buffer the Address, $\overline{\mathrm{RAS}}, \overline{\mathrm{CAS}}$ and WRITE ENABLE signals to the RAMs. The Am2965 and Am2966 are pin compatible devices with the Am74S240 and Am74S244. These RAM drivers are specifically designed for driving dynamic RAMs and feature high capacitance drive, guaranteed maximum undershoot of less than -0.5 volts and high $\mathrm{V}_{\mathrm{OH}}$ of greater than $\mathrm{V}_{\mathrm{CC}}-1.15$ volts. The Am2965 is inverting and the Am2966 is noninverting. The devices feature symmetrical rise and fall times and have guaranteed minimum and maximum tpD specifications for both 50 pF and 500 pF loads.

Figure 5. Am2964B Dynamic Memory Controller


# Am2900 Family Applications Literature 

Available from AMD's Customer Education Center



## School of Advanced Engineering

## BIPOLAR APPLICATION DESIGN COURSES

AMD's School of Advanced Engineering offers graduate-level instruction in designing with the newest technologies. Bipolar design courses take you from the basics of bit-slice architecture through basic design with the 2900 Family on to the microprogram development system and its application to your design and finally to emulation and CPU architecture where students create microcode to drive an actual system, using the writable control store of the AmSYS29 development system.

For More Information:
Contact your AMD Sales Representative or write to:
Advanced Micro Devices
School of Advanced Engineering
Customer Education Center
490-A Lakeside Drive
P.O. Box 453

Sunnyvale, California 94086 U.S.A.

# Macro Meta Assembler from Microtec* 

The Macro Meta Assembler is a valuable programming tool for those faced with the problem of writing micro-programs for bit slice processors such as the AMD 2901 and other similar microprogrammable microprocessors. It is a necessity for anyone faced with the problem of micro-programming any wide-word driven micro-sequencer system.
The Macro Meta Assembler is an enhanced version of Microtec's Meta Assembler. It is totally upward compatible, yet can perform many functions that are difficult or impossible with more basic packages.
The principal new feature of the Macro Meta Assembler is a powerful macro facility that enables the user to define variable length microinstructions using a single mnemonic; to encode complex overlayed instructions, and to encode non-contiguous fields. Macros may be passed a variety of parameter types: Symbols, Numbers, Opcodes, and Character Strings. Within the Macro-expansion parameters may be dynamically concatenated to existing text or other parameters, Symbols may be declared Local to the current Macro or be defined globally, and a wide variety of operators have been implemented for use with conditional Macro expansion. Macro calls may be nested and may be recursive.

Other features that have been added to the language include the availability of boolean and relational operators in expressions, automatic generation of parity bits and entry point PROMs.

The Meta Assembler consists of three separate programs: the Definition Program, the Assembly Program, and the PROM Formatter Program. These programs allow the user to define a unique assembly language, assemble a program written in the user-defined language, and organize the resulting object module into arrays that are compatible with the target ROM/PROM memories.
The Definition Program allows the user to define instruction mnemonics and their associated formats. Instruction lengths may vary from 1 to 128 bits. An instruction format is defined by breaking the microword into fields as variables, constants, or "don't care" bits. The variable fields are filled in at Assembly time. Default values and certain permanent attributes may also be assigned to variable fields at Definition time. The Definition Program produces an output listing and a disk file which contains the symbols and instruction mnemonics. This Definition file is used by the Assembly program as a reference when assembling a program.
The Assembly Program is similar to a traditional two-pass assembler. A symbolic source program utilizing the mnemonics and symbols defined in the Definition Program is read as input; a program listing and object module are generated as output. The Assembler provides symbolic addressing, relative addressing, paged addressing, and other features found in typical assembly programs. The instruction syntax and assembler directives are compatible with those utilized by AMD in its literature and software products. Additional directives have been implemented for versatile listing and output controls.

Both the Definition Program and the Assembly Program are implemented with Conditional Assembly Operators. Conditional statements may be nested up to 16 levels and can be made dependent on general expressions, character string equality, and symbol definition status. A full cross reference table is provided in both programs.

The following directives are included in Microtec's Macro Meta Assembler Program:

| MACRO | - Define a Macro |
| :---: | :---: |
| ENDM | - End a Macro Definition |
| EXITM | - Alternater Macro Exit |
| LOCAL | - Define a Macro Local Symbol |
| IF | - Conditional Assembly if Expression is Non-Zero |
| ELSE | - Conditional Assembly Statement Converse |
| ENDIF | - Conditional Assembly Statement End |
| IFC | - Conditional Assembly if Character Strings |
| IFNC | - Conditional Assembly if Character Strings Don't Compare |
| IFD | - Conditional Assembly if Symbol Defined |
| IFND | - Conditional Assembly if Symbol Not Defined |
| MAP | - Generate Entry Point Table |
| DUP | - Duplicate a Line (in timesharing version of AMDASM) |
| DATA | - Define Data Word (in timesharing version of AMDASM) |

The PROM Formatter Program reads the object module produced by the Assembly Program and translates the format into one that can be read by a PROM programmer. BNPF, Data I/O ASCII hexadecimal, and the Step Engineering format are supported. Microwords in the object module can be divided into organizations that are compatible with the target PROM/ROM array. The length and width of PROMS may be specified as well as the value of "don't care" bits. The PROM Formatter has three new features that add to the versatility of the program: single bit parity generation; column switching; and column overlaying.

The Macro Meta Assembler is written in ANSI Fortran and will run on any general purpose digital computer that has a Fortran IV compiler, a word length of at least 16 bits, a disk or magnetic tape facility and $20-24 \mathrm{~K}$ words of program memory. In most systems these programs can be run in an overlayed mode if the required memory is not available.

The programs are well commented and modular. A detailed manual, source listing, test programs, and test program output listings accompany each software order. The test programs allow the operation of the software to be verified quickly and easily. A manual is available for a small fee, if further information is desired.

For additional information, contact Microtec, P.O. Box 60337, Sunnyvale, California 94088. Telephone (408) 7332919.

Microtec has available a Meta Assembler program for the AMD 2900 microprocessor and other similar microprogrammable microprocessors. The Assembler is compatible with AMD's AMDASM program, but is written in ANSI standard Fortran IV and will run on any machine that has:

1. A Fortran IV compiler
2. A word length of at least 16 bits
3. A disc or magnetic tape facility
4. 18 K words of Random Access Memory (in most systems these programs can be run in an overlayed mode if the required memory is not available)

The Meta Assembler Software Package actually consists of three separate programs, a Definition Program, an Assembly Program, and a PROM Formatter Program.
The Definition Program allows the user to define instruction mnemonics and their associated formats. Instruction lengths may vary from 1 to 128 bits. Symbolic Constants and reserved words may also be defined in the Definition Program. An instruction format is defined by breaking the microword into fields and defining the fields as constants, don't care bits, or variables which are filled in at assembly time. Default values and certain permanent attributes may also be assigned to variable fields at Definition time. The Definition Program produces an output listing and a disk file consisting of the defined symbols and instruction mnemonics. This Definition file is used by the Assembly program as a reference when assembling a program.
The Assembly program operates like a traditional assembler. A symbolic source program utilizing the mnemonics and symbols defined in the Definition Program is read as input, and a listing and object module are generated as output. The Assembler provides symbolic addressing, relative addressing, paged addressing, and other features found in typical assembly programs. The instruction syntax and assembler directives are compatible with those utilized by AMD in its literature and software products. Additional
directives have been implemented to provide for versatile listing and output controls.
Conditional Assembly statements are provided in both the Definition and Assembly programs. These statements may be nested up to 16 levels and can be made dependent on general expression. A full cross reference table is also provided in both programs.
Some features of Microtec's Meta Assembler are particularly helpful when assembling code for microprogrammable machines. The existence of don't care bits and instruction overlaying are included among these features. Bits of a microword which are not relevant to a particular instruction format may be defined as don't care bits. Don't care bits are printed as X's on the listing and do not have to be defined until the PROM Formatter program is executed. An instruction format with don't care bits can be overlayed with other instruction formats. Therefore when useful, an instruction format can be used to define only part of the microword, padding out the word with don't care bits.
The PROM Formatter Program reads the object module file produced by the Assembly program and translates the format into one that can be read by a PROM programmer. Both BNPF and Data I/O's ASCII hexadecimal format are supported. Microwords in the object module can be broken up into organizations that are compatible with the target PROM/ROM array. Users may specify PROMs of any width and length, as well as the value of don't care bits. Any or all PROMs may be listed and/or punched.

The programs are well commented and modular. A detailed manual, source listing, test programs, and test program output listings accompany each software order. The test programs allow the operation of the software to be verified quickly and easily. If the information given here is not sufficient, a manual is available for a small fee.
Coming soon is M29 AMD'S New Meta Assembler. Contact your local sales office for details.
For additional information, contact Microtec, P.O. Box 60337 Sunnyvale, Ca. 94088 (408) 733-2919

[^0]
## Videotape Seminar Kits

Advanced Micro Devices regularly prepares and presents seminars wordwide that describe the function and application of its Am2900 Family products. These seminars may also be presented at local factory or design centers through arrangement with the field Applications Engineer located at the AMD Sales Office.

It is now also possible to order the following seminars in videotape form with literature kits.

- 2Am29116 Sixteen-Bit Biplor Microprocessor and Peripherals
- 2Am29500 Array Processing/Digital Signal Processing Familly

The videotape is a 2-3 hour seminar covering the products function in detail and demonstrating aspects of system integration using the products, The literature kit includes a slide booklet, data sheets of all products covered in the seminar, and other relevant material.

These kits may be ordered from AMD's Customer Education Center. Contact your AMD Sales Representative for more infomation.

|  | Order Code | Prices(USA) |
| :--- | :---: | :---: |
| Am29116 Sixteen-Bit Biplor Microprocessor and Peripherals <br> - Videotape (includes one set of literature) | Am29116-VIDEO | \$99/Videotape |
| - Literature Kit (each additional set) | Am29116-LIT | $\$ 5 /$ set |
| Am29500 Array Processing (Digital Signal Processing Familly) <br> - Videotape (includes one set of literature) | Am29116-VIDEO | $\$ 99 /$ Videotape |
| - Literature Kit (each additional set) | Am29116-LIT | $\$ 5 /$ set |



## Am29300 Family

Am29323 32-Bit Parallel Multiplier ..... 3-1
Am2932532-Bit Floating Point Processor3-216-Bit Microprogram Sequencer3-50
Am2933232-Bit Arithmetic Logic Unit3-52
Am29334Four-Port, Dual-Access Register File3-54
Am2936032-Bit Error Detection and Correction Unit3-55
Am29368 1M-Bit Dynamic Memory Controller (DMC) ..... 3-56

# Am29323 

32－Bit Parallel Multiplier

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

－32－Bit Three－Bus Architecture
－The device has two 32－bit input ports and one 32－bit output port with maximum multiply time of 80 ns
－Single Clock with Register Enables
－The Am29323 is controlled by one clock with individual register enables
－Supports Multiprecision Multiplication
－The device has dual 32－bit registers on each data input port to perform multiprecision multiplication
－Transparent－Able Input，Output and Instruction Regis－ ters
－Input and output registers can be made transparent independently to eliminate unwanted pipeline delay
－Supports Two＇s complement，unsigned or mixed mode numbers
－Data Integrity Through Master－Slave Mode and Parity Check／Generate
－Parity check／generate catches inter－device connection errors and master／slave mode provides complete function check

The Am29323 is a high－speed $32 \times 32$－Bit Parallel Multipli－ er with 67－Bit Accumulator．The part is designed to maxi－ mize systern level performance by providing three 32－bit bus architecture and a single clock with register enables．

The Am29323 further enhances the system throughput by providing individual register feedthrough controls，byte parity checking on both input ports and generation on the output port，as well as，dual input registers on each data input bus to support multiprecision multiplication．The Am29323 can manage a wide variety of data types such as

Two＇s complement，unsigned or mixed mode input formats． $64 \times 64$ bit multiplication can be performed in seven clock cycles，including input and output．Additional features provided are format adjust control allowing for standard output or left shifted output suitable for Two＇s complement arithmetic．The part also features master／slave operation．

The Am29323 is designed with the IMOX ${ }^{\text {TM }}$ process，which allows internal ECL circuits with TTL compatible 1／O．The device is housed in a 168－lead pin－grid－array package．

BLOCK DIAGRAM
The Am29323 High－Speed $32 \times$ 32－Bit Parallel Multiplier


# Am29325 <br> 32-Bit Floating Point Processor <br> PRELIMINARY 

## DISTINCTIVE CHARACTERISTICS

- Single VLSI device performs high-speed floating-point arithmetic
- Floating-point addition, subtraction and multiplication in a single clock cycle
- Internal architecture supports sum-of-products, Newton-Raphson division
- 32-bit, 3-bus flow-through architecture
- Programmable I/O allows interface to 32 - and 16 -bit systems
- IEEE and DEC formats
- Performs conversions between formats
- Performs integer $\longrightarrow$ floating point conversions
- Six flags indicate operation status
- Register enables eliminate clock skew
- Input and output registers can be made transparent independently


## GENERAL DESCRIPTION

The Am29325 is a high-speed floating-point processor unit, It performs 32 -bit single-precision floating-point addition, subtraction, and multiplication operations in a single LSI integrated circuit, using the format specified by the proposed IEEE floating-point standard P754. The DEC singleprecision floating-point format is also supported. Operations for conversion between 32 -bit integer format and floatingpoint format are available, as are operations for converting between the IEEE and DEC floating-point formats: Any operation can be performed in a single clock cycle. Six flags invalid operation, inexact result, zero, not-a-number, overflow, and underflow - monitor the status of operations.
The Am29325 has a 3 -bus, 32 -bit architecture, with two input buses and one output bus. This configuration provides
high I/O bandwidth, allows access to all buses and affords a high degree of flexibility when connecting this device in a system. All buses are registered, with each register having a clock enable. Input and output registers may be made transparent independently. Two other I/O configurations, a 32-bit, 2 -bus architecture and a 16 -bit, 3 -bus architecture, are user-selectable, easing interface with a wide variety of systems. Thirty-two-bit internal feedforward data paths support accumulation operations, including sum-of-products and Newton-Raphson division.

Fabricated with the high-speed IMOX ${ }^{\text {TM }}$ bipolar process, the Am29325 is powered by a single 5 -volt supply. The device is housed in a 144 -pin pin-grid-array package.

Am29300 FAMILY HIGH PERFORMANCE SYSTEM BLOCK DIAGRAM


RELATED PRODUCTS

- Am29323-32 $\times 32$ Parallel Multiplier
- Am29332-32-Bit ALU
- Am29334-64×18 Four-Port Dual-Access
- Am29331 - 16-Bit Sequencer



## DEFINITION OF TERMS

## AFFINE MODE

One of two modes affecting the handling of operations on infinities - see the Operations with Infinities section under Operation in IEEE Mode below.

## BIASED EXPONENT

The true exponent of a floating-point number, plus a constant. For IEEE floating-point numbers, the constant is 127 ; for DEC floating-point numbers, the constant is 128 . See also True Exponent

## BUS

Data input or output channel for the floating-point processor.

## DEC RESERVED OPERAND

A DEC floating-point number that is interpreted as a symbol and has no numeric value. A DEC reserved operand has a sign of 1 and a biased exponent of 0 .

## DESTINATION FORMAT

The format of the final result produced by the floating-point ALU. The destination format can be IEEE floating-point, DEC floatingpoint or integer.

## FINAL RESULT

The result produced by the floating-point ALU.

## FRACTION

The twenty-three least-significant bits of the mantissa.

## INFINITELY PRECISE RESULT

The result that would be obtained from an operation if both exponent range and precision were unbounded.

## INPUT OPERANDS

The value or values on which an operation is performed. For example, the addition $2+3=5$ has input operands 2 and 3 .

## MANTISSA

The portion of a floating-point number containing the number's significant bits., For the floating-point number $1.101 \times 2^{-3}$, the mantissa is 1.101.

## NAN (Not-a-Number)

An IEEE floating-point number that is interpreted as a symbol, and has no numeric value. A NAN has a biased exponent of $255_{10}$ and a non-zero fraction.

## PORT

Data input or output channel for the floating-point ALU.

## PROJECTIVE MODE

One of two modes affecting the handling of operations on infinities - see the Operations with Infinities section under Operation in IEEE Mode below.

## ROUNDED RESULT

The result produced by rounding the infinitely precise result to fit the destination format.

## TRUE EXPONENT (or Exponent)

Number representing the power of two by which a floating-point number's mantissa is to be multiplied. For the floating-point number $1.101 \times 2^{-3}$, the true exponent is -3 .

## PIN DESCRIPTION

| $R_{\mathbf{0}}-R_{\mathbf{3 1}}$ | $R$ operand bus, input. $R_{0}$ is the least-signifi- <br> cant bit. |
| :--- | :--- |
| $S_{0}-S_{\mathbf{3 1}}$ | S operand bus, input. $S_{0}$ is the least-signifi- <br> cant bit. |
| $F_{\mathbf{0}}-F_{\mathbf{3 1}}$ | F operand bus, output. $F_{0}$ is the least- <br> significant bit. |

Register R clock enable, input. When $\overline{\mathrm{ENR}}$ is LOW, register R is clocked on the LOW-toHIGH transition of CLK. When ENR is HIGH, register R retains the previous contents.

ENS Register S clock enable, input. When $\overline{E N S}$ is LOW, register $S$ is clocked on the LOW-toHIGH transition of CLK. When ENS is HIGH, register $S$ retains the previous contents.
$\overline{\text { ENF }} \quad$ Register $F$ clock enable, input. When $\overline{E N F}$ is LOW, register $F$ is clocked on the LOW-toHIGH transition of CLK. When ENF is HIGH, register F retains the previous contents.
$\mathbf{F T}_{\mathbf{0}} \quad$ Input register feedthrough control, input. When $\mathrm{FT}_{0}$ is HIGH, registers R and S are transparent.
$\mathrm{FT}_{1} \quad$ Output register feedthrough control, input. When $\mathrm{FT}_{1}$ is HIGH, register F and the status flag register are transparent.
$\mathbf{I}_{0}-\mathbf{I}_{\mathbf{2}} \quad$ Operation select lines, inputs. Used to select the operation to be performed by the ALU. See the ALU Operation Select Table for a list of operations and the corresponding codes.
$I_{3}$
ALU S port input select, input. A LOW on I3
PROJ/ $\overline{\text { AFF }}$ selects register $S$ as the input to the ALU S port. A HIGH on $I_{3}$ selects register $F$ as the input to the ALU $S$ port.
$I_{4}$

IEEE/ $\overline{\text { DEC }}$

INEXACT
Register $R$ input select, input. A LOW on $I_{4}$ selects $R_{0}-R_{31}$ as the input to register. R. A HIGH selects the ALU F port as the input to register R.

IEEE/DEC mode select, input. When IEEE/' $\overline{\mathrm{DEC}}$ is HIGH, IEEE mode is selected. When IEEE/ $\overline{\mathrm{DEC}}$ is LOW, DEC mode is selected.

Inexact result flag, output. A HIGH indicates that the final result of the last operation was not infinitely precise, due to rounding.

INVALID

NAN

## OVERFLOW

Invalid operation flag, output. A HIGH indicates that the last operation performed was invalid, e.g., $x$ times 0 .

Not-a-number flag, output. A HIGH indicates that the final result produced by the last operation is not to be interpreted as a number. The output in such cases is either an IEEE Not-aNumber (NAN) or a DEC reserved operand.

Output enable, input. When $\overline{\mathrm{OE}}$ is LOW, the contents of register $F$ are placed on $F_{0}-F_{31}$. When $\overline{O E}$ is HIGH, $F_{0}-F_{31}$ assume a highimpedance state.

Input bus configuration control, input. A LOW on ONEBUS configures the input bus circuitry for two-input bus operation. A HIGH on ONEBUS configures the input bus circuitry for single-input bus operation.

Overflow flag, output. A HIGH indicates that the last operation produced a final result that overflowed the floating-point format.

Projective/affine mode select, input. Choice of projective or affine mode determines the way in which infinities are handled in IEEE mode. A LOW on PROJ// $\overline{A F F}$ selects affine mode; a HIGH selects projective mode.

Rounding mode selects, inputs. $\mathrm{RND}_{0}$ and $\mathrm{RND}_{1}$ select one of four rounding modes. See the Rounding Mode Select Table for a list of rounding modes and the corresponding control codes.
$\mathbf{S 1 6 / \overline { 3 2 }}$ Sixteen- or thirty-two-bit I/O mode select, input. A LOW on S16/32 selects the thirty-twobit I/O mode; a HIGH selects the sixteen-bit I/O mode. In thirty-two-bit mode, inputs and output buses are 32 bits wide. In sixteen-bit mode, input and output buses are sixteen bits

## UNDERFLOW

ZERO
wide, with the least and most significant portions of the thirty-two-bit input and output words being placed on the buses during the HIGH and LOW portions of CLK, respectively.

Underflow flag, output. A HIGH indicates that the last operation produced a rounded result that underflowed the floating-point format.

Zero flag, output. A HIGH indicates that the last operation produced a final result of zero.

Figure 1. Conceptual Model of the Process Performed by the Floating-Point ALU

the multiplication is performed in IEEE floating-point format; in $D E C$ mode (IEEE/DEC $=$ LOW) the multiplication is performed in DEC format.
The floating-point constant subtraction (2 MINUS S) operation subtracts the floating-point value on port $S$ from 2, and places the result on port F . The operand on port R is not used in this operation; its value will not affect the operation in any way. In IEEE mode (IEEE/ $\overline{\mathrm{DEC}}=\mathrm{HIGH})$ the operation is performed in IEEE floating-point format; in DEC mode (IEEE/DEC $=$ LOW $)$ the operation is performed in DEC format. This operation is used to support Newton-Raphson floating-point division; a description of its use appears in Appendix C.
The integer-to-floating-point conversion (INT-TO-FP) operation takes a 32-bit, two's complement integer on port $R$ and places the equivalent floating-point value on port $F$. The operand on port $S$ is not used in this operation; its value will not affect the operation in any way. In IEEE mode (IEEE/ $\overline{\mathrm{DEC}}=\mathrm{HIGH})$ the result is delivered in IEEE format; in DEC mode (IEEE/ $\overline{D E C}=$ LOW $)$ the result is delivered in DEC format.

ALU OPERATION SELECT TABLE

| $\mathrm{I}_{2}$ | $I_{1}$ | 10 | Operation | Output Equation |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Floating-point addition (R PLUS S) | $F=R+S$ |
| 0 | 0 | 1 | Floating-point subtraction (R MINUS S) | $F=R-S$ |
| 0 | 1 | 0 | Floating-point multiplication (R TIMES S) | $F=R * S$ |
| 0 | 1 | 1 | Floating-point constant subtraction (2 MINUS S) | $F=2-S$ |
| 1 | 0 | 0 | Integer-to-floating-point conversion (INT-TO-FP) | $F$ (floating-point) $=\mathrm{R}$ ( integer) |
| 1 | 0 | 1 | Floating-point-to-integer conversion (FP-TO-INT) | $F$ (integer) $=$ R (floating-point) |
| 1 | 1 | 0 | IEEE-TO-DEC format conversion (IEEE-TO-DEC) | $F$ (DEC format) $=R$ (IEEE format) |
| 1 | 1 | 1. | DEC-TO-IEEE format conversion (DEC-TO-IEEE) | $F($ IEEE format $)=R$ (DEC format) |

The floating-point-to integer conversion (FP-TO-INT) operation takes a floating-point number on port $R$ and places the equivalent 32 -bit, two's complement integer value on port $F$. The operand on port $S$ is not used in this operation; its value will not affect the operation in any way. In IEEE mode (IEEE/DEC $=H I G H$ ) the operand on port R is interpreted using the IEEE floating-point format; in DEC mode (IEEE/ $\overline{D E C}=$ LOW) it is interpreted using the DEC floating-point format.
The IEEE-to-DEC conversion operation (IEEE-TO-DEC) takes an IEEE-format floating-point number on port $R$ and places the equivalent DEC-format floating-point number on port $F$. The operand on port $S$ is not used in this operation; its value will not affect the operation in any way. The operation can be performed in either IEEE mode (IEEE/ $\overline{\mathrm{DEC}}=\mathrm{HIGH}$ ) or DEC mode (IEEE/ $\overline{\mathrm{DEC}}=\mathrm{LOW})$.
The DEC-to-IEEE conversion operation (DEC-TO-IEEE) takes a DEC-format floating-point number on port $R$ and places the equivalent IEEE-format floating-point number on port $F$. The operand on port $S$ is not used in this operation; its value will not affect the operation in any way. The operation can be performed in either IEEE mode (IEEE/DEC $=\mathrm{HIGH}$ ) or DEC mode (IEEE/ $\overline{\mathrm{DEC}}=\mathrm{LOW})$.

## Status Flag Generator

The status flag generator controls the state of six flags that report the status of floating-point ALU operations. The flags indicate when an operation is invalid (e.g., infinity times zero) or when an operation has produced an overflow, an underflow, a nonnumerical result (e.g., a NAN or DEC reserved operand), an inexact result, or a result of zero. The flags represent the status of the most-recently-performed operation. Flag status is stored in the flag status register on the LOW-to-HIGH transition of CLK. When the output register feedthrough control $\mathrm{FT}_{1}$ is HIGH, the flag status register is made transparent.

## Data Path

The 32-bit data path consists of the $R$ and $S$ input buses, the $F$ output bus, data registers $R, S$, and $F$, the register $R$ input multiplexer, and the ALU port S input multiplexer.

Input operands enter the floating-point processor through the 32 -bit $R$ and $S$ input buses, $R_{0}-R_{31}$ and $S_{0}-S_{31}$. Results of operations appear on the 32 -bit $F$ bus, $F_{0}-F_{31}$. The $F$ bus assumes a high-impedance state when output enable $\overline{\mathrm{OE}}$ is HIGH.
The $R$ and $S$ registers store input operands; the $F$ register stores the final result of the floating-point ALU operation. Each register has an independent clock enable ( $\overline{E N R}, \overline{E N S}$ and $\overline{\text { ENF }}$ ). When a register's clock enable is LOW, the register stores the data on its input at the LOW-to-HIGH transition of CLK; when the clock enable is HIGH, the register retains its current data. All data registers are fully edge-triggered - both the input data and the register enable need only meet modest setup and hold time requirements. Registers $R$ and $S$ can be made transparent by setting $\mathrm{FT}_{0}$, the input register feedthrough control, HIGH. Register F can be made transparent by setting $\mathrm{FT}_{1}$, the output register feedthrough control, HIGH.
The register $R$ input multiplexer selects either the $R$ input bus or the floating-point ALU's F port as the input to register R. Selection is controlled by $\mathrm{I}_{4}$ - a LOW selects the R input bus; a HIGH selects the ALU F port. The ALU port S input multiplexer selects either register $S$ or register $F$ as the input to the floating-point ALU's $S$ port. Selection is controlled by $I_{3}$ - a LOW selects register S; a HIGH selects register F .
Data selected by $I_{3}$ and $I_{4}$ is described in the Mux Select Tables. When registers $R$ and $S$ are transparent ( $\mathrm{FT}_{0}=\mathrm{HIGH}$ ) multiplexer select $I_{4}$ must be kept LOW, so that the register $R$ input multiplexer selects $R_{0}-R_{31}$. When register $F$ is transparent ( $F_{1}$ $=$ HIGH) multiplexer select $l_{3}$ must be kept LOW, so that the ALU port S input multiplexer selects register S .

## muX SELECT TABLES

| $I_{3}$ | Data selected for floating-point ALU S port |
| :--- | :--- |
| 0 | Register $S$ |
| 1 | Register $F$ |


| $I_{4}$ | Data selected for register $R$ input |
| :--- | :--- |
| 0 | R bus |
| 1 | Floating-point ALU port $F$ |

## I/O MODES

The Am29325 data path can be configured in one of three I/O modes: a 32 -bit, two-input-bus mode; a 32 -bit, single-input-bus mode; and a 16-bit, two-input-bus mode. These modes affect only the manner in which data is delivered to and taken from the Am29325; operation of the floating-point ALU is not altered. The I/O mode is selected with the ONEBUS and S16/32 controls. The I/O Mode Selection Table lists the control codes needed to invoke each I/O mode.

I/O MODE SELECTION TABLE

| S16/32 |  | ONEBUS |
| :---: | :---: | :--- |
| 0 | 0 | 32-bit, two-input-bus mode |
| 0 | 1 | 32-bit, single-input-bus mode(*) |
| 1 | 0 | 16-bit, two-input-bus mode(*) |
| 1 | 1 | Illegal I/O mode selection value |

$(*) \mathrm{FT}_{0}$ must be held LOW in this mode (see text).

## 32-Bit, Two-Input-Bus Mode

In this I/O mode, the $R$ and $S$ buses are configured as independent 32 -bit input buses, and the F bus is configured as a 32 -bit output bus. Figure 2 is a functional block diagram of the Am29325 in this $\mathrm{I} / \mathrm{O}$ mode.
$R$ and $S$ operands are taken from their respective input buses and clocked into the R and S registers on the LOW-to-HIGH transition of CLK. Register F is also clocked on the LOW-to-HIGH transition of CLK. Figure 5(a.) depicts typical I/O timing in this mode.

## 32-Bit, Single-Input-Bus Mode

In this I/O mode, the R and $S$ buses are connected to a single 32-bit multiplexed input data bus; the $F$ bus is configured as an independent 32 -bit output bus. Figure 3 is a functional block diagram of the Am29325 in this I/O mode. Note that both the R and $S$ bus lines must be wired to the input bus.
$R$ and $S$ operands are multiplexed onto the input bus by the host system. The S operand is clocked from the input bus into a temporary holding register on the HIGH-to-LOW transition of CLK and is transferred to register S on the LOW-to-HIGH transition of CLK. The R operand is clocked from the input bus into register R on the LOW-to-HIGH transition of CLK. Register F is clocked on the LOW-to-HIGH transition of CLK. Figure 5(b.) depicts typical $\mathrm{I} / \mathrm{O}$ timing in this mode.

When placed in this I/O mode, the data path will not function properly if the R and S registers are made transparent. Therefore input register feedthrough control $\mathrm{FT}_{0}$ must be held LOW in this mode.

Figure 2. Functional Block Diagram for the 32-Bit, Two-Input-Bus Mode


05621A-4

Figure 3. Functional Block Diagram for the 32-Bit, Single-Input-Bus Mode


05621A-5

## 16-Bit, Two-Input-Bus Mode

In this I/O mode, the $R$ and $S$ buses are configured as independent 16 -bit input buses, and the F bus is configured as a 16 -bit output bus. Figure 4 is a functional block diagram of the Am29325 in this I/O mode. Note that the 16 LSBs and 16 MSBs of the R, S and $F$ buses must be wired to their respective system buses in parallel.
Thirty-two-bit operands are passed along the 16 -bit data buses by time-multiplexing the 16 LSBs and 16 MSBs of each 32-bit word. For the R input bus, the host system multiplexes the 16 LSBs and 16 MSBs of the R operand onto the 16 -bit R bus. The 16 LSBs of the R operand are stored in a temporary holding register on the HIGH-to-LOW transition of CLK. The 16 MSBs are clocked into register R on the LOW-to-HIGH transition of CLK; at the same time, the 16 LSBs are transferred from the temporary holding register to register R. Transfer of data from the $S$ input bus to the $S$ register takes place in a similar fashion. Register $F$ is clocked on the LOW-to-HIGH transition of CLK. Circuitry internal to the Am29325 multiplexes data from register F onto the 16-bit output bus by enabling the 16 LSBs of the F output bus when CLK is HIGH, and enabling the 16 MSBs of the F output bus when CLK is LOW. Figure 5(c.) depicts typical $1 / O$ timing in this mode.

When placed in this I/O mode, the data path will not function properly if the $R$ and $S$ registers are made transparent. Therefore input register feedthrough control $\mathrm{FT}_{0}$ must be held LOW in this mode. Caution must also be taken in controlling the register $R$ input multiplexer control line, $\mathrm{I}_{4}$, in this $\mathrm{I} / \mathrm{O}$ mode. $\mathrm{I}_{4}$ should be changed only when CLK is HIGH, in addition to meeting the setup and hold time requirements given in the Switching Characteristics section.

## OPERATION IN IEEE MODE

When input signal IEEE/DEC is HIGH, the IEEE mode of operation is selected. In this mode the Am29325 uses the floating-point format set forth in the IEEE Proposed Standard for Binary Floating-Point Arithmetic, P754. In addition, the IEEE mode complies with most other aspects of single-precision floatingpoint operation outlined in the proposed standard - differences are discussed in Appendix $\mathbf{A}$.

## IEEE Floating-Point Format

The IEEE single-precision floating-point word is thirty-two bits wide, and is arranged in the format shown in Figure 6. The floating-point word is divided into three fields: a single-bit sign, an eight-bit biased exponent, and a 23-bit fraction.
The sign bit indicates the sign of the floating-point number's value. Non-negative values have a sign of 0 ; negative values, a sign of 1 . The value zero may have either sign.
The biased exponent is aneight-bit unsigned integer field representing a multiplicative factor of some power of two. The bias value is 127. If, for example, the multiplicative factor for a floating-point number is to be $2^{a}$, the value of the biased exponent would be $a+127$; $a$ is called the true exponent.

The fraction is a 23 -bit unsigned fractional field containing the 23 least-significant bits of the floating-point number's 24-bit mantissa. The weight of fraction's most significant bit is $2^{-1}$; the weight of the least-significant bit is $2^{-23}$.

Figure 4. Functional Block Diagram for the 16-Bit, Two-Input-Bus Mode


A floating-point number is evaluated or interpreted per the following conventions:

$$
\text { let } \mathrm{s}=\text { sign bit }
$$

$e=$ biased exponent
$f=$ fraction
if $e=0$ and $f=0 \ldots$ value $=(-1)^{s_{*}}(0)(+0,-0)$
if $e=0$ and $f<>0 \ldots$ value $=$ denormalized number
if $0<\mathrm{e}<255 \ldots$. value $=(-1)^{\mathrm{s}_{*}}\left(2^{\mathrm{e}-127}\right) *(1 . \mathrm{f})$
(normalized number)
if $\mathrm{e}=255$ and $\mathrm{f}=0 \ldots$ value $=(-1)^{\mathrm{s}_{*}(x)}(+x,-x)$
if $e=255$ and $f<>0 \ldots$ value $=$ not-a-number (NAN)
Zero - The value zero can have either a positive or negative sign. Rules for determining the sign of a zero produced by an operation are given in the Sign Bit section on page 12.
Denormalized Number - A denormalized number represents a quantity with magnitude less than $2^{-126}$ but greater than zero.

Normalized Number - A normalized number represents a quantity with magnitude greater than or equal to $2^{-126}$ but less than $2^{128}$.

## Example 1:

The number +3.5 can be represented in floating-point format as follows:

$$
\begin{aligned}
& +3.5=11.1_{2} \times 2^{0} \\
& =1.11_{2} \times 2^{1} \\
& \operatorname{sign}=0 \\
& \text { biased exponent }=1_{10}+127_{10}=128_{10} \\
& =10000000_{2} \\
& \text { fraction }=11000000000000000000000_{2} \\
& \text { (the leading } 1 \text { is implied in the format) }
\end{aligned}
$$

Concatenating these fields produces the floating-point word $40600000_{16}$.

Figure 5. Typical Bus Timing for the $\mathrm{I} / \mathrm{O}$ Modes, with $\mathrm{FT}_{0}=\mathrm{LOW}, \mathrm{FT}_{1}=$ LOW

a) 32-Bit, Two-Input-Bus Mode

b) 32-Bit, Single-Input-Bus Mode

c) 16-Bit, Two-Input-Bus Mode

Figure 6. IEEE Mode Single-Precision Floating-Point Format


VALUE $=(-1)^{\mathrm{S}}\left(2^{\mathrm{E}-127}\right)(1 . \mathrm{F})$

Example 2:
The number $\mathbf{- 1 1 . 3 7 5}$ can be represented in floating-point format as follows:

$$
\begin{aligned}
-11.375 & =-1011.011_{2} \times 2^{0} \\
& =-1.011011_{2} \times 2^{3}
\end{aligned}
$$

sign $=1$

$$
\begin{aligned}
\text { biased exponent } & =3_{10}+127_{10}=130_{10} \\
& =10000010_{2}
\end{aligned}
$$

fraction $=01101100000000000000000_{2}$ (the leading 1 is implied in the format)
Concatenating these fields produces the floating-point word C1360000 16 .
Infinity - Infinity can have either a positive or negative sign. The way in which infinities are interpreted is determined by the state of the projective/affine mode select, PROJ/ $\overline{\mathrm{AFF}}$.

Not-a-Number - A not-a-number, or NAN, does not represent a numeric value, but is interpreted as a signal or symbol. NANs are used to indicate invalid operations, and as a means of passing process status information through a series of calculations. NANs arise in two ways: they can be generated by the Am29325 to indicate that an invalid operation has taken place (e.g., infinity times zero), or they can be provided by the user as an input operand. There are two types of NANs: signalling and quiet. These NANs have the formats shown in Figure 7.

## IEEE Mode Integer Format

Integer numbers are represented as 32-bit, two's complement words; Figure 8 depicts the integer format. The integer word can represent a range of integer values from $-2^{31}$ to $2^{31}-1$.

Figure 7. Signalling and Quiet NAN Formats


Figure 8. Thirty-Two-Bit Integer Format

BIT NUMBER:


## Operations

All eight floating-point ALU operations discussed in the Functional Description section above can be performed in IEEE mode. Various exceptional aspects of the R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, INT-TO-FP, and FP-TO-INT operations for this mode are described below. The IEEE-TO-DEC and DEC-TO-IEEE operations are discussed separately in the IEEE-TO-DEC and DEC-TO-IEEE Operations section on page 23.

Operations with NANs - NANs arise in two ways: they can be generated by the Am29325 to indicate that an invalid operation has taken place (e.g., infinity times zero), or they can be provided by the user as an input operand. There are two types of NANs: signalling and quiet. These NANs have the formats shown in Figure 7.
Signalling. NANs set the invalid operation flag when they appear as an input operand to an operation. They are useful for indicating uninitialized variables, or for implementing user-designed extensions to the operations provided. The ALU never produces a signalling NAN as the final result of an operation.

Quiet NANs are generated for invalid operations. When they appear as an input operand, they are passed through most operations without setting the invalid flag, the floating-point-tointeger conversion operation being the exception.

The sign of any input operand NAN is ignored. All quiet NANs produced as the final result of an operation have a sign of 0 .
When a NAN appears as an input operand, the final result of the operation is a quiet NAN that is created by taking the input NAN and forcing bit 22 LOW and bit 21 HIGH. If an operation has two NANs as input operands, the resulting quiet NAN is created using the NAN on the R port.
When a quiet NAN is produced as the final result of an invalid operation whose input operand or operands are not NANs, the resulting NAN will always have the value 7FA00000 ${ }_{16}$.
The NAN flag will be HIGH whenever an operation produces a NAN as a final result.
Example 1:
Suppose the floating-point addition operation is performed with the following input operands:
R port: $3 F 800000_{16}\left(1.0 * 2^{0}\right)$
S port: 7FC1234516 (signalling NAN)
Result: The signalling NAN on the $S$ port is converted to a quiet NAN by forcing bit 22 LOW and bit 21 HIGH. The operation's final result will be 7FA12345 16 . Since one of the two input operands is a signalling NAN, the invalid flag will be HIGH; the NAN flag will also be HIGH.
Example 2:
Suppose the floating-point multiplication operation is performed with the following input operands:
R port: FFF11111 ${ }_{16}$ (signalling NAN)
S port: 7FC22222 ${ }_{16}$ (quiet NAN)
Result: Since both input operands are NANs, the NAN on the $R$ port is chosen for output. In addition to forcing bit 22 LOW, the sign bit (bit 31) is set LOW (bit 21 is already HIGH, and need not be changed). The operation's final result will be 7FB11111 ${ }_{16}$. Since one of the two input operands is a signalling NAN, the invalid flag is HIGH; the NAN flag will also be HIGH.

Example 3:
Suppose the floating-point subtraction operation is performed with the following input operands:

R port: FF800001 ${ }_{16}$ (quiet NAN)
S port: 7F800000 16 ( $+x$ )
Result: To create the final result, the quiet NANs sign bit (bit 31 ) is forced LOW and bit 21 is forced HIGH (bit 22 is already LOW, and need not be changed). The final result will be 7FA00001 ${ }_{16}$. The NAN flag will be HIGH.

Operations with Denormalized Numbers - The proposed IEEE standard incorporates denormalized numbers to allow a means of gradual underflow for operations that produce non-zero results too small to be expressed as a normalized floating-point number. The Am29325 does not support gradual underflow. If a floating-point operation produces a non-zero rounded result that is not large enough to be expressed as a normalized floatingpoint number, the final result will be a zero of the same sign; the inexact, underflow, and zero flags will be HIGH. If an input operand is a denormalized number, the floating-point ALU will assume that operand to be a zero of the same sign.

Operations Producing Overflows - If an operation has a finite input operand or operands, and if the operation produces a rounded result that is too large to fit in the destination format, that operation is said to have overflowed.
A floating-point overflow occurs if an R PLUS S, R MINUS S, R TIMES S, or 2 MINUS S operation with finite input operand(s) produces a result which, after rounding, has a magnitude greater than or equal to $2^{128}$. Positive or negative infinity will appear as the final result if the rounded result is positive or negative, respectively, and the overflow and inexact flags will be HIGH.
Integer overflow occurs when the fixed-to-floating-point conversion operation attempts to convert a number which, after rounding, is greater than $2^{31}-1$ or less than $-2^{31}$. The final result will be quiet NAN $7 F A 0000{ }_{16}$, and the invalid operation and NAN flags will be HIGH. Note that the overflow and inexact flags remain LOW for integer overflow.

Operations Producing Underflows - If an operation produces a floating-point rounded result having a magnitude too small to be expressed as a normalized floating-point number, but greater than zero, that operation is said to have underflowed. Underflow occurs when an R PLUS S, R MINUS S, or R TIMES S operation produces a result which, after rounding, has a magnitude in the range:

$$
0<\text { magnitude }<2^{-126}
$$

In such cases, the final result will be $+0\left(00000000_{16}\right)$ if the rounded result is non-negative, and $-0\left(80000000_{16}\right)$ if the rounded result is negative. The underflow, inexact, and zero flags will be HIGH.
Underflow does not occur if the destination format is integer. If the infinitely precise result of a floating-point-to-integer conversion has a magnitude greater than 0 and less than 1 but the rounded result is 0 , the underflow flag remains LOW.

Operations with Infinities - In most cases, positive and negative infinity are valid input arguments for the R PLUS S, R MINUS S, R TIMES S, and 2 MINUS S operations. Those cases for which infinities are not valid inputs for these operations are listed in the IEEE Mode Invalid Operations Table (see next page).
Infinities in IEEE mode can be handled either as projective or affine. The projective mode is selected when PROJ/AFF is HIGH;
the affine mode is selected when PROJ/ $\overline{\text { AFF }}$ is LOW. The only differences between the modes that are relevant to Am29325 operation occur during the addition and subtraction of infinities:

| Operation | Affine Mode | Projective Mode |
| :---: | :---: | :---: |
| $(+x)+(+x)$ | Output $+x$ | Output 7FA00000 ${ }_{16}$ (quiet NAN), set invalid and NAN flags |
| $(-x)+(-x)$ | Output - $x$ | Output 7FA00000 16 (quiet NAN), set invalid and NAN flags |
| $(+x)-(-x)$ | Output $+x$ | Output 7FA00000 16 (quiet NAN), set invalid and NAN flags |
| $(-x)-(+x)$ | Output - $x$ | Output 7FA00000 ${ }_{16}$ (quiet NAN), set invalid and NAN flags |

If an R PLUS S, R MINUS S, R TIMES S, or 2 MINUS S operation has infinity as an input operand or operands, the final result, if valid, is presumed to be exact. For example, adding $+\infty$ and 2.0 will produce a final result of $+x$; since the result is considered exact, the inexact flag remains LOW.

Invalid Operations - If an input operand is invalid for the operation to be performed, that operation is considered invalid. When an invalid operation is performed, the floating-point ALU produces a quiet NAN as the final result, and the invalid operation flag goes HIGH. The IEEE Mode Invalid Operations Table lists the cases for which the invalid flag is HIGH in IEEE mode, and the final results produced for these operations.

IEEE MODE INVALID OPERATIONS TABLE

| Operation | Input Operand | Final Result |
| :---: | :---: | :---: |
| R PLUS S | $\begin{array}{r} (+x)+(-x) \\ \text { or }(-x)+(+x) \end{array}$ | 7FA00000 ${ }_{16}$ (quiet NAN) |
| R PLUS S | $\begin{aligned} & (+x)+(+x) \\ \text { or }(-x) & +(-x) \text { (Note } 1) \end{aligned}$ | $\text { 7FA00000 }{ }_{16}$ <br> (quiet NAN) |
| R MINUS S | $\begin{array}{r} (+x)-(+x) \\ \text { or }(-x)-(-x) \end{array}$ | 7FA00000 ${ }_{16}$ (quiet NAN) |
| R MINUS S | $\begin{aligned} (+x) & -(-x) \\ \text { or }(-x) & -(+x)(\text { Note 1) } \end{aligned}$ | 7FA00000 ${ }_{16}$ (quiet NAN) |
| R TIMES S | $\begin{array}{r} (+0) *(+x) \\ \text { or }(+0) *(-x) \\ \text { or }(-0) *(+x) \\ \text { or }(-0) *(-x) \end{array}$ | 7FA00000 ${ }_{16}$ (quiet NAN) |
| R PLUS S R MINUS S R TIMES S | $R$ or $S$ is a signalling NAN | (Note 2) |
| 2 MINUS S | S is a signalling NAN | (Note 2) |
| FP-TO-INT, | $R$ is a signalling or quiet NAN | (Note 2) |
| FP-TO-INT | $\begin{array}{r} \mathrm{R}>2^{31-1} \\ \text { or } \mathrm{R}<-\left(2^{31}\right) \end{array}$ | $\text { 7FA00000 }{ }_{16}$ <br> (quiet NAN) |

Notes: 1. These cases are invalid in projective mode only.
2. Results for these operations are described in the Operations with NANs section.

## The Sign Bit

For most floating-point operations, the sign bit of the final result is unambiguous, i.e., there is only one sign bit value that yields a numerically correct result. Operations that produce an infinitely
precise result of zero, however, present a problem, as the IEEE floating-point format allows for representation of both +0 and -0 . (It should be noted that floating-point operations producing underflow results output a zero of the same sign as the final result, and are therefore unambiguous.) The following rules can be used to determine the signs of zero produced in such cases:

R PLUS S - The operations $+x+(-x)$ and $-x+(+x)$ produce a final result of zero; the sign of the zero is dependent on the rounding mode:

| Rounding Mode | Sign of Final Result |
| :--- | :---: |
| Round to nearest | 0 |
| Round toward $-x$ | 1 |
| Round toward $+x$ | 0 |
| Round toward 0 | 0 |

The operation $+0+(+0)$ produces a final result of +0 ; the operation $-0+(-0)$ produces a final result of -0 .

R MINUS S - The operations $+x-(+x)$ and $-x-(-x)$ produce a final result of zero; the sign of the zero is dependent on the rounding mode:

| Rounding Mode | Sign of Result |
| :--- | :---: |
| Round to nearest | 0 |
| Round toward $-x$ | 1 |
| Round toward $+x$ | 0 |
| Round toward 0 | 0 |

The operation $+0-(-0)$ produces a final result of +0 ; the operation $-0-(+0)$ produces a final result of -0 .

R TIMES S - The sign of any multiplication result other than a NAN is the exclusive-OR of the signs of the input operands. Therefore, if x is non-negative,

> +0 times $+x$ produces a final result of +0,
> +0 times $-x$ produces a final result of -0,
> -0 times $+x$ produces a final result of -0,
> -0 times $-x$ produces a final result of +0

2 MINUS S - If $S$ equals 2 , the final result is -0 for the round toward $-x$ mode, and +0 for all other rounding modes.

## Rounding

Rounding is performed whenever an operation produces an infinitely precise result that cannot be represented exactly in the destination format. For example, suppose a floating-point operation produces the infinitely precise result

## $1.10101010101010101010101 \backslash 01 \times 2^{3}$.

In this example, the fraction portion of the mantissa has twentyfive bits; the IEEE floating-point format can accommodate only twenty-three. The backslash ( $\backslash$ ) in the mantissa represents the boundary between the first twenty-three bits of the fraction and any remaining bits. Rounding is the process by which this result is approximated by a representation that fits the destination format.

There are four rounding modes in IEEE mode: round to nearest, round toward $+x$, round toward $-x$, and round toward 0 . The rounding mode is chosen using the rounding mode select lines, $\mathrm{RND}_{0}$ and $\mathrm{RND}_{1}$. The Rounding Mode Select Table lists the select states needed to obtain the desired rounding mode.

ROUNDING MODE SELECT TABLE

| RND $_{\mathbf{1}}$ | RND $_{\mathbf{0}}$ | Rounding Mode |
| :---: | :---: | :--- |
| 0 | 0 | Round to nearest |
| 0 | 1 | Round toward $-\infty$ |
| 1 | 0 | Round toward $+\infty$ |
| 1 | 1 | Round toward 0 |

Round to Nearest - In this rounding mode the infinitely precise result of an operation is rounded to the closest representation that fits in the destination format. If the infinitely precise result is exactly halfway between two representations, it is rounded to the representation having an LSB of zero. Rounding is performed both for floating-point and integer destination formats.
Figure 9 illustrates four examples of the round to nearest process for operations having a floating-point destination format. The infinitely precise result of an operation is represented by an X on the number line; the black dots on the number line indicate those values that can be represented exactly in the floating-point format.
Example 1:
In Figure 9(a), the infinitely precise result of an operation is: $2^{20}+2^{-4}+2^{-5}=1.0000000000000000000000011 \times 2^{20}$.

The result is rounded to the closest representable floating-point value,
$2^{20}+2^{-3}=1.00000000000000000000001 \times 2^{20}$.

## Example 2:

In Figure 9(b), the infinitely precise result of an operation is: $2^{20}-2^{-4}+2^{-8}=1.111111111111111111111110001 \times 2^{19}$.

This result is rounded to the closest representable floating-point value,
$2^{20}-2^{-4}=1.11111111111111111111111 \times 29$.

## Example 3:

In Figure 9(c), the infinitely precise result of an operation is:

```
-(220+2-3+2-4)
    =-1.00000000000000000000001\1 x 220. 1
```

This result is exactly halfway between two representable floating-point values. Accordingly, it is rounded to the closest representation with an LSB of zero, or
$-\left(2^{20}+2 * 2^{-3}\right)=-1.00000000000000000000010 \times 2^{20}$.

## Example 4:

In Figure 9(d), the infinitely precise result of an operation is:
$2^{20}+3 * 2^{-3}=1.00000000000000000000011 \times 2^{20}$.

This result can be represented exactly in the floating-point format, and is left unaltered by the rounding process.

Figure 9. Floating-Point Rounding Examples for Round to Nearest Mode


Figure 10 illustrates four examples of the round to nearest process for operations having an integer destination format. The infinitely precise result of an operation is represented by an $X$ on the number line; the black dots on the number line indicate those values that can be represented exactly in the integer format.

## Example 1:

In Figure 10(a), the infinitely precise result of an operation is: $2^{10-2-2}=00 \ldots 001111111111.11$.
The result is rounded to the closest representable integer value, $2^{10}=00 . .010000000000$.

## Example 2:

In Figure 10(b), the infinitely precise result of an operation is: $2^{10}+2^{0}+2^{-3}=00 \ldots 010000000001.001$.
This result is rounded to the closest representable floating-point value,
$210+20=00 \ldots 010000000001$.

## Example 3:

In Figure 10(c), the infinitely precise result of an operation is: $-\left(2^{10}+2^{0}+2^{-1}\right)=11 \ldots 101111111110.1$.

This result is exactly halfway between two representable integer values. Accordingly, it is rounded to the closest representation with an LSB of zero, or
$-\left(2^{10}+2 * 2^{0}\right)=11 \ldots 101111111110$.

## Example 4:

In Figure 10(d), the infinitely precise result of an operation is: $2^{10}+3 * 2^{20}=00 \ldots 010000000011$.

This result can be represented exactly in the integer format, and is left unaltered by the rounding process.

Figure 10. Integer Rounding Examples for Round to Nearest Mode


Round Toward $-\infty-$ In this rounding mode the result of an operation is rounded to the closest representation that is less than or equal to the infinitely precise result, and which fits the destination format. Rounding is performed both for floating-point and integer destination formats.

Figure 11 illustrates four examples of the round toward $-x$ process for operations having a floating-point destination format. The infinitely precise result of an operation is represented by an $X$ on the number line; the black dots on the number line indicate those values that can be represented exactly in the floating-point format.

## Example 1:

In Figure 11(a), the infinitely precise result of an operation is: $2^{20}+2^{-4}+2^{-5}=1.00000000000000000000000 \backslash 11 \times 2^{20}$;
This result cannot be represented exactly in floating-point format, and is rounded to the next-smaller floating-point representation:
$220=1.00000000000000000000000 \times 220$.

## Example 2:

In Figure 11(b), the infinitely precise result of an operation is: $220-2^{-4}+2^{-8}=1.11111111111111111111111 \backslash 0001 \times 219$.

This result cannot be represented exactly in floating-point format, and is rounded to the next-smaller floating-point representation:
$2^{20-2-4}=1.11111111111111111111111 \times 2^{19}$.

## Example 3:

In Figure 11(c), the infinitely precise result of an operation is:
$-\left(2^{20}+2^{-3}+2^{-4}\right)$

$$
=-1.00000000000000000000001 \backslash 1 \times 220 .
$$

This result cannot be represented exactly in floating-point format, and is rounded to the next-smaller floating-point representation:
$-\left(2^{20}+2 * 2^{-3}\right)=-1.00000000000000000000010 \times 220$.

## Example 4:

In Figure $11(\mathrm{~d})$, the infinitely precise result of an operation is: $2^{20}+3 * 2^{-3}=1.00000000000000000000011 \times 2^{20}$.
This result can be represented exactly in the floating-point format, and is left unaltered by the rounding process.

Figure 11. Floating-Point Rounding Examples for Round Toward - $\infty$ Mode


05621 A- 13

Figure 12 illustrates four examples of the round toward $-x$ process for operations having an integer destination format. The infinitely precise result of an operation is represented by an X on the number line; the black dots on the number line indicate those values that can be exactly represented in the integer format.

## Example 1:

In Figure 12(a), the infinitely precise result of an operation is: $2^{10}-2^{-2}=00 \ldots 001111111111.11$.
The result is rounded to the next-smaller representable integer value,
$2^{10}-2^{0}=00 \ldots 001111111111$.

## Example 2:

In Figure 12(b), the infinitely precise result of an operation is: $210+2^{0}+2^{-3}=00 \ldots . .010000000001 .001$.

This result is rounded to the next-smaller representable integer value,

$$
210+2^{0}=00 \ldots . .010000000001
$$

## Example 3:

In Figure 12(c), the infinitely precise result of an operation is: $-\left(2^{10}+2^{0}+2^{-1}\right)=11 \ldots 101111111110.1$.
This result is rounded to the next-smaller representable integer value:

$$
-\left(2^{10}+2^{*} 2^{0}\right)=11 \ldots 101111111110 .
$$

Example 4:
In Figure 12(d), the infinitely precise result of an operation is: $210+3 * 2^{0}=00 \ldots 010000000011$.
This result can be represented exactly in the integer format, and is unaltered by the rounding process.

Figure 12. Integer Rounding Examples for Round Toward - $\infty$ Mode

b)

Round Toward $+\infty$ - In this rounding mode the result of an operation is rounded to the closest representation that is greater than or equal to the infinitely precise result, and which fits the destination format. Rounding is performed both for floating-point and integer destination formats.

Figure 13 illustrates four examples of the round toward $+\infty$ process for operations having a floating-point destination format. The infinitely precise result of an operation is represented by an X on the number line; the black dots on the number line indicate those values that can be represented exactly in the floating-point format

Example 1:
In Figure 13(a), the infinitely precise result of an operation is: $2^{20}+2^{-4}+2^{-5}=1.00000000000000000000000 \backslash 11 \times 2^{20}$.
This result cannot be represented exactly in floating-point format, and is rounded to the next-larger floating-point representation:
$2^{20}+2^{-3}=1.00000000000000000000001 \times 2^{20}$.

## Example 2:

In Figure 13(b), the infinitely precise result of an operation is: $2^{20}-2^{-4}+2^{-8}=1.11111111111111111111111 \backslash 0001 \times 2^{19}$.

This result cannot be represented exactly in floating-point format, and is rounded to the next-larger floating-point representation:
$2^{20}=1.00000000000000000000000 \times 2^{20}$.

## Example 3

In Figure 13(c), the infinitely precise result of an operation is:

$$
\begin{aligned}
& -\left(2^{20}+2^{-3}+2^{-4}\right) \\
& =-1.00000000000000000000001 \backslash 1 \times 2^{20} .
\end{aligned}
$$

This result cannot be represented exactly in floating-point format, and is rounded to the next-larger floating-point representation:
$-\left(2^{20}+2^{-3}\right)=-1.00000000000000000000001 \times 2^{20}$.

## Example 4:

In Figure 13(d), the infinitely precise result of an operation is: $2^{20}+3 * 2^{-3}=1.00000000000000000000011 \times 2^{20}$.

This result can be represented exactly in the floating-point format - no rounding takes place.

Figure 13. Floating-Point Rounding Examples for Round Toward $+\infty$ Mode


05621A-15

Figure 14 illustrates four examples of the round toward $+x$ process for operations having an integer destination format. The infinitely precise result of an operation is represented by an X on the number line; the black dots on the number line indicate those values that can be exactly represented in the integer format.

## Example 1:

In Figure 14(a), the infinitely precise result of an operation is: $210-2^{-2}=00 \ldots 001111111111.11$.

The result is rounded to the next-larger representable integer value,
$210=00 \ldots 010000000000$.

## Example 2:

In Figure 14(b), the infinitely precise result of an operation is: $210+2^{0}+2^{-3}=00 \ldots 010000000001.001$.

This result is rounded to the next-larger representable integer value,
$210+2 * 20=00 \ldots 010000000010$.

## Example 3:

In Figure 14(c), the infinitely precise result of an operation is: $-\left(2^{10}+2^{0}+2^{-1}\right)=11 \ldots 101111111110.1$
This result is rounded to the next-larger representable integer value:

$$
-\left(2^{10}+2^{0}\right)=11 \ldots 1011111111110 .
$$

## Example 4:

In Figure 14(d), the infinitely precise result of an operation is: $2^{10}+3 * 2^{0}=00 \ldots 010000000011$.

This result can be represented exactly in the integer format - no rounding takes place.

Figure 14. Integer Rounding Examples for Round Toward $+\infty$ Mode


Round Toward 0 - In this rounding mode the result of an operation is rounded to the closest representation whose magnitude is less than or equal to the infinitely precise result, and which fits the destination format. Rounding is performed both for floating-point and integer destination formats.
Figure 15 illustrates four examples of the round toward 0 process for operations having a floating-point destination format. The infinitely precise result of an operation is represented by an $X$ on the number line; the black dots on the number line indicate those values that can be represented exactly in the floating-point format.

## Example 1:

In Figure 15(a), the infinitely precise result of an operation is: $2^{20}+2^{-4}+2^{-5}=1.00000000000000000000000 \backslash 11 \times 2^{20}$.

This result cannot be represented exactly in floating-point format, and is rounded to: $220=1.00000000000000000000000 \times 220$.

## Example 2:

In Figure 15(b), the infinitely precise result of an operation is:

This result cannot be represented exactly in floating-point format, and is rounded to:
$2^{20}-2^{-4}=1.11111111111111111111111 \times 219$.
Example 3:
In Figure 15(c), the infinitely precise result of an operation is:

$$
\begin{aligned}
& -\left(2^{20}+2^{-3}+2^{-4}\right) \\
& =-1.00000000000000000000001 \backslash 1 \times 220
\end{aligned}
$$

This result cannot be represented exactly in floating-point format, and is rounded to:
$-\left(220+2^{-3}\right)=-1.00000000000000000000001 \times 220$.
Example 4:
In Figure 15(d), the infinitely precise result of an operation is: $2^{20}+3^{* 2-3}=1.00000000000000000000011 \times 2^{20}$.
This result can be represented exactly in the floating-point format, and is unaffected by the rounding process.

Figure 15. Floating-Point Rounding Examples for Round Toward 0 Mode


05621A-17

Figure 16 illustrates four examples of the round toward 0 process for operations having an integer destination format. The infinitely precise result of an operation is represented by an $X$ on the number line; the black dots on the number line indicate those values that can be exactly represented in the integer format.

## Example 1:

In Figure 16(a), the infinitely precise result of an operation is: $2^{10-2-2}=00 \ldots 001111111111.11$.
The result is rounded to:
$210-20=00 \ldots 001111111111$.
Example 2:
In Figure 16(b), the infinitely precise result of an operation is: $2^{10}+2^{0}+2^{-3}=00 \ldots 010000000001.001$.
The result is rounded to:
$2^{10}+2^{0}=00 \ldots 010000000001$.

## Example 3:

In Figure 16(c), the infinitely precise result of an operation is: $-\left(2^{10}+2^{0}+2^{-1}\right)=11 \ldots 101111111110.1$.
This result is rounded to:
$-\left(2^{10}+2^{0}\right)=11 \ldots 101111111111$.

## Example 4:

In Figure 16(d), the infinitely precise result of an operation is: $210+3 * 20=00 \ldots 010000000011$.
This result can be represented exactly in the integer format, and is unaffected by the rounding process.

## Flag Operation

The Am29325 generates six status flags to monitor floating-point processor operation. The following is a summary of flag conventions in IEEE mode:

Invalid Operation Flag - The invalid operation flag is HIGH when an input operand is invalid for the operation to be performed. The IEEE Mode Invalid Operations Table on page 12 lists the cases for which the invalid operation flag is HIGH in IEEE mode, and the corresponding final result. In cases where the invalid operation flag is HIGH, the overflow, underflow, zero, and inexact flags are LOW; the NAN flag will be HIGH.

Overflow Flag - The overflow flag is HIGH if an R PLUS S, R MINUS S, R TIMES S, or 2 MINUS S operation with finite input operand(s) produces a result which, after rounding, has a magnitude greater than or equal to $2^{128}$. The final result will be $+x$ or $-x$.

Underflow Flag - The underflow flag is HIGH if an R PLUS S, R MINUS S, or R TIMES S operation produces a result which, after rounding, has a magnitude in the range:

$$
0<\text { magnitude }<2-126
$$

The final result will be $+0\left(00000000_{16}\right)$ if the rounded result is non-negative, and $-0\left(80000000_{16}\right)$ if the rounded result is negative.

Inexact Flag - The inexact flag is HIGH if the final result of an R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, INT-TO-FP, or FP-TO-INT operation is not equal to the infinitely precise result. Note that if the underflow or overflow flag is HIGH, the inexact flag will also be HIGH.

Figure 16. Integer Rounding Examples for Round Toward 0 Mode



Zero Flag - The zero flag is HIGH if the final result of an operation is zero. For operations producing an IEEE floatingpoint number, the flag accompanies outputs $+0\left(00000000_{16}\right)$ and $-0\left(80000000_{16}\right)$. For operations producing an integer, the flag accompanies the output $0\left(00000000_{16}\right)$.

NAN Flag - The NAN flag is HIGH if an R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, or FP-TO-INT operation produces a NAN as a final result.

## OPERATION IN DEC MODE

When input signal IEEE/ $\overline{\mathrm{DEC}}$ is LOW, the DEC mode of operation is selected. In this mode the Am29325 uses the single-precision floating-point format (floating F) set forth in Digital Equipment Corporation's VAX Architecture Manual. In addition, the DEC mode complies with most other aspects of single-precision floating-point operation outlined in the manual - differences are discussed in Appendix B.

## DEC Floating-Point Format

The DEC single-precision floating-point word is thirty-two bits wide, and is arranged in the format shown in Figure 17. The floating-point word is divided into three fields: a single-bit sign, an eight-bit biased exponent, and a 23 -bit fraction.
The sign bit indicates the sign of the floating-point number's value. Non-negative values have a sign of 0 , negative values a sign of 1 .
The biased exponent is an eight-bit unsigned integer field representing a multiplicative factor of some power of two. The bias value is 128 . If, for example, the multiplicative factor for a floating-point number is to be $2^{a}$, the value of the biased exponent would be $a+128$; $a$ is called the true exponent.

The fraction is a 23 -bit unsigned fractional field containing the 23 least-significant bits of the floating-point number's 24 -bit mantissa. The weight of this field's most significant bit is $2^{-2}$; the weight of the least-significant bit is 2-24.

A floating-point number is evaluated or interpreted per the following conventions:
let $\mathrm{s}=$ sign bit
e = biased exponent
$f=$ fraction
if $\mathrm{e}=0$ and $\mathrm{s}=0 \ldots$ value $=0$
if $e=0$ and $s=1 \ldots$ value $=D E C$ reserved operand
if $0<\mathrm{e} \leqslant 255$. . value $=(-1)^{\mathrm{s} *}\left(2^{\mathrm{e}-128) *(.1 f)}\right.$
(normalized number)
Zero - The value zero always has a sign of zero.

DEC Reserved Operand - A DEC reserved operand does not represent a numeric value, but is interpreted as a signal or symbol. DEC reserved operands are used to indicate invalid operations and operations whose results have overflowed the destination format. They may also be used to pass symbolic information from one calculation to another.

Normalized Number - A normalized number represents a quantity with magnitude greater than or equal to 2-128 but less than 2127.

## Example 1:

The number +3.5 can be represented in floating-point format as follows:

$$
\begin{aligned}
+3.5 & =11.1_{2} \times 20 \\
& =.111_{2} \times 2^{2}
\end{aligned}
$$

sign $=0$

$$
\begin{aligned}
\text { biased exponent } & =22_{10}+128_{10}=130_{10} \\
& =10000010_{2}
\end{aligned}
$$

fraction $=11000000000000000000000_{2}$ (the leading 1 is implied in the format)
Concatenating these fields produces the floating-point word $41600000_{16}$

Example 2:
The number -11.375 can be represented in floating-point format as follows:

$$
\begin{aligned}
-11.375 & =-1011.011_{2} \times 2^{0} \\
& =-.1011011_{2} \times 2^{4}
\end{aligned}
$$

sign $=1$
biased exponent $=410+128_{10}=132_{10}$

$$
=10000100_{2}
$$

fraction $=01101100000000000000000_{2}$
(the leading 1 is implied in the format)
Concatenating these fields produces the floating-point word C2360000 ${ }_{16}$.

## DEC Mode Integer Format

DEC mode integer format is identical to that of the IEEE mode. Integer numbers are represented as 32 -bit, two's complement words; Figure 7 depicts the integer format. The integer word can represent a range of integer values from $-2^{31}$ to $231-1$.

## Operations

All eight floating-point ALU operations discussed in the General Description section can be performed in DEC mode.

Figure 17. DEC-Mode Floating-Point Format


VALUE $=(-1)^{\mathrm{S}}\left(\mathbf{2}^{\mathrm{E}-128}\right)(.1 \mathrm{~F})$

Various exceptional aspects of the R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, INT-TO-FP, and FP-TO-INT operations for this mode are described below. The IEEE-TO-DEC and DEC-TO-IEEE operations are discussed separately in the IEEE-TO-DEC and DEC-TO-IEEE Operations section on page 23.

Operations with DEC Reserved Operands - DEC reserved operands arise in two ways: they can be generated by the Am29325 to indicate that an invalid operation or floating-point overflow has taken place, or they can be provided by the user as an input operand.
When a DEC reserved operand appears as an input operand, the final result of the operation is the same DEC reserved operand. If an operation has two DEC reserved operands as inputs, the DEC reserved operand on the R port becomes the final result.
The NAN flag will be HIGH whenever an operation produces a DEC reserved operand as a final result.

## Example 1:

Suppose the floating-point addition operation is performed with the following input operands:

R port: $\mathbf{4 0 8 0 0 0 0 0}_{16}\left(0.1 * 2^{1}\right)$
S port: 80012345 ${ }_{16}$ (DEC reserved operand)
Result: This operation produces the DEC reserved operand on the S port, $80012345_{16}$, as the final result. The NAN flag will be HIGH.

Example 2:
Suppose the floating-point multiplication operation is performed with the following input operands:
R port: $80765432_{16}$ (DEC reserved operand)
S port: $8000000{ }_{16}$ (DEC reserved operand)
Result: Since both input operands are DEC reserved operands, the operand on the R port, $80765432_{16}$, is the final result of the operation. The NAN flag will be HIGH.

Operations Producing Overflows - If an operation produces a rounded result that is too large to fit in the destination format, that operation is said to have overflowed.
A floating-point overflow occurs if a R PLUS S, R MINUS S, R TIMES S, or 2 MINUS S operation with finite input operand(s) produces a result which, after rounding, has a magnitude greater than or equal to $2^{127}$. The final result in such cases will be DEC reserved operand $80000000_{16}$; the overflow, inexact, and NAN flags will be HIGH.
Integer overflow occurs when the fixed-to-floating-point conversion operation attempts to convert to integer a floating-point number which, after rounding, is greater than $2^{31}-1$ or less than $-2^{31}$. The final result in such cases will be DEC reserved operand $80000000_{16}$; the invalid operation flag will be HIGH. Note that the overflow and inexact flags remain LOW for integer overflow.

Operations Producing Underflows - If an operation produces a floating-point result which, after rounding, has a magnitude too small to be expressed as a normalized floating-point number, but greater than zero, that operation is said to have underflowed. Underflow occurs when an R PLUS S, R MINUS S, or R TIMES S operation produces a result which, after rounding, has magnitude:

$$
0<\text { magnitude }<2-128 .
$$

The final result in such cases will be $0\left(00000000_{16}\right)$. The underflow, inexact, and zero flags will be HIGH.

Underflow does not occur if the destination format is integer. If the infinitely precise result of a floating-point-to-integer conversion has a magnitude greater than 0 and less than 1, but the rounded result is 0 , the underflow flag remains LOW.

Invalid Operations - If an input operand is invalid for the operation to be performed, that operation is considered invalid. In DEC mode, there are only two invalid operations:

- Performing a floating-point-to-integer conversion on a value too large to be expressed as a 32 -bit integer. In this case the final result will be DEC reserved operand $80000000_{16}$, and the invalid operation and NAN flags will be HIGH.
- Performing a floating-point-to-integer conversion on a DEC reserved operand. In this case the final result will be the input DEC reserved operand, and the invalid operation and NAN flags will be HIGH.


## Sign Bit

For all operations producing a DEC floating-point result, the sign bit of the final result is unambiguous, i.e., there is only one sign bit value that yields a numerically correct result.

## Rounding

There are four rounding modes for DEC operation: round to nearest, round toward $+x$, round toward $-x$, and round toward 0 . The round toward $+x$, round toward $-x$, and round toward 0 modes are performed in a manner identical to that for IEEE operation; refer to the Rounding section under Operation in IEEE Mode on page 12. The round to nearest mode is similar to that for IEEE operation, but differs in one respect: for the case in which the infinitely-precise result of an operation is exactly halfway between two representable values, DEC round to nearest mode rounds to the value with the larger magnitude, rather than to the value whose LSB is 0 .

## Flag Operation

The Am29325 generates six status flags to monitor floating-point processor operation. The following is a summary of flag operation in DEC mode:

Invalid Operation Flag - The invalid operation flag is HIGH if the FP-TO-INT operation is performed on a floating-point number too large to be converted to an integer, or on a DEC reserved operand. If the FP-TO-INT operation is performed on a floatingpoint number too large to be converted to integer, the final result is the DEC reserved operand $80000000_{16}$. If the FP-TO-INT operation is performed on a DEC reserved operand, that operand becomes the final result.

Overflow Flag - The overflow flag is HIGH if an R PLUS S, R MINUS S, R TIMES S, or 2 MINUS S operation produces a result which, after rounding, has a magnitude greater than or equal to 2127. The final result will be the DEC reserved operand $80000000_{16}$.

Underflow Flag - The underflow flag is HIGH if an R PLUS S, R MINUS S, or R TIMES S operation produces a result which, after rounding, has a magnitude in the range:

$$
\cdot 0<\text { magnitude }<2^{-128 .}
$$

The final result will be $0\left(00000000_{16}\right)$ in such cases.
Inexact Flag - The inexact flag is HIGH if the final result of an R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, INT-TO-FP, or FP-TO-INT operation is not equal to the infinitely precise result. Note that if the underflow or overflow flag is HIGH, the inexact flag will also be HIGH.

Zero Flag - The zero flag is HIGH if the final result of an operation is zero. For operations producing an integer or a DEC floating-point number, the flag accompanies the output 0 ( $00000000_{16}$ ). (It should be noted that any operation producing a floating-point 0 in DEC mode will output $00000000_{16}$.)
NAN Flag - The NAN flag is HIGH if an R PLUS S, R MINUS S, R TIMES S, 2 MINUS S, or FP-TO-INT operation produces a DEC reserved operand as the final result.

## IEEE-TO-DEC AND DEC-TO-IEEE OPERATIONS

The IEEE-TO-DEC and DEC-TO-IEEE operations are used to convert floating-point numbers between the IEEE and DEC formats. Both operations work in a manner independent of the IEEE/ $\overline{\mathrm{DEC}}$ mode control.

## IEEE-TO-DEC Conversion

This operation converts an IEEE floating-point number to DEC floating-point format. Most conversions are exact; in no case
does the round mode have any affect on the final result. There are, however, a few exceptional cases:
a.) If the IEEE floating-point input has a magnitude greater than or equal to $2^{127}$, it is too large to be represented by a DEC floating-point number. The final result will be the DEC reserved operand $80000000_{16}$; the overflow, inexact, and NAN flags will be HIGH.
b.) If the IEEE floating-point input is a NAN, the final result will be the DEC reserved operand $80000000_{16}$; the invalid and NAN flags will be HIGH.
c.) If the IEEE floating-point input is a denormalized number, the final result will be a DEC $0\left(00000000_{16}\right)$; the zero flag will be HIGH.
d.) If the IEEE floating-point input is +0 or -0 , the final result will be a DEC $0\left(00000000_{16}\right)$; the zero flag will be HIGH.

## DEC-TO-IEEE Conversion

This operation 'converts a DEC floating-point number to IEEE floating-point format. Most conversions are exact; in no case does the round mode have any affect on the final result. There are, however, a few exceptional cases:
a.) If the DEC floating-point input is not 0 , but has a magnitude less than 2-126, it is too small to be expressed as a normalized IEEE floating-point number. The final result will be an IEEE floating-point 0 having the same sign as the input ( $00000000_{16}$ for positive inputs and $80000000_{16}$ for negative inputs); the underflow, inexact, and zero flags will be HIGH.
b.) If the DEC floating-point input is a DEC reserved operand, the final result will be quiet NAN 7FAOOOOO 16 ; the invalid operation and NAN flags will be HIGH.
c.) If the DEC floating-point input is 0 , the final result will be IEEE floating-point $+0\left(00000000_{16}\right)$; the zero flag will be HIGH.

## APPENDIX A:

## Differences Between the IEEE Proposed Standard for Binary

 Floating-Point Arithmetic and the Am29325's IEEE ModeWhen operated in IEEE mode, the Am29325 High-speed Floating-Point Processor complies with the single-precision portion of the IEEE Proposed Standard for Binary Floating-Point Arithmetic (P754, draft 10.0) in most respects. There are, however, several differences:

## Denormalized Numbers

The Am29325 does not handle denormalized numbers. A denormalized input will be converted to a zero of the same sign before the specified operation takes place. The operation proceeds in exactly the same manner as if the input were +0 or -0 , producing the same numerical result and flags.
If the result of an operation, after rounding, has a magnitude smaller than $2^{-126}$, the result is replaced by a zero of the same sign.

## Representation of Overflows

In some rounding modes, the proposed IEEE standard requires that overflows be represented as the format's most positive or most negative finite number. In particular:

- When rounding toward 0 , all overflows should produce a result of the largest representable finite number with the sign of the intermediate result.
- When rounding toward $-x$, all positive overflows should produce a result of the largest representable positive finite number.
- When rounding toward $+x$, all negative overflows should produce a result of the largest representable negative finite number.

The Am29325, however, always represents positive overflows as $+\infty$ and negative overflows as $-x$, regardless of rounding mode.

## Projective Mode

The proposed IEEE standard provides only for an affine mode to control the handling of infinities. The Am29325 provides both affine and projective modes; the desired mode can be selected by the user.

## Traps

The proposed IEEE standard stipulates that the user be able to request a trap on any exception. The Am29325 does not support trap operation, and behaves as if traps are disabled.

## Resetting of Flags

The proposed IEEE standard states that once an exception flag has been set, it is reset only at the user's request. The Am29325's flags, however, reflect the status of the most recent operation.

## Generation of the Underflow Flag

The proposed IEEE standard suggests several possible criteria for determining if underflow occurs. These criteria generate underflow flags that differ in subtle ways. The underflow criteria chosen for the Am29325 stipulate that underflow occurs if:
a) the rounded result of an operation has a magnitude in the range:

$$
0<\text { magnitude }<2^{-126}
$$

and
b) the final result is not equal to the infinitely precise result.

Since the Am29325 never produces a denormalized number as the final result of a calculation, condition (b) is true whenever (a) is true. Note, then, that the operation of the Am29325's underflow flag is somewhat different than that of an "IEEE standard" system using the same underflow criteria. For example, if an operation should produce an infinitely precise result that is exactly $2^{-127}$, an "IEEE standard" system would produce that value as the final result, expressed as a denormalized number. Since that system's final result is exact, the underflow flag would remain LOW. The Am29325, on the other hand, would output zero; since its final result is not exact, the underflow flag would be HIGH.

## APPENDIX B:

## Differences Between DEC VAX and Am29325 DEC Mode

Operation in DEC mode complies with most aspects of singleprecision floating-point operation outlined in the Digital Equipment Corporation's VAX Architecture Manual. However, there are some differences that should be noted:

## Format

The Am29325's DEC format is:

| sign | - bit 31 |
| :--- | :--- |
| exponent | - bits $30-23$ |
| mantissa | $-22-0$ |

The VAX format is

| sign | - bit 15 |
| :--- | :--- |
| exponent | $-14-7$ |
| mantissa | - bits $6-0$, bits $31-16$. |

In both cases, fields are listed from MSB to LSB, with bit 31 the MSB of the 32-bit word. The Am29325's DEC format can be converted to VAX format by swapping the 16 LSBs and 16 MSBs of the 32-bit word.

## Flags vs. Exceptions

In DEC VAX operation, certain unusual conditions arising during system operation may incur an exception, or an indication to the operating system that special handling is needed.
The VAX recognizes a number of arithmetic exceptions. The following exceptions are relevant to the operations supported by the Am29325:

Integer overflow trap - indicates that the last operation produced an integer overflow. The LŚBs of the correct result are stored in the destination operand.
Floating-point overflow trap/fault - indicates that the last operation produced, after normalization and rounding, a floating-point number with magnitude greater than or equal to $2^{127}$. A trap replaces the destination operand with the DEC reserved operand $80000000_{16}$; a fault leaves the destination operand unchanged.
Floating-point underflow trap/fault - indicates that the last operation produced, after normalization and rounding, a floating-point number with magnitude less than $2^{-128}$. A trap replaces the destination operand with zero; a fault leaves the destination operand unchanged.
Reserved operand fault - indicates that the last operation had a reserved operand as an input. The destination operand is unchanged.

The Am29325 does not directly support DEC traps and faults. Rather, it indicates unusual conditions by setting one or more of the six status flags HIGH. Table d2 describes flag operation in DEC mode.

## Integer Overflow

In cases of integer overflow, the VAX signals the integer overflow trap and stores the LSBs of the correct result. The Am29325 sets the invalid operation flag and outputs the DEC reserved operand $80000000_{16}$.

## Floating-Point Underflow/Overflow Operation

The VAX Architecture Manual specifies the action to be taken on the destination operand when floating-point underflow or overflow is encountered. The Am29325 has no immediate control over this destination operand, as it resides somewhere off-chip, either in a register or memory location. This isn't so much a difference between the VAX specification and Am29325 operation as it is a difference in scope.
The Am29325 responds to floating-point underflow by producing a final result of $0\left(00000000_{16}\right)$; the underflow, inexact, and zero flags will be HIGH. It responds to floating-point overflow by producing the DEC reserved operand $80000000_{16}$ as the final result; the overflow, inexact, and NAN flags will be HIGH.

## Handling of DEC Reserved Operands

If an operation has a DEC reserved operand as an input, the Am29325 will produce that operand as the final result. If an operation has two input arguments and both are DEC reserved operands, the operand on port R becomes the final result. For the VAX, operations with a DEC reserved operand input or inputs do not modify the destination operand. As mentioned above, control of the destination operand is beyond the scope of the Am29325's operation.

## Inexact Flag

The Am29325 provides an inexact flag to indicate that the final result produced by an operation is not equal to the infinitely precise result. The VAX does not provide this flag.

## APPENDIX C:

## Performing Floating-Point Division on the Am29325

While the Am29325 does not have a floating-point division instruction, it can be used to evaluate reciprocals. The division:

$$
C=A / B
$$

can then be performed by evaluating:

$$
C=A *(1 / B)
$$

Only a modest amount of external hardware is needed to implement the reciprocal function.
The technique for calculating reciprocals is based on the Newton-Raphson method for obtaining the roots of an equation. The roots of equation:

$$
F(x)=0
$$

can be found by iteratively evaluating the equation

$$
x_{i+1}=x_{i}-F\left(x_{i}\right) / F^{\prime}\left(x_{i}\right) .
$$

The process begins by making a guess as to the value of $x_{i}$, and using this guess or "seed" value to perform the first iteration. Iterations are continued until the root is evaluated to the desired accuracy. The number of iterations needed to achieve a given accuracy depends both on the accuracy of the seed value and the nature of $\mathrm{F}(\mathrm{x})$.
Now consider the equation

$$
F(x)=(1 / x)-B .
$$

The root of $F(x)$ is $1 / B$. The reciprocal of $B$, then, can be found by using the Newton-Raphson method to find the root of $F(x)$. The iterative equation for finding the root is

$$
\begin{aligned}
x_{i+1} & =x_{i}-F\left(x_{i}\right) / F^{\prime}\left(x_{i}\right) \\
& =x_{i}-\left(1 / x_{i}-B\right) /-\left(x_{i}\right)^{-2} \\
& =x_{i}\left(2-B * x_{i}\right) .
\end{aligned}
$$

It can be shown that, in order for this iterative equation to converge, the seed value $x_{0}$ must fall in the range

$$
\begin{array}{lll} 
& 0<x_{0}<2 / B & \text { if } B>0 \\
\text { or } & 2 / B<x_{0}<0 & \text { if } B<0 .
\end{array}
$$

For example, if the reciprocal of 3 is to be evaluated, the seed value must be between 0 and $2 / 3$.

The error of $x_{i}$ reduces quadratically; that is, if the error of $x_{i}$ is $e$, the error is reduced to order $\mathrm{e}^{2}$ by the next iteration. The number of bits of accuracy in the result, then, roughly doubles after every iteration. While this is only an approximation of the actual error produced, it is a handy rule-of-thumb for determining the number of iterations needed to produce a result of a certain accuracy, given the accuracy of the seed.

## Example 1:

Find the reciprocal of 7.25 .

## Solution:

The seed value must fall in the range

$$
\begin{aligned}
& 0<x_{0}<2 / 7.25 \\
\text { or } & 0<x_{0}<.275862 .
\end{aligned}
$$

Suppose $x_{0}$ is chosen to be .1
Iteration 1: $\mathrm{x}_{1}=\mathrm{x}_{0}\left(2-\mathrm{B} * \mathrm{x}_{0}\right)$

$$
\begin{aligned}
& =.1(2-(7.25)(.1)) \\
& =.1275
\end{aligned}
$$

The actual value of $1 / 7.25$, to ten decimal places, is .1379310345.
The error after each iteration is:

| Iteration | $\mathbf{x}_{\mathbf{i}}$ | Error to Ten Places |
| :---: | :--- | :--- |
| 0 | .1 | -0.0379310345 |
| 1 | .1275 | -0.0104310345 |
| 2 | .1371421875 | -0.0007888470 |
| 3 | .1379265230 | -0.0000045115 |

## Example 2:

Find the reciprocal of -.3 .
Solution:
The seed value must fall in the range

$$
\begin{array}{ll} 
& 2 /(-.3)<x_{0}<0 \\
\text { or } & -6.66<x_{0}<0 .
\end{array}
$$

Suppose $x_{0}$ is chosen to be -2.0.
Iteration 1: $\mathrm{x}_{1}=\mathrm{x}_{0}\left(2-\mathrm{B} * \mathrm{x}_{0}\right)$

$$
=-2.0(2-(-.3)(-2.0))
$$

$$
=-2.8
$$

Iteration 2: $\mathrm{x}_{2}=\mathrm{x}_{1}\left(2-\mathrm{B} * \mathrm{x}_{1}\right)$

$$
\begin{aligned}
& =-2.8(2-(-.3)(-2.8)) \\
& =-3.248
\end{aligned}
$$

Iteration 3: $\mathrm{x}_{3}=\mathrm{x}_{2}\left(2-\mathrm{B} * \mathrm{x}_{2}\right)$

$$
\begin{aligned}
& =-3.248(2-(-.3)(-3.248)) \\
& =-3.3311488
\end{aligned}
$$

Iteration 4: $\mathrm{x}_{4}=\mathrm{x}_{3}\left(2-\mathrm{B} * \mathrm{x}_{3}\right)$

$$
\begin{aligned}
& =-3.3311488 * \\
& =-(2-(-.3)(-3.3311488)) \\
& =-3.333331902
\end{aligned}
$$

The actual value of $1 /(-.3)$, to ten decimal places, is -3.333333333 .
The error after each iteration is:

| $\mathbf{i}$ | $\mathbf{x}_{\mathbf{i}}$ | Error to Ten Places |
| :--- | :--- | :---: |
| 0 | -2.0 | 1.333333333 |
| 1 | -2.8 | 0.533333333 |
| 2 | -3.248 | 0.085333333 |
| 3 | -3.3311488 | 0.002184533 |
| 4 | -3.333331902 | 0.000001431 |

In order to implement the Newton-Raphson method on the Am29325, some means is needed to generate the seed used in the first iteration. One approach is to place a hardware seed look-up table between the R bus and the Am29325; see Table c1. A more detailed diagram of the look-up table appears in Figure c2.

$$
\begin{aligned}
& \text { Iteration 2: } \mathrm{x}_{2}=\mathrm{x}_{1}\left(2-\mathrm{B} * \mathrm{x}_{1}\right) \\
& =.1275(2-(7.25)(.1275)) \\
& =.1371421875 \\
& \text { Iteration 3: } \mathrm{x}_{3}=\mathrm{x}_{2}\left(2-\mathrm{B} * \mathrm{x}_{2}\right) \\
& =.1371421875 * \\
& \text { (2-(7.25) (.1371421875)) } \\
& =.1379265230
\end{aligned}
$$

TABLE c1. CONTENTS OF THE SEED EXPONENT PROM

| DEC |  | IEEE |  |
| :---: | :---: | :---: | :---: |
| Address (16) | Data (16) | Address (16) | Data (16) |
| 000 | (Note 1) | 100 | FD |
| 001 | (Note 1) | 101 | FC |
| 002 | FF | 102 | FB |
| 003 | FE | 103 | FA |
| 004 | FD | 104 | F9 |
| 005 | FC | 105 | F8 |
| 006 | FB | 106 | F7 |
| 007 | FA | 107 | F6 |
| 008 | F9 | 108 | F5 |
| 009 | F8 | 109 | F4 |
| 00A | F7 | 10A | F3 |
| OOB | F6 | 10B | F2 |
| OOC | F5 | 10C | F1 |
| 00D | F4 | 10D | F0 |
| OOE | F3 | 10E | EF |
| 00F | F2 | 10F | EE |
| 010 | F1 | 110 | ED |
| 011 | FO | 111 | EC |
| 012 | EF | 112 | EB |
| - | - | - | - |
| - | $\cdot$ | - | - |
| OEE | 13 | 1EE | OF |
| OEF | 12 | 1EF | OE |
| OFO | 11 | 1F0 | OD |
| OF1 | 10 | 1F1. | OC |
| OF2 | OF | 1F2 | OB |
| OF3 | OE | 1 F3 | OA |
| OF4 | OD | 1F4 | 09 |
| OF5 | OC | 1F5 | 08 |
| OF6 | OB | 1F6 | 07 |
| OF7 | OA | 1F7 | 06 |
| OF8 | 09 | 1 F8 | 05 |
| OF9 | 08 | 1F9 | 04 |
| OFA | 07 | 1FA | 03 |
| OFB | 06 | 1FB | 02 |
| OFC | 05 | 1FC | 01 |
| OFD | 04 | 1FD | (Note 2) |
| OFE | 03 | 1FE | (Note 2) |
| OFF | 02 | 1FF | (Note 2) |

Notes: 1. The reciprocals of these numbers are toolarge to be represented in DEC format.
2. The reciprocals of these numbers are too small to be represented in normalized IEEE format.

Figure c1. Adding a Hardware Look-Up Table to the Am29325


The look-up table has two sections: a biased exponent look-up PROM and a fraction look-up PROM. The seed biased exponent look-up table is stored in a 512 -by- 8 -bit PROM. This table consists of two sections - the DEC format section, which occupies addresses $000-0 \mathrm{FF}_{16}$, and the IEEE section, which occupies addresses $100-1 \mathrm{FF}_{16}$. The appropriate table will be selected automatically if address line $A_{8}$ is wired to the Am29325's IEEE/ $\overline{D E C}$ pin. The equations implemented by these table sections are:
DEC table: seed biased exponent

$$
=257_{10} \text {-input biased exponent }
$$

IEEE table: seed biased exponent

$$
=252_{10}-\text { input biased exponent }
$$

Table c1 lists the contents of this PROM.
The seed fraction look-up table is stored in one or more PROMs, the number of PROMs depending on the desired accuracy of the seed value. The hardware depicted in Figure c2 uses two 4K-by-8-bit PROMs to implement a fraction look-up table whose
inputs are the 12 MSBs of the input argument's fraction. These PROMs output the 16 MSBs of the seed's fraction field - the remaining 7 bits of fraction are set to 0 . The equation implemented in this table is:

$$
\text { seed fraction }=\frac{2}{1+\text { input fraction }}-1 \text {, }
$$

where the value of the input fraction falls in the range

$$
0 \leqslant \text { input fraction }<1 .
$$

Note that the seed fraction must also be constrained to fall in the range

$$
0 \leqslant \text { seed fraction }<1 .
$$

Therefore, if the input fraction is 0 , the corresponding seed fraction stored in the table must be $.1111 \ldots 111_{2}$, not $1.0_{2}$. The same seed fraction look-up table may be used for both IEEE and DEC formats. Table c2 contains a partial listing for the seed fraction look-up table shown in Figure c2.

TABLE c2. CONTENTS OF THE SEED FRACTION PROMs

| Address (16) | Value of Input Fraction (10) | Value of Seed Fraction (10) | $\begin{aligned} & \text { PROM Ou } \\ & \mathbf{R}_{22}-R_{15} \end{aligned}$ | $\begin{aligned} & \text { tputs (16) } \\ & R_{14}-R_{7} \\ & \hline \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| 000 | 0.0 | 0.9999999999 (see text) | FF | FF |
| 001 | 0.0002441406 | 0.9995118370 | FF | E0 |
| 002 | 0.0004882812 | 0.9990239150 | FF | CO |
| 003 | 0.0007324219 | 0.9985362280 | FF | AO |
| 004 | 0.0009765625 | 0.9980487790 | FF | 80 |
| 005 | 0.0012207031 | 0.9975615710 | FF | 60 |
| 006 | 0.0014648438 | 0.9970745970 | FF | 40 |
| 007 | 0.0017089844 | 0.9965878630 | FF | 20 |
| 008 | 0.0019531250 | 0.9961013650 | FF | 00 |
| 009 | 0.0021972656 | 0.9956151030 | FE | E1 |
| 00A | 0.0024414063 | 0.9951290800 | FE | C0 |
| 00B | 0.0026855469 | 0.9946432920 | FE | A1 |
| OOC | 0.0029296875 | 0.9941577400 | FE | 81 |
| . | - | - | . | . |
| - | - | - | - | - |
| - | - | - | $\cdot$ | - |
| FF6 | 0.9975585938 | 0.0012221950 | 00 | 50 |
| FF7 | 0.9978027344 | 0.0010998410 | 00 | 48 |
| FF8 | 0.9980486750 | 0.0009775170 | 00 | 40 |
| FF9 | 0.9982910156 | 0.0008552230 | 00 | 38 |
| FFA | 0.9985351563 | 0.0007329590 | 00 | 30 |
| FFB | 0.9987792969 | 0.0006107240 | 00 | 28 |
| FFC | 0.9990234375 | 0.0004885200 | 00 | 20 |
| FFD | 0.9992675781 | 0.0003663450 | 00 | 18 |
| FFE | 0.9995117188 | 0.0002442000 | 00 | 10 |
| FFF | 0.9997558594 | 0.0001220850 | 00 | 08 |

Figure c2. The Hardware Lookup-Up Table


SEED FRACTION

With the hardware look-up table in place, the reciprocal of value $B$ can be calculated with the following series of operations:
1.) Place $B$ on both the $R$ and $S$ buses. The $2: 1$ multiplexer at the output of the hardware look-up table should select the output of the look-up table. (see Figure c3-a)
2.) Load the seed value $x_{0}$ into register $R$ and load $B$ into register $S$. Select the R TIMES S operation. (see Figure c3-b)
3.) Load product $B * x_{0}$ into register $F$. Select the 2 MINUS $S$ operation, and select register $F$ as the input to the ALU S port. (see Figure c3-c)
4.) Load 2-B*x 0 into register $F$. Select the R TIMES S operation and select register $F$ as the input to the ALU S port. (see Figure c3-d)
5.) Load the value $\mathrm{x}_{1}\left(=\mathrm{x}_{0}\left(2-\mathrm{B} * \mathrm{x}_{0}\right)\right)$ into registers R and F . Select the R TIMES S operation. (see Figure c3-e)
6.) Repeat steps 3 through 5 until the result has the accuracy desired.

Figure c3-a. Data Flow for Step 1 of the Reciprocal Procedure


Figure c3-b. Data Flow for Step 2 of the Reciprocal Procedure


Figure c3-c. Data Flow for Step 3 of the Reciprocal Procedure


Figure c3-d. Data Flow for Step 4 of the Reciprocal Procedure


Figure c3-e. Data Flow for Step 5 of the Reciprocal Procedure


A tabular description of the operations above is given in Table c3. The following examples, performed in IEEE format, illustrate the process.
Example 1:
Find the reciprocal of 25.3 .
Solution: The IEEE floating-point representation for 25.3 is 41 CA6666 ${ }_{16}$. The reciprocal process is begun by feeding this value to both the seed look-up table and
port S . The look-up table produces the value $.03952789_{10}\left(3 \mathrm{D} 21 \mathrm{E} 800_{16}\right)$. The reciprocal is evaluated using the procedure described above; register values for each step are given in Table c4. The expected result, to the precision of the floating-point word, is $.03952569_{10}$ (3D21E5B1 ${ }_{16}$ ). In this case the expected result is produced after the first iteration. All subsequent iterations produce the same result, and are therefore unnecessary.

TABLE c3. SEQUENCE OF EVENTS FOR EVALUATING RECIPROCALS

## Clock

| Cycle | $\mathrm{I}_{0}-\mathrm{I}_{2}$ | $l_{3}$ | $\mathrm{I}_{4}$ | ENR | ENS | $\overline{\text { ENF }}$ | Register $\mathbf{R}$ | Register S | Register F | First iteration |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Y | $\times$ | 0 | 0 | 0 | X | - | - | - |  |
| 2 | R TIMES S | 0 | x | 1 | 1 | 0 | $\mathrm{x}_{0}$ | B | - |  |
| 3 | 2 Minus S | 1 | x | 1 | 1 | 0 | $\mathrm{x}_{0}$ | B | B* ${ }_{0}$ |  |
| 4 | R TIMES S | 1 | 1 | 0 | 1 | 0 | $\mathrm{x}_{0}$ | B | $2-B+x_{0}$ |  |
| 5 | R TIMES S | 0 | x | 1 | 1 | 0 | $X_{1}\left(=X_{0}\left(2-B * X_{0}\right)\right)$ | B | $X_{1}\left(=X_{0}\left(2-B * X_{0}\right)\right)$ |  |
| 6 | 2 MINUS S | 1 | X | 1 | 1 | 0 | $\mathrm{x}_{1}$ | B | $\mathrm{B} * \mathrm{X}_{1}$ | Second iteration |
| 7 | R TIMES S | 1 | 1 | 0 | 1 | 0 | $\mathrm{x}_{1}$ | B | $2-\mathrm{B} \cdot \mathrm{X}_{1}$ |  |
| 8 | R TIMES S | 0 | X | 1 | 1 | 0 | $\mathrm{X}_{2}\left(=X_{1}\left(2-B * X_{1}\right)\right)$ | B | $\mathrm{X}_{2}\left(=\mathrm{X}_{1}\left(2-B * x_{1}\right)\right)$ |  |

$X=$ DON'T CARE

TABLE c4. INPUT BUS AND REGISTER VALUES FOR EXAMPLE 1

| Clock Cycle | R Input | $S$ Input | Register R | Register S | Register F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\begin{aligned} & \text { 3D21E800 } \\ & (.03952789) \end{aligned}$ | $\begin{aligned} & 4_{1 \text { CA6666 }}^{16} \end{aligned}$ | - | - | - |  |
| 2 | - | - | $\begin{aligned} & 3 \mathrm{D} 21 \mathrm{E} 800_{16} \\ & (.03952789) \end{aligned}$ | $\begin{aligned} & \text { 41CA6666. }_{16} \\ & (25.3) \end{aligned}$ | - |  |
| 3 | - | - | $\begin{aligned} & 3 \mathrm{D} 21 \mathrm{E} 800_{16} \\ & (.03952789) \end{aligned}$ | $\begin{aligned} & \text { 41CA6666 }_{16} \\ & (25.3) \end{aligned}$ | $\begin{aligned} & \text { 3F8001D3 }_{16} \\ & (1.0000556) \end{aligned}$ |  |
| 4 | - | - | $\begin{aligned} & 3 \mathrm{D} 21 \mathrm{E} 800_{16} \\ & (.03952789) \end{aligned}$ | $\begin{aligned} & 4_{1} \text { CA6666 }_{16} \\ & (25.3) \end{aligned}$ | $\begin{aligned} & 3 F 7 F F C 5 A_{16} \\ & (.99984419) \end{aligned}$ |  |
| 5 | - | - | $\begin{aligned} & 3 D 21 E 5 B 116 \\ & (.03952569) \end{aligned}$ | $\begin{aligned} & \text { 41CA6666 }_{16} \\ & (25.3) \end{aligned}$ | $\begin{aligned} & 3 \mathrm{D} 21 E 5 B 1_{16} \\ & (.03952569) \end{aligned}$ | - Result of first iteration |
| 6 | - | - | $\begin{aligned} & \text { 3D21E5B1 }_{16} \\ & (.03952569) \end{aligned}$ | $\begin{aligned} & \text { 41CA6666 } \\ & \text { (25.3) } \end{aligned}$ | $\begin{aligned} & 3 F 7 F F F F F_{16} \\ & (.99999994) \end{aligned}$ |  |
| 7 | - | - | $\begin{aligned} & \text { 3D21E5B1 } 16 \\ & (.03952569) \end{aligned}$ | $\begin{aligned} & 4_{1 C A 6666}^{16} \\ & (25.3) \end{aligned}$ | $\begin{aligned} & 3 F 800000_{16} \\ & (1.0) \end{aligned}$ |  |
| 8 | - | - | $\begin{aligned} & 3 \mathrm{D} 21 E 5 B 1_{16} \\ & (.03952569) \end{aligned}$ | $\begin{aligned} & \text { 41CA6666 }_{16} \\ & (25.3) \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { 3D21E5B1 } 16 \\ & (.03952569) \\ & \hline \end{aligned}$ | Result of second iteration |

Example 2:
Find the reciprocal of -.4725 .
Solution: The IEEE floating-point representation for -. 4725 is BEF1EB85 ${ }_{16}$. The reciprocal process is begun by feeding this value to both the seed look-up table and port S . The look-up table produces the value $-2.11621094_{10}\left(\mathrm{C} 0077000_{16}\right)$. The reciprocal is
evaluated using the procedure described above; register values for each step are given in Table c5. The expected result, to the precision of the floating-point word, is $-2.116402_{10}$ (C0077322 ${ }_{16}$ ). In this case the expected result is produced after the first iteration. All subsequent iterations produce the same result, and are therefore unnecessary.

TABLE c5. INPUT BUS AND REGISTER VALUES FOR EXAMPLE 2

| Clock Cycle | R Input | $S$ Input | Register R | Register S | Register F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\begin{aligned} & \mathrm{C} 0077000_{16} \\ & (-2.1162109) \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 }_{16} \\ & (-0.4725) \end{aligned}$ | - | - | - |  |
| 2 | - | - | $\begin{aligned} & \mathrm{C} 0077000_{16} \\ & (-2.1162109) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 } 16 \\ & (-0.4725) \end{aligned}$ | - - | , |
| 3 | - | - | $\begin{aligned} & \mathrm{C} 0077000_{16} \\ & (-2.1162109) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 } 16 \\ & (-0.4725) \end{aligned}$ | 3F7FFA14 ${ }_{16}$ (0.99990963) |  |
| 4 | - | - | $\begin{aligned} & \mathrm{C} 0077000_{16} \\ & (-2.1162109) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 }_{16} \\ & (-0.4725) \end{aligned}$ | $\begin{aligned} & \text { 3F8002F6 }_{16} \\ & (1.0000904) \end{aligned}$ |  |
| 5 | - | - | $\begin{aligned} & C 0077322_{16} \\ & (-2.116402) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 }_{16} \\ & (-0.4725) \end{aligned}$ | $\begin{aligned} & C 0077322_{16} \\ & (-2.116402) \end{aligned}$ | Result of first iteration |
| 6 | - | - | $\begin{aligned} & C 0077322_{16} \\ & (-2.116402) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 }_{16} \\ & (-0.4725) \end{aligned}$ | $\begin{aligned} & 3 F 800000_{16} \\ & (1.0) \end{aligned}$ |  |
| 7 | - | - | $\begin{aligned} & C_{0077322}^{16} \\ & (-2.116402) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 } 16 \\ & (-0.4725) \end{aligned}$ | $\begin{aligned} & 3 F 800000_{16} \\ & (1.0) \end{aligned}$ |  |
| 8 | - | - | $\begin{aligned} & \mathrm{C}_{0} 077322_{16} \\ & (-2.116402) \end{aligned}$ | $\begin{aligned} & \text { BEF1EB85 } 16 \\ & (-0.47 .25) \end{aligned}$ | $\begin{aligned} & C 0077322_{16} \\ & (-2.116402) \end{aligned}$ | -Result of second iteration |

## APPENDIX D:

## Summary of Flag Operation

Tables d 1 , d 2 , and d 3 summarize flag operation for the IEEE mode, the DEC mode, and for the IEEE-TO-DEC and DEC-TOIEEE operations.

TABLE d1. FLAG SUMMARY FOR IEEE MODE

| Operation | Condition(s) | INV | OVF | UNF | INE | ZER | NAN |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Any operation listed in the IEEE Invalid Operations Table | - | H | L | L | L | L | H |
| R PLUS S <br> R MINUS S <br> R TIMES S <br> 2 MINUS S | Input operands are finite, $\mid$ rounded result $\mid \geqslant 2^{128}$ | L | H | L | H | L | L |
| R PLUS S R MINUS S R TIMES S | $0<\mid$ rounded result $\mid<2-126$ | L | L | H | H | H | L |
| R PLUS S R MINUS S R TIMES S 2 MINUS S INT-TO-FP FP-TO-INT | Final result does not equal infinitely precise result | L | - | - | H | - | L |
| RPLUS S R MINUS S R TIMES S 2 MINUS S INT-TO-FP FP-TO-INT | Final result is zero | L | L | - | - | H | L |
| RPLUS S RMINUS S R TIMES S 2 MINUS S FP-TO-INT | Final result is a NAN | - | L | L | L | L | H |

[^1]TABLE d2. FLAG SUMMARY FOR DEC MODE

| Operation | Condition(s) | INV | OVF | UNF | INE | ZER | NAN |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FP-TO-INT | Rounded result > $2^{31-1}$ <br> or rounded result $<-2^{31}$ | H | L | L | L | L | H |
| FP-TO-INT | Input is a DEC reserved operand | H | L | L | L | L | H |
| R PLUS S R Minus S R TIMES S 2 MINUS S | $\mid$ Rounded result $\mid \geqslant 2127$ | L | H | L | H | L | H |
| RPLUS S R MINUS S R TIMES S | $0<\mid$ rounded result $\mid<2^{-128}$ | L | L | H | H | H | L |
| R PLUS S R MINUS S R TIMES S 2 MINUS S INT-TO-FP FP-TO-INT | Final result does not equal infinitely precise result | L | - | - | H | $\stackrel{\square}{*}$ | $\bullet$ |
| R PLUS S R MINUS S R TIMES S 2 MINUS S INT-TO-FP FP-TO-INT | Final result is zero | L | L | - | - | H |  |
| R PLUS S R MINUS S R TIMES S 2 MINUS S FP-TO-INT | Final result is a DEC reserved operand | - | - | L | L | L | H |

Notes: INV = Invalid operation flag $H=H$ HIG
OVF = Overflow flag $\quad . \quad=$ State of flag

UNF = Underflow flag depends on the
INE = Inexact flag input operands
ZER $=$ Zero flag and the operation
NAN $=$ NAN flag performed
$\mathrm{L}=$ LOW

TABLE d3. FLAG SUMMARY FOR IEEE-TO-DEC AND DEC-TO-IEEE CONVERSIONS

| Operation | Condition(s) | INV | OVF | UNF | INE | ZER | NAN |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IEEE-TO-DEC | Input is a NAN | H | L | L | L | L | H |
| IEEE-TO-DEC | $\mid$ Input $\mid \geqslant 2^{127}$ | L | H | L | H | L | H |
| DEC-TO-IEEE | Input is a DEC reserved operand | H | L | L | L | L | H |
| DEC-TO-IEEE | $0<\mid$ rounded result $\mid<2^{-126}$ | L | L | H | H | H | L |
| DEC-TO-IEEE IEEE-TO-DEC | Final result is 0 | L | L | - | - | H | L |

Notes: INV = Invalid operation flag $\quad \mathrm{H}=\mathrm{HIGH}$
OVF = Overflow flag $\quad=$ State of flag
UNF = Underflow flag depends on the
INE $=$ Inexact flag input operands
ZER $=$ Zero flag and the operation
NAN $=$ NAN flag performed
$\mathrm{L}=$ LOW

ABSOLUTE MAXIMUM RATINGS
Storage Temperature . . . . . . . . . . . . . . . . . . . . . . -65 to $+150^{\circ} \mathrm{C}$
Temperature Under Bias - TC $\ldots . . . . . . .-55$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ................................ -0.5 to +7.0 V
DC Voltage Applied to Outputs
for High State . . . . . . . . . . . . . . . . . . . . . . -0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ Max

DC Output Current, into Outputs . . . . . . . . . . . . . . . . . . . . . 30mA
DC Input Current ............................ 30 to +5.0 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 device reliability.

OPERATING RANGES
Commercial (C) Devices

Supply Voltage ............................ +4.75 to +5.25 V
Military (M) Devices
Temperature ( $\mathrm{T}_{\mathrm{C}}$ ) ........................... -55 to $+125^{\circ} \mathrm{C}$
Supply Voltage ............................... +4.5 to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed

DC CHARACTERSITICS OVER OPERATING RANGE unless otherwise specified


Notes: 1. For conditions shown as Min or Max, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical values are for $\mathrm{V}_{\mathrm{CC}}=+25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Measured with $\overline{O E}$ LOW, and with all output bits ( $F_{0}-F_{31}$ and flag outputs) LOW.

Am29325
SWITCHING CHARACTERISTICS OVER OPERATING RANGE

| Parameter | Description |  | Test Conditions | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ | $V_{C C}=+5 \mathrm{~V} \pm 5 \%$ |  | $V_{\text {CC }}=+5 \mathrm{~V} \pm 10 \%$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Typ | Min | Max | Min | Max |  |
| $t_{\text {ASC }}$ | Clocked Add, Subtract Time (R PLUS S, R MINUS S, 2 MINUS S) |  |  |  |  |  |  |  | ns |  |
| ${ }^{\text {m }}$ MC | Clocked Multiply Time (R TIMES S) |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t CC }}$ | Clocked Conversion Time (INT-TO-FP, FP-TO-INT, IEEE-TO-DEC, DEC-TO-IEEE) |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t }}$ SUC | Unclocked Add, Subtract Time (R, S to F, Flags) for R PLUS S, R MINUS S, and 2 MINUS S Instructions |  | $\begin{aligned} & \mathrm{FT}_{0}=\mathrm{HIGH} \\ & \mathrm{FT}_{1}=\mathrm{HIGH} \end{aligned}$ |  |  |  |  | ns |  |
| ${ }^{\text {t MUC }}$ | Unclocked Multiply Time (R, S to F, Flags) for R TIMES S Instruction |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t CuC }}$ | Unclocked Conversion Time (R, S to F, Flags) for INT-TO-FP, FP-TO-INT, IEEE-TO-DEC and DEC-TO-IEEE Instructions |  |  |  |  |  | - | ns |  |
| $t_{\text {PWH }}$ | Clock Pulse Width HIGH |  |  |  |  |  |  | ns |  |
| $t_{\text {PWL }}$ | Clock Pulse Width LOW |  |  |  |  |  |  | ns |  |
| tPDOF1 | Clock to $F_{0}-F_{31}$ and Flag Outputs |  | $\begin{aligned} & \mathrm{FT}_{0}=\mathrm{LOW} \\ & \mathrm{FT}_{1}=\mathrm{HIGH} \end{aligned}$ |  |  |  |  | ns |  |
| tPDOF2 |  |  | $\mathrm{FT}_{1}=$ LOW |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{PLL}}$ | $\overline{\mathrm{OE}}$ Enable Time | Z to LOW |  |  |  |  |  | ns |  |
| $t_{\text {PZ }}$ |  | $Z$ to HIGH |  |  |  |  |  | ns |  |
| $t_{\text {PLZ }}$ | $\overline{\mathrm{OE}}$ Disable Time | LOW to Z |  |  |  |  |  | ns |  |
| tPHZ |  | HIGH to Z |  |  |  |  |  | ns |  |
| ${ }^{\text {tPZL16 }}$ | Clock $\uparrow$ to $\mathrm{F}_{0}-\mathrm{F}_{15}$ Enable, 16-Bit I/O Niode | Z to LOW | $\begin{aligned} & \mathrm{S} 16 / \overline{32}=\mathrm{HIGH} \\ & \text { ONEBUS }=\text { LOW } \end{aligned}$ |  |  |  |  | ns |  |
| $t_{\text {PRH16 }}$ |  | $Z$ to HIGH |  |  |  |  |  | ns |  |
| $t_{\text {PLZ16 }}$ | Clock $\downarrow$ to $F_{0}-F_{15}$ Disable, 16-Bit I/O Mode | LOW to $Z$ | $\begin{aligned} & \mathrm{S} 16 / \overline{32}=\mathrm{HIGH} \\ & \text { ONEBUS }=\text { LOW } \end{aligned}$ |  |  |  |  | ns |  |
| ${ }^{\text {t PHZ } 16}$ |  | HIGH to $Z$ |  |  |  |  |  | ns |  |
| ${ }^{\text {t P Z } 16}$ | Clock $\downarrow$ to $F_{16}-F_{31}$ Enable, 16-Bit I/O Mode | $Z$ to LOW |  |  |  |  |  | ns |  |
| ${ }^{\text {tPZH16 }}$ |  | $Z$ to HIGH |  |  |  |  |  | ns |  |
| ${ }^{\text {tpLZ }}$ 16 6 | Clock $\uparrow$ to $\mathrm{F}_{16}-\mathrm{F}_{31}$ Disable, 16-Bit I/O Mode | LOW to Z |  |  |  |  |  | ns |  |
| ${ }^{\text {tPHZ16 }}$ |  | HIGH to Z |  |  |  |  |  | ns |  |
| ${ }^{\text {t }}$ SCE | Register Clock Enable Setup Time |  | $\begin{aligned} & \mathrm{FT}_{0}=\mathrm{LOW} \\ & \mathrm{FT}_{1}=\mathrm{LOW} \end{aligned}$ |  |  |  |  | ns |  |
| $t_{\text {HCE }}$ | Register Clock Enable Hold Time |  | $\begin{aligned} & \mathrm{FT}_{0}=\mathrm{LOW} \\ & \mathrm{FT}_{1}=\mathrm{LOW} \end{aligned}$ |  |  |  |  | ns |  |
| ${ }^{\text {t SD1 }}$ | $R_{0}-R_{31}, S_{0}-S_{31}$ Setup Time (Note 1) |  | $\mathrm{FT}_{0}=$ LOW |  |  |  |  | ns |  |
| $t_{\text {HD1 }}$ | $R_{0}-R_{31}, S_{0}-S_{31}$ Hold Time (Note 1) |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t }}$ SD2 | $R_{0}-R_{31}, S_{0}-S_{31}$ Setup Time (Note 1) |  | $\begin{aligned} & \mathrm{FT}_{0}=\mathrm{HIGH} \\ & \mathrm{FT}_{1}=\mathrm{LOW} \end{aligned}$ |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HD} 2}$ | $\mathrm{R}_{0}-\mathrm{R}_{31}, \mathrm{~S}_{0}-\mathrm{S}_{31}$ Hold Time (Note 1) |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t }}{ }^{\text {102 }}$ | $\mathrm{I}_{0}-\mathrm{I}_{2}$ Instruction Select Setup Time |  | FT for Destination Register = LOW |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HIO} 2}$ | $\mathrm{I}_{0}-\mathrm{I}_{2}$ Instruction Select Hold Time |  |  |  |  |  |  | ns |  |
| ${ }^{\text {PPDIO2 }}$ | $\mathrm{I}_{0}-\mathrm{I}_{2}$ Instruction Select to $\mathrm{F}_{0}-\mathrm{F}_{31}$, Flags |  | $F T_{1}=\mathrm{HIGH}$ |  |  |  |  | ns |  |
| ${ }^{\text {t }}$ S 3 | $\mathrm{I}_{3}$ Port S Input Select Setup Time |  | $\mathrm{FT}_{1}=\mathrm{LOW}$ |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HI} 3}$ | $I_{3}$ Port S Input Select Hold Time |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t }}$ S $4{ }^{\text {a }}$ | $\mathrm{I}_{4}$ Register R Input Select Setup Time (Note 1) |  | $\mathrm{FT}_{0}=\mathrm{LOW}$ |  |  |  |  | ns |  |
| $\mathrm{t}_{\mathrm{HI} 4}$ | $1_{4}$ Register R Input Select Hold Time (Note 1) |  |  |  |  |  |  | ns |  |
| ${ }^{\text {t SRM }}$ | Round Mode Select Setup Time |  | FT for Destination Register $=$ LOW |  |  |  |  | ns |  |
| $t_{\text {HRM }}$ | Round Mode Select Hold Time |  |  |  |  |  |  | ns |  |
| tPRF | Round Mode Select to $\mathrm{F}_{0}-\mathrm{F}_{31}$, Flags |  | $\mathrm{FT}_{1}=\mathrm{HIGH}$ |  |  |  |  | ns |  |

Notes: 1. See timing diagram for desired mode of operation to determine clock edge to which these setup and hold times apply.

[^2]
\[

CLOCKED OPERATION: $$
\begin{aligned}
\mathrm{FT}_{0} & =\text { HIGH } \\
\mathrm{FT}_{1} & =\text { LOW }
\end{aligned}
$$
\]




## 16-BIT, TWO-INPUT-BUS MODE



Note 1. $I_{4}$ has special setup and hold time requirements in this mode. All other control signals have timing requirements as shown in the diagram "Clocked operation, $\mathrm{FT}_{0}=$ LOW, $\mathrm{FT}_{1}=$ LOW."

OUTPUT ENABLE/DISABLE TIMING


## Am29325 PINOUT

SORTED BY PIN

| Line \# | Pkg Pin | Function |
| :---: | :---: | :---: |
| 1 | A1 | Inexact |
| 2 | A2 | Invalid |
| 3 | A3 | $\mathrm{F}_{29}$ |
| 4 | A4 | $\mathrm{F}_{30}$ |
| 5 | A5 | $\mathrm{F}_{23}$ |
| 6 | A6 | $\mathrm{F}_{26}$ |
| 7 | A7 | $\mathrm{F}_{21}$ |
| 8 | A8 | $\mathrm{F}_{22}$ |
| 9 | A9 | $\mathrm{F}_{17}$ |
| 10 | A10 | $\mathrm{F}_{18}$ |
| 11 | A11 | $\mathrm{F}_{13}$ |
| 12 | A12 | $\mathrm{F}_{12}$ |
| 13 | A13 | $\mathrm{F}_{7}$ |
| 14 | A14 | $\mathrm{F}_{8}$ |
| 15 | A15 | $\mathrm{F}_{5}$ |
| 16 | B1 |  |
| 17 | B2 | NAN |
| 18 | B3 | Zero |
| 19 | B4 | $\mathrm{F}_{31}$ |
| 20 | B5 | Overflow |
| 21 | B6 | $\mathrm{F}_{27}$ |
| 22 | B7 | $\mathrm{F}_{24}$ |
| 23 | B8 | $\mathrm{F}_{19}$ |
| 24 | B9 | $\mathrm{F}_{20}$ |
| 25 | B10 | $\mathrm{F}_{15}$ |
| 26 | B11 | $\mathrm{F}_{14}$ |
| 27 | B12 | $\mathrm{F}_{9}$ |
| 28 | B13 | $\mathrm{F}_{6}$ |
| 29 | B14 | $\mathrm{F}_{3}$ |
| 30 | B15 | $\mathrm{F}_{4}$ |
| 31 | C1 | $l_{1}$ |
| 32 | C2 |  |
| 33 | C3 | GND, TTL |
| 34 | C4 | GND, TTL |
| 35 | C5 | $\mathrm{FL}_{1}$ Underflow |
| 36 | C6 | $\mathrm{F}_{28}$ |
| 37 | C7 |  |
| 38 | C8 | $\mathrm{V}_{\mathrm{CC}}$, TTL |
| 39 | C9 | $\mathrm{V}_{\mathrm{CC}}$, TTL |
| 40 | C10 |  |
| 41 | C11 | $\mathrm{F}_{11}$ |
| 42 | C12 | $\mathrm{F}_{10}$ |
| 43 | C13 | GND, TTL |
| 44 | C14 | $\mathrm{F}_{2}$ |
| 45 | C15 | $\mathrm{F}_{1}$ |
| 46 | D1 | ENF |
| 47 | D2 | IEEE/ $\overline{\text { DEC }}$ |
| 48 | D3 | ENR |
| 49 | D13 | GND, TTL |
| 50 | D14 | GND, TTL |
| 51 | D15 | GND, TTL |
| 52 | E1 | 14 |
| 53 | E2 | $\mathrm{FT}_{0}$ |
| 54 | E3 | ENS |
| 55 | E13 | GND, TTL |
| 56 | E14 | $\mathrm{F}_{0}$ |
| 57 | E15 | PROJ/ $\overline{\text { AFF }}$ |
| 58 | F1 | ONEBUS |
| 59 | F2 | $\mathrm{FT}_{1}$ |
| 60 | F3 | S16/32 |

SORTED BY FUNCTION

| Function | Pkg Pin |
| :---: | :---: |
| CLK | $J 1$ |
| ENF | D1 |
| ENR | D3 |
| ENS | E3 |
| $\mathrm{F}_{0}$ | E14 |
| $\mathrm{F}_{1}$ | C15 |
| $\mathrm{F}_{2}$ | C14 |
| $\mathrm{F}_{3}$ | B14 |
| $\mathrm{F}_{4}$ | B15 |
| $\mathrm{F}_{5}$ | A15 |
| $\mathrm{F}_{6}$ | B13 |
| $\mathrm{F}_{7}$ | A13 |
| $\mathrm{F}_{8}$ | A14 |
| $\mathrm{F}_{9}$ | B12 |
| $\mathrm{F}_{10}$ | C12 |
| $\mathrm{F}_{11}$ | C11 |
| $\mathrm{F}_{12}$ | A12 |
| $\mathrm{F}_{13}$ | A11 |
| $\mathrm{F}_{14}$ | B11 |
| $\mathrm{F}_{15}$ | B10 |
| $\mathrm{F}_{16}$ | C10 |
| $\mathrm{F}_{17}$ | A9 |
| $\mathrm{F}_{18}$ | A10 |
| $\mathrm{F}_{19}$ | B8 |
| $\mathrm{F}_{20}$ | B9 |
| $\mathrm{F}_{21}$ | A7 |
| $\mathrm{F}_{22}$ | A8 |
| $\mathrm{F}_{23}$ | A5 |
| $\mathrm{F}_{24}$ | B7 |
| $\mathrm{F}_{25}$ | C7 |
| $\mathrm{F}_{26}$ | A6 |
| $\mathrm{F}_{27}$ | B6 |
| $\mathrm{F}_{28}$ | C6 |
| $\mathrm{F}_{29}$ | A3 |
| $\mathrm{F}_{30}$ | A4 |
| F31 | B4 |
| $\mathrm{FT}_{0}$ | E2 |
| $\mathrm{FT}_{1}$ | F2 |
| GND, ECL | N3 |
| GND, ECL | H14 |
| GND, ECL | G13 |
| GND, ECL | M3 |
| GND, ECL | H13 |
| GND, ECL | J13 |
| GND, TTL | D15 |
| GND, TTL | D14 |
| GND, TTL | E13 |
| GND, TTL | F13 |
| GND, TTL | C4 |
| GND, TTL | C3 |
| GND, TTL | D13 |
| GND, TTL | C13 |
| 10 | C2 |
| $I_{1}$ | C1 |
| $\mathrm{l}_{2}$ | B1 |
| $l_{3}$ | P9 |
| 14 | E1 |
| IEEE/DEC | D2 |
| Inexact | A1 |
| Invalid | A2 |



Am29325 PINOUT (Cont)

SORTED BY PIN

| Line \# | Pkg <br> Pin | Function |
| :--- | :--- | :--- |
| 121 | P7 | $\mathrm{R}_{5}$ |
| 122 | P 8 | $\mathrm{R}_{4}$ |
| 123 | P 9 | $\mathrm{I}_{3}$ |
| 124 | P 10 | $\mathrm{~S}_{31}$ |
| 125 | P 11 | $\mathrm{~S}_{26}$ |
| 126 | P 12 | $\mathrm{~S}_{25}$ |
| 127 | P 13 | $\mathrm{~S}_{22}$ |
| 128 | P 14 | $\mathrm{~S}_{21}$ |
| 129 | P 15 | $\mathrm{~S}_{16}$ |
| 130 | R 1 | $\mathrm{R}_{20}$ |
| 131 | R 2 | $\mathrm{R}_{17}$ |
| 132 | R 3 | $\mathrm{R}_{18}$ |
| 133 | R 4 | $\mathrm{R}_{13}$ |
| 134 | R 5 | $\mathrm{R}_{12}$ |
| 135 | R 6 | $\mathrm{R}_{7}$ |
| 136 | R 7 | $\mathrm{R}_{6}$ |
| 137 | R 8 | $\mathrm{R}_{1}$ |
| 138 | $\mathrm{R9}$ | $\mathrm{R}_{2}$ |
| 139 | R 10 | $\mathrm{~S}_{30}$ |
| 140 | R 11 | $\mathrm{~S}_{29}$ |
| 141 | R 12 | $\mathrm{~S}_{24}$ |
| 142 | R 13 | $\mathrm{~S}_{23}$ |
| 143 | R 14 | $\mathrm{~S}_{20}$ |
| 144 | R 15 | $\mathrm{~S}_{19}$ |

SORTED BY FUNCTION

| Function | Pkg Pin |
| :---: | :---: |
| $\mathrm{S}_{20}$ | R14 |
| $\mathrm{S}_{21}$ | P14 |
| $\mathrm{S}_{22}$ | P13 |
| $\mathrm{S}_{23}$ | R13 |
| $\mathrm{S}_{24}$ | R12 |
| $\mathrm{S}_{25}$ | P12 |
| $\mathrm{S}_{26}$ | P11 |
| $\mathrm{S}_{27}$ | N11 |
| $\mathrm{S}_{28}$ | N10 |
| $\mathrm{S}_{29}$ | R11 |
| $\mathrm{S}_{30}$ | R10 |
| $\mathrm{S}_{31}$ | P10 |
| Underflow | C5 |
| $V_{C C}, \mathrm{ECL}$ | J3 |
| $\mathrm{V}_{\mathrm{CC}}$, ECL | G2 |
| $V_{C C}, \mathrm{ECL}$ | G3 |
| $\mathrm{V}_{\mathrm{CC}}$, ECL | H2 |
| $\mathrm{V}_{\mathrm{CC}}$, ECL | N13 |
| $V_{C C}$, ECL | N12 |
| $V_{C C}$, ECL | H3 |
| $\mathrm{V}_{\mathrm{CC}}$, ECL | H1 |
| $V_{\text {cc }}$, TTL | C8 |
| $\mathrm{V}_{\mathrm{CC}}$, TTL | C9 |
| Zero | B3 |

## POWER SUPPLY WIRING CONSIDERATIONS



05621A-34

Notes: 1. All power supply pins must be connected.
2. ECL GND and TTL GND should not be connected directly into the main system ground plane. Using signal plane traces as short and wide as possible, ECL GND pins should be connected together, as should TTL GND pins, but without interconnection. These separate ground buses should be connected together and to the system ground plane at a decoupling capacitor close to the package. ECL $V_{C C}$ and TTL $V_{C C}$ should be treated similarly. See diagram above.


THERMAL CHARACTERISTICS

PHYSICAL DIMENSIONS

*Subject to change.

The International Standard of Quality guarantees the AQL on all electrical parameters, AC and DC . over the entire operating range.

## Am29331

16-Bit Microprogram Sequencer

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- 16-Bits Address Up to 64K Words

Like the other members of the Am29300 family, the Am29331 supports 80-90ns microcycle for the 32bit high-performance system.

- Real Time Interrupt Support Micro-TRAP and interrupts are handled transparently at any microinstruction boundary.
- Built-In Conditional Test Logic

Generates inequality evaluation branch conditions from four ALU status bits, eight external test inputs and a polarity control input.

- Break-Point Logic

Built-in address comparator allows break-points in the microcode for debugging and statistics collection.

- Master/Slave Error Checking

Two sequencers can operate in parallel as a master and a slave. The slave generates a fault flag for unequal results.

- 33-Level Stack

Provides support for interrupts, loops and subroutine nesting. It can be accessed through the D-bus to support diagnostics.

## GENERAL DESCRIPTION

The Am29331 is a 16 -bit wide high-speed single chip sequencer designed to control the execution sequence of microinstructions stored in the microprogram memory. The instruction set is designed to resemble high level language constructs, thereby bringing high level language programming to the micro level.

The Am29331 is interruptible at any microinstruction boundary to support real time interrupts. Interrupts are handled transparently to the microprogrammer as an unexpected procedure call. Traps are also handled transparently at any microinstruction boundary. This feature allows reexecution of the prior microinstruction. Two separate buses are provided to bring a branch address directly into the chip from two sources to avoid slow turn-on and turn-off times
for different sources connected to the data input bus. Four sets of multiway inputs are also provided to avoid slow turnon and turn-off times for different branch address sources. This feature allows implementation of table look-up or use of external conditions as part of a branch address. The thirty-three-deep stack provides the ability to support interrupts, loops and subroutine nesting. The stack can be read through the D-bus to support diagnostics or to implement multitasking at the micro-architecture level. The master/ slave mode provides a complete function check for the device.
The Am29331 is designed with the IMOX ${ }^{\text {TM }}$ process which allows internal ECL circuits with TTL compatible I/O. It is housed in a 120 pin-grid-array package.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29323 | $32 \times 32$ Parallel Multiplier |
| Am29325 | 32 -Bit Floating Point Processor |
| Am29332 | 32 -Bit ALU |
| Am29334 | $64 \times 18$ Four-Port, Dual-Access Register File |



ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Single Chip, 32-Bit ALU

Supports 80-90ns microcycle for the 32-bit data path. It is a combinatorial ALU with equal cycle time for all instructions

- Flow Through Architecture

A combinatorial ALU with two input data ports and one output data port allows implementation of parallel or pipelined architectures

- 64-Bit In, 32-Bit Out Funnel Shifter

This unique functional block allows n-bit shift-up, shift-down, 32-bit barrel shift or 32-bit field extract

- Supports All Data Types

It supports one-, two-, three- and four-byte data for all operations and variable-length fields for logical operations

- Multiply and Divide Support

Built-in hardware to support two-bit at a time modified Booth's algorithm and one-bit at a time division algorithm

- Extensive Error Checking

Parity check and generate provides data transmission check. Master/slave mode provides complete functional checking

## GENERAL DESCRIPTION

The Am29332 is a 32-bit wide non-cascadable ALU with integration of functions that normally don't cascade such as barrel shifters, priority encoders and mask generators. Two input data ports and one output data port provide flow through architecture and allow the designer to implement his/her architecture with any degree of pipelining and no built-in penalties for branching. Also, the simplicity of a three-bus ALU allows easy implementation of parallel or reconfigurable architectures. The register file is off-chip to allow unlimited expansion and regular addressability.

The Am29332 supports one-, two-, three- and four-byte data for arithmetic and logic operations. It also supports
multiprecision arithmetic and shift operations. For logical operations, it can support variable-length fields up to 32 bits. When fewer than four bytes are selected, unselected bits are passed to the destination without modification. The device also supports two-bit at a time modified Booth's algorithm for high-speed multiplication and one-bit at a time division. Both signed and unsigned integers for all byte aligned data types mentioned above are supported.

The Am29332 is designed to support 80-90 ns microcycle time. The device is packaged in a 168 pin-grid-array package.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29323 | $32 \times 32$ Parallel Multiplier |
| Am29325 | 32 -Bit Floating Point Processor |
| Am29331 | 16 -Bit Microprogram Sequencer |
| Am29334 | $64 \times 18$ Four-Port, Dual-Access Register File |



## Am29334

Four-Port, Dual-Access Register File

ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Fast

With an access time of 20ns, the Am29334 supports 80-90ns microcycle when used with the Am29300 family for 32-bit systems.

- $64 \times 18$ Bits Wide Register File

The Am29334 is a high-performance, high-speed, dual-access RAM with two READ ports and two WRITE ports.

- Cascadable

The Am29334 is cascadable to support either wider word width, deeper register files, or both.

- Simplified Timing Control

Control for write enable timing and for on-chip read/write multiplexer are derived from a singlephase clock input.

- Byte Parity Storage Width of 18 bits facilitates byte parity storage for each port and provides consistency with the Am29332 32-bit ALU.
- Byte Write Capability Byte-write enable pins allow byte or full word writes.


## GENERAL DESCRIPTION

The Am29334 is a 64-word deep and 18-bit wide dualaccess register file designed to support other members of the Am29300 family by providing high-speed storage. It has two write and two read ports for data and four 6-bit address ports. Two address ports are associated with each pair of read and write data ports; one to read data and the other to write. The device is capable of performing two reads and two writes in one cycle. The 18-bit wide register file allows
storage of byte parity to support parity check and generate in the Am29332 32-bit ALU. Independent control for each read and write data port allows the Am29334 to be used as a high-speed shared memory or as a mailbox for a multiprocessor system. The device is designed to support an access time of 20 ns . It is housed in a 120 pin-grid-array package.


RELATED PRODUCTS

| Part No. | Description | Part No. | Description |
| :--- | :--- | :--- | :--- |
| Am29323 | $32 \times 32$ Parallel Multiplier | Am29331 | 16-Bit Microprogram Sequencer <br> Am29325 |

## Am29360

32-Bit Error Detection and Correction Unit

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Boosts memory reliability
- Corrects all single bit errors
- Detects all double and some triple bit errors
- Reliability of dynamic RAM memory system is increased
- Very high speed
- Perfect for microprocessor, minicomputer and mainframe systems
- All necessary features are built-in to the Am29360 including memory testing, Reconfiguration, Diagnostics, and Data In/Out, Data Bits Out and Check Bits Out latches
- Handles data word widths from 8- to 32-bits
- Byte writes on all word widths from 8- to 32 -bits
- Diagnostics built-in
- The processor may exercise the memory or Am29360 under software control to check for proper operations
- Built-in Memory Timing Controller (MTC)
- Supports byte writes
- Delay line controlled timings
- Arbitrates between refresh and memory request
- Refresh internal timer for generating refresh requests independent of processor

The Am29360 Error Detection and Correction Unit (EDC) contains the logic necessary to generate check bits on a 32-bit data field according to a modified hamming code, and to correct a data word when check bits are supplied. Operating on data read from memory, the Am29360 will correct any single-bit error and will detect all double and some triple bit errors. For 32-bit words, 7 check bits are used. In all configurations, the device makes the error syndrome bits available on output signals $S / C_{0}-S_{7}$ for data logging.

The Am29360 also features diagnostic modes, in which diagnostic data can be forced into portions of the chip to simplify device testing and to execute system diagnostic functions.

The built-in MTC (Memory Timing Controller) generates all timing signals for the on-board error detection and correction function. The Am29360 also has a general purpose CPU interface and a Power-up sequence which includes eight RAS-only Wake-Up cycles, a two part Test (Read/ Write, Increment) and memory Initialize.

## BLOCK DIAGRAM



BD003160

## Am29368

## 1M-Bit Dynamic Memory Controller (DMC)

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Provides control for $16 \mathrm{~K}, 64 \mathrm{~K}, 256 \mathrm{~K}$, and 1 M -bit dynamic RAMs
- Outputs directly drive up to 88 DRAMs, with a guaranteed worst-case undershoot
- Highest-order two address bits select one of four banks of RAMs
- Separate output enable for multi-channel access to memory
- Supports scrubbing operations and nibble-mode access
- $\mathrm{IMOX}^{\mathrm{TM}}$ processing


## GENERAL DESCRIPTION

The Am29368 Dynamic Memory Controller (DMC) is intended to be used with today's high-performance memory systems. The DMC will act as the address controller between any processor and dynamic memory array, using its two 10-bit address latches to hold the Row and Column addresses for any DRAM up to 1 M -bit. These latches, and the two Row/Column refresh address counters, feed into a 10-bit, 4-input MUX for output to the dynamic RAM address lines. A 2-bit bank select latch for the two high-order address bits is provided to select one each of the four $\overline{\operatorname{RAS}_{N}}$ and $\overline{C A S_{N}}$ outputs.

The Am29368 has two basic modes of operation, read/ write and refresh. In refresh mode, the two counters cycle through the refresh addresses. If memory scrubbing is not being implemented, only the Row Counter is used, generating up to 1024 addresses to refresh a 1024-cycle-refresh 1 M -bit DRAM. When memory scrubbing is being performed, both the Row and Column counters are used to perform read-modify-write cycles. In this mode all $\overline{\text { AASN}_{N}}$ outputs will be active while only one $\overline{\mathrm{CAS}}_{\mathrm{N}}$ is active at a time. The Am29368 is available in a 52 -pin dual in-line package.



## Am2960-2970 <br> Dynamic Memory Support Index

Am2960-70 Memory Suppport Family System Overview ..... 4-1
Am2960/Am2960A Cascadable 16-Bit Error ..... 4-5
Am2961/Am2962 4-Bit Error Correction Multiple Bus Buffers ..... 4-44Am2964B/Am2964C
Dynamic Memory Controller ..... 4-52
Am2965/Am2966 Octal Dynamic Memory Drivers with Three-State Outputs ..... 4-66
Am2968 Dynamic Memory Controller (DMC) ..... 4-72
Dynamic Memory Timing Controller ..... 4-89
Dynamic Memory Timing Controller ..... 4-95
Am2971 Programmable Event Generator (PEG) ..... 4-99
Am8163/Am8167 Dynamic Memory Timing, Refresh and EDC Controllers ..... 4-100

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry.
For specific testing details contact your local AMD sales representative.
The company assumes no responsibility for the use of any circuits described herein.

## INTRODUCTION

Memory system designs are increasingly shaped by three requirements:

1. Higher system performance
2. More memory capacity in less space
3. Increased reliability

The Am2960-70 Memory Support Family is a family of LSI building blocks which excels in satisfying these three requirements and provides a complete systems solution for designs using 64 K or 256 K DRAMs. The family members include:

```
Am2960 Error Detection and Correction Unit
Am2961/62 EDC Bus Buffers
Am2964B Dynamic Memory Controller (64K DRAM Version)
Am2965/66 Dynamic RAM Drivers
Am2968 Dynamic Memory Controller (256K DRAM Version)
Am2969 Timing Controller
Am2970 Timing Controller
Am8163/67 System and Timing Controller for MOS MPUs
```

These are general purpose products. They will support any supplier's DRAMs and will work with any processor type: 8086, 80186, 80286, 68000, Z8000, and Am2900 processors. They may also be used to support word widths of any size from 8 bits to 64 bits.

Figure 1 shows the system interconnection for a typical memory system for 256K DRAMs, and Figure 2 shows the system interconnection for a typical memory system using 64K DRAMs. In both cases, the memory support subsystem interfaces to the System Data Bus, Address Bus, and control signals. Also, in both cases all, or almost all, of the memory support functions are handled by AMD LSI devices. This simplifies the design of the memory system and, more importantly, allows the board space available for DRAMs to be maximized because the LSI solution for control and error correction is very compact.

## ERROR DETECTION AND CORRECTION

It is important that memory systems function reliably. The number of bytes of storage is increasing rapidly in memory systems at the same time that the density of the MOS DRAMs is growing. With 64 K and 256 K DRAMs, alpha particle sensitivity is much greater than that of smaller DRAMs because of the reduced size of the memory cells and the smaller stored charge of the cell. A Technical Report follows the Am2960 data sheet in this section and is entitled "Am2960 Boosts Memory Reliability." This technical report gives some statistics on soft error rates for DRAMs. It also demonstrates the dramatic increase in memory reliability gained from the use of Hamming Code Error Detection and Correction schemes, such as those used by the Am2960 EDC (Error Detection and Correction) unit.

Data interface between the dynamic memories, the Am2960 EDC chip, and the system data bus is accom-
plished by means of the Am2961/62 bus buffers. Figure 3 depicts the architecture of these devices along with a simplified block diagram of the Am2960. The Am2961 is inverting between the system data bus and the EDC bus while the Am2962 is noninverting. As shown in Figure 3, the Am2961 and Am2962 contain two internal latches, a multiplexer, and a RAM driver output buffer.
These devices feature 4-bit-wide data paths to and from the RAM, the EDC, and the system data bus. The bus-input (BI) latch is used predominantly in byte WRITE operations, so that an incoming byte from the system data bus can be stored while the memory is being read, and any necessary correction made in the bytes not being changed. The busoutput (BO) latch is used predominantly for storing the output data if the processor is in the single-step mode. In the single-step mode it is necessary to hold the output data on the system data bus, but the memory must be released for refresh.

The Am2960 Error Detection and Correction Unit contains all the logic necessary to generate check bits on a 16 -bit data field according to a modified Hamming code and to correct the data word when check bits are supplied. Operating on the data read from memory, the Am2960 will correct any single-bit error and will detect all double- and some triple-bit errors. For 16 -bit words, 6 check bits are used. The Am2960 is expandable to operate on 32 -bit words ( 7 check bits) and 64 -bit words ( 8 check bits). In all configurations, the device makes the error syndrome bits available on separate outputs for data logging.
The Am2960 also features two diagnostic modes in which diagnostic data can be forced into portions of the device to simplify device testing and to execute system diagnostic functions.
The 16 -bit Diagnostic Latch is loadable from the bidirectional data lines under control of the Diagnostic Latch Enable, LE DIAG. It contains check bit information in one byte and control information in the other, and is used for driving the device when in the Internal Control mode, or for supplying check bits when in one of the Diagnostic modes.

The control logic determines the specific operating mode. Normally the control logic is driven by external control inputs; however, in the Internal Control mode, the control signals are instead read from the Diagnostic Latch.

The Am2960 is a very fast EDC device, but even faster versions will soon be available. A speed selected version, the Am2960-1, is described in the Am2960 data sheet, and an IMOX ${ }^{\text {TM }}$ version, the Am2960A, will be available by late 1984. All speed-improved versions have identical functions and are electrically plug-compatible with the current Am2960.

## MEMORY SYSTEM CONTROL AND TIMING

Two Dynamic Memory Controllers are available for generating address, $\overline{\mathrm{RAS}}$, and $\overline{\mathrm{CAS}}$ signals for memory banks. The Am2964B is designed to work with 64K DRAMs of which each device can handle up to four banks for a total control
capacity of 256 K words. The new Am2968 is designed to work with 256 K DRAMs and can also handle up to four banks for a total control capacity of 1 Megaword (the words can be as many bits wide as desired). Also, the Am2968 does not require external driver chips as does the Am2964B - the Am2968 has the memory drivers, with all of the undershoot control and
speed features of the Am2965/66, built right into its address, RAS, and CAS outputs.

For generating the timing and control signals required by the Am2964B/68 and the Am2960/61/62, there are several different devices available, optimized for different system requirements. For MOS Microprocessor systems, use the Am8163 or Am8167.

Figure 1. New Generation Am2900 High Performance Memory Subsystem Using 256 K or $\mathbf{6 4 K}$ DRAMs


Figure 2. Am2900 High Performance Memory Subsystem Using 64K DRAMs


Figure 3. EDC Data Path


Figure 4. Am2960 Block Diagram


Both of these devices will interface easily to iAPX86/186, Z8000, or 68000 microprocessors. The Am8163 and Am8167 provide the control signals and timing signals for the memory controllers, the EDC, and the data bus buffers - in addition, the Am8163/67 decode the memory system control signals directly from the MOS Microprocessor, requiring in most cases only a few gates and at most a single PAL ${ }^{\text {TM }}$ for interfacing. In this section are detailed block diagrams of systems showing how to interface the Am2960-70 Family devices to the most popular MOS microprocessors.
For high-performance Am2900-based processors or other high-speed processor designs, use the Am2969 or Am2970 to generate timing and control signals.

Following is a description of the function of the Am2964B/65/ 66 for Dynamic Memory Control for 64K DRAMs. The Am2968 incorporates these features and more into a single IC for use with 256 K DRAMs.

The Am2964B Dynamic Memory Controller is used to provide all address handling, as well as RAS and CAS decoding and control. A block diagram of the Am2964B Dynamic Memory Controller is shown in Figure 5. The device contains 18 input latches for capturing an 18 -bit address for memory control; the two highest order addresses are decoded in the Am2964B to select one of four banks of RAM by selecting one of the four RAS outputs.

The Am2964B is designed to operate with either 16K Dynamic RAMs or 64K Dynamic RAMs. Thus, the designer either uses 14 of the multiplexer address inputs and 7 of the address outputs or all 16 of the multiplexer address inputs and all 8 of the address outputs as needed by the memory. In the case of 16K Dynamic RAMs, 7 address inputs are provided to the RAM during the RAS LOW signal, and then the 8 -bit multiplexer is switched so that 7 upper address bits are provided to the RAM for the CAS LOW part of the cycle. The Am2964B

Dynamic Memory Controller contains an 8 -bit refresh counter that is used to supply the refresh address to the dynamic memory during the refresh cycle. This counter can be used in either the 128 or 256 line refresh mode. A CAS buffer is included in the dynamic memory controller so that the CAS output can be inhibited during refresh.
Normal operation of the Dynamic Memory Controller is to provide the address, close the input address latches and kick off a normal memory cycle. This is accomplished by bringing the RASI input LOW, which will cause one of the RAS outputs to go LOW. After the required RAS hold time, the MSEL input will be used to switch the multiplexer to the other address latch. Then the CASI input will be driven LOW, causing the CASO output to go LOW and execute the CAS part of the memory cycle. The refresh cycle is executed by driving the $\overline{\text { RFSH }}$ input LOW, which causes the multiplexer to connect the refresh counter to its address outputs. Then the $\overline{\text { RASI }}$ input is driven LOW, which causes all four RAS outputs to go LOW. This will simultaneously refresh all four banks of dynamic RAMs controlled by the Am2964B Dynamic Memory Controller. When either the $\overline{\text { FFSH }}$ or RASI input is brought HIGH, the refresh counter is advanced so it will be ready for the next refresh cycle.

As can be seen in Figure 1, Dynamic RAM Drivers can be used in large memory systems to buffer the Address, $\overline{\text { RAS }}, \overline{\mathrm{CAS}}$ and WRITE ENABLE signals to the RAMs. The Am2965 and Am2966 are pin-compatible devices with the Am74S240 and Am74S244. These RAM drivers are specifically designed for driving dynamic RAMs and feature high capacitance drive, guaranteed maximum undershoot of less than -0.5 volts, and high $\mathrm{V}_{\mathrm{OH}}$ of greater than $\mathrm{V}_{\mathrm{CC}}=1.15$ volts. The Am2965 is inverting and the Am2966 is noninverting. The devices feature symmetrical rise and fall times and have guaranteed minimum and maximum $\mathrm{t}_{\mathrm{PD}}$ specifications for both 50 pF and 500 pF loads.

Figure 5. Am2964B Dynamic Memory Controller


## Am2960／Am2960A

16－Bit Error Detection and Correction Unit
ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

－Boosts Memory Reliability
Corrects all single－bit errors．Detects all double and some triple－bit errors．Reliability of dynamic RAM systems is increased more than 60 －fold．
－Very High Speed
Perfect for MOS microprocessor，minicomputer，and main－frame systems．
－Data in to error detect： 32 ns worst case．
－Data in to corrected data out： 65 ns worst case． High performance systems can use the Am2960 EDC in check－only mode to avoid memory system slow－ down．
－Handles Data Words From 8 Bits to 64 Bits The Am2960 EDC cascades： 1 EDC for 8 bits or 16 bits， 2 for 32 bits， 4 for 64 bits．
－Easy Byte Operations
Separate byte enables on the data out latch simpli－ fy the steps and cut the time required for byte writes．
－Diagnostics Built－In
The processor may completely exercise the EDC under software control to check for proper operation of the EDC．

## GENERAL DESCRIPTION

The Am2960 Error Detection and Correction Unit（EDC） contains the logic necessary to generate check bits on a 16 －bit data field according to a modified Hamming Code， and to correct the data word when check bits are supplied． Operating on data read from memory，the Am2960 will correct any single－bit error and will detect all double and some triple－bit errors．For 16 －bit words， 6 check bits are used．The Am2960 is expandable to operate on 32－bit
words（ 7 check bits）and 64 －bit words（ 8 check bits）．In all configurations，the device makes the error syndrome avail－ able on separate outputs for data logging．

The Am2960 also features two diagnostic modes，in which diagnostic data can be forced into portions of the chip to simplify device testing and to execute system diagnostic functions．The product is supplied in a 48 lead hermetic DIP package．


## CONNECTION DIAGRAM <br> Top View

| CORRECT | $1^{\circ}$ |  | 48 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
| data 15 | 2 |  | 47 |  | DUAG MODE 1 |
| DATA 14 | 3 |  | 46 |  | dag mode 0 |
| DATA 13 | 4 |  | 45 |  | CODE 102 |
| OATA 12 | 5 |  | 44 |  | COOE |
| LEIN | 6 |  | 43 |  | CODE ID 0 |
| Ledag | 7 |  | 42 |  | GENEAATE |
| סE BYTE 1 | 8 |  | 41 |  | c8 6 |
| data 11 | 9 |  | 40 |  | C8O |
| data 10 | 10 |  | 39 |  | CB 5 |
| data 9 | 11 |  | 38 |  | CB 4 |
| data ${ }^{\text {d }}$ | 12 | Am2980 | 37 |  | CB 3 |
| GROUNO | 13 | flatpak | 36 |  | $\mathrm{V}_{\mathrm{cc}}$ |
| Data 7 | 14 |  | 35 |  | CB 2 |
| data 6 | 15 |  | 34 |  | CB 1 |
| data 5 | 16 |  | 33 |  | MULT ERAO\% |
| data 4 | 17 |  | 32 |  | EABDR |
| $\overline{O E}$ BYTE 0 | 18 |  | 31 |  | OESC |
| LEOUT | 19 |  | 30 |  | Sc 0 |
| data 3 | 20 |  | 29 |  | SC 5 |
| data 2 | 21 |  | 28 |  | Sc 3 |
| data 1 | 22 |  | 27 |  | Sc 2 |
| data o | 23 |  | 26 |  | SC 4 |
| Sc 1 | 24 |  | 25 |  | Sc 6 |

Note: Pin 1 is marked for orientation
METALLIZATION AND PAD LAYOUT


DIE SIZE: $0.200^{\prime \prime} \times \mathbf{0 . 1 8 3 "}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) )
M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
\(\mathrm{D}-48\)-pin CERDIP (D-48-2)
\[
X \text { - Dice }
\]
Device type
Cascadable 16-Bit Error Detection and Correction Unit
```

| Valid Combinations |  |
| :--- | :--- |
| Am2960 | DC, DCB, DM, |
| Am2960A | DMB |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## EDC Architecture

The EDC Unit is a powerful 16 -bit cascadable slice used for check bit generation, error detection, error correction and diagnostics.

As shown in the block diagram, the device consists of the following:

- Data Input Latch
- Check Bit Input Latch
- Check Bit Generation Logic
- Syndrome Generation Logic
- Error Detection Logic
- Error Correction Logic
- Data Output Latch
- Diagnostic Latch
- Control Logic


## Data Input Latch

16 bits of data are loaded from the bidirectional DATA lines under control of the Latch Enable input, LE $\mathbb{N}$. Depending on the control mode, the input data is either used for check bit generation or error detection/correction.

## Check Bit Input Latch

Seven check bits are loaded under control of LE IN. Check bits are used in the Error Detection and Error Correction modes.

## Check Bit Generation Logic

This block generates the appropriate check bits for the 16 bits of data in the Data Input Latch. The check bits are generated according to a modified Hamming code.

## Syndrome Generation Logic

In both Error Detection and Error Correction modes, this logic block compares the check bits read from memory against a newly generated set of check bits produced for the data read in from memory. If both sets of check bits match, then there are no errors. If there is a mismatch, then one or more of the data or check bits is in error.

The syndrome bits are produced by an exclusive-OR of the two sets of check bits. If the two sets of check bits are identical (meaning there are no errors) the syndrome bits will be all zeroes. If there are errors, the syndrome bits can be


## DETAILED DESCRIPTION

The EDC contains the logic necessary to generate check bits on a 16-bit data field according to a modified Hamming code. Operating on data read from memory, the EDC will correct any single-bit error, and will detect all double and some triple-bit errors. The Am2960 may be configured to operate on 16 -bit data words (with 6 check bits), 32-bit data words (with 7 check bits) and 64 -bit data words (with 8 check bits). In fact the EDC can be configured to work on data words from 8 to 64 bits. In all configurations, the device makes the error syndrome bits available on separate outputs for error data logging.

## Code and Byte Specification

The EDC may be configured in several different ways and operates differently in each configuration. It is necessary to indicate to the device what size data word is involved and which bytes of the data word it is processing. This is done with input lines CODE $\mathrm{ID}_{0-2}$, as shown in Table I. The three modified Hamming codes referred to in Table I are:

- 16/22 - 16 data bits
- 6 check bits
- 22 bits in total.
- 32/39 code - 32 data bits
- 7 check bits
- 39 bits in total.
- 64/72 code - 64 data bits
- 8 check bits
- 72 bits in total.

CODE ID input $001\left(\mathrm{ID}_{2}, I \mathrm{ID}_{1}, I \mathrm{ID}_{0}\right)$ is a special code used to operate the device in Internal Control Mode (described later in this section).

## Control Mode Selection

The device control lines are GENERATE, CORRECT, PASS THRU, DIAG MODE $\mathrm{O}_{0-1}$ and CODE $\mathrm{ID}_{0-2}$. Table III indicates the operating modes selected by various combinations of the control line inputs.

## Diagnostics

Table II shows specifically how DIAG MODE $E_{0-1}$ select between normal operation, initialization, and one of two diagnostic modes.

The Diagnostic Modes allow the user to operate the EDC under software control in order to verify proper functioning of the device.

## Check and Syndrome Bit Labeling

The check bits generated in the EDC are designated as follows:

- 16-bit configuration - CX C0, C1, C2, C4, C8;
- 32-bit configuration - CX, C0, C1, C2, C4, C8, C16;
- 64-bit configuration - CX, C0, C1, C2, C4, C8, C16, C32.

Syndrome bits are similarly labeled SX through S32. There are only 6 syndrome bits in the 16 -bit configuration, 7 for 32 bits, and 8 syndrome bits in the 64 -bit configuration.

## Initialize Mode

The inputs of the Data Output Latch are forced to zeroes. The check bit outputs (SC) are generated to correspond to the allzero data. ERROR and MULT ERROR are forced HIGH in the Initialize Mode.
Initialize Mode is useful after power up when RAM contents are random. The EDC may be placed in initialize mode and its' outputs written in to all memory locations by the processor.

TABLE I. HAMMING CODE AND SLICE IDENTIFICATION.

| CODE <br> $\mathbf{I D}_{\mathbf{2}}$ | CODE <br> $\mathbf{I D}_{\mathbf{1}}$ | CODE <br> $\mathbf{I D}_{\mathbf{0}}$ | Hamming Code and Slice Selected |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Code 16/22 |
| 0 | 0 | 1 | Internal Control Mode |
| 0 | 1 | 0 | Code 32/39, Bytes 0 and 1 |
| 0 | 1 | 1 | Code 32/39, Bytes 2 and 3 |
| 1 | 0 | 0 | Code 64/72, Bytes 0 and 1 |
| 1 | 0 | 1 | Code 64/72, Bytes 2 and 3 |
| 1 | 1 | 0 | Code 64/72, Bytes 4 and 5 |
| 1 | 1 | 1 | Code 64/72, Bytes 6 and 7 |

TABLE II. DIAGNOSTIC MODE CONTROL.

| DIAG <br> MODE $_{\mathbf{1}}$ | DIAG <br> MODE $_{\mathbf{0}}$ |  |
| :---: | :---: | :--- |
| 0 | 0 | Diagnostic Mode Selected |
| 0 | 1 | Non-diagnostic mode. The EDC functions normally in all modes. <br> generated check bits when in the Generate Mode. The EDC functions normally in the Detect or <br> Correct modes. |
| 1 | 0 | Diagnostic Detect/Correct. In the Detect or Correct Mode, the contents of the Diagnostic Latch <br> are substituted for the check bits normally read from the Check Bit Input Latch. The EDC <br> functions normally in the Generate Mode. |
| 1 | 1 | Initialize. The outputs of the Data Input Latch are forced to zeroes (and latched upon removal of <br> the Initialize Mode) and the check bits generated correspond to the all-zero data. |

## HAMMING CODE SELECTION

The Am2960 EDC uses a modified Hamming Code that allows 1．the EDC to be cascaded，2．all double errors to be detected， 3．the gross error conditions of all 0 s or 1 s to be detected．

The error correction code can be selected independent of the processor with the exception of diagnostics software．

Diagnostic software run by a processor to check out the EDC system must know specifically which code is being used．This
is only a problem when the EDC replaces an existing MSI implementation on an existing computer．In this case，the computer＇s software must first determine which of two codes （the old one used by the MSI implementation or the new one used by the EDC）is used by the computer＇s memory system．

This is easily determined by writing a test data word into memory and then examining whether the generated check bits are typical of the old or the new code．From then on the software runs only the diagnostic appropriate for the code used on that particular computer＇s memory system．

## 16－BIT DATA WORD CONFIGURATION

The 16－bit format consists of 16 data bits， 6 check bits and is referred to as 16／22 code（see Figure 5．）
The 16 －bit configuration is shown in Figure 6.

## Generate Mode

In this mode，check bits will be generated that correspond to the contents of the Data Input Latch．The check bits generat－ ed are placed on the outputs $\mathrm{SC}_{0-5}\left(\mathrm{SC}_{6}\right.$ is a logical one，or high）．

Check bits are generated according to a modified Hamming code．Details of the code for check bit generation are contained in Table IV．Each check bit is generated as either an XOR or XNOR of eight of the 16 data bits as indicated in the table．The XOR function results in an even parity check bit，the XNOR is an odd parity check bit．

Figure 1 shows the data flow in the Generate Mode．

## Detect Mode

In this mode the device examines the contents of the Data Input Latch against the Check Bit Input Latch，and will detect all single－bit errors，all double－bit errors and some triple－bit errors．If one or more errors are detected，ERROR goes LOW． If two or more errors are detected，MULT ERROR goes LOW． Both error indicators are HIGH if there are no errors．

Also available on device outputs $\mathrm{SC}_{0-5}$ are the syndrome bits generated by the error detection step．The syndrome bits may be decoded to determine if a bit error was detected and，for single－bit errors，which of the data or check bits is in error． Table $V$ gives the chart for decoding the syndrome bits generated by the 16－bit configuration（as an example，if the syndrome bits SX／S0／S1／S2／S4／S8 were 101001，this would be decoded to indicate that there is a single－bit error at data bit 9）．If no error is detected，the syndrome bits will all be zeroes．

In Detect Mode，the contents of the Data Input Latch are driven directly to the inputs of the Data Output Latch without correction．

## Correct Mode

In this mode，the EDC functions the same as in Detect Mode except that the correction network is allowed to correct （complement）any single－bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch．（See Figure 2．）If multiple errors are detected，the output of the correction network is unspecified．If the single－bit error is a check bit，there is no automatic correction．If check bit correction is desired，this can be done by placing the device in Generate Mode to produce a correct check bit sequence for the data in the Data Input Latch．

## Pass Thru Mode

In this mode，the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch，and the contents of the Check Bit Input Latch are placed on outputs $\mathrm{SC}_{0-5}$ ．ERROR and MULT ERROR are forced HIGH in this mode．

## Diagnostic Latch

The Diagnostic Latch serves both for diagnostic uses and internal control uses．It is loaded from the DATA lines under the control of LE DIAG．Table VI shows the loading definitions for the DATA lines．

## Diagnostic Generate Diagnostic Detect Diagnostic Correct

These are special diagnostic modes selected by DIAG MODE $_{0-1}$ where either normal check bit inputs or outputs are substituted for by check bits loaded into the Diagnostic Latch
(see Table III for details). Figures 3 and 4 illustrate the flow of data during the two diagnostic modes.

## Internal Control Mode

This mode is selected by CODE $I D_{0-2}$ input $001\left(\mathrm{ID}_{2}, I \mathrm{ID}_{1}, I \mathrm{ID}_{0}\right)$.


Figure 1. Check Bit Generation


Figure 2. Error Detection and Correction


Figure 3. Diagnostic Check Bit Generation


Figure 4. Diagnostic Detect and Correct


DF000220

Uses Modified Hamming Code 16/22

- 16 data bits
- 6 check bits
-22 bits in total


SYNDROME/CHECK BIT OUTPUTS FOR 16-BIT CONFIGURATION

DF000210
Figure 6. 16-Bit Configuration

Figure 5. 16-Bit Data Format

## SYNDROME DECODE <br> TO BIT-IN-ERROR <br> 8-BIT MODE

| Syndrome <br> Bits |  | S4 | 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S0 | S1 |  | 0 | 0 | 1 | 1 |
| 0 | 0 |  | $*$ | C 4 | C 2 | 5 |
| 0 | 1 |  | C 1 | 3 | TM | 7 |
| 1 | 0 | C 0 | 2 | 1 | 6 |  |
| 1 | 1 | TM | 4 | 0 | TM |  |

*     - no errors detected

TM - two or more errors

TABLE IV．16－BIT MODIFIED HAMMING CODE－CHECK BIT ENCODE CHART

| Generated Check Bits | Parity | Participating Data Bits |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| CX | Even（XOR） |  |  | X | x |  | X |  |  | X | X |  | X |  |  | X |  |
| C0 | Even（XOR） | X | X | X |  | X |  | X |  | X |  | X |  | X |  |  |  |
| C1 | Odd（XNOR） | X |  |  | X | X |  |  | x |  | X | X |  |  | $x$ |  | X |
| C2 | Odd（XNOR） |  | X |  |  |  | X | X | x |  |  |  | X | X | X |  |  |
| C4 | Even（XOR） |  |  | x | X | X | X | X | x |  |  |  |  |  |  | $x$ | $x$ |
| C8 | Even（XOR） |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |

The check bit is generated as either an XOR or XNOR of the eight data bits noted by an＂$X$＂in the table．

TABLE V．
SYNDROME DECODE TO BIT－IN－ERROR

| Syndrome Bits |  |  | S8 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | S4 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| SX S0 S1 |  |  | S2 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 |  | ＊ | C8 | C4 | T | C2 | T | T | M |
| 0 | 0 | 1 |  | C1 | T | T | 15 | T | 13 | 7 | T |
| 0 | 1 | 0 |  | CO | T | T | M | T | 12 | 6 | T |
| 0 | 1 | 1 |  | T | 10 | 4 | T | 0 | T | T | M |
| 1 | 0 | 0 |  | CX | T | T | 14 | T | 11 | 5 | T |
| 1 | 0 | 1 |  | T | 9 | 3 | T | M | T | T | M |
|  | 1 | 0 |  | T | 8 | 2 | T | 1 | T | T | M |
| 1 | 1 | 1 |  | M | T | T | M | T | M | M | T |

＊－no errors detected
Number－location of the single bit－in－error
T－two errors detected
M－three or more errors detected

TABLE VI．
DIAGNOSTIC LATCH LOADING－ 16－BIT FORMAT

| Data Bit | Internal Function |
| :---: | :--- |
| 0 | Diagnostic Check Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6,7 | Don＇t Care |
| 8 | CODE ID 0 |
| 9 | CODE 1D 1 |
| 10 | CODE ID 2 |
| 11 | DIAG MODE 0 |
| 12 | DIAG MODE 1 |
| 13 | CORRECT |
| 14 | PASS THRU |
| 15 | Don＇t Care |

1 are unspecified．All of the latch enables and control signals
must be input to both of the devices．

## Generate Mode

In this mode，check bits will be generated that correspond to the contents of the Data Input Latch．The check bits generat－ ed are placed on the outputs $\mathrm{SC}_{0-6}$ of Slice 2／3．

Check bits are generated according to a modified Hamming code．Details of the code for check bit generation are contained in Table X．Check bits are generated as either an
XOR or XNOR of 16 of the 32 data bits as indicated in the XOR or XNOR of 16 of the 32 data bits as indicated in the table．The XOR function results in an even parity check bit，the XNOR in an odd parity check bit．

## Detect Mode

In this mode，the device examines the contents of the Data Input Latch against the Check Bit Input Latch，and will detect all single－bit errors，all double－bit errors，and some triple－bit errors．If one or more errors are detected，ERROR goes LOW． If two or more errors are detected，MULT ERROR goes LOW． Both error indicators are HIGH if there are no errors．The valid Both error indicators are HIGH if there are no errors．The valid

## 32－BIT DATA WORD CONFIGURATION

The 32－bit format consists of 32 data bits and 7 check bits and is referred to as $32 / 39$ code（see Figure 7）．

The 32－bit configuration is shown in Figure 8.
The upper EDC（Slice 0／1）handles the least significant bytes 0 and 1 －the external DATA lines 0 to 15 are connected to the same numbered inputs of the upper device．The lower EDC （Slice 2／3）handles the most significant bytes 2 and 3－the external DATA lines for bits 16 to 31 are connected to inputs DATA $_{0}$ through DATA 15 respectively．

The valid syndrome and check bit outputs are those of Slice $2 / 3$ as shown in the diagram．In Correct Mode these must be read into Slice $0 / 1$ via the CB inputs and are selected by the MUX as inputs to the bit－in－error decoder（see block diagram）． This requires external buffering and output enabling of the check bit lines，as shown．The $\overline{O E} S C$ signal can be used to control enabling of check bit inputs－when syndrome outputs are enabled，the external check bit inputs will be disabled．

The valid $\overline{E R R O R}$ and MULT ERROR outputs are those of the Slice 2／3．The ERROR and MULT ERROR outputs of Slice 0／

ERROR and MULT ERROR signals are those of Slice 2/ 3 -those of Slice 0/1 are undefined.

Also available on Slice $2 / 3$ outputs $S_{0-6}$ are the syndrome bits generated by the error detection step. The syndrome bits may be decoded to determine if a bit error was detected and, for single-bit errors, which of the data or check bits is in error. Table VII gives the chart for decoding the syndrome bits generated for the 32-bit configuration (as an example, if the syndrome bits SX/S0/S1/S2/S4/S8/S16 were 0010011, this would be decoded to indicate that there is a single-bit error at data bit 25). If no error is detected, the syndrome bits will be all zeroes.

In Detect Mode, the contents of the Data Input Latch are driven directly to the inputs of the Data Output Latch without corrections.

## Correct Mode

In this mode, the EDC functions the same as in Detect Mode except that the correction network is allowed to correct (complement) any single-bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch. If multiple errors are detected, the output of the correction network is unspecified. If the single-bit error is a check bit, there is no automatic correction; if desired, this would be done by placing the device in Generate Mode to produce a correct check bit sequence for the data in the Data Input Latch.

For data correction, both Slices $0 / 1$ and $2 / 3$ require access to the syndrome bits on Slice 2/3's outputs $\mathrm{SC}_{0-6}$. Slice $2 / 3$ has access to these syndrome bits through internal data paths, but for Slice 0/1 they must be read through the inputs $\mathrm{CB}_{0-6}$. The device connections for this are shown in Figure 8. When in Correct Mode, the SC outputs must be enabled so that they are available for reading in through the $C B$ inputs.

## Pass Thru Mode

In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output latch, and the contents of the Check Bit Input Latch are placed on outputs $\mathrm{SC}_{0-6}$ of Slice 2/3. ERROR and MULT ERROR are forced HIGH in this mode.

TABLE VII.
SYNDROME DECODE TO BIT-IN-ERROR


*     - no errors detected

Number - number of the single bit-in-error
T - two errors detected
M - three or more errors detected


DF000460
Figure 7. 32-Bit Data Format

Figure 8. 32-Bit Configuration

TABLE VIII.
KEY AC CALCULATIONS FOR THE 32-BIT CONFIGURATION

| 32-Bit <br> Propagation Delay |  | Component Delay from Am2960 AC Specifications, Table C |
| :---: | :---: | :---: |
| From | To |  |
| DATA | Check Bits Out | (Data to SC) + (CB to SC, CODE ID 011) |
| DATA in | Corrected DATA Out | (DATA to SC) + (CB to SC, CODE ID 011) + (CB to DATA, CODE ID 010) |
| DATA | Syndromes Out | (DATA to SC) + (CB to SC, CODE ID 011) |
| DATA | ERROR for 32 Bits | (DATA to SC) + (CB to ERROR, CODE ID 011) |
| DATA | MULT ERROA for 32 Bits | (DATA to SC) + (CB to MULT ERROR, CODE ID 011) |

TABLE IX．
DIAGNOSTIC LATCH LOADING－32－BIT FORMAT

| Data Bit | Internal Function |
| :---: | :---: |
| 0 | Diagnostic Check Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6 | Diagnostic Check Bit 16 |
| 7 | Don＇t Care |
| 8 | Slice 0／1－CODE ID 0 |
| 9 | Slice 0／1－CODE ID 1 |
| 10 | Slice 0／1－CODE ID 2 |
| 11 | Slice 0／1－DIAG MODE 0 |
| 12 | Slice 0／1－DIAG MODE 1 |
| 13 | Slice 0／1－CORRECT |
| 14 | Slice 0／1－PASS THRU |
| 15 | Don＇t Care |
| 16－23 | Don＇t Care |
| 24 | Slice 2／3－CODE ID 0 |
| 25 | Slice 2／3－CODE ID 1 |
| 26 | Slice 2／3－CODE ID 2 |
| 27 | Slice 2／3－DIAG MODE 0 |
| 28 | Slice 2／3－DIAG MODE 1 |
| 29 | Slice 2／3－CORRECT |
| 30 | Slice 2／3－PASS THRU |
| 31 | Don＇t Care |

TABLE X．
32－BIT MODIFIED HAMMING CODE－CHECK BIT ENCODE CHART

| Generated Check Bits | Parity | Participating Data Bits |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{lllll}0 & 1 & 2 & 3\end{array}$ | $\begin{array}{lllll}4 & 5 & 6 & 7\end{array}$ | $\begin{array}{lllll}8 & 9 & 10 & 11\end{array}$ | 12131415 |
| CX | Even（XOR） | X | $\mathrm{X} \quad \mathrm{X} \times$ | $\mathrm{X} \times \mathrm{X}$ | X |
| CO | Even（XOR） | $\mathrm{x} \times \mathrm{x}$ | $\mathrm{X} \quad \mathrm{x}$ | $x \quad x$ | X |
| C1 | Odd（XNOR） | $x \quad x$ | $x \quad x$ | X X | $x \quad \mathrm{X}$ |
| C2 | Odd（XNOR） | X X | $x \times \mathrm{x}$ | X | X $\times$ |
| C 4 | Even（XOR） | $\times \times$ | $\times \times \times \times$ |  | $x \times$ |
| C8 | Even（XOR） |  |  | $\mathrm{X} \times \mathrm{X} \times$ | $\times \times \times \times$ |
| C16 | Even（XOR） | $\times \times \times \mathrm{X}$ | $\times \times \times \times$ |  |  |


| Generated Check Bits | Parity | Participating Data Bits |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16171819 | 20212223 | 24252627 | 28293031 |
| CX | Even（XOR） | $x \times \times$ | X | X | $\times \times \quad \mathrm{X}$ |
| C0 | Even（XOR） | $x \times x$ | $x \quad x$ | $x \quad x$ | X |
| C1 | Odd（XNOR） | $x$ | $x \quad x$ | $\times \mathrm{X}$ | $\mathrm{X} \quad \mathrm{X}$ |
| C2 | Odd（XNOR） | X X | $x \times \mathrm{x}$ | X | $\mathrm{X} \times$ |
| C4 | Even（XOR） | $\times \mathrm{X}$ | $\times \times \times \mathrm{x}$ |  | $\times \mathrm{x}$ |
| C8 | Even（XOR） |  |  | $x \times \times \times$ | $x \times \times \times$ |
| C16 | Even（XOR） |  |  | $\mathrm{X} \times \mathrm{X} \times$ | $\mathrm{X} \times \mathrm{X} \times$ |

The check bit is generated as either an XOR or XNOR of the sixteen data bits noted by an＂$X$＂in the table．

## 64－BIT DATA WORD CONFIGURATION

The 64－bit format consists of 64 data bits， 8 check bits and is referred to as 64／72 code（see Figure 9．）．

The configuration to process 64－bit format is shown in Figure 6．In this configuration，a portion of the syndrome generation and error detection is implemented externally of the EDCs in MSI．For error correction，the syndrome bits generated must be read back into all four EDCs through the CB inputs．This necessitates the check bit buffering shown in the connection diagram of Figure 10．The $\overline{O E}$ SC signal can control the check bit enabling；when syndrome bit outputs are enabled，the external check bit lines will be disabled so that the syndrome bits may be read onto the CB inputs．

The error detection signals for the 64－bit configuration differ from the 16－and 32－bit configurations．The ERROR signal functions the same：＂it is LOW if one or more errors are detected，and HIGH if no errors are detected．The DOUBLE ERROR signal is HIGH if and only if a double－bit error is detected；it is LOW otherwise．All of the MULT ERROR outputs of the four devices are valid．MULT ERROR is LOW for all three ERROR cases and some DOUBLE ERROR combinations．（See TOME definition in Functional Equations section．）It is HIGH if either zero or one errors are detected．

This is a different meaning for MULT ERROR than in other configurations．

## Generate Mode

In this mode，check bits will be generated that correspond to the contents of the Data Input Latch．The check bits generat－ ed appear at the outputs of the XOR gates as indicated in Figure 10.
Check bits are generated according to a modified Hamming code．Details of the code for check bit generation are contained in Table XII．Check bits are generated as either an XOR or XNOR of 32 of the 64 bits as indicated in the table． The XOR function results in an even parity check bit，the XNOR in an odd parity check bit．

## Detect Mode

In this mode，the device examines the contents of the Data Input Latch against the Check Bit Input Latch，and will detect all single－bit errors，all double－bit errors and some triple－bit errors．If one or more errors are detected，ERROR goes LOW． If exactly two errors are detected，$\overline{D O U B L E}$ ERROR goes HIGH．If three or more errors are detected，MULT ERROR goes LOW－the MULT ERROR output of any of the four EDCs may be used．
Available as XOR gate outputs are the generated syndrome bits（see Figure 10）．The syndrome bits may be decoded to determine if a bit error was detected and，for single－bit errors， which of the data or check bits is in error．Table XIII gives the chart for encoding the syndrome bits generated for the 64－bit configuration（as an example，if the syndrome bits $\mathrm{SX} / \mathrm{S} 1 / \mathrm{S} 2 /$ S4／S8／S16／S32 were 00100101，this would be decoded to
indicate that there is a single－bit error at data bit 41）．If no error is detected，the syndrome bits will all be zeroes．
In Detect Mode，the contents of the Data Input Latch are driven directly to the inputs of the Data Output Latch without corrections．

## Correct Mode

In this mode，the EDC functions the same as in Detect Mode except that the correction network is allowed to correct （complement）any single－bit error of the Data Input Latch before putting it onto the inputs of the Data Output Latch．If multiple errors are detected，the output of the correction network is unspecified．If the single－bit error is a check bit， there is no automatic correction．Check bit correction can be done by placing the device in generate mode to produce a correct check bit sequence for the data in the Data Input Latch．
To perform the correction step，all four slices require access to the syndrome bits which are generated externally of the devices．This access is provided by reading the syndrome bits in through the CB inputs，where they are selected as inputs to the bit－in－error decoder by the multiplexer（see Block Dia－ gram）．The device connections for this are shown in Figure 10. When in Correct Mode，the SC outputs must be enabled so that the syndrome bits are available at the CB inputs．

## Pass Thru Mode

In this mode，the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch，and the contents of Check Bit Input Latch are passed through the external XOR network and appear inverted at the XOR gate outputs labeled CX to C32（see Figure 10）．

## Diagnostic Latch

The Diagnostic Latch serves both for diagnostic uses and internal control uses．It is loaded from the DATA lines under the control of LE DIAG．Table XIV shows the loading defini－ tions for the DATA lines．

## Diagnostic Generate Diagnostic Detect Diagnostic Correct

These are special diagnostic modes selected by DIAG MODE $_{0-1}$ where either normal check bit inputs or outputs are substituted for by check bits from the Diagnostic Latch．See Table II for details．

## Internal Control Mode

This mode is selected by CODE $1 D_{0-2}$ ，input $001\left(I D_{2}, I D_{1}\right.$ ， $\mathrm{ID}_{0}$ ）．
When in Internal Control Mode，the EDC takes the CODE $I_{0-2}$ ，DIAG MODE $0_{0-1}$ ，CORRECT and PASS THRU signals from the internal Diagnostic Latch rather than from the external control lines．Table XIV gives format for loading the Diagnostic Latch．


Figure 9．64－Bit Data Format


Notes: 1. In Pass Thru Mode the Contents of the Check Latch Appear on the XOR Outputs Inverted. 2. In Diagnostic Generate Mode the Contents of the Diagnostic Latch Appear on the XOR Outputs Inverted.

Figure 10. AM2960-64-Bit Data Configuration

TABLE XI.
KEY AC CALCULATIONS FOR THE 64-BIT CONFIGURATION

| 64-BitPropagation Delay |  | Component Delays from Am2960 AC Specifications, Table C (plus MSI) |
| :---: | :---: | :---: |
| From | To |  |
| DATA | Check Bits Out | (DATA to SC) + (XOR Delay) |
| DATA in | Corrected DATA Out | (DATA to SC) + (XOR Delay) + (Buffer Delay) + (CB to DATA, CODE ID 1xx) |
| DATA | Syndromes | (DATA to SC) + (XOR Delay) |
| DATA | ERROR for 64 Bits | (DATA to SC) + (XOR Delay) + (NOR Delay) |
| DATA | MULT ERROR for 64 Bits | (DATA to SC) + (XOR Delay) + (Buffer Delay) + (CB to MULT ERROR, CODE ID 1 xx ) |
| DATA | DOUBLE ERROR for 64 Bits | (DATA to SC) $+($ XOR Delay $)+($ XOR/NOR Delay $)$ |

TABLE XII. 64-BIT MODIFIED HAMMING CODE - CHECK BIT ENCODE

| Generated <br> Check Bits | Parity | Participating Data Bits |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| $\begin{aligned} & \mathrm{CX} \\ & \mathrm{CO} \end{aligned}$ | Even (XOR) <br> Even (XOR) | X | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X | X | $x$ | X |  |  | $x$ | x | $x$ | X |  | X |  |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) <br> Odd (XNOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ |  | x | X | $X$ | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | X | X | X | X | X X |  | X |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | X | X | X | X | X | X | X | X | X | X | X | X | X <br> X |
| $\begin{aligned} & \mathrm{C} 16 \\ & \mathrm{C} 32 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  | X <br> X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  |  | $\begin{aligned} & x \\ & x \end{aligned}$ | X <br> $\times$ |  |  |  |  |  |  |  |  |  |


| Generated Check Bits | Parity | Participating Data Bits |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| $\begin{aligned} & \mathrm{CX} \\ & \mathrm{CO} \end{aligned}$ | Even (XOR) <br> Even (XOR) | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ | X | X | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ | X | X | X |  | X |  |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) <br> Odd (XNOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ |  | X | X | X | $x$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | X | X | X | X | $x$ |  | X |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | x | X | X | X | X | X | X | X | $x$ | X | $x$ | X <br> $\times$ <br> $\times$ | X |
| $\begin{aligned} & \mathrm{C} 16 \\ & \mathrm{C} 32 \\ & \hline \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  |  |  |  |  |  |  | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | X | X | X <br>  <br> X | X | $\begin{aligned} & x \\ & x \end{aligned}$ | X <br> X |

table XII.
64-BIT MODIFIED HAMMING CODE - CHECK BIT ENCODE (Cont.)

| Generated Check Bits | Parity | Participating Data Bits |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
| $\begin{aligned} & \mathrm{CX} \\ & \mathrm{CO} \end{aligned}$ | Even (XOR) <br> Even (XOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X |  | X |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) <br> Odd (XNOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ |  | X | X | X | $x$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | X | X | X | X | X X |  | X |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | X | X | X | X | X | X | X | X | X | X | X | X | X <br> X |
| $\begin{aligned} & \text { C16 } \\ & \text { C32 } \end{aligned}$ | Even (XOR) <br> Even (XOR) |  | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |


| Generated Check Bits | Parity | Participating Data Bits |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |
| $\begin{aligned} & \mathrm{CX} \\ & \mathrm{CO} \end{aligned}$ | Even (XOR) <br> Even (XOR) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $x$ | X |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X |  | X |
| $\begin{aligned} & \mathrm{C} 1 \\ & \mathrm{C} 2 \end{aligned}$ | Odd (XNOR) <br> Odd (XNOR) | $\begin{array}{\|l} x \\ x \end{array}$ | $x$ |  | X | X | X | X | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ |  | X | X | $x$ | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |  | x |
| $\begin{aligned} & \mathrm{C} 4 \\ & \mathrm{C} 8 \end{aligned}$ | Even (XOR) <br> Even (XOR) |  |  | X | X | X | X | X | x | X | X | X | x | X | X | X <br> X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ |
| $\begin{aligned} & \mathrm{C} 16 \\ & \text { C32 } \\ & \hline \end{aligned}$ | Even (XOR) <br> Even (XOR) | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X | X |

The check bit is generated as either an XOR or XNOR of the 32 data bits noted by an " $X$ ' in the table.
táble Xili. SYNDROME dECODE TO BIT-IN-ERROR

| Sx | Synd | rome ts | S2 | $\begin{gathered} \mathbf{S 3 2} \\ \text { S16 } \\ \text { S8 } \\ \text { S4 } \end{gathered}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 1 1 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |  | * | C32 | C16 | T | CS | T | T | M | C4 | T | T | M | T | 46 | 62 | T |
| 0 | 0 | 0 | 1 |  | C2 | T | T | M | T | 43 | 59 | T | T | 53 | 37 | T | M | T | T | M |
| 0 | 0 | 1 | 0 |  | C1 | T | T | M | T | 41 | 57 | T | T | 51 | 35 | T | 15 | T | T | 31 |
| 0 | 0 | 1 | 1 |  | T | M | M | T | 13 | T | T | 29 | 23 | T | T | 7 | T | M | M | T |
| 0 | 1 | 0 | 0 |  | CO | T | T | M | T | 40 | 56 | T | T | 50 | 34 | T | M | T | T | M |
| 0 | 1 | 0 | 1 |  | T | 49 | 33 | T | 12 | T | T | 28 | 22 | T | T | 6 | T | M | M | T |
| 0 | 1 | 1 | 0 |  | T | M | M | T | 10 | T | T | 26 | 20 | T | T | 4 | T | M | M | T |
| 0 | 1 | 1 | 1 |  | 16 | T | T | 0 | T | M | M | T | T | M | M | T | M | T | T | M |
| 1 | 0 | 0 | 0 |  | CX | T | T | M | T | M | M | T | T | M | M | T | 14 | T | T | 30 |
| 1 | 0 | 0 | 1 |  | T | M | M | T | 11 | T | T | 27 | 21 | T | T | 5 | T | M | M | T |
| 1 | 0 | 1 | 0 |  | T | M | M | T | 9 | T | T | 25 | 19 | T | T | 3 | T | 47 | 63 | T |
| 1 | 0 | 1 | 1 |  | M | T | T | M | T | 45 | 61 | T | T | 55 | 39 | T | M | T | T | M |
| 1 | 1 | 0 | 0 |  | T | M | M | T | 8 | T | T | 24 | 18 | T | T | 2 | T | M | M | T |
| 1 | 1 | 0 | 1 |  | 17 | T | T | 1 | T | 44 | 60 | T | T | 54 | 38 | T | M | T | T | M |
| 1 | 1 | 1 | 0 |  | M | T | T | M | T | 42 | 58 | T | T | 52 | 36 | T | M | T | T | M |
| 1 | 1 | 1 | 1 |  | T | 48 | 32 | T | M | T | T | M | M | T | T | M | T | M | M | T |

*     - no errors detected

Number - the number of the single bit-in-error

T - two errors detected
M - more than two errors detected

TABLE XIV．DIAGNOSTIC LATCH LOADING－64－BIT FORMAT

| Data Bit | Internal Function |
| :---: | :---: |
| 0 | Diagnostic Check Bit X |
| 1 | Diagnostic Check Bit 0 |
| 2 | Diagnostic Check Bit 1 |
| 3 | Diagnostic Check Bit 2 |
| 4 | Diagnostic Check Bit 4 |
| 5 | Diagnostic Check Bit 8 |
| 6， 7 | Don＇t Care |
| 8 | Slice 0／1－CODE ID 0 |
| 9 | Slice 0／1－CODE ID 1 |
| 10 | Slice 0／1－CODE ID 2 |
| 11 | Slice 0／1－DIAG MODE 0 |
| 12 | Slice 0／1－DIAG MODE 1 |
| 13 | Slice 0／1－CORRECT |
| 14 | Slice 0／1－PASS THRU |
| 15 | Don＇t Care |
| 16－23 | Don＇t Care |
| 24 | Slice 2／3－CODE ID 0 |
| 25 | Slic̣e 2／3－CODE ID 1 |
| 26 | Slice $2 / 3$－CODE ID 2 |
| 27 | Slice $2 / 3$－DIAG MODE 0 |
| 28 | Slice 2／3－DIAG MODE 1 |
| 29 | Slice 2／3－CORRECT |
| 30 | Slice 2／3－PASS THRU |


| Data Bit | Internal Function |
| :---: | :---: |
| 31 | Don＇t Care |
| 32－37 | Don＇t Care |
| 38 | Diagnostic Check Bit 16 |
| 39 | Don＇t Care |
| 40 | Slice 4／5－CODE ID 0 |
| 41 | Slice 4／5－CODE ID 1 |
| 42 | Slice 4／5－CODE ID 2 |
| 43 | Slice 4／5－DIAG MODE 0 |
| 44 | Slice 4／5－DIAG MODE 1 |
| 45 | Slice 4／5－CORRECT |
| 46 | Slice 4／5－PASS THRU |
| 47 | Don＇t Care |
| 48－54 | Don＇t Care |
| 55 | Diagnostic Check Bit 32 |
| 56 | Slice 6／7－CODE ID 0 |
| 57 | Slice 6／7－CODE ID 1 |
| 58 | Slice 6／7－CODE ID 2 |
| 59 | Slice 6／7－DIAG MODE 0 |
| 60 | Slice 6／7－DIAG MODE 1 |
| 61 | Slice 6／7－CORRECT |
| 62 | Slice 6／7－PASS THRU |
| 63 | Don＇t Care |

## SYSTEM DESIGN CONSIDERATIONS

## High Performance Parallel Operation

For maximum memory system performance，the EDC should be used in the Check－Only configuration shown in Figure 11. With this configuration，the memory system operates as fast with EDC as it would without．

On reads from memory，data is read out from the RAMs directly to the data bus（same as in a non－EDC system）．At the same time，the data is read into the EDC to check for errors．If an error exists，the EDC＇s error flags are used to interrupt the CPU and／or to stretch the memory cycle．If no error is detected，no slowdown is required．

If an error is detected，the EDC generates corrected data for the processor．At the designer＇s option the correct data may be written back into memory；error logging and diagnostic routines may also be run under processor control．

The Check－Only configuration allows data reads to proceed as fast with EDC as without．Only if an error is detected is there any slowdown．But even if the memory system had an error every hour this would mean only one error every 3－4 billion memory cycles．So even with a very high error rate，EDC in a Check－Only configuration has essentially zero impact on memory system speed．

On writes to memory，check bits must be generated before the full memory word can be written into memory．But using the Am2961／62 Data Bus Buffers allows the data word to be buffered on the memory board while check bits are generated． This makes the check bit generate time transparent to the processor．

## EDC in the Data Path

The simplest configuration for EDC is to have the EDC directly in the data path，as shown in Figure 12 （Correct－Always Configuration）．In this configuration，data read from memory is always corrected prior to putting the data on the data bus．The advantages are simpler operation and no need for mid－cycle interrupts．The disadvantage is that memory system speed is slowed by the amount of time it takes for error correction on every cycle．

Usually the Correct－Always Configuration will be used with MOS microprocessors which have ample memory timing budgets．Most high performance processors will use the high performance parallel configuration shown in Figure 11 （Check－ Only Configuration）．

## Scrubbing Avoids Double Errors

Single－bit errors are by far the most common in a memory system，and are always correctable by the EDC．

Double－bit memory errors are far less frequent than single－bit （50 to 1，or 100 to 1）and are always detected by the EDC，but not corrected．

In a memory system，soft errors occur only one at a time．A double－bit error in a data word occurs when a single soft error is left uncorrected and is followed by another error in the data word hours，days，or weeks after the first．
＂＇Scrubbing＇memory periodically avoids almost all double－bit errors．In the scrubbing operation，every data word in memory is periodically checked by the EDC for single－bit errors．If one is found，it is corrected and the data word written back into
memory. Errors are not allowed to pile up, and most double-bit errors are avoided.

The scrubbing operation is generally done as a background routine when the memory is not being used by the processor. If memory is scrubbed frequently, errors that are detected and corrected during processor accesses need not be immediately written back into memory. Instead, the error will be corrected in memory during scrubbing. This reduces the time delay involved in a processor access of an incorrect memory word.

## Correction of Double-Bit Errors

In some cases, double-bit memory errors can be corrected! This is possible when one of the two bit errors is a hard error.

When a double bit error is detected, the data word should be checked to determine if one of the errors is a hard error. If so, the hard error bit may be corrected by inverting it, leaving only a single, correctable error. The time for this operation is negligible, since it will occur infrequently.


## WRITE

READ
DF000291
Figure 11. Check-Only Configuration


WRITE
READ
DF000910
Figure 12. Correct-Always Configuration

The procedure after detection of a double error is as follows:

- Invert the data bits read from memory.
- Write the inverted data back into the same memory word.
- Re-read the memory location and XOR the newly read out value with the old. If there is no hard error, then the XOR result will be all 1 's. If there is a hard error, it will have the same bit value regardless of what was written in. So it will show as a 0 after the XOR operation.
- Invert the hard error bit (this will "correct" it) leaving only one error in the data.
- The EDC can then correct the single bit error.
- Rewrite the correct data word into memory. This does not change the hard error, but does eliminate the soft error. So the next memory access will find only a single-bit, correctable error.

An example helps to illustrate the procedure:

## Example of Double-Bit Error Correction When One is a Hard Error

1. Data Read from Memory ( $D_{1}$ ) 16 data bits
1111111100000011

6 check bits 011010
2. EDC detects a multiple error. Syndromes: 011000
3. Syndrome decode indicates a double-bit error.
4. Invert the bits read from memory ( $D_{1}$ )
5. Write $D_{1}$ back to the same memory location
6. Read back the memory location ( $\mathrm{D}_{2}$ )
7. XOR $D_{1}$ and $D_{2}$

$$
0000000011111101 \quad 100101
$$

8. So the last data bit is the hard error. Use this to modify $\mathrm{D}_{1}$
9. Pass the modified $D_{1}$ through the EDC. The EDC detects a single bit correctable error and outputs corrected data:
10. Write the corrected data back to memory to fix the soft error.

## Error Logging and Preventative Maintenance

The effectiveness of preventative maintenance can be increased by logging information on errors detected by the EDC. This is called error logging.
The EDC provides syndromes when errors are detected. The syndromes indicate which bit is in error. In most memory systems, each individual RAM supplies only one bit of the memory word. So the syndrome and data word address specify which RAM was in error.
Typically a permanent/hard RAM failure is preceded by a period of time where the RAM displays an increasing frequency of intermittent, soft errors. Error logging statistic can be used to detect an increasing intermittent error frequency so that the RAM can be replaced before a permanent failure occurs.
Error logging also records the location of already hard failed RAMs. With EDC a hard failure will not halt system operation. EDC can always correct single-bit errors even if it is a hard error. EDC can also correct double-bit errors where one is hard and one soft (see "Correction of Double Bit Errors'" Section). The ability to continue operation despite hard errors can greatly reduce the need for emergency field maintenance. The hard-failed RAMs can be instead replaced at low cost during a regularly-scheduled preventative maintenance session.

## Reducing Check Bit Overhead

Memory word widths need not be the same as the data word width of the processor. There is a substantial reduction in check bit overhead if wider memory words are used:

| Memory Word |  | Check <br> Bit Overhead |
| :---: | :---: | :---: |
| \# Data Bits | \# Check Bits |  |
| 8 | 5 | $38 \%$ |
| 16 | 6 | $27 \%$ |
| 32 | 7 | $14 \%$ |
| 64 | 8 | $11 \%$ |



Figure 13. EDC Per Board
This reduction in check bit overhead lowers cost and increases the amount of data that can be packed on to each board.

The trade－off is that when writing data pieces into memory that are narrower than the memory word width，more steps are required．These steps are exactly the same as those de－ scribed in Byte Write in the Applications section．No penalty exists for reads from memory．

## EDC Per Board vs EDC Per System

The choice of an EDC per system or per board depends on the economics and the architecture of the system．

Certainly the cheaper approach is to have only one EDC per system and this is a viable solution if only one memory location is accessed at a time．

This solution does require that the system has both data and check bit lines（see Figure 14）．This makes retrofitting a system difficult and creates complications if static or ROM memory，which do not require check bits，are mixed in with dynamic RAM．

If the system has an advanced architecture，it is quite likely that it is necessary to simultaneously access memory loca－ tions on different memory boards（see Figure 13）．Architectur－ al features that require this are interleaved memory，cache memory，and DMA that is done simultaneously with processor memory accesses．EDC per board is a simpler system from a design standpoint．

The EDC is designed to work efficiently in either the per system or per board configurations．


Figure 14．EDC Per System

## FUNCTIONAL EQUATIONS

The following equations and tables describe in detail how the output values of the AM2960 EDC are determined as a function of the value of the inputs and the internal states．Be sure to carefully read the following definitions of symbols before examining the tables．

## Definitions

$D_{i}-\left(\right.$ DATA $_{i}$ if LE IN is HIGH or the output of bit $i$ of the Data Input Latch if LE $\mathbb{N}$ is LOW）
$\mathrm{C}_{\mathrm{i}} \leftarrow \mathrm{CB}_{\mathrm{i}}$ if LE IN is HIGH or the output of bit $i$ of the Check Bit Latch if LE $\mathbb{N}$ is LOW）
DLi－Output of bit $i$ of the Diagnostic Latch
$\mathrm{S}_{\mathrm{i}}$－Internally generated syndromes（same as outputs of $\mathrm{SC}_{\mathrm{i}}$ if outputs enabled）
$P A \leftarrow D 0 \oplus D 1 \oplus D 2 \oplus D 4 \oplus D 6 \oplus D 8 \oplus D 10 \oplus D 12$
$\mathrm{PB} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 1 \oplus \mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 4 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7$
$\mathrm{PC} \leftarrow \mathrm{D} 8 \oplus \mathrm{D} 9 \oplus \mathrm{D} 10 \oplus \mathrm{D} 11 \oplus \mathrm{D} 12 \oplus \mathrm{D} 13 \oplus \mathrm{D} 14 \oplus$
$P D \leftarrow D 0 \oplus D 3 \oplus D 4 \oplus D 7 \oplus D 9 \oplus D 10 \oplus D 13 \oplus D 15$
$\mathrm{PE} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 1 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7 \oplus \mathrm{D} 11 \oplus \mathrm{D} 12 \oplus \mathrm{D} 13$
$\mathrm{PF}-\mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 4 \oplus \mathrm{D} 5 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7 \oplus \mathrm{D} 14 \oplus \mathrm{D} 15$
$\mathrm{PG}_{1} \leftarrow \mathrm{D} 0 \oplus \mathrm{D} 4 \oplus \mathrm{D} 6 \oplus \mathrm{D} 7$
$\mathrm{PG}_{2} \leftarrow \mathrm{D} 1 \oplus \mathrm{D} 2 \oplus \mathrm{D} 3 \oplus \mathrm{D} 5$
$\mathrm{PG}_{3} \leftarrow \mathrm{D} 8 \oplus \mathrm{D} 9 \oplus \mathrm{D} 11 \oplus \mathrm{D} 14$
$\mathrm{PG}_{4} \leftarrow \mathrm{D} 10 \oplus \mathrm{D} 12 \oplus \mathrm{D} 13 \oplus \mathrm{D} 15$

## Error Signals

$\overline{E R R O R} \leftarrow\left(\overline{\mathrm{~S} 6 \cdot\left(\mathrm{ID}_{1}+1 D_{2}\right)}\right) \cdot \overline{\mathrm{S} 5} \cdot \overline{\mathrm{~S} 4} \cdot \overline{\overline{S 3}} \cdot \overline{\mathrm{~S} 2} \cdot \overline{\mathrm{~S} 1} \cdot \overline{\mathrm{SO}}+\mathrm{GENERATE}+$ INITIALIZE＋PASSTHRU
$\overline{\text { MULT ERROR（16 and 32－Bit Modes）}}-\overline{\left(\left(\mathrm{S} 6 \cdot 1 \mathrm{I}_{1}\right) \oplus \mathrm{S} 5 \oplus \mathrm{~S} 4 \oplus \mathrm{~S} 3 \oplus \mathrm{~S} 2 \oplus \mathrm{~S} 1 \oplus \mathrm{~S} 0\right.}$ ）（ERROR $)+$ TOME ＋GENERATE＋PASSTHRU＋INITIALIZE
$\overline{\text { MULT ERROR }}$（64－Bit Modes）$\leftarrow \overline{\text { TOME }}+$ GENERATE＋PASSTHRU＋INITIALIZE

TOME (Three or More Errors)*

|  |  |  | $\begin{array}{r} \mathrm{SO} \\ * * S 6 \\ \mathrm{~S} 5 \\ \mathrm{~S} 4 \end{array}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | 1 1 1 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S1 | S2 | S3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 |  | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 |  | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 |  | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 |  | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 |  | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 1 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 0 |  | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 |  | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

*(S6, S5, .. S0 are internal syndromes except in Modes 010, 100, 101, 110, 111 (CODE ID $, ~ I D_{1}, I D_{0}$ ).
In these modes the syndromes are input over the Check-Bit lines. $\mathrm{S} 6 \leftarrow \mathrm{C} 6, \mathrm{~S} 5 \leftarrow \mathrm{C} 5, \ldots \mathrm{~S} 1 \leftarrow \mathrm{C} 1, \mathrm{~S} 0 \leftarrow \mathrm{C} 0$.
**The S6 internal syndrome is always forced to 0 in CODE ID 000.

## SC Outputs

Tables XV, XVI, XVII, XVIII, XIX show how outputs $\mathrm{SC}_{0-6}$ are generated in each control mode for various CODE IDs (internal control mode not applicable).

TABLE XV.

| GENERATE | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode (Check Bits) | 000 | 010 | 011 | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0-}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{4}{ }^{\oplus} \mathrm{CB}_{0}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ |
| $\mathrm{SC}_{1}$ - | PA | PA | $\mathrm{PA} \oplus \mathrm{CB}_{1}$ | PA | PA | PA | PA |
| $\mathrm{SC}_{2}+$ | $\overline{P D}$ | $\overline{P D}$ | $\mathrm{PD} \oplus \mathrm{CB}_{2}$ | $\overline{\overline{P D}}$ | PD | PD | PD |
| $\mathrm{SC}_{3}$ - | $\overline{\text { PE }}$ | $\overline{\text { PE }}$ | $\mathrm{PE} \oplus \mathrm{CB}_{3}$ | $\overline{\text { PE }}$ | PE | PE | PE |
| $\mathrm{SC}_{4}+$ | PF | PF | $\mathrm{PF} \oplus \mathrm{CB}_{4}$ | PF | PF | PF | PF |
| $\mathrm{SC}_{5}$ - | PC | PC | $\mathrm{PC} \oplus \mathrm{CB}_{5}$ | PC | PC | PC | PC |
| $\mathrm{SC}_{6}+$ | 1 | PB | $\mathrm{PC} \oplus \mathrm{CB}_{6}$ | PB | PB | PB | PB |

TABLE XVI.

| Detect and Correct | CODE ID $_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Modes (Syndromes) | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}+$ | $\underset{\oplus C 0}{\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}}$ | $\underset{\oplus C 0}{\mathrm{PG}_{1} \oplus \mathrm{PG}_{3}}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{4} \\ \oplus \mathrm{CB}_{0} \end{gathered}$ | $\underset{\oplus \mathrm{C} 0}{\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ |
| $\mathrm{SC}_{1}$ - | $\mathrm{PA} \oplus \mathrm{C} 1$ | $\mathrm{PA} \oplus \mathrm{C} 1$ | $\mathrm{PA} \oplus \mathrm{CB}_{1}$ | $\mathrm{PA} \oplus \mathrm{C} 1$ | PA | PA | PA |
| $\mathrm{SC}_{2 \leftarrow}$ | $\overline{\mathrm{PD}} \oplus \mathrm{C} 2$ | $\overline{\mathrm{PD}} \oplus \mathrm{C} 2$ | $\mathrm{PD} \oplus \mathrm{CB}_{2}$ | $\overline{\mathrm{PD}} \oplus \mathrm{C} 2$ | PD | PD | PD |
| $\mathrm{SC}_{3}$ - | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | $\mathrm{PE} \oplus \mathrm{CB}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{C} 3$ | PE | PE | PE |
| $\mathrm{SC}_{4}$ - | $\mathrm{PF} \oplus \mathrm{C} 4$ | $\mathrm{PF} \oplus \mathrm{C} 4$ | $\mathrm{PF} \oplus \mathrm{CB}_{4}$ | $\mathrm{PF} \oplus \mathrm{C} 4$ | PF | PF | PF |
| $\mathrm{SC}_{5}$ - | $\mathrm{PC} \oplus \mathrm{C} 5$ | $\mathrm{PC} \oplus \mathrm{C} 5$ | $\mathrm{PC} \oplus \mathrm{CB}_{5}$ | $\mathrm{PC} \oplus \mathrm{C} 5$ | PC | PC | PC |
| $\mathrm{SC}_{6} \leftarrow$ | 1 | $\mathrm{PB} \oplus \mathrm{C} 6$ | $\mathrm{PC} \oplus \mathrm{CB}_{6}$ | PB | PB | $\mathrm{PB} \oplus \mathrm{C} 6$ | $\mathrm{PB} \oplus \mathrm{C} 6$ |

*In CODE $I D_{2-0} 011$ the Check-Bit Latch is forced transparent; the Data Latch operates normally.

TABLE XVII.

| Diagnostic Read Mode | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{DL} L_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{1} \oplus \mathrm{PG}_{3} \\ \oplus \mathrm{DL} \mathrm{~L}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus \mathrm{PG}_{4} \\ \oplus \mathrm{CB}_{0} \end{gathered}$ | $\begin{gathered} \mathrm{PG}_{2} \oplus{ }^{\oplus} \mathrm{PG}_{3} \\ \oplus \mathrm{D} \mathrm{~L}_{0} \end{gathered}$ | $\mathrm{PG}_{2} \oplus \mathrm{PG}_{3}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ | $\mathrm{PG}_{1} \oplus \mathrm{PG}_{4}$ |
| $\mathrm{SC}_{1}$ - | $\mathrm{PA} \oplus \mathrm{DL}_{1}$ | $\mathrm{PA} \oplus \mathrm{DL}_{1}$ | $\mathrm{PA} \oplus \mathrm{CB}_{1}$ | $\mathrm{PA} \oplus \mathrm{DL}_{1}$ | PA | PA | PA |
| $\mathrm{SC}_{2}+$ | $\overline{\mathrm{PD}} \oplus \mathrm{DL}_{2}$ | $\overline{\mathrm{PD}} \oplus \mathrm{DL}_{2}$ | $\mathrm{PD} \oplus \mathrm{CB}_{2}$ | $\overline{\mathrm{PD}} \oplus \mathrm{DL}_{2}$ | PD | PD | PD |
| $\mathrm{SC}_{3}+$ | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | $\mathrm{PE} \oplus \mathrm{CB}_{3}$ | $\overline{\mathrm{PE}} \oplus \mathrm{DL}_{3}$ | PE | PE | PE |
| $\mathrm{SC}_{4} \leftarrow$ | $\mathrm{PF} \oplus \mathrm{DL}_{4}$ | $\mathrm{PF} \oplus \mathrm{DL}_{4}$ | $\mathrm{PF} \oplus \mathrm{CB}_{4}$ | $\mathrm{PF} \oplus \mathrm{DL}_{4}$ | PF | PF | PF |
| $\mathrm{SC}_{5}$ - | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | $\mathrm{PC} \oplus \mathrm{CB}_{5}$ | $\mathrm{PC} \oplus \mathrm{DL}_{5}$ | PC | PC | PC |
| $\mathrm{SC}_{6}+$ | 1 | $\mathrm{PB} \oplus \mathrm{DL}_{6}$ | $\mathrm{PC} \oplus \mathrm{CB}_{6}$ | PB | PB | $\mathrm{PB} \oplus \mathrm{DL}_{6}$ | $\mathrm{PB} \oplus \mathrm{DL}_{7}$ |

${ }^{*}$ In CODE $I_{2-0} 011$ the Check-Bit Latch is forced transparent; the Data Latch operates normally.

TABLE XVIII.

| Diagnostic Write Mode | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}$ - | DLo | $\mathrm{DL}_{0}$ | $\mathrm{CB}_{0}$ | DLo | 1 | 1 | 1 |
| $\mathrm{SC}_{1}$ - | DL | DL | $\mathrm{CB}_{1}$ | DL | 1 | 1 | 1 |
| $\mathrm{SC}_{2}-$ | $\mathrm{DL}_{2}$ | $\mathrm{DL}_{2}$ | $\mathrm{CB}_{2}$ | DL2 | 1 | 1 | 1 |
| $\mathrm{SC}_{3}$ - | DL3 | DL3 | $\mathrm{CB}_{3}$ | $\mathrm{DL}_{3}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{4}$ - | $\mathrm{DL}_{4}$ | $\mathrm{DL}_{4}$ | $\mathrm{CB}_{4}$ | $\mathrm{DL}_{4}$ | 1 | 1 | 1 |
| $\mathrm{SC}_{5}+$ | DL5 | DL5 | $\mathrm{CB}_{5}$ | DL5 | 1 | 1 | 1 |
| $\mathrm{SC}_{6}+$ | 1 | DL6 | $\mathrm{CB}_{6}$ | 1 | 1 | DL6 | DL7 |

*In CODE $\mathrm{ID}_{2-0} 011$ the Check-Bit Latch is forced transparent; the Data Input Latch operates normally.
tABLE XIX.

| PASS THRU Mode | CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 000 | 010 | 011* | 100 | 101 | 110 | 111 |
| $\mathrm{SC}_{0}$ | C0 | C0 | $\mathrm{CB}_{0}$ | C0 | 1 | 1 | 1 |
| $\mathrm{SC}_{1}$ | C1 | C1 | $\mathrm{CB}_{1}$ | C1 | 1 | 1 | 1 |
| $\mathrm{SC}_{2}-$ | C2 | C2 | $\mathrm{CB}_{2}$ | C2 | 1 | 1 | 1 |
| $\mathrm{SC}_{3}$ - | C3 | C3 | $\mathrm{CB}_{3}$ | C3 | 1 | 1 | 1 |
| $\mathrm{SC}_{4}+$ | C4 | C4 | $\mathrm{CB}_{4}$ | C 4 | 1 | 1 | 1 |
| $\mathrm{SC}_{5}$ - | C5 | C5 | $\mathrm{CB}_{5}$ | C5 | 1 | 1 | 1 |
| $\mathrm{SC}_{6}$ - | 1 | C6 | $\mathrm{CB}_{6}$ | 1 | 1 | C6 | C6 |

*In CODE $\mathrm{ID}_{2-0} 011$ the Check-Bit Latch is forced transparent; the Data Input Latch operates normally.

## Data Correction

Tables XX to XXVI shows which data output bits are corrected (inverted) depending upon the syndromes and the CODE ID position. Note that the syndromes that determine data correction are in some cases syndromes input externally via the $C B$

TABLE XX. CODE $I D_{2-0}=000^{*}$

|  | TABLE XX. CODE $\mathrm{ID}_{2-0}=000$ * |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \hline \text { S5 } \\ & \text { S4 } \\ & \text { S3 } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | 1 1 1 |
| S2 S1 |  |  |  |  |  |  |  |  |  |
| 00 |  | - | - | - | 5 | - | 11 | 14 | - |
| 01 |  | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 10 |  | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 11 |  | - | 0 | 4 | - | 10 | - | - | - |

*Unlisted S combinations are no correction.
inputs and in some cases syndromes generated internally by that EDC ( $\mathrm{S}_{\mathrm{i}}$ are the internal syndromes and are the same as the value of the $\mathrm{SC}_{\mathrm{i}}$ output of that EDC if enabled).

The tables show the number of data bit inverted (corrected) if any for the CODE ID and syndrome combination.

TABLE XXI. CODE $I D_{2-0}=010^{*}$

*Unlisted CB combinations are no correction.

TABLE XXII. CODE $\mathrm{ID}_{\mathbf{2 - 0}}=\mathbf{0 1 1 *}$

|  |  |  |  |  |  |  |  |  |  | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | S5 | 0 | 0 | $0$ | 0 | $1$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $1$ |  |
|  |  | S4 | 0 | 0 | 1 | 1 | 0 | 0 | 1 |  |
|  |  | S3 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |  |
|  | S1 |  |  |  |  |  |  |  |  |  |
| 0 | 0 |  | - | - | - | 5 | - | 11 | 14 | - |
| 0 | 1 |  | - | 1 | 2 | 6 | 8 | 12 | - | - |
| 1 | 0 |  | - | - | 3 | 7 | 9 | 13 | 15 | - |
| 1 | 1 |  | - | 0 | 4 | - | 10 | - | - | - |

*Unlisted S combinations are no correction.

TABLE XXIII. CODE $I_{2-0}=100^{*}$

| $\mathbf{C B}_{\mathbf{0}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{C B}_{6}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\mathbf{C B}_{5}$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| $\mathbf{C B}_{\mathbf{4}}$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $\mathbf{C B}_{3}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\mathbf{C B}_{\mathbf{2}} \mathbf{C B}_{1}$ |  |  |  |  |  |  |  |  |
| 0 | 0 | - | 11 | 14 | - | - | - | - |
| 0 | 1 | 8 | 12 | - | - | - | 1 | 2 |
| 1 | 0 | 9 | 13 | 15 | - | - | - | 3 |
| 1 | 1 | 10 | - | - | - | - | 0 | 4 |

*Unlisted CB combinations are no correction.

TABLE XXIV. CODE $\mathrm{ID}_{2-0}=101^{*}$

|  | $\mathbf{C B}_{\mathbf{0}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{C B}_{\mathbf{6}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\mathbf{C B}_{\mathbf{5}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\mathbf{C B}_{\mathbf{4}}$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $\mathbf{C B}_{\mathbf{3}}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\mathbf{C B}_{\mathbf{2}} \mathbf{C B}_{\mathbf{1}}$ |  |  |  |  |  |  |  |  |
| 0 | 0 | - | - | - | 5 | - | 11 | 14 |
| 0 | 1 | - | 1 | 2 | 6 | 8 | 12 | - |
| 1 | 0 | - | - | 3 | 7 | 9 | 13 | 15 |
| 1 | 1 | - | 0 | 4 | - | - |  |  |

*Unlisted CB combinations are no correction.

TABLE XXV. CODE $1 D_{2-0}=110^{*}$

|  | $\mathbf{C B}_{\mathbf{0}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{C B}_{6}$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| $\mathbf{C B}_{\mathbf{5}}$ | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| $\mathbf{C B}_{\mathbf{4}}$ | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| $\mathbf{C B}_{\mathbf{3}}$ | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |
| $\mathbf{C B}_{\mathbf{2}} \mathbf{C B}_{\mathbf{1}}$ |  |  |  |  |  |  |  |  |
| 0 | 0 | - | - | - | 5 | - | 11 | 14 |
| 0 | 1 | - | 1 | 2 | 6 | 8 | 12 | - |
| 1 | 0 | - | - | 3 | 7 | 9 | 13 | 15 |
| 1 | 1 | - | 0 | 4 | - | 10 | - | - |

*Unlisted CB combinations are no correction.

TABLE XXVI. CODE $\mathrm{ID}_{2-0}=111^{*}$

*Unlisted CB combinations are no correction.

## APPLICATIONS

## Byte Write

Byte operations are increasingly common for 16 -bit and 32 -bit processors. These complicate memory operations because check bits are generated for a complete 16-bit or 32-bit or 64bit memory word-not for a single byte.

To write a byte into memory with EDC requires the following steps:

- Latch the byte into the Am2961/62 bus buffers (Figure 15)
- Read the complete data word from memory (Figure 15)
- Correct the complete data word if necessary (Figure 15)
- Insert the byte to be written into the data word (Figure 16)
- Generate new check bits for the entire data word (Figure 16)
- Store the data word back into memory (Figure 16)
(In fact, these steps must be taken for any piece of data being written into memory that is not as wide as a full memory word.)

The Am2960 EDC is designed with the intent of keeping byte operations simple in EDC systems. The EDC has separate output enables for each byte in the Data Output Latch. As shown in Figures 15 and 16, this allows the data word to be read from memory, the new byte to be inserted among the old, and new check bits to be generated using less time and less hardware than if separate byte enables were not available.


AF000730

Figure 15. Byte Write, Phase 1: Read Out the Old Word and Correct


AF000730

Figure 16. Byte Write, Phase 2: Insert the New Byte, Generate Checks and Write Into Memory

## Diagnostics

EDC is used to boost the reliability of the overall system. It is necessary to also be able to check the operation of the EDC itself. For this reason the EDC has an internal control mode, a diagnostic latch, and two diagnostic modes.

To check that the EDC is functioning properly, the processor can put the EDC under software control by setting CODE ID 2 -0 to 001. This puts the EDC into Internal Control Mode. In Internal Control Mode the EDC is controlled by the contents of the Diagnostic Latch which is loaded from the DATA inputs under processor control.

The EDC is set into CORRECT Mode. The processor loads in a known set of check bits into the Diagnostic Latch, a known set of data bits into the Data In Latch, and forces data errors. The output of the EDC (syndromes, error flags, corrected data) is then compared against the expected responses. By exercising the EDC with a string of data/check combinations and comparing the output against the expected responses, the EDC can be fully checked out.

## Eight Bit Data Word

Eight bit MOS microprocessors can use EDC too. Only five check bits are required. The EDC configuration for eight bits is shown in Figure 17. It operates as does the normal 16-bit configuration with the upper byte fixed at 0 .

Check bit overhead for 8-bit data words can be reduced two ways. See the sections "Single Error Correction Only" and 'Reducing Check Bit Overhead.'


Figure 17. 8-Bit Configuration

## Other Word Widths

EDC on data words other than $8,16,32$, of 64 bits can be accomplished with the AM2960. In most cases the extra data bits can be forced to a constant, and EDC will proceed as normal. For example, a 24-bit data word is shown in Figure 18.

## Single Error Correction Only

The EDC normally corrects all single-bit errors and detects all double-bit and some triple-bit errors. To save one check bit per word, the ability to detect double bit errors can be sacrificed-single errors are still detected and corrected.


Figure 18. 24-Bit Configuration

| Data Bits | Check Bits Required |  |
| :---: | :---: | :---: |
|  | Single Error <br> Correction Only | Single Error Correct <br> \& Double Error Detect |
|  | 4 | 5 |
| 16 | 5 | 6 |
| 32 | 6 | 7 |
| 64 | 7 | 8 |



Figure 19. 8-Bit Single Error Correction Only


Figure 20. 16-Bit Single Error Correction Only


* The Code ID Combination for this Slice Forces the Check Bit Latch Transparent.

Figure 21. 32-Bit Single Correct Only


Notes: 1. In Pass Thru Mode the Contents of the Check Latch Appear on the XOR Outputs Inverted.
2. In Diagnostic Generate Mode the Contents of the Diagnostic Latch appear on the XOR Outputs Inverted.

Figure 22. 64-Bit Single Correct Only


Figure 23. Inhibition of Data Modification

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Case)
Under Bias $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continous -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State -0.5V to Vcc Max DC Input Voltage .-0.5 V to +5.5 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current
........ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Descriptions | Test Conditions (Note 1) |  |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ | $\mathrm{l}^{\mathrm{OH}}=-0.8 \mathrm{~mA}$ |  | COM'L | 2.7 |  |  | Volts |
|  |  |  |  |  | MIL | 2.4 |  |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ | $\mathrm{lOL}=8 \mathrm{~mA}$ |  |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | Guaranteed Input Logical HIGH Voltage for all Inputs (Note 7) |  |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Voltage | Guaranteed Input Logical LOW Voltage for all Inputs (Note 7) |  |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{\mathbb{N}}=0.5 \mathrm{~V} \\ & \hline \end{aligned}$ | DATA $_{0-15}$ |  |  |  |  | -410 | $\mu \mathrm{A}$ |
|  |  |  | All Other Inputs |  |  |  |  | -360 |  |
| IIH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | DATA $_{0-15}$ |  |  |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  | All Other Inputs |  |  |  |  | 50 |  |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| $\begin{aligned} & \text { lozh } \\ & \text { lozL } \end{aligned}$ | Off State (High Impedance) Output Current | VCC MAX | DATA0-15 |  | $\mathrm{V}_{\mathrm{O}}=2.4$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5$ |  |  | -410 |  |
|  |  |  | $\mathrm{SC}_{0-6}$ |  | $\mathrm{V}_{\mathrm{O}}=2.4$ |  |  | 50 |  |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5$ |  |  | -50 |  |
| Ios | Output Short Circuit Current (Note 3) | $V_{C C}=V_{C C} M A X+0.5 V, V_{O}=0.5 \mathrm{~V}$ |  |  |  | -25 |  | -85 | mA |
| ICC | Power Supply Current (Note 6) | $V_{C C}=M A X$ |  | $\mathrm{T}_{\mathrm{A}}=$ |  |  | 275 | 390 | mA |
|  |  |  | COM'L | $T_{A}=$ | $+70^{\circ} \mathrm{C}$ |  |  | 400 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=$ |  |  |  | 365 |  |
|  |  |  | MIL | $\mathrm{T}_{\mathrm{C}}=$ | to $+125^{\circ} \mathrm{C}$ |  |  | 400 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=$ | $5^{\circ} \mathrm{C}$ |  |  | 345 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. These are three-state outputs internally connected to TTL inputs. Input Characteristics are measured with output enables HIGH.
5. "MIL" = Am2960XM, DM, FM. "COM'L" = Am2960XC, DC.
6. Worst case ICC is at minimum temperature.
7. These input levels provide zero noise immunity and should only be tested in a static, noise-free environment.


TEST OUTPUT LOADS

| Pin \＃ | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | $\mathrm{D}_{0}-\mathrm{D}_{15}$ | Fig． 24 | $430 \Omega$ | $1 \mathrm{~K} \Omega$ |
| $24-30$ | $\mathrm{SC}_{0}-\mathrm{SC}_{6}$ | Fig． 24 | $430 \Omega$ | $1 \mathrm{~K} \Omega$ |
| 32 | ERROR | Fig． 25 | $470 \Omega$ | $3 \mathrm{k} \Omega$ |
| 33 | $\overline{\text { MULTERROR }}$ | Fig． 25 | $470 \Omega$ | $3 \mathrm{~K} \Omega$ |

For additional information on testing，see section ＇＇Guidelines on Testing Am2900 Family Devices．＇

## Notes on Testing

Incoming test procedures on this device should be carefully planned，taking into account the complexity and power levels of the part．The following notes may be useful．
1．Insure the part is adequately decoupled at the test head． Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes．

2．Do not leave inputs floating during any tests，as they may start to oscillate at high frequency．

3．Do not attempt to perform threshold tests at high speed． Following an input transition，ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$ ．Inductance in the ground cable may allow the ground pin at the device to rise by 100＇s of millivolts momentarily．
4．Use extreme care in defining input levels for AC tests．Many inputs may be changed at once，so there will be significant
noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $V_{\text {IH }}$ until the noise has settled．AMD recommends using $V_{I L} \leqslant 0.4 \mathrm{~V}$ and $\mathrm{V}_{1 \mathrm{H}} \leqslant 2.4 \mathrm{~V}$ for AC tests．

5．To simplify failure analysis，programs should be designed to perform DC，Function，and AC tests as three distinct groups of tests．

6．To assist in testing，AMD offers documentation on our test procedures and，in most cases，can provide Fairchild Sentry programs，under license．

7．Changing the CODE ID inputs can cause loss of data in some of the Am2960 internal latches．Specifically，the entire checkbit latch and bits 6 and 7 of the diagnostic latch are indeterminate after a change in CODE ID inputs．
Logic simulations should store＇$x$＇（i．e．，＇＇don＇t care＇）in these bits after CODE ID change．Test programs should reload these registers before they are used．

## 1. Am2960 Guaranteed Commercial Range Performance

The tables below specify the guaranteed performance of the Am2960 over the commercial operating range of $0^{\circ} \mathrm{C}$ to
$+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{CC}}$ from 4.75 V to 5.25 V . All data are in ns, with inputs switching between $O \mathrm{~V}$ and 3 V at $1 \mathrm{~V} /$ ns and measurements made at 1.5 V . All outputs have maximum DC load.

This data applies to the following part numbers: Am2960DC, XC.

## A. Combinational Propagation Delays

$C_{L}=50 \mathrm{pF}$

| From Input | To Output |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{SC}_{0-6}$ | DATA ${ }_{0-15}$ | ERROR | MULT ERROR |
| DATA $0-15$ | 32 | 65* | 32 | 50 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE } \mathrm{ID}_{2-0} 000,011 \text { ) } \end{aligned}$ | 28 | 56 | 29 | 47 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE } \mathrm{ID}_{2-0} 010,100, \\ & 101,110,111 \text { ) } \\ & \hline \end{aligned}$ | 28 | 45 | 29 | 34 |
| GENERATE | 35 | 63 | 36 | 55 |
| CORRECT <br> (Not Internal Control Mode) | - | 45 | - | - |
| DIAG MODE <br> (Not Internal Control Mode) | 50 | 78 | 59 | 75 |
| PASS THRU <br> (Not Internal Control Mode) | 36 | 44 | 29 | 46 |
| CODE $\mathrm{ID}_{2-0}$ | 61 | 90 | 60 | 80 |
| LE IN (From latçhed to transparent) | 39 | 72* | 39 | 59 |
| LE OUT <br> (From latched to transparent) | - | 31 | - | - |
| LE DIAG <br> (From latched to transparent; Not Internal Control Mode) | 45 | 78 | 45 | 65 |
| Internal Control Mode: <br> LE DIAG <br> (From latched to transparent) | 67 | 96 | 66 | 86 |
| Internal Control Mode: <br> DATA 0.15 <br> (Via Diagnostic Latch) | 67 | 96 | 66 | 86 |

*Data In (or LE In) to Correct Data Out measurement requires timing as shown in Figure D opposite.
B. Set-up and Hold Times Relative to Latch Enables

| From Input | To (Latching Up Data) | Set-up Time | Hold <br> Time |
| :---: | :---: | :---: | :---: |
| DATA0-15 | LE IN | 6 | 7 |
| $\mathrm{CB}_{0-6}$ | LE IN | 5 | 6 |
| DATA0-15 | LE OUT | 44 | 5 |
| $\mathrm{CB}_{0-6}$ (CODE ID 000, 011) | LE OUT | 35 | 0 |
| $\mathrm{CB}_{0-6}$ <br> (CODE ID 010, <br> 100, 101, 110, 111) | LE OUT | 27 | 0 |
| GENERATE | LE OUT | 42 | 0 |
| CORRECT | LE OUT | 26 | 1 |
| DIAG MODE | LE OUT | 69 | 0 |
| PASS THRU | LE OUT | 26 | 0 |
| CODE ID 2.0 | LE OUT | 81 | 0 |
| LE IN | LE OUT | 51 | 5 |
| DATA $_{0-15}$ | LE DIAG | 6 | 8 |

C. Output Enable/Disable Times

Output disable tests performed with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ and measured to 0.5 V change of output voltage level.

| Input | Output | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\overline{\text { OE BYTE 0, }}$OE BYTE 1 | DATA $_{0-15}$ | 30 | 30 |
| $\overline{\mathrm{OE} ~ S C ~}$ | $\mathrm{SC}_{0-6}$ | 30 | 30 |



Figure D.

## 1. Am2960 Guaranteed Military Range Performance

The tables below specify the guaranteed performance of the Am2960 over the military operating range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ case temperature, with $\mathrm{V}_{\mathrm{CC}}$ from 4.5 V to 5.5 V . All
data are in ns , with inputs switching between 0 V and 3 V at $1 \mathrm{~V} /$ ns and measurements made at 1.5 V . All outputs have maximum DC load.

This data applies to the following part numbers: Am2960DM, FM, XM.
A. Combinational Propagation Delays
$C_{L}=50 \mathrm{pF}$

| From Input | To Output |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | SC0-6 | DATA ${ }_{\text {0-15 }}$ | ERROR | MULT ERROR |
| DATA $_{0-15}$ | 35 | 73* | 36 | 56 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE ID } 2-0000,011 \text { ) } \\ & \hline \end{aligned}$ | 30 | 61 | 31 | 50 |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE ID } \\ & 101,110,111 \text { ) } \\ & \hline \end{aligned}$ | 30 | 50 | 31 | 37 |
| GENERATE | 38 | 69 | 41 | 62 |
| $\begin{aligned} & \text { CORRECT } \\ & \text { (Not Internal Control Mode) } \end{aligned}$ | - | 49 | - | - |
| $\begin{aligned} & \text { DIAG MODE } \\ & \text { (Not Internal Control Mode) } \end{aligned}$ | 58 | 89 | 65 | 90 |
| $\begin{aligned} & \text { PASS THRU } \\ & \text { (Not Internal Control Mode) } \end{aligned}$ | 39 | 51 | 34 | 54 |
| CODE $\mathrm{ID}_{2-0}$ | 69 | 100 | 68 | 90 |
| LE IN <br> (From latched to transparent) | 44 | 82* | 43 | 66 |
| LE OUT <br> (From latched to transparent) | - | 33 | - | - |
| LE DIAG (From latched to transparent; Not Internal Control Mode) | 50 | 88 | 49 | 72 |
| Internal Control Mode: LE DIAG <br> (From latched to transparent) | 75 | 106 | 74 | 96 |
| Internal Control Mode: <br> DATA ${ }_{0-15}$ <br> (Via Diagnostic Latch) | 75 | 106 | 74 | 96 |

*Data In (or LE In) to Correct Data Out measurement requires timing as shown in Figure D opposite.
B. Set-up and Hold Times Relative to Latch Enables

| From Input | To <br> (Latching <br> Up Data) | Set-up <br> Time | Hold <br> Time |
| :--- | :--- | :---: | :---: |
| ${\text { DATA } A_{0-15}}^{\text {LE IN }}$ | 7 | 7 |  |
| ${\text { CB } 0_{0-6}}^{\text {LE IN }}$ | 5 | 7 |  |
| DATA $_{0-15}$ | LE OUT | 50 | 5 |
| CB <br> (CODE ID <br> O00, 011) | LE OUT | 38 | 0 |
| CB <br> (CODE ID 010, <br> 100, 101, 110, 111) | LE OUT | 30 | 0 |
| GENERATE | LE OUT | 46 | 0 |
| CORRECT | LE OUT | 28 | 1 |
| DIAG MODE | LE OUT | 84 | 0 |
| PASS THRU | LE OUT | 30 | 0 |
| CODE ID $2-0$ | LE OUT | 89 | 0 |
| LE IN | LE OUT | 59 | 5 |
| DATA | LE DIAG | 7 | 9 |

## C. Output Enable/Disable Times

Output disable tests performed with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ and measured to 0.5 V change of output voltage level.

| Input | Output | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\overline{\mathrm{OE}}$ BYTE 0, | DATA $_{0-15}$ | 35 | 35 |
| $\overline{\mathrm{OE}}$ BYTE 1 | SC $_{0-6}$ | 35 | 35 |

## D. Minimum Pulse Widths

| LE IN, LE OUT, LE DIAG | 15 |
| :--- | :--- |



Figure D.

## Am2960A Guaranteed Commercial Range Performance

The tables below specify the guaranteed performance of the Am2960A over the commercial operating range of $0^{\circ} \mathrm{C}$ to
$+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{CC}}$ from 4.75 V to 5.25 V . All data are in ns , with inputs switching between $O \mathrm{~V}$ and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.

This data applies to the following part numbers: Am2960ADC XC.
A. Combinational Propagation Delays
$C_{L}=50 \mathrm{pF}$

| From Input | To Output |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | SCo-6 | DATA0-15 | ERROR | MULT ERROR |
| DATA ${ }_{0-15}$ |  |  |  |  |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE } \mathrm{ID}_{2-0} 000,011 \text { ) } \end{aligned}$ |  |  |  |  |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \left(\mathrm{CODE} \mathrm{ID}_{2-0} 010,100\right. \text {, } \\ & 101,110,111 \text { ) } \end{aligned}$ |  |  |  |  |
| GENERATE |  |  |  |  |
| CORRECT <br> (Not internal Control Mode) |  |  |  |  |
| DIAG MODE <br> (Not Internal Control Mode) |  |  |  |  |
| PASS THRU <br> (Not Internal Control Mode) |  |  |  |  |
| CODE $\mathrm{ID}_{2-0}$ |  |  |  |  |
| LE IN <br> (From latched to transparent) |  |  |  |  |
| LE OUT <br> (From latched to transparent) |  |  |  |  |
| LE DIAG <br> (From latched to transparent; Not Internal Control Mode) |  |  |  |  |
| Internal Control Mode: <br> LE DIAG <br> (From latched to transparent) |  |  |  |  |
| Internal Control Mode: DATA ${ }_{0-15}$ <br> (Via Diagnostic Latch) |  |  |  |  |

*Data $\ln$ (or LE In) to Correct Data Out measurement requires timing as shown in Figure D opposite.
B. Set-up and Hold Times Relative to Latch Enables

| From Input | To (Latching Up Data) | Set-up Time | Hold <br> Time |
| :---: | :---: | :---: | :---: |
| DATA $_{0-15}$ | LE $\mathbb{N}$ |  |  |
| $\mathrm{CB}_{0-6}$ | LE IN |  |  |
| DATA0-15 | LE OUT |  |  |
| $\mathrm{CB}_{0-6}$ (CODE ID 000, 011) | LE OUT |  |  |
| $\mathrm{CB}_{0-6}$ <br> (CODE ID 010, <br> $100,101,110,111)$ | LE OUT |  |  |
| GENERATE | LE OUT |  |  |
| CORRECT | LE OUT |  |  |
| DIAG MODE | LE OUT |  |  |
| PASS THRU | LE OUT |  |  |
| CODE $\mathrm{ID}_{2-0}$ | LE OUT |  |  |
| LE IN | LE OUT |  |  |
| DATA $_{0-15}$ | LE DIAG |  |  |

C. Output Enable/Disable Times

Output disable tests performed with $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ and measured to 0.5 V change of output voltage level.

| Input | Output | Enable | Disable |
| :--- | :--- | :--- | :--- |
| $\overline{\text { OE BYTE 0, }}$ |  |  |  |
| OE BYTE 1 | DATAO-15 |  |  |
| $\overline{O E}$ SC | $S_{0-6}$ |  |  |

## D. Minimum Pulse Widths

| LE IN, LE OUT, LE DIAG |  |
| :--- | :--- |



Figure D.

## Am2960A Guaranteed Military Range Performance

The tables below specify the guaranteed performance of the Am2960A over the military operating range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ case temperature, with $\mathrm{V}_{\mathrm{CC}}$ from 4.5 V to 5.5 V . All
data are in ns , with inputs switching between OV and 3 V at $1 \mathrm{~V} /$ ns and measurements made at 1.5 V . All outputs have the maximum DC load.

This data applies to the following part numbers: Am2960ADM, FM, XM.

## A. Combinational Propagation Delays

$$
C_{L}=50 p \mathrm{~F}
$$

| From Input | To Output |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{S C}_{0-6}$ | DATA 0 -15 | ERROR | MULT ERROR |
| DATA ${ }_{\text {- } 15}$ |  |  |  |  |
| $\begin{aligned} & \mathrm{CB}_{0-6} \\ & \text { (CODE } \\ & \hline \end{aligned}$ |  |  |  |  |
| $\begin{aligned} & \text { CB0.6 } \\ & \text { (CODE } \mathrm{CD}_{2-0010,100,} \\ & 101,110,111) \end{aligned}$ |  |  |  |  |
| GENERATE |  |  |  |  |
| CORRECT <br> (Not Internal Control Mode) |  |  |  |  |
| DIAG MODE <br> (Not Internal Control Mode) |  |  |  |  |
| PASS THRU (Not Internal Control Mode) |  |  |  |  |
| CODE 1D2-0 |  |  |  |  |
| LE IN <br> (From latched to transparent) |  |  |  |  |
| LE OUT <br> (From latched to transparent) |  |  |  |  |
| LE DIAG <br> (From latched to transparent; Not Internal Control Mode) |  |  |  |  |
| Internal Control Mode: <br> LE DIAG <br> (From latched to transparent) |  |  |  |  |
| Internal Control Mode: DATA ${ }_{0-15}$ (Via Diagnostic Latch) |  |  |  |  |

*Data In (or LE In) to Correct Data Out measurement requires timing as shown in Figure D opposite.

| From Input | To (Latching Up Data) | Set-up Time | Hold Time |
| :---: | :---: | :---: | :---: |
| DATA ${ }_{0-15}$ | LE IN |  |  |
| $\mathrm{CB}_{0-6}$ | LE IN |  |  |
| DATA0-15 | LE OUT |  |  |
| $\mathrm{CB}_{0-6}$ <br> (CODE ID <br> 000, 011) | LE OUT |  |  |
| $\mathrm{CB}_{0-6}$ <br> (CODE ID 010, <br> 100, 101, 110, 111) | LE OUT |  |  |
| GENERATE | LE OUT |  |  |
| CORRECT | LE OUT |  |  |
| DIAG MODE | LE OUT |  |  |
| PASS THRU | LE OUT |  |  |
| CODE $\mathrm{ID}_{2-0}$ | LE OUT |  |  |
| LE IN | LE OUT |  |  |
| DATA $_{0-15}$ | LE DIAG |  |  |



Figure D.

## Am2961/Am2962

## 4-Bit Error Correction Multiple Bus Buffers

## DISTINCTIVE CHARACTERISTICS

- Provides complete data path interface between the Am2960 Error Detection and Correction Unit, the system data bus and dynamic RAM memory
- Three-state 24 mA output to data bus
- Three-state data output to memory
- Inverting data bus for Am2961 and noninverting for Am2962
- Data bus latches allow operation with multiplexed buses
- Space saving 24-pin 0.3" package

GENERAL DESCRIPTION

The Am2961 and Am2962 are high-performance, lowpower Schottky multipie bus buffers that provide the complete data path interface between the Am2960 Error Detection and Correction Unit, dynamic RAM memory and the system data bus. The Am2961 provides an inverting data path between the data bus $\left(\mathrm{B}_{\mathrm{i}}\right)$ and the Am2960 error correction data input $\left(\mathrm{Y}_{\mathrm{i}}\right)$ and the Am2962 provides a noninverting configuration ( $B_{j}$ to $Y_{i}$ ). Both devices provide inverting data paths between the Am2960 and memory data bus, thereby optimizing internal data path speeds.

The Am2961 and Am2962 are 4-bit devices. Four devices are used to interface each 16-bit Am2960 Error Detection and Correction Unit with dynamic memory. The system can easily be expanded to 32 or more bits for wider memory applications. The 4-bit configuration allows enabling the appropriate devices two-at-a-time for intermixed word or byte, read and write in 16-bit systems with error correction.

Data latches between the error correction data bus and the system data bus facilitate byte writing in memory systems wider than 8-bits. They also provide a data holding capability during single-step system operation.

## BLOCK DIAGRAM



BD001170
*Am2962 is the same function but noninverting to the system data bus, B.

## ADVANCED INFORMATION

- 25-30\% speed improvement plug-in replacements for Am2961/ Am2962.



FUNCTION TABLES

Y-BUS OUTPUT

| LEY | $\overline{\text { DII }}_{\mathbf{I}}$ | $\bar{B}_{1}{ }^{*}$ <br> Am2961 | $\mathbf{B}_{1}{ }^{*}$ <br> Am2962 | s | OEY | Y |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | L | Z |
| X | L | X | X | L | H | H |
| X | H | X | X | L | H | L |
| H | X | L | H | H | H | H |
| H | X | H | L | H | H | L |
| L | X | X | X | H | H | NC |

${ }^{*} \overline{\mathrm{OEB}}=\mathrm{HIGH}$ for $B$ data input

| $\mathbf{Y}$ | $\overline{\mathbf{O E D}}$ | $\overline{\mathbf{D O}}$ |
| :---: | :---: | :---: |
| $\mathbf{X}$ | $H$ | $Z$ |
| $L$ | $L$ | $H$ |
| $H$ | $L$ | $L$ |


＊Since the EDC Data Bus Buffers are four－bit wide devices，controls can be paired to device inputs to provide byte level controls （for any data width）．

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature Under Bias

Power Applied $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continous． $\qquad$
DC Voltage Applied to Outputs For
High Output State $\qquad$ －0．5V to VCC Max
DC Input Voltage $\qquad$
DC Output Current，Into Outputs ．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．． 30 mA
DC Input Current ．．．．．．．．．．．．．．．．．．．．．．．．．．．．．－30mA to＋5．0mA
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 device reliability．

## OPERATING RANGES



Supply Voltage ．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．．+4.5 V to +5.5 V Operating ranges define those limits over which the function－ ality of the device is guaranteed．

## DC CHARACTERISTICS OVER OPERATING RANGE－Y BUS

| Parameters | Descriptions | Test Conditions（Note 1） |  | Min | Typ <br> （Note 2） | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{array}{\|l\|} \hline V_{C C}=M I N \\ V_{I N}=V_{I H} \text { or } V_{I L} \\ \hline \end{array}$ | $\mathrm{IOH}=-3.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{\mathrm{IL}} \end{aligned}$ | $\mathrm{IOL}=8 \mathrm{~mA}$ |  | 0.3 | 0.45 | Volts |
|  |  |  | $\mathrm{lOL}=16 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 | ， |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs | MIL |  |  | 0.7 | Volts |
|  |  |  | COM＇L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  |  | －1．5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ | OEY＝LOW |  |  | －2．0 | mA |
| IIH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ | OEY＝LOW |  |  | 100 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ | OEY＝LOW |  |  | 1.0 | mA |
| ISC | Output Short Circuit Current （Note 3） | $V_{C C}=M A X$ |  | －30 |  | －130 | mA |

DC CHARACTERISTICS OVER OPERATING RANGE－B BUS

| Parameters | Descriptions | Test Conditions（Note 1） |  | Min | Typ <br> （Note 2） | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH |  | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ | $\mathrm{IOH}^{2}=-3.0 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  | Output HIGH Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2.0 |  |  |  |
| 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}$ | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.3 | 0.45 | Volts |
|  |  |  | $\mathrm{IOL}=24 \mathrm{~mA}$ |  | 0.35 | 0.50 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
|  |  | Guaranteed input logical LOW voltage for all inputs | MIL |  |  | 0.7 | Volts |
| $V_{\text {IL }}$ | Input LOW Level |  | COM＇L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{lin}^{2}=-18 \mathrm{~mA}$ |  |  |  | －1．5 | Volts |
| IIL | Input LOW Current | $V_{C C}=$ MAX，$V_{1 N}=0.4 \mathrm{~V}$ | $\overline{\mathrm{OEB}}=\mathrm{HIGH}$ |  |  | －1．0 | mA |
| 1 H | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ | $\overline{O E B}=\mathrm{HIGH}$ |  |  | 100 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ | $\overline{\mathrm{OEB}}=\mathrm{HIGH}$ |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current （Note 3） | $V_{C C}=$ MAX |  | －50 |  | －150 | mA |

Notes：1．For conditions as MIN or MAX，use the appropriate value specified under Operating Range for the applicable device type． 2．Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading．
3．Not more than one output should be shorted at a time．Duration of the short circuit test should not exceed one second．


## SWITCHING TEST CIRCUIT



Figure 1.


Figure 2.


Figure 3.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*
Am2961

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Propagation Delay $\overline{\mathrm{B}}$ to Y (Latch Transparent, OEY $=$ LEY $=$ HIGH ) | Figure 1$C_{L}=5 \mathrm{pF}$ |  | 25 |  | 28 | ns |
| tPHL |  |  |  | 25 |  | 28 | ns |
| tplu | Propagation Delay DI to $Y$ (OEY = HIGH, $S=$ LOW) |  |  | 15 |  | 18 | ns |
| tPHL |  |  |  | 15 |  | 18 | ns |
| tple | Propagation Delay $S$ to $Y$ ( $\mathrm{OEY}=\mathrm{HIGH}$ ) |  |  | 25 |  | 28 | ns |
| tPHL |  |  |  | 25 |  | 28 | ns |
| tpLH | Propagation Delay LEY to $Y$ ( $\mathrm{OEY}=\mathrm{S}=\mathrm{HIGH}$ ) |  |  | 25 |  | 30 | ns |
| $\mathrm{tPHL}^{\text {chen }}$ |  |  |  | 35 |  | 40 | ns |
| tpZH | Y Bus Output Enable Time OEY to $Y$ |  |  | 18 |  | 21 | ns |
| tpZL |  |  |  | 18 |  | 21 | ns |
| tPHZ | Y Bus Output Disable Time OEY to Y |  |  | 18 |  | 21 | ns |
| tplz |  |  |  | 18 |  | 21 | ns |
| tpLH | Propagation Delay LEB to $\bar{B}$ ( $\overline{\mathrm{OEB}}=\mathrm{LOW}$ ) | Figure 1 $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$$R_{L}=270 \Omega$$\mathrm{R}_{2}=1 \mathrm{k} \Omega$ |  | 25 |  | 30 | ns |
| tPHL |  |  |  | 35 |  | 40 | ns |
| tpl | Propagation Delay $Y$ to $\bar{B}$ (Latch Transparent, $L E B=H I G H, O E B=L O W, O E Y=L O W$ ) |  |  | 18 |  | 21 | ns |
| tPHL |  |  |  | 20 |  | 23 | ns |
| tPLH | Propagation Delay $Y$ to $\bar{B}$ (Latch Transparent, $\mathrm{LEB}=\mathrm{HIGH}, \overline{\mathrm{OEB}}=\mathrm{LOW}, \mathrm{OEY}=\mathrm{LOW}$ ) | Figure 1$\begin{aligned} & C_{L}=300 \mathrm{pF} \\ & R_{L}=270 \Omega \\ & R_{2}=1 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | 26 |  | 30 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 31 |  | 35 | ns |
| tPZH | $\bar{B}$ Bus Output Enable Time $\overline{O E B}$ to $\bar{B}$ | Figure 1 <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> $R_{L}=270 \Omega$ <br> $R_{2}=1 \mathrm{k} \Omega$ |  | 18 |  | 21 | ns |
| tPZL |  |  |  | 18 |  | 21 | ns |
| tplz | $\bar{B}$ Bus Output Disable Time $\overline{O E B}$ to $\bar{B}$ |  |  | 18 |  | 21 | ns |
| tphz |  |  |  | 18 |  | 21 | ns |
| tpLH | Propagation Delay Y to $\overline{\mathrm{DO}}$ (OED = OEY = LOW) | Figure 2$\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{PF} \\ \mathrm{R} & =2 \mathrm{k} \Omega \end{aligned}$ |  | 15 |  | 18 | ns |
| tPHL |  |  |  | 20 |  | 23 | ns |
| tPZH | $\overline{\mathrm{DO}}$ Output Enable Time OED to DO | Figure 3 $C_{L}=50 \mathrm{pF}$$R=680 \Omega$ |  | 28 |  | 30 | ns |
| tPZL |  |  |  | 28 |  | 30 | ns |
| tPHZ | $\overline{\mathrm{DO}}$ Output Disable Time OED to DO |  |  | 16 |  | 18 | ns |
| tPLZ |  |  |  | 24 |  | 28 | ns |
| ts | $\overline{\mathrm{B}}$ to LEY Set-up Time $(\overline{\mathrm{OEB}}=\mathrm{HIGH})$ | Figure 1$\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=390 \Omega \\ & \mathrm{R}_{2}=1 \mathrm{k} \Omega \\ & \hline \end{aligned}$ | 6 |  | 6 |  | ns |
| $t_{H}$ | $\bar{B}$ to LEY Hold Time ( $\overline{\mathrm{OEB}}=\mathrm{HIGH}$ ) |  | 9 |  | 10 |  | ns |
| ts | $Y$ to LEB Set-up Time ( $O E Y=$ LOW $)$ | Figure 1 <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> $R_{\mathrm{L}}=270 \Omega$ <br> $\mathrm{R}_{2}=1 \mathrm{k} \Omega$ | 6 |  | 6 |  | ns |
| $\mathrm{tH}_{\mathrm{H}}$ | $Y$ to LEB Hold Time (OEY = LOW) |  | 9 |  | 10 |  | ns |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*
Am2962

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Propagation Delay B to $Y$ (Latch Transparent, OEY = LEY = HIGH) | Figure 1$\begin{aligned} C_{L} & =5 p F \\ R_{L} & =390 \Omega \\ R_{2} & =1 \mathrm{k} \Omega \end{aligned}$ |  | 27 |  | 28 | ns |
| tphL |  |  |  | 27 |  | 28 | ns |
| tplH | Propagation Delay $\overline{\mathrm{DI}}$ to Y (OEY = HIGH, S = LOW) |  |  | 15 |  | 18 | ns |
| $\mathrm{t}^{\text {PHL }}$ |  |  |  | 15 |  | 18 | ns |
| tple | Propagation Delay S to Y ( $\mathrm{OEY}=\mathrm{HIGH}$ ) |  |  | 25 |  | 28 | ns |
| tPHL |  |  |  | 25 |  | 30 | ns |
| tple | Propagation Delay LEY to Y ( $O E Y=S=H I G H$ ) |  |  | 25 |  | 30 | ns |
| tPHL |  |  |  | 35 |  | 40 | ns |
| tPZH | Y Bus Output Enable Time OEY to $Y$ |  |  | 18 |  | 21 | ns |
| $\mathrm{t}_{\mathrm{PZL}}$ |  |  |  | 18 |  | 21 | ns |
| tphz | Y Bus Output Disable Time OEY to $Y$ |  |  | 18 |  | 21 | ns |
| tplz |  |  |  | 18 |  | 21 | ns |
| tplH | Propagation Delay LEB to B ( $\overline{\mathrm{OEB}}=\mathrm{LOW}$ ) | Figure 1 <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> $R_{L}=270 \Omega$ <br> $\mathrm{R}_{2}=1 \mathrm{k} \Omega$ |  | 25 |  | 30 | ns |
| tpHL |  |  |  | 35 |  | 40 | ns |
| tplH | Propagation Delay Y to B (Latch Transparent, $L E B=H I G H, \overline{O E B}=L O W, O E Y=L O W)$ |  |  | 20 |  | 23 | ns |
| tPHL |  |  |  | 21 |  | 24 | ns |
| tplH | Propagation Delay Y to B (Latch Transparent, $\mathrm{LEB}=\mathrm{HIGH}, \overline{\mathrm{OEB}}=\mathrm{LOW}, \mathrm{OEY}=\mathrm{LOW}$ ) | Figure 1$\begin{aligned} C_{L} & =300 \mathrm{p} \\ R_{L} & =270 \Omega \\ R_{2} & =1 \mathrm{k} \Omega \end{aligned}$ |  | 28 |  | 32 | ns |
| tPHL |  |  |  | 32 |  | 36 | ns |
| tpZH | B Bus Output Enable Time OEB to B | Figure 1 <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> $R_{\mathrm{L}}=270 \Omega$ $R_{2}=1 \mathrm{k} \Omega$ |  | 18 |  | 21 | ns |
| tpZL |  |  |  | 18 |  | 21 | ns |
| tplZ | B Bus Output Disable Time $\overline{O E B}$ to B |  |  | 18 |  | 21 | ns |
| tpHz |  |  |  | 18 |  | 21 | ns |
| tpLH | Propagation Delay $Y$ to $\overline{\mathrm{DO}}$ ( $\overline{O E D}=$ OEY = LOW) | Figure 2$\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R} & =2 \mathrm{~K} \Omega \end{aligned}$ |  | 15 |  | 18 | ns |
| tpHL |  |  |  | 20 |  | 23 | ns |
| tpZH | $\overline{\mathrm{DO}}$ Output Enable Time OED to DO | $S=2$ <br> $S=1$ <br> $S=2$ <br> $S=1$ <br> Figure 3 <br> $C_{L}=50 \mathrm{pF}$ <br> $R=680 \Omega$ |  | 28 |  | 30 | ns |
| tpZL |  |  |  | 28 |  | 30 | ns |
| tphz | $\overline{\mathrm{DO}}$ Output Disable Time $\overline{O E D}$ to $\overline{D O}$ |  |  | 16 |  | 18 | ns |
| tplZ |  |  |  | 24 |  | 28 | ns |
| ts | $B$ to LEY Set-up Time ( $\overline{\mathrm{OEB}}=\mathrm{HIGH}$ ) | Figure 1 <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> $R_{\mathrm{L}}=390 \Omega$ <br> $\mathrm{R}_{2}=1 \mathrm{k} \Omega$ | 8 |  | 8 |  | ns |
| $t_{H}$ | $B$ to LEY Hold Time ( $\overline{\mathrm{OEB}}=\mathrm{HIGH}$ ) |  | 8 |  | 9 |  | ns |
| ts | $Y$ to LEB Set-up Time (OEY = LOW) | Figure 1$\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =270 \Omega \\ R_{2} & =1 \mathrm{k} \Omega \end{aligned}$ | 8 |  | 8 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | $Y$ to LEB Hold Time (OEY = LOW) |  | 8 |  | 9 |  | ns |

[^3]
## Am2964B/Am2964C*

## Dynamic Memory Controller

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Dynamic Memory Controller for 16 K and 64 K MOS dynamic RAMs
- 8-Bit Refresh Counter for refresh address generation, has clear input and terminal count output
- Refresh Counter terminal count selectable at 256 or 128
- Latch input $\overline{\text { RAS }}$ Decoder provides $4 \overline{\text { RAS }}$ outputs, all active during refresh
- Dual 8-Bit Address Latches plus separate $\overline{\text { RAS }}$ Decoder Latches
- Burst mode, distributed refresh or transparent refresh mode determined by user


## GENERAL DESCRIPTION

The Am2964B Dynamic Memory Controller (DMC) replaces a dozen MSI devices by grouping several unique functions. Two 8-bit latches capture and hold the memory address. These latches and a clearable, 8 -bit refresh counter feed into an 8 -bit, 3 -input, Schottky speed MUX for output to the dynamic RAM address lines.

The same silicon chip also includes a special $\overline{\mathrm{RAS}}$ decoder and CAS buffer. Placing these functions on the same chip minimizes the time skew between output functions which would otherwise be separate MSI chips, and therefore allows a faster memory cycle time by the amount of skew eliminated.

The $\overline{\text { RAS }}$ Decoder allows upper addresses to select one-offour banks of RAM by determining which bank receives a $\overline{\mathrm{RAS}}$ input. During refresh ( $\overline{\mathrm{RFSH}}=\mathrm{LOW}$ ) the decoder mode is changed to four-of-four and all banks of memory receive a $\overline{\text { RAS }}$ input for refresh in response to a $\overline{\text { RASI }}$ active LOW input. CAS is inhibited during refresh.
Burst mode refresh is accomplished by holding RFSH LOW and toggling RASI.
$A_{15}$ is a dual function input which controls the refresh counter's range. For 64K RAMs it is an address input. For 16 K RAMs it can be pulled to +12 V through $1 \mathrm{~K} \Omega$ to terminate the refresh count at 128 instead of 256.

BLOCK DIAGRAM


## ADVANCED INFORMATION

## Am2964C

- Uses ECL internal circuitry with $I M O X^{T M}$ processing to offer higher performance
- Plug-in replacement for Am2964B
Note：Pin 1 is marked for orientation
METALLIZATION AND PAD LAYOUT

DIE SIZE $0.156^{\prime \prime} \times \mathbf{0 . 1 4 3 "}$


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges．The order number is formed by a combination of the following： Device number，speed option（if applicable），package type，operating range and screening option（if desired）．

```
Am2964B
```



```
Device type Dynamic Memory Controller
```

| Valid Combinations |  |
| :--- | :--- |
| Am2964B | DC，DCB，DM，DMB |
| Am2964C | LC，LM，LMB |
|  | XC，XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish．

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{0}-\mathrm{A}_{7}$ | 1 | The low order Address inputs are used to latch eight Row Address inputs for the RAM. These inputs drive the outputs $\mathrm{O}_{0}-\mathrm{O}_{7}$ when MSEL is HIGH. |
|  | $\mathrm{A}_{8}-\mathrm{A}_{15}$ | 1 | The high order Address inputs are used to latch eight Column Address inputs for the RAM. These inputs drive the outputs $\mathrm{O}_{0}-\mathrm{O}_{7}$ when MSEL is LOW. |
| 11 | $\mathrm{A}_{15}$ | 1 | $A_{15}$ is a dual input. With normal TTL level inputs $A_{15}$ acts as address input $A_{15}$ for 64 K RAMs. If $A_{15}$ is pulled up to +12 V through a $1 \mathrm{~K} \Omega$ resistor, the terminal count output. TC, will go LOW every 128 counts (for 16 K RAMs) instead of every 256 counts. |
|  | $\mathrm{O}_{0}-\mathrm{O}_{7}$ | 0 | The RAM address outputs. The eight-bit width is designed for dynamic RAMs up to 64K. |
| 16 | MSEL | 1 | The Multiplexer-SELect input determines whether low order or high order address inputs appear at the multiplexer outputs $\mathrm{O}_{0}-\mathrm{O}_{7}$. When MSEL is HIGH the low order address latches ( $\mathrm{A}_{0}-\mathrm{A}_{7}$ ) are connected to the outputs. When MSEL is LOW the high order address latches are connected to the outputs. |
| 25 | $\overline{\text { RFSH }}$ | 1 | The Refresh control input. When active LOW the $\overline{\text { RFSH }}$ input switches the address output multiplexer to output the inverted contents of the 8 -bit refresh counter. RFSH LOW also inhibits the CAS buffer and changes the mode of the $\overline{\mathrm{RAS}}$ decoder from one-of-four to four-of-four so that all four $\overline{\mathrm{RAS}}$ decoder outputs, $\overline{\mathrm{RAS}}_{0}, \overline{\operatorname{RAS}}_{1}, \overline{\mathrm{RAS}}_{2}$ and $\overline{\mathrm{RAS}}_{3}$, go LOW in response to a LOW input at $\overline{\text { RASI. This action refreshes one row address in each of the four RAS decoded }}$ memory banks. The refresh counter is advanced at the end of each refresh cycle by the LOW-to-HIGH transition of $\overline{\text { RFSH }}$ or RASI (whichever occurs first). In burst mode refresh, $\overline{\text { RFSH }}$ may be held LOW and refresh accomplished by toggling RASI. |
| 9 | $\overline{\text { TC }}$ | 0 | The Terminal Court output. A LOW output at $\overline{\text { TC }}$ indicates that the refresh counter has been sequenced through either 128 or 256 refresh addresses depending on $A_{15}$. The TC output remains active LOW until the refresh counter is advanced by the rising edge of RASI or RFSH. |
| 8 | $\overline{\text { CLR }}$ | 1 | The refresh counter Clear input. An active LOW input at $\overline{\text { CLR }}$ resets the refresh counter to all LOW (refresh address output to all HIGH). |
| 36 | LE | 1 | The address latch enable input. An active HIGH input at LE causes the two 8-bit address latches and the 2-bit $\overline{\text { RAS }}$ Select input latch to go transparent, accepting new input data. A LOW input on LE latches the input data which meets set-up and hold time requirements. |
| $\frac{4}{5}$ | RSEL_ and RSEL 1 | 1 | The $\overline{\mathrm{RAS}}$ decoder Select inputs. Data (latched) at these inputs (normally higher order addresses) is decoded by the $\overline{\mathrm{RAS}}$ Decoder to "RAS Select" one of four banks of memory with $\overline{\mathrm{RAS}}_{0}, \overline{\mathrm{RAS}}_{1}, \overline{\mathrm{RAS}}_{2}$ or $\overline{\mathrm{RAS}}_{3}$. |
| 3 | $\overline{\text { RASI }}$ | 1 | The Row Address Strobe Input. During normal memory cycles the selected $\overline{\mathrm{RAS}}$ Decoder output $\overline{\mathrm{RAS}}_{0}, \overline{\mathrm{RAS}}_{1}, \overline{\mathrm{RAS}}_{2}$ or $\overline{R A S}_{3}$ will go active LOW in response to an active LOW input at $\overline{\text { RASI. }}$. During refresh ( $\mathrm{RFSH}=\mathrm{LOW}$ ), all $\overline{\mathrm{RAS}}$ outputs go LOW in response to RASI = LOW. |
| $\begin{aligned} & 39,40, \\ & 1,2 \end{aligned}$ | $\begin{array}{\|l} \overline{\text { RAS }}_{0}, \\ \text { RAS }_{1}, \\ \text { RAS }_{2}, \\ \text { RAS }_{3} \\ \hline \end{array}$ | 0 | Row Address Strobe outputs ( $\left.\overline{\mathrm{RAS}_{\mathrm{i}}}\right)$. Each provides a Row Address Strobe for one of the four banks of memory. Each will go active LOW only when selected by RSEL $L_{0}$ and RSEL $_{1}$ and only when $\overline{\operatorname{RASI}}$ goes active LOW. All RAS $\mathrm{RA}_{-3}$ outputs go active low in response $\overline{\text { RASI }}$ when RFSH goes LOW. |
| 7 | $\overline{\text { CASI }}$ | 1 | The Column Address Strobe. An active LOW input at CASI will result in an active LOW output at CASO, unless a refresh cycle is in progress ( $\overline{\text { RFSH }}=$ LOW). |
| 6 | CASO | 0 | The Column Address Strobe output. The active LOW $\overline{\text { CASO }}$ output strobes the Column Address into the dynamic RAM. $\overline{\text { CASO }}$ is inhibited during refresh ( $\overline{\mathrm{RFSH}}=\mathrm{LOW}$ ). |

RAS OUTPUT FUNCTION TABLE

| $\overline{\text { RFSH }}$ | $\overline{\text { RASI }}$ | RSEL $_{\mathbf{1}}$ | RSEL $_{\mathbf{0}}$ | $\overline{\text { RAS }}_{\mathbf{0}}$ | $\overline{\text { RAS }}_{\mathbf{1}}$ | $\overline{\text { RAS }}_{\mathbf{2}}$ | $\overline{\text { RAS }}_{\mathbf{3}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | $H$ | X | X | $H$ | $H$ | $H$ | $H$ |
| $L$ | $L$ | X | X | L | L | L | L |
| $H$ | $H$ | X | X | $H$ | $H$ | $H$ | $H$ |
| $H$ | $L$ | $L$ | $L$ | $L$ | $H$ | $H$ | $H$ |
| $H$ | $L$ | $L$ | $H$ | $H$ | $L$ | $H$ | $H$ |
| $H$ | $L$ | $H$ | $L$ | $H$ | $H$ | $L$ | $H$ |
| $H$ | $L$ | $H$ | $H$ | $H$ | $H$ | $H$ | $L$ |

## CASO FUNCTION TABLE

| RFSH | CASI | CASO |
| :---: | :---: | :---: |
| H | L | L |
| $H$ | $H$ | $H$ |
| L | X | $H$ |

ADDRESS OUTPUT FUNCTION TABLE

| MSEL | RFSH | $\mathbf{0}_{\mathbf{0}}-\mathbf{0}_{7}$ |
| :---: | :---: | :---: |
| $H$ | $H$ | $A_{0}-A_{7}$ |
| $L$ | $H$ | $A_{8}-A_{15}$ |
| $X$ | $L$ | Refresh Address |

REFRESH ADDRESS COUNTER FUNCTION TABLE

| $A_{15}$ | $\overline{\text { CLR }}$ | $\overline{\text { RFSH }}$ | RASI | $\overline{\text { TC }}$ | REFRESH COUNT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | L | X | X | X | $\mathrm{FF}_{\mathrm{H}}$ | Clear Counter |
| X | H | L | X | X | NC | Output Refresh Address No Change for Counter |
| X | H | 5 | L | X | Count - 1 | Return to Memory Cycle Mode and Decrement Counter |
| X | H | L | L | X | NC | Output all RAS $\mathrm{F}_{\mathrm{i}}$ to RAM No Change for Counter |
| X | H | L | 5 | X | Count - 1 | Return RAS it $^{\text {to }}$ HIGH and Decrement Counter |
| L or H | H | X | X | L | $0^{00} \mathrm{H}$ | Terminal Count for 256 Line Refresh |
| $+12 \mathrm{~V}^{*}$ | H | X | X | L | $00^{H}$ and $80{ }^{\text {H }}$ | Terminal Count for 128 Line Refresh |

* Through $1 \mathrm{~K} \Omega$ resistor.


## BURST REFRESH TIMING



The timing shown assumes that burst mode applications may power-down the Am2964B with the RAM.
Therefore the counter is cleared prior to executing the refresh sequence.

## APPLICATION

## Architecture

The Dynamic Memory Controller (DMC) provides address multiplexing, refresh address generation and $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ control for the MOS dynamic RAM memories of any data width. The eight bit address path is designed for 64 K RAMs and can be used with 16K RAMs.
Sixteen address input latches and two $\overline{\mathrm{RAS}}$ Select latches (for higher order addresses) allow the DMC to control up to 256 K words of memory (with 64K RAMs) by using the internal RAS decoder to select from one-of-four banks of RAMs.

## Speed With Minimum Skew

The DMC provides Schottky speed in all of the critical paths. In addition, time skew between the Address, $\overline{\text { RAS }}$ and CAS paths is minimized (and specified) by placing these function on the same chip. The inclusion of the CAS buffer allows matching of its propagation delay, plus provides the CAS inhibit function during $\overline{R A S}$ - only refresh.

## Input Latches

The eighteen input latches are transparent when LE is HIGH and latch the input data meeting set-up and hold time requirements when LE goes LOW. In systems with separate address and data buses, LE may be permanently enabled HIGH.

## Refresh Counter

The 8 -bit refresh counter provides both 128 and 256 line refresh capability. Refresh control is external to allow maximum user flexibility. Transparent (hidden), burst, synchronous or asynchronous refresh modes are all possible.

The refresh counter is advanced at the LOW-to-HIGH transition of RFSH (or RASI). This assures a stable counter output for the next refresh cycle. The counter will continue to cycle through 256 addresses unless reset to zero by CLR. This actually causes all outputs to go HIGH since the output MUX is inverting. (Address inputs to outputs are non-inverting since both the input latches and output MUX are inverting).


Address and $\overline{\text { RAS/ CAS }}$ drivers each drive 22 RAM inputs at each output. Timing skew is minimized by using one device for address lines and one device for $\overline{R A S} / \overline{C A S}$, spreading the $\overline{C A S}$ loading over four drivers to equalize the capacitive load on each driver.

Figure 1. Dynamic Memory Control with Error Detection and Correction

## Refresh Terminal Count

The refresh counter also provides a Terminal Count output for burst mode refresh applications. TC normally occurs at count 255 ( $0_{0}$ to $0_{7}$ all LOW when $\overline{\text { RFSH }}$ is LOW). $\overline{\text { TC }}$ can be made to occur at count 127 for 128 line burst mode refresh by pulling $A_{15}$ up to +12 V through a $1 \mathrm{~K} \Omega \pm 10 \%$ resistor. The counter actually cycles through 256 with $\overline{T C}$ determined by $A_{15}$. Otherwise, $\mathrm{A}_{15}$ functions as an address input when driven at normal TTL levels.

## Three Input 8-Bit Address Multiplexer

The address MUX is 8 -bits wide (for 64K RAMs) and has three data sources: the lower address input latch ( $A_{0}$ to $A_{7}$ ), the upper address input latch ( $\mathrm{A}_{8}$ to $\mathrm{A}_{15}$ ) and the internal refresh counter. The lower address latch is selected when MSEL is HIGH. This is normally the Row address. The upper address latch is selected when MSEL is LOW. This is normally the Column address. The third source, the refresh counter, is selected when $\overline{\text { RFSH }}$ is LOW and overrides MSEL.

When $\overline{\text { RFSH }}$ goes LOW, the MUX selects the refresh counter address and CASO is inhibited. Also, the $\overline{R A S}$ Decoder
function is changed from one-of-four to four-of-four so all $\overline{\text { AAS }}$ outputs $\overline{\mathrm{RAS}}_{0}-\overline{\mathrm{RAS}}_{3}$ go LOW to refresh all banks of memory when RASI goes LOW. When RFSH is HIGH only one RAS output goes low. This is determined by the RAS Select inputs, RSEL 0 and RSEL 1 . In either case the $\overline{\text { RAS }}$ Decoder output timing is controlled by RASI to make sure the refresh count appears at $0_{0}-0_{7}$ before $\overline{\operatorname{RAS}}_{0}-\overline{\mathrm{RAS}}_{3}$ go LOW. This assures meeting Row address Set-up time requirement of the RAM ( $t_{A S R}$ ).

## Maximum Performance System

The typical organization of a maximum performance 16 -bit system including Error Detection and Correction is shown in Figure 1. Delay lines provide the most accurate timing and are recommended for $\overline{\mathrm{RAS}} / \mathrm{MSEL} / \overline{\mathrm{CAS}}$ timing in this type of system.

## Controlling 16K RAMs or Smaller Systems

16K RAMs require seven address inputs and 128 line refresh. Also, $A_{0}$ is often used to designate upper or lower byte transactions in 16 -bit systems. These modifications are shown in Figure 2.


Figure 2. Word Organized Memory Using 16K RAMs

## ABSOLUTE MAXIMUM RATINGS

## Storage Temperature

$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continous...........................................-0.5V to +7.0V
DC Voltage Applied to Outputs For
High Output State $\qquad$
DC Input Voltage
-0.5 V to $\mathrm{V}_{\mathrm{CC}}$ Max
Output Current
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Descriptions | Test Conditions (Note 1) |  | Min | Typ <br> (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & I_{O H}=-1 \mathrm{~mA} \end{aligned}$ | TC | 2.5 |  |  | Volts |
|  |  |  | Others | 3.0 |  |  | Volts |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & I_{O H}=-15 \mathrm{~mA} \\ & \hline \end{aligned}$ | All outputs except TC | 2.0 |  |  | Volts |
| 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}$ | All outputs except $\overline{\mathrm{TC}}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $\overline{\mathrm{TC}}, \mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| VIL | Input LOW level | Guaranteed input lo voltage for all inpu | al LOW |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IIN}=-1$ |  |  |  | -1.5 | Volts |
| ILI | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.4 V \end{aligned}$ | $\overline{\text { RASI }}$ |  |  | -3.2 | mA |
|  |  |  | CASI, MSEL, $\overline{\text { RFSH }}$ |  |  | -1.6 | mA |
|  |  |  | $\begin{aligned} & A_{0}-A_{15}, \overline{C L R} \\ & \text { RSEL }_{0,1}, L E \end{aligned}$ |  | : | -0.4 | mA |
| ${ }_{1 / 4}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 V \end{aligned}$ | RASI |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  | $\overline{\text { CASI, MSEL, }} \overline{\text { RFSH }}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\begin{array}{\|l} A_{0}-A_{15}, \overline{C L R} \\ \text { RSELO, }_{0,1}, \mathrm{LE} \\ \hline \end{array}$ |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\overline{\text { RASI }}$ |  |  | 2.0 | mA |
|  |  |  | $\overline{\text { CASI, MSEL, }} \overline{\text { RFSH }}$ |  |  | 1.0 | mA |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{A}_{0}-\mathrm{A}_{15}, \overline{\mathrm{CLR}} \\ & \text { RSEL }_{0,1}, \mathrm{LE} \\ & \hline \end{aligned}$ |  |  | 0.1 | mA |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=$ MAX ( Note 3 |  | -40 |  | -100 | mA |
| Icc | Power Supply Current (Note 4) | $25^{\circ} \mathrm{C}, 5 \mathrm{~V}$ |  |  | 122 |  | mA |
|  |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | COM'L |  |  | 173 | mA |
|  |  | $70^{\circ} \mathrm{C}$ |  |  |  |  |  |
|  |  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | MIL |  |  | 164 | mA |
|  |  | $+125^{\circ} \mathrm{C}$ |  |  |  | 150 | mA |
| IT | A15 Enable Current | $\mathrm{A}_{15}$ connected to +12 V through $1 \mathrm{~K} \Omega \pm 10 \%$ |  |  |  | 5 | mA |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second
4. ICC is worst case when the Address inputs are latched HIGH, the refresh counter is at terminal count (255), RASI and CASI are HIGH and all other inputs are LOW.

SWITCHING CHARACTERISTICS over operating range for $C_{L}=50 \mathrm{pF}$
Am2964B (Notes 5, 6)

| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max | Min | Max |  |
| 1 | tPD |  | $A_{i}$ to $O_{i}$ Delay | $C_{L}=50 \mathrm{pF}$ | 14 |  | 19 |  | 23 | ns |
| 2 | tPHL | $\overline{\text { RASI }}$ to $\overline{\text { RAS }}$ ( $(\overline{\text { RFSH }}=\mathrm{H})$ | 14 |  |  | 20 |  | 23 | ns |
| 3 | tPHL | $\overline{\text { RASI }}$ to $\overline{\text { RAS }_{i}}(\overline{\text { RFSH }}=\mathrm{L})$ | 14 |  |  | 20 |  | 23 | ns |
| 4 | tPD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 17 |  | 9 |  | 9 |  | ns |
| 5 | tpD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 17 |  |  | 21 |  | 25 | ns |
| 6 | tPHL | CASI to $\overline{\text { CASO }}$ ( $\overline{\text { RFSH }}=\mathrm{H}$ ) | 12 |  |  | 17 |  | 19 | ns |
| 7 | tPHL | $\mathrm{RSEL}_{i}$ to $\overline{\mathrm{RAS}}_{i}(L E=H, \overline{\text { RASI }}=\mathrm{L})$ | 15 |  |  | 20 |  | 24 | ns |
| 8 | tplH | $\overline{\mathrm{RFSH}}$ to $\overline{\mathrm{TC}}(\overline{\mathrm{RASI}}=\mathrm{L})$ | 30 |  |  | 40 |  | 50 | ns |
| 9 | tPLH | $\overline{\text { RASI }}$ to $\overline{\text { TC }}(\overline{\text { RFSH }}=\mathrm{L})$ | 25 |  |  | 35 |  | 40 | ns |
| 10 | tpW | $\overline{\text { AASI }}=\mathrm{L}(\overline{\text { RFSH }}=\mathrm{L})$ | 10 |  | 50 |  | 50 |  | ns |
| 11 | tpw | $\overline{\text { AASI }}=\mathrm{H}(\overline{\text { RFSH }}=\mathrm{L})$ | 10 |  | 50 |  | 50 |  | ns |
| 12 | tPD | $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\text { RASI }}=\mathrm{X})$ | 17 |  |  | 21 |  | 25 | ns |
| 13 | tPHL | $\overline{\text { RFSH }}$ to $\overline{\text { RAS }}_{\mathrm{i}}(\overline{\mathrm{RASI}}=\mathrm{L})$ | 19 |  |  | 26 |  | 29 | ns |
| 14 | tpw | $\overline{C L R}=L$ | 10 |  | 30 |  | 35 |  | ns |
| 15 | tplH | $\begin{aligned} & \overline{\overline{\text { FFSH}}} \text { to } \overline{\text { CASO }} \\ & (\overline{\text { RASI }}=\mathrm{L} \overline{\mathrm{CASI}}=\mathrm{L}, \text { Note } 7) \end{aligned}$ | 16 |  |  | 21 |  | 25 | ns |
| 16 | tpD | LE to $\mathrm{O}_{\mathrm{i}}$ | 25 |  |  | 35 |  | 40 | ns |
| 17 | tPHL | LE to $\overline{\mathrm{AAS}}_{i}$ | 30 |  |  | 40 |  | 45 | ns |
| 18 | tplH | $\overline{C L R}$ to TC | 35 |  |  | 45 |  | 56 | ns |
| 19 | tplH | $\overline{C L P}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 31 |  |  | 44 |  | 54 | ns |
| 20. | ts | $A_{i}$ to LE Set-Up Time | 0 |  | 5 |  | 5 |  | ns |
| 21 | ${ }_{\text {t }}^{\mathrm{H}}$ | $A_{i}$ to LE Hold Time | 5 |  | 12 |  | 15 |  | ns |
| 22 | ts | RSELi to LE Set-Up Time | 0 |  | 5 |  | 5 |  | ns |
| 23 | $\mathrm{t}_{\mathrm{H}}$ | RSELi to LE Hold Time | 10 |  | 17 |  | 25 |  | ns |
| 24 | ts | $\overline{C L R}$ Recovery Time | 10 |  | 16 |  | 18 |  | ns |
| 25 | tSKEW | $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}} \mathrm{i}(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 8) | 2 |  |  | 5 |  | 6 | ns |
| 26 | tSKEW | $\mathrm{O}_{i}$ to CASO (Note 8) | 6 |  |  | 8 |  | 8 | ns |
| 27 | tSKEW | $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}}_{i}(\overline{\mathrm{RFSH}}=\mathrm{L}$, Note 9) | 6 |  |  | 8 |  | 10 | ns |
| 28 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{MSEL}}=\bar{L}$, Note 10) | 1 |  |  | 5 |  | 5 | ns |

Notes: 5. Minimum spec limits for $t_{p w}, t_{s}$ and $t_{H}$ are minimum system operating requirements. Limits for $t_{S K E W}$ and $t_{P D}$ are guaranteed test limits for the device.
6. All AC parameters are specified at the 1.5 V level.
7. $\overline{\text { RFSH }}$ inhibits $\overline{\text { CASO }}$ during refresh. Specification is for CASO inhibit time.
8. $O_{i}$ to $\overline{\operatorname{RAS}}_{i}(\overline{\mathrm{RFSH}}=\mathrm{HIGH})$ skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASI}}$ to $\overline{\mathrm{RAS}}_{i}$ delay and slowest $A_{i}$ to $O_{i}$ delay within a single device. $O_{i}$ to CASO skew is maximum difference between fastest CASI to CASO delay and slowest MSEL to $O_{i}$ delay within a single device. See application section entitled Memory Cycle Timing for correlation to System Timing requirements.
9. $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{LOW})$ skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASI}}$ to $\overline{\mathrm{RAS}}_{i}$ delay and slowest $\overline{\mathrm{RFSH}}$ to $\mathrm{O}_{\mathbf{i}}$ delay within a single device. See application section on Refresh Timing for correlation to system refresh timing requirements.
10. $O_{i}$ to $\overline{\operatorname{RAS}} \bar{i}_{i}$ (MSEL $\left.=\right\rceil$ ) skew is guaranteed maximum difference between fastest MSEL $Z$ to $O_{i}$ delay and slowest RASI to RAS ${ }_{\mathbf{j}}$ delay within a single device.

SWITCHING CHARACTERISTICS over operating range for $C_{L}=50 \mathrm{pF}$
Am2964B (Notes 5, 6)

| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max | Min | Max |  |
| 1 | tPD |  | $A_{i}$ to $O_{i}$ Delay | $C_{L}=150 \mathrm{pF}$ | 20 |  | 25 |  | 30 | ns |
| 2 | $\mathrm{tPHL}^{\text {che }}$ | $\overline{\text { RASI }}$ to $\overline{\text { RAS }} \mathrm{i}(\overline{\text { RFSH }}=\mathrm{H})$ | 18 |  |  | 24 |  | 27 | ns |
| 3 | tpHL | $\overline{\text { RASI }}$ to $\overline{\text { AAS }}$ ( $(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 18 |  |  | 24 |  | 27 | ns |
| 4 | tPD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 23 |  | 12 |  | 12 |  | ns |
| 5 | tPD | MSEL to $\mathrm{O}_{\mathrm{i}}$ | 23 |  |  | 27 |  | 31 | ns |
| 6 | tPHL | $\overline{\text { CASI }}$ to $\overline{\text { CASO }}$ ( $\overline{\text { RFSH }}=\mathrm{H}$ ) | 17 |  |  | 24 |  | 26 | ns |
| 7 | tpHL | RSEL ${ }_{\text {i }}$ to $\overline{\text { AAS }}^{\text {i }}(\mathrm{LE}=\mathrm{H}, \overline{\mathrm{RASI}}=\mathrm{L})$ | 19 |  |  | 27 |  | 30 | ns |
| 8 | tpLH | $\overline{\text { RFSH }}$ to TC ( $\overline{\text { RASI }}=\mathrm{L}$ ) | 34 |  |  | 45 |  | 55 | ns |
| 9 | tpLH | $\overline{\text { RASI }}$ to $\overline{\text { TC }}(\overline{\text { RFSH }}=\mathrm{L})$ | 32 |  |  | 45 |  | 55 | ns |
| 10 | tpw | $\overline{\text { RASI }}=\mathrm{L}(\overline{\text { RFSH }}=\mathrm{L})$ | 10 |  | 50 |  | 50 |  | ns |
| 11 | tpw | $\overline{\text { AASI }}=\mathrm{H}(\overline{\text { RFSH }}=\mathrm{L})$ | 10 |  | 50 |  | 50 |  | ns |
| 12 | tPD | $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\text { RASI }}=\mathrm{X})$ | 21 |  |  | 27 |  | 30 | ns |
| 13 | tpHL | $\overline{\mathrm{FFSS}}$ to $\overline{\mathrm{RAS}} \mathbf{~}(\overline{\mathrm{RASI}}=\mathrm{L})$ | 25 |  |  | 33 |  | 36 | ns |
| 14 | tpw | $\overline{\mathrm{CLP}}=\mathrm{L}$ | 10 |  | 30 |  | 35 |  | ns |
| 15 | tpLH | $\overline{\mathrm{RFSH}}$ to $\overline{\text { CASO }}$ $(\mathrm{RASI}=\mathrm{L} \overline{\mathrm{CASI}}=\mathrm{L}$, Note 7$)$ | 21 |  |  | 27 |  | 31 | ns |
| 16 | tPD | LE to $\mathrm{O}_{\mathrm{i}}$ | 30 |  |  | 40 |  | 50 | ns |
| 17 | tpHL | LE to $\overline{\text { AAS }}_{\text {i }}$ | 34 |  |  | 45 |  | 54 | ns |
| 18 | $\mathrm{tpLH}^{\text {P }}$ | $\overline{\mathrm{CLR}}$ to TC | 39 |  |  | 55 |  | 60 | ns |
| 19 | tpLH | $\overline{C L R}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ | 38 |  |  | 50 |  | 62 | ns |
| 20 | ts | $A_{i}$ to LE Set-Up Time | 0 |  | 5 |  | 5 |  | ns |
| 21 | ${ }_{\text {th }}$ | $A_{i}$ to LE Hold Time | 5 |  | 12 |  | 12 |  | ns |
| 22 | ${ }_{\text {t }}$ | RSEL i $_{\text {to }}$ LE Set-Up Time | 0 |  | 5 |  | 5 |  | ns |
| 23 | $\mathrm{th}_{\mathrm{H}}$ | RSELi to LE Hold Time | 10 |  | 17 |  | 25 |  | ns |
| 24 | ts | CLPR Recovery Time | 10 |  | 16 |  | 18 |  | ns |
| 25 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}$ ( $(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 8) | 3 |  |  | 6 |  | 7 | ns |
| 26 | tskew | $\mathrm{O}_{\mathrm{i}}$ to CASO (Note 8) | 6 |  |  | 8 |  | 8 | ns |
| 27 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}} ;{ }_{\mathrm{C}}(\overline{\mathrm{RFSH}}=\mathrm{L}$, Note 9) | 6 |  |  | 9 |  | 10 | ns |
| 28 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{BAS}}$ ( $\overline{\text { MSEL }}=7$, Note 10) | 1 |  |  | 5 |  | 5 | ns |

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful.

1. Insure the part is adequately decoupled at the test head. Large changes in VCC current as the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2.Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3.Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4.Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\mathrm{IL}}$. or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 2.4 \mathrm{~V}$ for AC tests.
5.To simplify failure analysis, programs should be designed to perform $D C$, Function, and $A C$ tests as three distinct groups of tests.
6.To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

SWITCHING CHARACTERISTICS over operating range for $C_{L}=50 \mathrm{p} F$

## Am2964C (Notes 5,6)

| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max | Min | Max |  |
| 1 | tPD |  | $A_{i}$ to $O_{i}$ Delay | $C_{L}=50 \mathrm{pF}$ |  |  |  |  |  | ns |
| 2 | tPHL | $\overline{\text { RASI }}$ to $\overline{\text { RAS }}(\overline{\text { RFSH }}=\mathrm{H})$ |  |  |  |  |  |  | ns |
| 3 | tpHL | $\overline{\text { RASI }}$ to $\overline{\text { RAS }}$ ( $(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 4 | tPD | MSEL to $\mathrm{O}_{\mathrm{i}}$ |  |  |  |  |  |  | ns |
| 5 | $t_{P D}$ | MSEL to $\mathrm{O}_{i}$ |  |  |  |  |  |  | ns |
| 6 | tPHL | CASI to $\overline{\text { CASO }}(\overline{\text { RFSH }}=\mathrm{H})$ |  |  |  |  |  |  | ns |
| 7 | tPHL | RSEL $^{\text {i }}$ to $\overline{\text { AAS }}^{\text {i }}(L E=H, \overline{\text { RASI }}=L)$ |  |  |  |  |  |  | ns |
| 8 | tplH | $\overline{\text { RFSH }}$ to $\overline{\text { TC }}$ ( $\overline{\mathrm{RASI}}=\mathrm{L}$ ) |  |  |  |  |  |  | ns |
| 9 | tplH | RASI to TC ( $\overline{\text { RFSH }}=\mathrm{L}$ ) |  |  |  |  |  |  | ns |
| 10 | tpW | $\overline{\text { RASI }}=\mathrm{L}(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 11 | tpw | $\overline{\text { RASI }}=\mathrm{H}(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 12 | tPD | $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RASI}}=\mathrm{X})$ |  |  |  |  |  |  | ns |
| 13 | tPHL | $\overline{\mathrm{RFSH}}$ to $\left.\overline{\mathrm{RAS}} \mathrm{i}^{(\overline{\text { RASI }}=}=\mathrm{L}\right)$ |  |  |  |  |  |  | ns |
| 14 | tpw | $\overline{C L R}=L$ |  |  |  |  |  |  | ns |
| 15 | tplH | $\begin{aligned} & \overline{\text { RFSH }} \text { to } \overline{\text { CASO }} \\ & (\text { RASI }=L \overline{\text { CASI }}=L \text {, } \text { Note } 7 \text { ) } \end{aligned}$ |  |  |  |  |  |  | ns |
| 16 | tPD | LE to $\mathrm{O}_{\mathrm{i}}$ |  |  |  |  |  |  | ns |
| 17 | tPHL | LE to $\overline{\text { AAS }}$; |  |  |  |  |  |  | ns |
| 18 | tplH | CLR to TC |  |  |  |  |  |  | ns |
| 19 | tplH | $\overline{C L R}$ to $\mathrm{O}_{i}(\overline{\mathrm{RFSH}}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 20 | $\mathrm{ts}^{\text {S }}$ | $A_{i}$ to LE Set-Up Time |  |  |  |  |  |  | ns |
| 21 | $t_{H}$ | $A_{i}$ to LE Hold Time |  |  |  |  |  |  | ns |
| 22 | ts | RSELi to LE Set-Up Time |  |  |  |  |  |  | ns |
| 23 | ${ }_{H}$ | RSELi to LE Hold Time |  |  |  |  |  |  | ns |
| 24 | ts | $\overline{C L R}$ Recovery Time |  |  |  |  |  |  | ns |
| 25 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 8) |  |  |  |  |  |  | ns |
| 26 | tSKEW | $\mathrm{O}_{i}$ to CASO (Note 8) |  |  |  |  |  |  | ns |
| 27 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{AAS}}_{i}(\overline{\mathrm{RFSH}}=\mathrm{L}$, Note 9) |  |  |  |  |  |  | ns |
| 28 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}$ ( $\mathrm{MSEL}=7$, Note 10) |  |  |  |  |  |  | ns |

Notes: 5. Minimum spec limits for $t_{p w}, t_{s}$ and $t_{H}$ are minimum system operating requirements. Limits for tSKEW and tPD are guaranteed test limits for the device.
6. All AC parameters are specified at the 1.5 V level.
7. $\overline{\mathrm{RFSH}}$ inhibits $\overline{\mathrm{CASO}}$ during refresh. Specification is for CASO inhibit time.
8. $\mathrm{O}_{i}$ to $\overline{\mathrm{RAS}}_{i}(\overline{\mathrm{RFSH}}=\mathrm{HIGH})$ skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASI}}$ to $\overline{\mathrm{RAS}}_{i}$ delay and slowest $A_{i}$ to $O_{i}$ delay within a single device. $O_{i}$ to CASO skew is maximum difference between fastest CASI to CASO delay and slowest MSEL to $O_{i}$ delay within a single device. See application section entitled Memory Cycle Timing for correlation to System Timing requirements.
9. $\mathrm{O}_{i}$ to $\overline{\operatorname{RAS}}_{i}(\overline{\mathrm{RFSH}}=\mathrm{LOW})$ skew is guaranteed maximum difference between fastest $\overline{\mathrm{RASI}}$ to $\overline{\mathrm{RAS}}_{i}$ delay and slowest $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}$ delay within a single device. See application section on Refresh Timing for correlation to system refresh timing requirements.
10. $O_{i}$ to $\overline{\operatorname{RAS}}_{i}(M S E L=\rceil$ ) skew is guaranteed maximum difference between fastest MSEL $Z$ to $O_{i}$ delay and slowest $\overline{\text { RASII }}$ to $\overline{\operatorname{RAS}} \mathrm{S}_{\mathrm{i}}$ delay within a single device.

SWITCHING CHARACTERISTICS over operating range for $C_{L}=150 \mathrm{pF}$
Am2964C (Notes 5,6)

| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max | Min | Max |  |
| 1 | tPD |  | $A_{i}$ to $O_{i}$ Delay | $C_{L}=150 \mathrm{pF}$ |  |  |  |  |  | ns |
| 2 | $\mathrm{t}_{\text {PHL }}$ | $\overline{\text { RASI }}$ to $\widehat{\text { AAS }}_{\text {i }}(\overline{\text { RFSH }}=\mathrm{H})$ |  |  |  |  |  |  | ns |
| 3 | $\mathrm{tpHL}^{\text {che }}$ | $\overline{\text { RASI }}$ to $\overline{\text { AAS }}^{\text {j }}$ ( $\overline{\text { FSSH }}=$ L $)$ |  |  |  |  |  |  | ns |
| 4 | tpD | MSEL to $\mathrm{O}_{\mathrm{i}}$ |  |  |  |  |  |  | ns |
| 5 | ${ }_{\text {tPD }}$ | MSEL to $\mathrm{O}_{\mathrm{i}}$ |  |  |  |  |  |  | ns |
| 6 | tphL | $\overline{\text { CASI }}$ to CASO $(\overline{\text { RFSH }}=\mathrm{H})$ |  |  |  |  |  |  | ns |
| 7 | $t_{\text {P }}^{\text {HL }}$ | $\mathrm{RSEL}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}(\mathrm{LE}=\mathrm{H}, \overline{\mathrm{RASI}}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 8 | tpli | $\overline{\text { RFSH }}$ to $\overline{\text { TC }}(\overline{\text { RAS }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 9 | $\mathrm{tPLH}^{\text {P }}$ | $\overline{\text { RASI }}$ to $\overline{\text { TC }}(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 10 | tPW | $\overline{\text { RASI }}=\mathrm{L}(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 11 | tpw | $\widehat{\text { RASI }}=\mathrm{H}(\overline{\text { RFSH }}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 12 | $t_{\text {PD }}$ | $\overline{\text { RFSH }}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\text { RASI }}=\mathrm{X})$ |  |  |  |  |  |  | ns |
| 13 | $t_{\text {PHL }}$ | $\overline{\mathrm{FFSH}}$ to $\overline{\mathrm{RAS}}$ ( $\overline{\mathrm{RASI}}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 14 | tpw | $\overline{\mathrm{CLF}}=\mathrm{L}$ |  |  |  |  |  |  | ns |
| 15 | tPLH | $\begin{aligned} & \overline{\overline{\mathrm{RFSH}}} \text { to } \overline{\mathrm{CASO}} \\ & (\mathrm{RASI}=\mathrm{L} \overline{\mathrm{CASI}}=\mathrm{L}, \text { Note } 7) \end{aligned}$ |  |  |  |  |  |  | ns |
| 16 | tPD | LE to $\mathrm{O}_{\mathrm{i}}$ |  |  |  |  |  |  | ns |
| 17 | $\mathrm{t}_{\text {PHL }}$ | LE to $\overline{\text { AAS }}_{i}$ |  |  |  |  |  |  | ns |
| 18 | tPLH | $\overline{\text { CLP }}$ to TC |  |  |  |  |  |  | ns |
| 19 | tPLH | $\overline{\mathrm{CLF}}$ to $\mathrm{O}_{\mathrm{i}}(\overline{\mathrm{RFSH}}=\mathrm{L})$ |  |  |  |  |  |  | ns |
| 20 | ts | $A_{i}$ to LE Set-Up Time |  |  |  |  |  |  | ns |
| 21 | $\mathrm{t}_{\mathrm{H}}$ | $A_{i}$ to LE Hold Time |  |  |  |  |  |  | ns |
| 22 | ts | RSEL L $_{\text {to }}$ LE Set-Up Time |  |  |  |  |  |  | ns |
| 23 | $\mathrm{t}_{\mathrm{H}}$ | RSELi to LE Hold Time |  |  |  |  |  |  | ns |
| 24 | ts | $\overline{\text { CLP }}$ Recovery Time |  |  |  |  |  |  | ns |
| 25 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}} ;(\overline{\mathrm{RFSH}}=\mathrm{H}$, Note 8$)$ |  |  |  |  |  |  | ns |
| 26 | ${ }_{\text {tSKEW }}$ | $\mathrm{O}_{i}$ to CASO (Note 8) |  |  |  |  |  |  | ns |
| 27 | ${ }^{\text {tSkEW }}$ | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}} \mathrm{i}^{( } \overline{\mathrm{RFSH}}=\mathrm{L}$, Note 9) |  |  |  |  |  |  | ns |
| 28 | tSKEW | $\mathrm{O}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}}$ ( $\overline{\mathrm{MSEEL}}=7$, Note 10) |  |  |  |  |  |  | ns |

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful.

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2.Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3.Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4.Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\text {IH }}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 2.4 \mathrm{~V}$ for AC tests.
5.To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6.To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

## MEMORY CYCLE TIMING

The relationship between DMC specifications and system timing requirements are shown in Figure 3. $\mathrm{T}_{1}, \mathrm{~T}_{2}$ and $\mathrm{T}_{3}$ represent the minimum timing requirements at the DMC inputs to guarantee that RAM timing requirements are met and that maximum system performance is achieved.

The minimum requirement for $T_{1}, T_{2}$ and $T_{3}$ are as follows:

$$
\mathrm{T}_{1} \mathrm{MIN}=\mathrm{t}_{\mathrm{RAH}}+\mathrm{t}_{28}
$$

$$
T_{2} M I N=T_{1}+t_{26}+t_{\text {ASC }}
$$

$$
T_{3} M I N=t_{A S R}+t_{25}
$$

See RAM data sheet for applicable values for $t_{\text {RAH }}, t_{\text {ASC }}$ and $t_{\text {ASR }}$.

a. Specifications Applicable to Memory Cycle Timing

b. Desired System Timing

Figure 3. Memory Cycle Timing

## REFRESH CYCLE TIMING

The timing relationships for refresh are shown in Figure 4.
$\mathrm{T}_{4}$ minimum is calculated as follows： $\mathrm{T}_{4}=\mathrm{t}_{\mathrm{ASR}}+\mathrm{t}_{27}$



27）＝GUARANTEED MAX DIFFERENCE BETWEEN FASTEST RASI TO $\overline{\mathrm{RAS}}_{;}$DELAY AND SLOWEST $\overline{\operatorname{RFS}}$ TO O O DELAY ON any single device．

WF001880

## b．Desired System Timing

Figure 4．Refresh Timing

## Am2965/Am2966

Octal Dynamic Memory Drivers with Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Controlled rise and fall characteristics Internal resistors provide symmetrical drive to HIGH and LOW states, eliminating need for external series resistor.
- Output swings designed to drive 16 K and 64 K RAMs
$\mathrm{V}_{\mathrm{OH}}$ guaranteed at $\mathrm{V}_{\mathrm{CC}}-1.15 \mathrm{~V}$. Undershoot going LOW guaranteed at less than 0.5 V .
- Large capacitive drive capability 35 mA min source or sink current at 2.0 V . Propagation delays specified for 50 pF and 500 pF loads.
- Pin-compatible with 'S240 and 'S244

Non-inverting Am2966 replaces 74S244; inverting Am2965 replaces 74S240. Faster than 'S240/244 under equivalent load.

- No-glitch outputs

Outputs forced into OFF state during power up and down. No glitch coming out of three-state.

## GENERAL DESCRIPTION

The Am2965 and Am2966 are designed and specified to drive the capacitive input characteristics of the address and control lines of MOS dynamic RAMs. The unique design of the lower output driver includes a collector resistor to control undershoot on the HIGH-to-LOW transition. The upper output driver pulls up to $\mathrm{V}_{\mathrm{CC}}-1.15 \mathrm{~V}$ to be compatible with MOS memory and is designed to have a rise time symmetrical with the lower output's controlled fall time. This allows optimization of Dynamic RAM performance.

The Am2965 and Am2966 are pin-compatible with the popular 'S240 and 'S244 with identical 3-state output enable controls. The Am2965 has inverting drivers and the Am2966 has non-inverting drivers.

The inclusion of an internal resistor in the lower output driver eliminates the requirement for an external series resistor, therefore reducing package count and the board area required. The internal resistor controls the output fall and undershoot without slowing the output rise.

These devices are designed for use with the Am2964 Dynamic Memory Controller where large dynamic memories with highly capacitive input lines require additional buffering. Driving eight address lines or four $\overline{\text { RAS }}$ and four $\overline{\text { CAS }}$ lines with drivers on the same silicon chip also provides a significant performance advantage by minimizing skew between drivers. Each device has specified skew between drivers to improve the memory access worst case timing over the min and max tPD difference of unspecified devices.

## BLOCK DIAGRAM

Am2965


Am2966



*Address and $\overline{\operatorname{RAS}} / \overline{C A S}$ drivers each drive 22 RAM inputs at each output. Timing skew is minimized by using one device for address lines and one device for $\overline{\text { RAS }} / \overline{\mathrm{CAS}}$, spreading the $\overline{\mathrm{CAS}}$ loading over four drivers to equalize the capacitive load on each driver.

DYNAMIC MEMORY CONTROL WITH ERROR DETECTION AND CORRECTION

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient)
Under Bias .................................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continous -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $\mathrm{V}_{\mathrm{Cc}}$ Max
DC Input Voltage $\qquad$
$\qquad$ .-0.5 V to +7.0 V
DC Output Current, Into Outputs ............. 200 mA DC input Current -30 mA to +5.0 mA
Stresses abovove 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Descriptions |  | Test Conditions (Note 1) |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\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}=-1 \mathrm{~mA}$ | $V_{C C}-1.15$ | $V_{C C}-0.7 \mathrm{~V}$ |  | Volts |
| VOL | Output LOW Voltage |  | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ | $1 \mathrm{OL}=1 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  |  | 0.8 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level |  |  | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level |  | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}^{\prime}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current |  | $V_{C C}=M A X, V_{\text {IN }}=0.4 V$ | DATA |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | 1'G, $\overline{2 \mathrm{G}}$ |  |  | -400 |  |
| IIH | Input HIGH Current |  |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| IOZH | Off-State Current |  | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozL | Off-State Current |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -200 | $\mu \mathrm{A}$ |
| lOL | Output Sink Current |  | $\mathrm{V}_{\mathrm{OL}}=2.0 \mathrm{~V}$ |  | 50 |  |  | mA |
| IOH | Output Source Current |  | $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ |  | -35 |  |  | mA |
| Isc | Output Short Circuit Current (Note 3) |  | $V_{C C}=M A X$ |  | $\begin{gathered} -60 \\ \text { (see } \mathrm{lOH} \\ \hline \end{gathered}$ |  | -200 | mA |
| Icc | Supply Current | Am2965 | All Outputs HIGH | $V_{C C}=M A X$ <br> Outputs Open |  | 24 | 50 | mA |
|  |  |  | All Outputs LOW |  |  | 86 | 125 |  |
|  |  |  | All Outputs Hi-Z |  |  | 86 | 125 |  |
|  |  | Am2966 | All Outputs HIGH | $V_{C C}=M A X$ <br> Outputs Open |  | 53 | 75 |  |
|  |  |  | All Outputs LOW |  |  | 92 | 130 |  |
|  |  |  | All Outputs Hi-Z |  |  | 116 | 150 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type. 2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

## SWITCHING TEST CIRCUIT


${ }^{*} t_{\text {pd }}$ specified at $\mathrm{C}=50$ and 500 pF
Figure 1. Capacitive Load Switching.


TC000450

Figure 2. Three-State Enable/Disable.

TYPICAL OUTPUT DRIVER



SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | Propagation Delay Time from LOW-to-HIGH Output | Figure 1 Test Circuit Figure 3 Voltage Levels and Waveforms | $\mathrm{C}_{\mathrm{L}}=0 \mathrm{pF}$ |  | 6 | (Note 4) |  |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 6 | 9 | 15 | ns |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ | 18 | 22 | 30 |  |
| tPHL | Propagation Delay Time from HIGH-to-LOW Output |  | $\mathrm{C}_{\mathrm{L}}=0 \mathrm{pF}$ |  | 4 | (Note 4) | ns |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 5 | 7 | 15 |  |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ | 18 | 22 | 30 |  |
| tplz | Output Disable Time from LOW, HIGH | Figures 2 and 4, $\mathrm{S}=1$ |  |  | 11 | 20 | ns |
| tphz |  | Figures 2 and 4, $S=2$ |  |  | 6.5 | 12 |  |
| tpZL | Output Enable Time from LOW, HIGH | Figures 2 and 4, $S=1$ |  |  | 12 | 20 | ns |
| tpZH |  | Figures 2 and 4, $S=2$ |  |  | 12 | 20 |  |
| tSKEW | Output-to-Output Skew | Figures 1 and $3, C_{L}=50 \mathrm{pF}$ |  |  | $\pm 0.5$ | $\begin{gathered} \pm 3.0 \\ \text { (Note 5) } \end{gathered}$ | ns |
| VONP | Output Voltage Undershoot | Figures 1 and $3, C_{L}=50 \mathrm{pF}$ |  |  | 0 | -0.5 | Volts |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified (Note 6)

| Parameters | Description | Test Conditions |  | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max | Min | Max |  |
| tpl | Propagation Delay Time LOW-to-HIGH Output | Figures 1 and 3 | $C_{L}=50 \mathrm{pF}$ | 4 | 17 | 4 | 20 | ns |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ | 18 | 35 | 18 | 40 |  |
| tPHL | Propagation Delay Time HIGH-to-LOW Output | Figures 1 and 3 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 4 | 17 | 4 | 20 | ns |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ | 18 | 35 | 18 | 40 |  |
| tpLz | Output Disable Time from LOW, HIGH | Figures 2 and 4 | $\mathrm{S}=1$ | . | 24 |  | 24 | ns |
| tPHZ |  |  | $\mathrm{S}=2$ |  | 16 |  | 16 |  |
| tPZL | Output Enable Time from LOW, HIGH | Figures 2 and 4 | $\mathrm{S}=1$ |  | 28 |  | 28 | ns |
| tpzH |  |  | $\mathrm{S}=2$ |  | 28 |  | 28 |  |
| Vonp | Output Voltage Undershoot | Figures 1 and 3, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | -0.5 |  | -0.5 | Volts |

Notes: 4. Typical time shown for reference only - not tested.
5. Time Skew specification is guaranteed by design but not tested
6. AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.
7. $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ for Flatpak versions.

TYPICAL SWITCHING CHARACTERISTICS
voltage waveforms


WF002120
$t_{r}=t_{f}=2.5 \mathrm{~ns}$
$f=2.5 \mathrm{MHz}$
$t_{\mathrm{pw}}=200 \mathrm{~ns}$
Figure 3. Output Drive Levels.

The RAM Driver symmetrical output design offers significant improvement over a standard Schottky output by providing a balanced drive output impedance ( $\approx 25 \Omega$ both HIGH and LOW), and by pulling up to MOS $\mathrm{V}_{\mathrm{OH}}$ levels ( $\mathrm{V}_{\mathrm{CC}}-1.5 \mathrm{~V}$ ). External resistors, not required with the RAM Driver, protect standard Schottky drivers from error causing undershoot but also slow the output rise by adding to the internal R.


Figure 5. $\mathrm{t}_{\mathrm{PLH}}$ for $\mathrm{V}_{\mathrm{OH}}=2.7 \mathrm{Vol}$ vs. $\mathrm{C}_{\mathrm{L}}$.


WF002130

$$
t_{r}=t_{f}=2.5 n s
$$

$$
f=1 \mathrm{MHz}
$$

$$
t_{\mathrm{pw}}=800 \mathrm{~ns}
$$

Figure 4. Three-State Control Levels.

The RAM Driver is optimized to drive LOW' at maximum speed based on safe undershoot control and to drive HIGH with a symmetrical speed characteristic. This is an optimum approach, because the dominant RAM loading characteristic is input capacitance.

The curves shown below provide performance characteristics typical of both the inverting (Am2965) and non-inverting (Am2966) RAM Drivers.


Figure 6. $\mathrm{t}_{\mathrm{PHL}}$ for $\mathrm{V}_{\mathrm{OL}}=0.8$ Volts vs. $\mathrm{C}_{\mathrm{L}}$.

The curves above depict the typical tPLH and tPHL for the RAM Driver outputs as a function of load capacitance. The minimums and maximums are shown for worst case design. The typical band is provided as a guide for intermediate capacitive loads.

## Am2968

Dynamic Memory Controller (DMC)

PRELIMINARY

## DISTINCTIVE CHARACTERISTICS

- Provides control for $16 \mathrm{~K}, 64 \mathrm{~K}$, and 256 K dynamic RAMs
- Outputs directly drive up to 88 DRAMs, with a guaranteed worst-case limit on the undershoot
- Highest-order two address bits select one of four banks of RAMs
- Separate output enable for multi-channel access to memory
- Supports scrubbing operations and nibble-mode access
- 48-pin dual in-line package


## GENERAL DESCRIPTION

The Am2968 Dynamic Memory Controller (DMC) is intended to be used with today's high performance memory systems. The DMC acts as the address controller between any processor and dynamic memory array, using its two 9 bit address latches to hold the Row and Column addresses for any DRAM up to 256 K . These latches, and the two Row/Column refresh address counters, feed into a 9 -bit, 4input MUX for output to the dynamic RAM address lines. A 2-bit bank select latch for the two high-order address bits is provided to select one each of the four $\overline{\operatorname{RAS}}_{i}$ and $\overline{\mathrm{CAS}}_{\mathrm{i}}$ outputs.

The Am2968 has two basic modes of operation, read/write and refresh. In refresh mode, the two counters cycle through the refresh addresses. If memory scrubbing is not being implemented, only the Row Counter is used, generating up to 512 addresses to refresh a 512 -cycle-refresh 256 K DRAM. When memory scrubbing is being performed, both the Row and Column counters are used to perform read-modify-write cycles. In this mode all $\overline{\mathrm{RAS}} ;$ outputs will be active while only one $\overline{\mathrm{CAS}}_{\mathrm{i}}$ is active at a time.



AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{array}{r} 3-12 \\ 15-22 \end{array}$ | $A_{0}-A_{17}$ | 1 | Address Inputs. $A_{0}-A_{8}$ are latched in as the nine-bit Row Address for the RAM. These inputs drive $Q_{0}-Q_{8}$ when the Am2968 is in the Read/Write mode and MSEL is LOW. A9 - A17 are latched in as the Column Address, and will drive $\mathrm{Q}_{0}-\mathrm{Q}_{8}$ when MSEL is HIGH and the DMC is in the Read/Write mode. The addresses are latched with the Latch Enable (LE) signal. |
| 23, 24 | $\begin{aligned} & \text { SEL } L_{0}, \\ & \text { SEL } \end{aligned}$ | 1 | Bank Select. These two inputs are normally the two higher-order address bits, and are used in the Read/Write mode to select which bank of memory will be receiving the $\overline{\mathrm{RAS}}_{\mathrm{i}}$ and $\overline{\mathrm{CAS}}_{\mathrm{i}}$ signals after RASI and CASI go HIGH. |
| 14 | LE | 1 | Latch Enable. This active-HIGH input causes the Row, Column, and Bank Select latches to become transparent, allowing the latches to accept new input data. A LOW input on LE latches the input data, assuming it meets the setup and hold time requirements. |
| 2 | MSEL | 1 | Multiplexer Select. This input determines whether the Row or Column Address will be sent to the memory address inputs. When MSEL is HIGH the Column Address is selected, while the Row Address is selected when MSEL is LOW. The address may come from either the address latch or refresh address counter depending on $M C_{0,1}$. |
| 1 | $\overline{\text { CS }}$ | 1 | Chip Select. This active-LOW input is used to enable the DMC. When $\overline{\mathrm{CS}}$ is active, the Am2968 operates normally in all four modes. When $\overline{\mathrm{CS}}$ goes HIGH, the device will not enter the Read/Write mode. This allows other devices to access the same memory that the DMC is controlling (e.g., DMA controller). |
| 37 | $\overline{O E}$ | 1 | Output Enable. This active-LOW input enables/disables the output signals. When OE is HIGH, the outputs of the DMC enter the high-impedance state. The $\overline{\mathrm{OE}}$ signal allows more than one Am2968 to control the same memory, thus providing an easy method to expand the memory size. |
| 26, 25 | $\mathrm{MC}_{0}, \mathrm{MC}_{1}$ | 1 | Mode Control. These inputs are used to specify which of the four operating modes the DMC should be using. The description of the four operating modes is given in Table 1. |
| $\begin{aligned} & 43-39 \\ & 32-35 \end{aligned}$ | $Q_{0}-Q_{8}$ | 0 | Address Outputs. These address outputs will feed the DRAM address inputs, and provide drive for memory systems up to 500 picofarads in capacitance. |
| 27 | RASI | 1 | Row Address Strobe Input. During normal memory cycles, the decoded $\overline{\mathrm{RAS}}_{i}$ output ( $\overline{\mathrm{RAS}}_{0}, \overline{\mathrm{RAS}}_{1}, \overline{\mathrm{RAS}}_{2}$, or $\overline{\mathrm{RAS}}_{3}$ ) is forced LOW after receipt of RASI. In either Refresh mode, all four $\overline{\text { RAS }}_{\mathrm{i}}$ outputs will go LOW following RASI going HIGH. |
| $\begin{aligned} & 47,45,31, \\ & 29 \end{aligned}$ | $\overline{\operatorname{RAS}}_{0}-$ | 0 | Row Address Strobe. Each one of the Row Address Strobe outputs provides a $\overline{\mathrm{RAS}}_{\mathrm{i}}$ signal to one of the four banks of dynamic memory. Each will go LOW only when selected by $\mathrm{SEL}_{0}$ and $\mathrm{SEL}_{1}$ and only after RASI goes HIGH . All four go LOW in response to RASI in either of the Refresh modes. |
| 48 | CASI | 1 | Column Address Strobe Input. This input going active will cause the selected $\overline{\mathrm{CAS}}_{\mathrm{j}}$ output to be forced LOW. |
| $\begin{aligned} & 46,44,30, \\ & 28 \end{aligned}$ | $\overline{\mathrm{CAS}}_{0}{ }^{-}$ | 0 | Column Address Strobe. During normal Read/Write cycles the two select bits (SELo, SEL ${ }_{1}$ ) determine which $\overline{\mathrm{CAS}} \mathrm{S}_{\mathrm{i}}$ output will go active following CASI going HIGH. When memory scrubbing is performed, only the CAS; signal selected by CNTR $_{0}$ and CNTR $1_{1}$ will be active. For non-scrubbing cycles, all four $\overline{\text { CAS }}_{\mathrm{i}}$ outputs remain HIGH. |

Table 1. Mode Control Function Table

| MC ${ }_{1}$ | MC ${ }_{0}$ | Operating Mode |
| :---: | :---: | :---: |
| 0 | 0 | Refresh without Scrubbing. Refresh cycles are performed with only the Row Counter being used to generate addresses. In this mode, all four $\overline{\mathrm{RAS}}_{i}$ outputs are active while the four $\overline{\mathrm{CAS}}_{i}$ signals are kept HIGH. |
| 0 | 1 | Refresh with Scrubbing/Initialize. During this mode, refresh cycles are done with both the Row and Column counters generating the addresses. MSEL is used to select between the Row and Column counter. All four $\overline{\mathrm{RAS}}_{i}$ go active in response to RASI, while only one CAS; output goes LOW in response to CASI. The Bank Counter keeps track of which CAS $_{i}$ output will go active. This mode is also used on system power-up so that the memory can be written with a known data pattern. |
| 1 | 0 | Read/Write. This mode is used to perform Read/Write cycles. Both the Row and Column addresses are latched and multiplexed to the address output lines using MSEL. SEL ${ }_{0}$ and SEL $_{1}$ are decoded to determine which $\overline{\operatorname{RAS}}_{\mathrm{i}}$ and $\overline{\mathrm{CAS}}_{\mathrm{i}}$ will be active. |
| 1 | 1 | Clear Refresh Counter. This mode will clear the three refresh counters (Row, Column, and Bank) on the HIGH-toLOW transition of RASI, putting them at the start of the refresh sequence. In this mode, all four $\overline{\mathrm{RAS}}_{\mathrm{i}}$ are driven LOW upon receipt of RASI so that DRAM wake-up cycles may be performed. |

## ADDRESS OUTPUT FUNCTION TABLE

| $\overline{\mathbf{C S}}$ | MC1 | MC 0 | MSEL | Mode | MUX Output |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | X | Refresh without Scrubbing | Row Counter Address |
|  | 0 | 1 | 1 | Refresh with Scrubbing | Column Counter Address |
|  |  |  | 0 |  | Row Counter Address |
|  | 1 | 0 | 1 | Read/Write | Column Address Latch |
|  |  |  | 0 |  | Row Address Latch |
|  | 1 | 1 | X | Clear Refresh Counter | Zero |
| 1 | 0 | 0 | X | Refresh without Scrubbing | Row Counter Address |
|  | 0 | 1 | 1 | Refresh with Scrubbing | Column Counter Address |
|  |  |  | 0 |  | Row Counter Address |
|  | 1 | 0 | X | Read/Write | Zero |
|  | 1 | 1 | X | Clear Refresh Counter | Zero |

$\overline{R A S}$ OUTPUT FUNCTION TABLE

| RASI | CS | $\mathrm{MC}_{1}$ | MC ${ }_{0}$ | SEL ${ }_{1}$ | SEL ${ }_{0}$ | Mode | $\overline{\mathrm{RAS}}_{0}$ | $\overline{\text { RAS }}_{1}$ | $\overline{\mathbf{R A S}}_{2}$ | $\overline{\text { RAS }}^{\text {S }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | X | X | X | X | X | X | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | X | X | Refresh without Scrubbing | 0 | 0 | 0 | 0 |
|  |  | 0 | 1 | X | X | Refresh with Scrubbing | 0 | 0 | 0 | 0 |
|  |  | 1 | 0 | 0 | 0 | Read/Write | 0 | 1 | 1 | 1 |
|  |  |  |  | 0 | 1 |  | 1 | 0 | 1 | 1 |
|  |  |  |  | 1 | 0 |  | 1 | 1 | 0 | 1 |
|  |  |  |  | 1 | 1 |  | 1 | 1 | 1 | 0 |
|  |  | 1 | 1 | X | X | Clear Refresh Counter | 0 | 0 | 0 | 0 |
|  | 1 | 0 | 0 | X | X | Refresh without Scrubbing | 0 | 0 | 0 | 0 |
|  |  | 0 | 1 |  |  | Refresh with Scrubbing | 0 | 0 | 0 | 0 |
|  |  | 1 | 0 |  |  | Read/Write | 1 | 1 | 1 | 1 |
|  |  | 1 | 1 |  |  | Clear Refresh Counter | 0 | 0 | 0 | 0 |

CAS OUTPUT FUNCTION TABLE

| Inputs |  |  |  |  |  | Internal |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CASI | $\overline{\mathbf{C S}}$ | $\mathrm{MC}_{1}$ | MC ${ }_{0}$ | SEL ${ }_{1}$ | SEL ${ }_{0}$ | CNTR 1 | CNTR 0 | $\overline{\mathrm{CAS}}_{0}$ | $\overline{\text { CAS }}_{1}$ | $\mathrm{CAS}_{2}$ | $\mathrm{CAS}_{3}$ |
|  |  | 0 | 0 | X | X | X | X | 1 | 1 | 1 | 1 |
|  |  |  |  |  |  | 0 | 0 | 0 | 1 | 1 | 1 |
|  |  |  | 1 |  |  | 0 | 1 | 1 | 0 | 1 | 1 |
|  |  | 0 | 1 | $x$ | $x$ | 1 | 0 | 1 | 1 | 0 | 1 |
|  |  |  |  |  |  | 1 | 1 | 1 | 1 | 1 | 0 |
|  | 0 |  |  | 0 | 0 |  |  | 0 | 1 | 1 | 1 |
|  |  |  |  | 0 | 1 |  |  | 1 | 0 | 1 | 1 |
|  |  | 1 | 0 | 1 | 0 | $x$ | $x$ | 1 | 1 | 0 | 1 |
| 1 |  |  |  | 1 | 1 |  |  | 1 | 1 | 1 | 0 |
|  |  | 1 | 1 | X | X | X | X | 1 | 1 | 1 | 1 |
|  |  | 0 | 0 | X | X | X | X | 1 | 1 | 1 | 1 |
|  |  |  |  |  |  | 0 | 0 | 0 | 1 | 1 | 1 |
|  |  |  |  |  |  | 0 | 1 | 1 | 0 | 1 | 1 |
|  | 1 | 0 | 1 | $x$ | $x$ | 1 | 0 | 1 | 1 | 0 | 1 |
|  |  |  |  |  |  | 1 | 1 | 1 | 1 | 1 | 0 |
|  |  | 1 | 0 | $x$ | X | X |  | 1 |  |  |  |
|  |  | 1 | 1 | X | X | X | X | 1 | 1 | 1 | 1 |
| 0 | X | X | X | X | X | X | X | 1 | 1 | 1 | 1 |

## APPLICATION

ARCHITECTURE
The Am2968 provides all the required data and refresh addresses needed by the dynamic RAM memory. In normal operation, the Row and Column addresses are multiplexed to the dynamic RAM by using MSEL, with the corresponding $\overline{\mathrm{RAS}} \mathrm{I}_{\mathrm{j}}$ and $\overline{\mathrm{CAS}} \mathrm{S}_{\mathrm{j}}$ signals activated to strobe the addresses into the RAM. High capacitance drivers on the outputs allow the DMC to drive four banks of 16 -bit words, including a 6 -bit checkword, for a total of 88 DRAMs.

## INPUT LATCHES

For those systems where addresses and data are multiplexed onto a single bus, the DMC has latches to hold the address information. The twenty input latches (Row, Column, and Bank Select) are transparent when Latch Enable (LE) is HIGH and will latch the input data meeting setup and hold time requirements when LE goes LOW. For systems where the processor has separate address and data buses, LE may be permanently enabled HIGH.

## REFRESH COUNTERS

The two 9-bit refresh counters make it possible to support 128, 256, and 512 line refresh. External control over what type of refresh is to be performed allows the user maximum flexibility when choosing the refreshing scheme. Transparent (hidden),
burst, synchronous or asynchronous refresh modes are all possible.

The refresh counters are advanced at the HIGH-to-LOW transition of RASI. This assures a stable counter output for the next refresh cycle.

## REFRESH WITH ERROR CORRECTION

The Am2968 makes it possible to correct single-bit errors in parallel with performing dynamic RAM refresh cycles. This "scrubbing" of memory can be done periodically as a background routine when the memory is not being used by the processor. In a memory scrubbing cycle ( $\mathrm{MC}_{1,0}=01$ ), the Row Address is strobed into all four banks with all four $\overline{\operatorname{RAS}}_{\mathrm{i}}$ outputs going LOW.

The Column Address is strobed into a single bank with the activated $\overline{\mathrm{CAS}} \mathrm{S}_{\mathrm{i}}$ output being selected by the Bank Counter. This type of cycle is used to simultaneously refresh the addressed row in all banks and read and correct (if necessary) one word in memory; thereby reducing the overhead associated with Error Detection and Correction. When doing refresh with memory scrubbing, both the Row and Column counters are multiplexed to the dynamic RAM address lines by using MSEL. Using the Refresh with Memory Scrubbing mode implies the presence of an error correcting facility such as the Am2960A EDC unit. When doing refresh without scrubbing, all four RAS ${ }_{j}$ still go LOW but the $\mathrm{CAS}_{j}$ outputs are all driven HIGH so as not to activate the output lines of the memory.

Figure 1.
a. One Megaword Dynamic Memory with Error Detection and Correction

b. One Megaword Dynamic Memory


## TIMING CONTROL

To obtain optimum performance and maximum design flexibility, the timing and control logic for the memory system has been kept a separate function. For systems implementing Error Detection and Correction, the Am2969 Memory Timing Controller (MTC) provides all the necessary control signals for the Am2968, Am2961/62 EDC Bus Buffers, and the Am2960A EDC unit (See Figure 1a). Systems not using EDC, can use the Am2970 MTC to provide the control for the Am2968 (See Figure 1b). Both the Am2969 and Am2970 Memory Timing Controllers use a delay line to provide the most accurate timing reference from which the control signals are derived.

## DECOUPLING

Due to the high switching speeds and high drive capability of the Am2968, it is necessary to decouple the device for proper operation. (See Fig. 2a) Recommended values for decoupling capacitors are between $0.01 \mu \mathrm{~F}$ and $1 \mu \mathrm{~F}$. For example to filter
noise at different frequencies we can make $\mathrm{C}_{1}=0.01 \mu \mathrm{~F}$ in parallel with a $1 \mu \mathrm{~F}$ and $\mathrm{C}_{2}=0.01 \mu \mathrm{~F}$. It is important to mount the capacitors as close as possible to the power pins ( $V_{C C}$, GND) to minimize lead inductance and noise.

## MEMORY EXPANSION

With a 9-bit address path, the Am2968 can control up to one megaword memory when using 256K dynamic RAMs. If a larger memory size is desired, the DMC's chip select (CS) makes it easy to double the memory size by using two Am2968s. Memory can be increased in one megaword increments by adding another DMC unit. A four-megaword memory system implementing EDC is shown in Figure 3.

## Vonp

The guaranteed maximum undershoot voltage of the Am2968 is -0.5 volts. VONP is measured with respect to the ground of pin 38 (Fig. 2b). Note that the ground of the capacitive load must be the same as for pin 38.

Figure 2.


Figure 2a.


Figure 2b.


Figure 3. Four Megaword Error Correcting Memory

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature with
Power Applied............................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ..........................................
DC Voltage Applied to Outputs For
High Output State......................... 0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage .................................... 0.5 V to +5.5 V
DC Output Current, Into Outputs ............................30mA
DC Input Current ............................... 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

| Commercial (C) Devices |  |
| :---: | :---: |
| $\mathrm{T}_{\text {A }}$ | 0 to $+70^{\circ} \mathrm{C}$ |
| $V_{C C}$ | $5.0 \mathrm{~V} \pm 10 \%$ |
| Min | 4.50 V |
| Max | ..... 5.50V |
| Military (M) Devices |  |
| TC... | -55 to $+125^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\text {cc }}$. | . $5.0 \mathrm{~V} \pm 10 \%$ |
| Min. | .... 4.50V |
| Max | . 5.50 V |
| Operating ranges define | wich the function- |

DC CHARACTERISTICS over operating. range unless otherwise specified

| Parameters | Descriptions | Test Conditions (Note 1) |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} \\ & V_{\mathrm{IN}}=\mathrm{V}_{1 \mathrm{H}} \text { or } V_{\mathrm{IL}} \\ & \mathrm{O}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \hline \end{aligned}$ | COMM | 2.7 |  |  | Volts |
|  |  |  | MIL | 2.5 |  |  |  |
| 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{I}_{\mathrm{OL}}=1 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.8 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{\text {IN }}=0.4 V \end{aligned}$ |  |  |  | -400 | $\mu \mathrm{A}$ |
| 1 H | Input HIGH Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{IN}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| $\\|$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=5.5 \mathrm{~V} \\ & \hline \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozh | Off-State Current | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| lozl | Off-State Current | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
| IOL | Output Sink Current | $\mathrm{V}_{\mathrm{OL}}=2.0 \mathrm{~V}$ |  | 45 |  |  | mA |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=$ MAX (Note 2) |  | -60 | -95 | -275 | mA |
| Icc | Power Supply Current | $V_{C C}=$ MAX | $25^{\circ} \mathrm{C}, 5 \mathrm{~V}$ |  | 230 |  |  |
|  |  |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | 280 |  |
|  |  |  | $+70^{\circ} \mathrm{C}$ |  | 200 | 260 |  |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |  | 295 |  |
|  |  |  | $+125^{\circ} \mathrm{C}$ |  | 195 | 255 |  |

Notes: 1. For conditions shown as Min or Max, use the appropriate value specified under Operating Range for the applicable device type.
2. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.


SWITCHING CHARACTERISTICS over operating range for $C_{L}=150 \mathrm{pF}$

| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL AND MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max |  |
| 1 | tPD |  | $A_{i}$ to $Q_{i}$ Delay | Fig. 4 and 6 $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ | 16 | 9 | 24 | ns |
| 2 | tPD | RASI to $\overline{\text { RAS }}_{\text {i }}$ | 15 |  | 9 | 23 | ns |
| 3 | tPD | CASI to CAS $_{\text {i }}$ | 14 |  | 9 | 22 | ns |
| 4 | tpo | MSEL to $\mathrm{Q}_{\mathrm{i}}$ | 17 |  | 9 | 26 | ns |
| 5 | $t_{P D}$ | $M C_{i}$ to $Q_{i}$ | 18 |  | 10 | 28 | ns |
| 6 | $t_{\text {PD }}$ | LE to $\overline{\text { AAS }}_{\text {i }}$ | 20 |  |  | 28 | ns |
| 7 | $t_{P D}$ | LE to CAS $_{i}$ | 19 |  |  | 27 | ns |
| 8 | $t_{\text {PD }}$ | $M C_{i}$ to $\overline{\text { AAS }}_{i}$ | 19 |  | 9 | 25 | ns |
| 9 | tPD | $M C_{i}$ to $\overline{C A S}_{i}$ | 17 |  | 9 | 23 | ns |
| 10 | tPD | LE to $Q_{i}$ | 20 |  | 10 | 27 | ns |
| 11 | tpWL | RASI, CASI | $C_{L}=150 p F$ | 10 | 20 |  | ns |
| 12 | tpWH | RASI, CASI |  | 10 | 20 |  | ns |
| 13 | ts | $A_{i}$ to LE |  | 1 | 5 |  | ns |
| 14 | $\mathrm{t}_{\mathrm{H}}$ | $A_{i}$ to LE |  | 1 | 5 |  | ns |
| 15 | tPD | CS to $Q_{i}$ |  | 19 |  | 27 | ns |
| 16 | tpD | CS to $\overline{\text { RAS }}_{i}$ |  | 14 |  | 22 | ns |
| 17 | tPD | CS to $\overline{C A S}_{i}$ |  | 14 |  | 22 | ns |
| 18 | tPD | SELi to $\overline{\text { RAS }}_{i}$ |  | 15 |  | 23 | ns |
| 19 | tpD |  |  | 14 |  | 22 | ns |
| 20 | ts | SELi to LE |  | 1 | 5 |  | ns |
| 21 | $\mathrm{t}_{\mathrm{H}}$ | SELi to LE |  | 1 | 5 |  | ns |
| 22 | tSKEW | $Q_{i}$ to $\overline{\mathrm{RAS}}_{i}\left(M C_{j}=10\right)$ |  | 10 |  | 15 | ns |
| 23 | tSKEW | $Q_{i}$ to $\overline{R A S}_{i}\left(M C_{i}=00,01\right)$ |  | 10 |  | 17 | ns |
| 24 | tSKEW | $Q_{i}$ to $\overline{\text { RAS }}_{i}$ |  | 2 |  | 8 | ns |
| 25 | tSKEW | $\mathrm{Q}_{\mathrm{i}}$ to $\overline{\mathrm{CAS}}_{i}$ |  | 15 |  | 17 | ns |
|  | VONP | Output Undershoot Voltage | Fig. 4 and 6 | 0 |  | -0.5 | V |


| Parameter |  | Description | Test Conditions | Typ | COMMERCIAL AND MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  | Max |  |
| 1 | tPD |  | $A_{i}$ to $Q_{i}$ Delay | $\begin{aligned} & \text { Fig. } 4 \text { and } 6 \\ & \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF} \end{aligned}$ | 29 | 12 | 40 | ns |
| 2 | tPD | RASI to $\widehat{\text { RAS }}_{\text {i }}$ | 28 |  | 12 | 40 | ns |
| 3 | tpD | CASI to $\mathrm{CAS}_{\mathrm{i}}$ | 26 |  | 12 | 37 | ns |
| 4 | tPD | MSEL to $\mathrm{Q}_{\mathrm{i}}$ | 29 |  | 12 | 42 | ns |
| 5 | tpD | $M C_{i}$ to $Q_{i}$ | 30 |  | 12 | 44 | ns |
| 6 | tpD | LE to $\overline{\operatorname{RAS}}_{\text {i }}$ | 32 |  |  | 46 | ns |
| 7 | tPD | LE to CAS ${ }_{\text {i }}$ | 31 |  |  | 45 | ns |
| 8 | tPD | $\mathrm{MC}_{\mathrm{i}}$ to $\overline{\mathrm{PAS}}_{\mathrm{i}}$ | 30 |  | 12 | 40 | ns |
| 9 | tpD | $\mathrm{MC}_{\mathrm{i}}$ to $\mathrm{CAS}_{i}$ | 28 |  | 12 | 40 | ns |
| 10 | tPD | LE to $\mathrm{Q}_{\mathrm{i}}$ | 32 |  | 12 | 46 | ns |
| 11 | tpwL | RASI, CASI | $C_{L}=500 \mathrm{pF}$ | 10 | 20 |  | ns |
| 12 | tpWH | RASI, CASI |  | 10 | 20 |  | ns |
| 13 | ts | $A_{i}$ to LE |  | 1 | 5 |  | ns |
| 14 | $\mathrm{tH}_{\mathrm{H}}$ | $\mathrm{A}_{\mathrm{i}}$ to LE |  | 1 | 5 |  | ns |
| 15 | tpd | $\overline{C S}$ to $Q_{i}$ |  | 30 |  | 45 | ns |
| 16 | tPD | CS to $\overline{\text { AAS }}_{\text {i }}$ |  | 27 |  | 40 | ns |
| 17 | tpD | CS to CAS ${ }_{\text {i }}$ |  | 26 |  | 38 | ns |
| 18 | tpD | $\mathrm{SEL}_{i}$ to $\overline{\mathrm{RAS}}_{\mathrm{i}}$ |  | 31 |  | 42 | ns |
| 19 | tPD | SEL $\mathrm{L}_{\mathrm{i}}$ to $\mathrm{CAS}_{\mathrm{i}}$ |  | 28 |  | 41 | ns |
| 20 | ts | SELi to LE |  | 1 | 5 |  | ns |
| 21 | ${ }_{\text {t }}$ | SELi to LE |  | 1 | 5 |  | ns |
| 22 | tSkEw | $\mathrm{Q}_{\mathrm{i}}$ to $\overline{\mathrm{ASS}}_{\mathrm{i}}\left(\mathrm{MC}_{\mathrm{i}}=10\right)$ |  | 10 |  | 18 | ns |
| 23 | tSKEW | $\mathrm{Q}_{\mathrm{i}}$ to $\overline{\mathrm{RAS}} \mathrm{S}_{\mathrm{i}}\left(\mathrm{MC}_{\mathrm{i}}=00,01\right)$ |  | 10 |  | 18 | ns |
| 24 | tSkEw | $Q_{i}$ to $\overline{\mathrm{RAS}}_{i}$ |  | 2 |  | 8 | ns |
| 25 | tSKEW | $\mathrm{a}_{\mathrm{i}}$ to $\mathrm{CAS}_{i}$ |  | 15 |  | 20 | ns |
|  | Vonp | Output Undershoot Voltage | Fig. 4 and 6 | 0 |  | -0.5 | V |

## SWITCHING TEST CIRCUIT




TC000510
${ }^{*} t_{\text {pd }}$ specified at $C_{L}=50,150$ and 500 pF
Figure 4. Capacitive Load Switching.
Figure 5. Three-State Enable/Disable.

TYPICAL SWITCHING CHARACTERISTICS

VOLTAGE WAVEFORMS


WF002122

TYPICAL OUTPUT DRIVER


Figure 6. Output Drive Levels.

THREE-STATE TIMING


WFR02941
Note: Decoupling is needed for all AC tests
Figure 7. Three-State Control Levels.

The RAM Driver symmetrical output design offers significant improvement over a standard Schottky output by providing a balanced drive output impedance ( $\approx 25 \Omega$ both HIGH and LOW), and by pulling up to MOS $\mathrm{V}_{\mathrm{OH}}$ levels ( $\mathrm{V}_{\mathrm{CC}}-1.5 \mathrm{~V}$ ). External resistors, not required with the RAM Driver, protect standard Schottky drivers from error causing undershoot but also slow the output rise by adding to the internal R.

The RAM Driver is optimized to drive LOW at maximum speed based on safe undershoot control and to drive HIGH with a symmetrical speed characteristic. This is an optimum approach because the dominant RAM loading characteristic is input capacitance.


## MEMORY CYCLE TIMING

The relationship between DMC specifications and system timing requirements are shown in Figure 8. $T_{1}, T_{2}$ and $T_{3}$ represent the minimum timing requirements at the DMC inputs to guarantee that RAM timing requirements are met and that maximum system performance is achieved.

The minimum requirement for $T_{1}, T_{2}$ and $T_{3}$ are as follows:

$$
\begin{aligned}
& T_{1} M I N=t_{\text {ASR }}+t_{22} \\
& T_{2} M I N=t_{\text {RAH }}+t_{24} \\
& T_{3} M I N=T_{2}+t_{25}+t_{\text {ASC }}
\end{aligned}
$$

See RAM data sheet for applicable values for $t_{\text {RAH, }} t_{\text {ASC }}$ and $t_{\text {ASR }}$.

Figure 8. Memory Cycle Timing
a. Specifications Applicable to Memory Cycle Timimg ( $\mathrm{MC}_{\boldsymbol{i}}=\mathbf{1}, \mathbf{0}$ )

2) GUARANTEED MAX difference between fastest rasi to $\overline{\text { AASS }}$ oelay and the slowest a, to o, delar on any single device
GUARANTEED MAX Difference between fastest msel roo oelay
and the slowest rasi to ras, oelay on any single device
and the slowest rasi to ras, oelay on any single device
GUARANTEEO MAX DIFFERENCE BET WEEN FASTEST CASI TO CAS, OELAY
AND THE SLOWEST MSEL TO O OELAY ON ANY SINGLE OEVICE
and the slowest msel to o, oelay on any single device
b. Desired System Timing


## REFRESH CYCLE TIMING

The timing relationships for refresh are shown in Figure 9.
$T_{4}$ minimum is calculated as follows:
$T_{4} \mathrm{MIN}=\mathrm{t}_{\mathrm{ASR}}+\mathrm{t}_{23}$
Figure 9. Refresh Cycle Timing
a. Specifications Applicable to Refresh Cycle Timing ( $\mathrm{MC}_{\mathrm{i}}=\mathbf{0 0}, 01$ )
 AND THE SLOWEST $A_{i}$ to $O_{i}$ DELAY ON ANY SINGLE DEVICE
(23) GUARANTEED MAX DIF FERENCE BETWEEN FASTEST RASI TO $\overline{R A S}$, DELAY AND THE SLOWEST MC, TO O, OELAY ON ANY SINGLE DEVICE
(24) GUARANTEED MAX DIF FERENCE BETWEEN FASTEST MSEL TO O; DELAY AND THE SLOWEST RASI TO RAS; DELAY ON ANY SINGLE DEVICE
25) GUARANTEEO MAX DIFFERENCE BETWEEN FASTEST CASI TO CAS, DELAY AND THE SLOWEST MSEL TO O; DELAV ON ANY SINGLE DEVICE
b. Desired Timing: Refresh with Scrubbing

CAS,

## REFRESH CYCLE TIMING

Figure 9. Refresh Cycle Timing (Cont.)
c. Desired Timing: Refresh without Scrubbing


## NANOSECONDS VERSUS PICOFARADS

To help calculate how the AC performance of the DMC will vary for capacitive loads other than 50,150, and 500pF refer to the table below.

Example: For a system capacitive load of 250 pF , add the delay associated with 100 pF from the table to the AC specs done at 150 pF .

> Change in Propagation Delay versus Loading Capacitance (TYPICAL)


LCR00011


# Am2969 

Dynamic Memory Timing Controller

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Provides complete timing control for $64 \mathrm{~K} / 256 \mathrm{~K}$ memory systems which utilize the Am2960, Am2961/62, and Am2968
- Supports byte-writes up to 32-bits wide
- Supports memory scrubbing during refresh
- Burst (up to 512-cycle), distributed, or hidden refresh
- Performs memory initialization
- Memory access/refresh request arbitration


## GENERAL DESCRIPTION

The Am2969 is a high-performance Memory Timing Controller (MTC). The Am2969 is designed to be used in memory systems which use the Am2968 Dynamic Memory Controller (DMC) as well as the popular Am2960 circuits for Error Detection and Correction (EDC). All of the control signials needed by the DMC and EDC circuits are generated by the Am2969 MTC. The EDC enable signals are configured for both word and byte operations including the data controls for byte write with error correction.

The Am2929 uses a delay-line to provide maximum flexibility to the memory system designer as well as allowing him to achieve maximum performance. The delay-line is the timing reference from which the MTC generates the control signals.
The Am2969 provides an internal refresh interval timer to generate refresh requests independent of the CPU. This guarantees proper refresh timing under all combinations of CPU and DMA requests.

BLOCK DIAGRAM


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2960/60A | 16-Bit Error Detection and Correction Unit |
| Am2961/62 | 4-Bit Multiple Bus Buffers |
| Am2968 | Dynamic Memory Controller |

buS RETRY MODE, Input
When this input is LOW, the Am2969 enters the Bus Retry Mode. In this mode the INTERR and INTACK pins assume the $\overline{B E R R}$ and HALT functions respectively. An explanation of the Bus Retry Mode is given in the "Application" section.

## BYTE/WORD, Input

This input indicates a byte operation is to be performed when HIGH, and a word operation when LOW.
CLK CLOCK, Input
For systems requiring synchronous arbitration of memory access and refresh requests, this input would receive the system clock. For asynchronous arbitration this input must be tied HIGH.

## CHIP SELECT, Input

When CS is LOW, the MTC is enabled. A memory read/write cycle can only be performed when CS is active, while refresh cycles occur independent of $\overline{C S}$. When $\overline{\mathrm{CS}}$ is HIGH, all memory requests (HIGH-to-LOW transition of CYCREQ) will be interpreted as refresh requests ('Hidden'" refresh).
CYCLE REQUEST, Input
When $\overline{\mathrm{CS}}$ is LOW, this input will generate an internal memory request for the Am2969 or the HIGH-to-LOW transition of CYCREQ.

## DTACK DATA TRANSFER ACKNOWLEDGE, Output

 The HIGH-to-LOW transition of DTACK informs the CPU that a write cycle has begun, or that data will be on the system bus at the correct time during a read cycle.ERR ERROR, Input
When this signal goes LOW, it indicates that an error has occurred on a read cycle. This input should be connected to the ERR output of the Am2960 EDC unit.
$\overline{\text { FR }} \quad$ FORCED REFRESH, Input
This input is used to force a refresh cycle at userdesignated times. The falling edge of $\overline{\mathrm{FR}}$ latches an internal refresh request. if the memory is busy, the refresh is done at the completion of the current cycle.

## H/F HALF/FULL, Input

This input indicates the relative size of the system bus with respect to the memory bus. It is HIGH if the system bus is half the memory width, and LOW if the system bus width is equal to the memory width.
INTERRUPT ACKNOWLEDGE (BUS

When INTACK goes LOW it will reset the Interrupt Request (INTERR) output of the Am2969. In the Bus Retry Mode, this pin will act as the BUS ERROR output. An explanation for $\overline{B E R R}$ is given in the "Application" section.

## INTERR INTERRUPT ERROR (HALT), Output <br> (HALT) (Output)

The INTERR output interrupts the processor if a single-bit error is detected in the "Fly-By" mode, or if a multiple-bit error is detected in the Flow-Thru mode (see "Application" section for descriptions of "Fly-By" and "Flow-Thru' modes). In the Bus Retry Mode, this pin will act as the HALT output which is explained in the "Application" section.

## INT/

NORM
When the Am2969 detects a falling edge on this input, it will enter the initialize mode of operation. This allows the memory to be initialized easily with a minimum of CPU overhead. When this input is HIGH, normal read/write and refresh cycles may be performed.
LEB LATCH ENABLE BUFFER, Output
This output is intended to be connected to the LEB input of the Am2961/62 EDC Bus Buffers. It controls the latching of data going from the EDC Bus Buffers to the system bus. When LEB is HIGH, the latch is transparent; when LOW, the data is latched.
LEI LATCH ENABLE IN, Output
This output is intended to be connected to the LE IN input of the Am2960 EDC unit. It controls the latching of data (data and check bits) into the EDC unit. The data is latched in when LEI is LOW.
LEO/GEN LATCH ENABLE OUT/GENERATE, Output
This output is intended to be connected to the L.E OUT and GENERATE inputs of the Am2960 EDC unit. LE OUT controls the latching of corrected data from the EDC into its output latch. GENER$\overline{\text { ATE }}$ instructs the Am2960 to generate check bits for the data in its input latch. When LEO/GEN is HIGH, the latch is transparent; when LOW, data is latched and the EDC unit goes into the Check Bit Generation mode.
$M_{0,1} \quad$ MODE CONTROL BITS 0 AND 1, Output These outputs are connected to the $\mathrm{MC}_{0,1}$ inputs of the Am2968 DMC. They indicate the type of memory cycle to be performed, as shown in Table A.

TABLE A. MODE SELECT TABLE

| $\mathbf{M C}_{\mathbf{1}}$ | $\mathbf{M C}_{\mathbf{0}}$ | Mode |
| :---: | :---: | :--- |
| 0 | 0 | Refresh without Scrubbing |
| 0 | 1 | Refresh with Scrubbing or Initialize |
| 1 | 0 | Read/Write |
| 1 | 1 | Clear Refresh Counter |

## MERR MULTIPLE ERROR, Input

This input identifies that a multiple error has been detected by the EDC unit. This input is intended to be connected to the MERR output of the Am2960.
$\overline{\text { OEBH, }}$
OEBL

OUTPUT ENABLE BUS HIGH, LOW, Output These outputs are used when interfacing to a system bus, which can either be the same width as memory or half the width. They control the multiplexing of the half-words on to the system bus from the EDC Bus Buffers. $\overline{O E B H}$ and $\overline{O E B L}$ are enabled as shown in Table B. These outputs are intended to be connected to the appropriate $\overline{\mathrm{OEB}}$ inputs of the Am2961/62.

TABLE B. OEB TRUTH TABLE

| $H / \bar{F}$ | A $_{1}$ | $\overline{\text { OEBH }}$ | $\overline{\text { OEBL }}$ |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

X = Don't Care
OUTPUT ENABLE HIGH AND LOW, Output
These signals are used to select the appropriate output from the EDC Bus Buffers and EDC unit(s), when performing either byte writes or word writes when $H / \bar{F}$ is high. $A_{0}$ and $A_{1}$ are decoded so that the selected byte or word may be written into memory. These signals are intended to be connected to the corresponding $\overline{O E}$ inputs of the Am2960 and OEY input of the Am2961/62. Table C shows how these outputs are enabled.
OUTPUT ENABLE SYNDROMES, Output
This output is intended to be connected to the $\overline{O E}$ $\overline{S C}$ input of the Am2960 EDC unit. It controls the feedback of the syndrome bits in the 32-bit and 64bit modes.
OSCILLATOR, Input

This input signal is used to generate an internal refresh clock. It is this oscillator which initiates a refresh cycle if $\overline{F R}$ does not go active. The OSC signal may come from either external components (RC circuit) or a TTL clock source.

RASI

ROW ADDRESS STROBE INPUT, Output
This output is connected to the RASI input of the Am2968 DMC. It is used to start a memory access for the DMC. The RASI output is also connected to the delay line to start the timing sequence. The rising edge of RASI initiates both actions.
REFRESH MODE, Input
These inputs control the type of refresh cycle the Am2969 is supposed to initiate, as specified in Table D.
READ/WRITE, Input
This input indicates a memory read request when HIGH, and a write request when LOW.

The S output is intended to be connected to the $S$ input of the Am2961/62 EDC Bus Buffers. It controls the source of data for the Am2960 EDC unit. When HIGH, data comes from the system bus; when LOW, data comes from memory.
SUPPRESS, Input
When SUP is driven LOW, it will inhibit access to memory by disabling WE. It can be used to prevent illegal access in memory-access-protected systems.
TIMING TAPS, Input
These inputs are the positive-edge triggered timing tap outputs from the timing reference (delay-line). They provide the necessary timing information for the Am2969 to control memory cycles. Definition of the ten timing taps is given in Table E.
WE WRITE ENABLE, Output
When $\overline{W E}$ is LOW, it causes data to be written into memory. $\overline{W E}$ is inhibited if $\overline{S U P}$ is LOW, or if a multiple error is encountered during a read-modifywrite cycle.

TABLE C. OUTPUT ENABLE TRUTH TABLE

| $\mathbf{H} / \overline{\mathbf{F}}$ | $\mathbf{B} / \overline{\mathbf{W}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathbf{O E H}}_{\mathbf{1}}$ | $\overline{\mathbf{O E H}}_{\mathbf{0}}$ | $\overline{\mathbf{O E L}}_{\mathbf{1}}$ | $\overline{\mathbf{O E L}}_{\mathbf{0}}$ | Cycle Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Full Word Write |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |  |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | Byte Write |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |  |
| 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |  |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Word Write |
| 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 |  |
| 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 |  |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | Byte Write |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |  |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |  |

TABLE D. REFRESH MODE SELECT TABLE

| $\mathbf{R M}_{\mathbf{2}}$ | $\mathbf{R M}_{\mathbf{1}}$ | $\mathbf{R M}_{\mathbf{0}}$ | Refresh Mode |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Not Scrubbing/Not Burst |
| 0 | 0 | 1 | Not Scrubbing/128-Cycle Burst |
| 0 | 1 | 0 | Not Scrubbing/256-Cycle Burst |
| 0 | 1 | 1 | Not Scrubbing/512-Cycle Burst |
| 1 | 0 | 0 | Scrubbing/Not Burst |
| 1 | 0 | 1 | Scrubbing/128-Cycle Burst |
| 1 | 1 | 0 | Scubbing/256-Cycle Burst |
| 1 | 1 | 1 | Scrubbing/512-Cycle Burst |

## table e. timing tap definition table

| Tap\# | Function |
| :---: | :--- |
| 1 | Controls when $\overline{\text { DTACK will go active during read cycles. }}$ |
| 2 | Identified when ERR flag is valid during a read cycle. <br> Also used to control when the $\overline{\text { RAS outputs of Am2968 }}$ <br> should be taken HIGH for read and full-word write <br> cycles. |
| 3 | Indicates that corrected data is available at output of <br> EDC unit during a read cycle with a single-bit error. |
| 4 | Controls when $\overline{\text { DTACK will go active during read-modify- }}$ <br> write cycles. |
| 5 | Identifies when data and check bits are available on the <br> memory bus during write cycles. |
| 6 | Identifies when corrected data and check bits are <br> available on the memory bus during read-modify-write <br> cycles. |
| 7 | Indicates that valid data is available from memory at <br> inputs of EDC unit during read cycles. |
| 8 | Identifies when a new memory cycle may begin after a <br> read or write cycle has been performed. |
| 9 | Controls when $\overline{\text { RAS outputs of DMC should go HIGH for }}$ <br> read-modify-write cycles. |
| 10 | ldentifies when a new memory cycle may begin after a <br> read-modify-write cycle has been performed. |

## APPLICATION

## ARCHITECTURE

The Am2969 MTC is designed to replace much of the MSI 'glue' logic which is commonly necessary in controlling dynamic memory systems. It is responsible for controlling/ arbitrating memory access and refresh, error detection and correction processes, and handshaking with the processor. The Am2969 supports both multiplexed and demultiplexed buses by controlling the output enable signals of the EDC Bus Buffers.

The Am2969 performs seven basic types of memory cycles READ WITHOUT ERROR, READ WITH ERROR, FULL WORD WRITE, PARTIAL WORD WRITE, REFRESH, SCRUBBING, and INITIALIZE. The cycles READ WITHOUT ERROR, FULL WORD WRITE, REFRESH, and INITIALIZE are normal (read/write) accesses to memory, while the others require extended (read-modify-write) accesses.

## ARBITRATION: SYNCHRONOUS vs ASYNCHRONOUS

The Am2969 arbitrates between processor (read/write) and refresh requests for a memory cycle. If both the refresh and processor cycle are requested at the same time, the processor request is serviced, first followed by the refresh request. A third type of access, memory initialization, is given priority over both processor and refresh requests. It is possible for the arbiter to be either synchronous with the system clock, or asynchronous. Synchronous arbitration requires that the inputs requesting memory, FR and CYCREQ, be clocked into the Am2969 by using the CLK input. In this mode, CYCREQ and $\overline{F R}$ are examined on the negative edge of CLK. When CLK is not used (tied HIGH), the AM2969 detects is absence and enters the asynchronous mode. In this mode the first memory request to occur will be serviced, but not until after an internal delay to avoid metastable states.

## FLOW-THRU vs FLY-BY READ CYCLES

The simplest way to use error-correcting memory is to extend all read cycles long enough to have single-bit errors detected before the data transfer acknowledge (DTACK) is asserted. In this way, cycles can be extended by the Am2969 on detection of a single-bit error with no external logic. When a multiple-bit error is detected, the processor is interrupted and an errorhandling subroutine can be initiated. The problem with this type of 'flow-thru' operation is that faster memory must be used to allow for the single-bit error flag to become valid before asserting DTACK. If faster memory is unavailable or undesirable, wait-states may have to be inserted into the read cycle and memory bandwidth is compromised.

In "fly-by" operation, the assumption is made that all reads will result in correct data; therefore, DTACK is asserted earlier in the cycle, which results in improved memory bandwidth. The processor will be interrupted whenever an error occurs.

One problem associated with fly-by operation comes from DTACK being asserted prior to ERR going active when a single-bit error is detected. In this case, the processor will be receiving incorrect data unknowingly. To correct this situation, additional logic may be required to cause the processor to accept the "true" corrected data.

The Am2969 determines whether flow-thru or fly-by operations should be performed by checking the relationship of $\mathrm{T}_{1}$ and $T_{2}$. The Fly-By mode is entered when $T_{1}$ occurs before $T_{2}$, and the flow-thru mode is identified by $T_{2}$ going LOW prior to $T_{1}$.

## BUS RETRY MODE

If the system processor can support a bus retry request, the Am2969 has a read access mode which offers the best of flow-thru and fly-by operation.

In this mode, read cycles are normally performed as fly-by. However, instead of interrupting the processor when a singlebit error is encountered, the Am2969 requests the last cycle to be "rerun' by asserting $\overline{B E R R}$ and $\overline{\text { HALT }}$ simultaneously. An internal status flip flop is set which reserves the next processor request for a read cycle to the same location. On this access, DTACK is delayed until the erroneous data has been corrected. If a multiple error is detected, $\overline{B E R R}$ is asserted and the processor can enter an error recovery subroutine.

## MEMORY INITIALIZATION

Error-correcting memories are normally initialized to avoid the read errors associated with memory which powers up in a random state. The Am2969 facilitates this procedure via the INIT/NORM input. The data pattern written to memory can either be all zero, using the INITIALIZE mode of the Am2960, or any desired pattern present on the system bus during the first memory cycle of the initialize routine.

Upon entering the INITIALIZE mode, the Am2969 performs eight "wake-up" cycles and then $2^{20}$ write/refresh cycles. Upon completion of the initialization, the Am2969 begins normal memory arbitration.

## REFRESH OPERATIONS

The Am2969 can support a variety of refresh schemes. The type of refresh is controlled via the RM0-2 inputs. Basic refresh types include distributed, as well as 128-, 256- or 512cycle burst.

The internal refresh request is controlled by the FR input, or the output of the internal oscillator as follows:

- In the burst mode of operation, the FR input is always the refresh clock.
- The FR input can also be used as the refresh clock in the distributed refresh (non-burst) mode. However, the internal oscillator takes over as the refresh clock if it goes through three cycles without a LOW level appearing on the FR input. This provision allows the primary refresh clock ( $\overline{\mathrm{FR}}$ ) to be interrupted while it is in the HIGH logic state, and for refresh operations to be resumed at the internal oscillator frequency.
- It is also possible to use the on-chip oscillator as the refresh clock in distributed refresh mode. In this case, the $\overline{F R}$ input should be tied HIGH. However, since the on-chip oscillator is asynchronous to the external CLK input, it is necessary to provide a synchronous refresh clock via the $\overline{F R}$ input if synchronous arbitration is desired.

The Am2969 has the ability to increase memory bandwidth by inserting refresh requests when the processor is accessing other devices or performing I/O operations (CYCREQ = LOW, $\overline{C S}=H I G H)$. A hidden refresh can only be performed once every refresh clock period, and occurs only with distributed refreshing. When a hidden refresh is performed, the Am2969 will skip the next refresh request. Figure 1 shows the timing involved to perform a hidden refresh cycle.

Depending on the system configuration and operation, it is possible for the DRAM to appear "static," providing that a hidden refresh can be performed every refresh clock period.

Figure 1. Hidden Refresh Cycle


## MEMORY ERROR SCRUBBING

Memory scrubbing is a housekeeping operation in which memory is checked for errors during normal refresh operations. On each refresh cycle, one memory location is read, checked for errors, and if necessary, corrected and written back to memory. This is a preventative operation to minimize the amount of error accumulation. If the processor is not attempting to access memory during a scrubbing cycle, the processing throughput for that cycle is increased over that of a system not implementing scrubbing. This is made possible because a non-scrubbing system forces the processor to wait after an error is detected, to allow the corrected data to be written back to memory. This occurs during a normal read
cycle. For a scrubbing system, the extra time needed to write corrected data back into memory can be 'hidden' from the processor since this occurs during refresh.
Once the $\overline{E R R}$ signal goes LOW during a scrubbing cycle, the Am2969 extends the cycle by not issuing DTACK. The writing of corrected data back into memory is accomplished by controlling the output enables of the EDC unit and EDC Bus Buffers. The Am2969 is also responsible for having the Am2968 DMC perform a write cycle so that the corrected data can be written into the same memory location. If a multiple-bit error is encountered during a scrubbing cycle, $\overline{W E}$ will be inhibited. The total time required to ''scrub" a one-megaword memory of all single-bit errors is 16 seconds (assuming one refresh cycle every $16 \mu \mathrm{sec}$ ).

One Megaword Dynamic Memory System with Error Detection and Correction


## Am2970

Dynamic Memory Timing Controller

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Provides complete timing control for 64K/256K memory systems which utilize the Am2968 Dynamic Memory Controller
- Supports extended cycle timing needed for byte-write operations
- Internal or external control of refresh
- Burst (up to 512-cycle), distributed, or hidden refresh
- Memory access/refresh request arbitration
- 24-pin $0.3^{\prime \prime}$ space-saving package


## GENERAL DESCRIPTION

The Am2970 is a high-performance Memory Timing Controller (MTC). The Am2970 is designed to be used in memory systems which use the Am2968 Dynamic Memory Controller (DMC).

All of the control signals needed by the DMC are generated by the Am2970 MTC.

The Am2970 uses a delay-line to provide maximum flexibility to the memory system designer as well as allowing him to
achieve maximum performance. The delay-line is the timing reference from which the MTC generates the control signals.

The Am2970 provides an internal refresh interval timer to generate refresh requests independent of the CPU. This guarantees proper refresh timing under all combinations of CPU and DMA requests.


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2968 | Dynamic Memory Controller |
| Am2971 | Programmable Event Generator |

## PIN DESCRIPTION

BYTE/WORD, Input
This input indicates a byte operation is to be performed when HIGH, and a word operation when LOW. When B/W is LOW, the Am2970 will provide an extended cycle so that a read-modity-write operation can be performed.
CLOCK, Input
For systems requiring synchronous arbitration of memory access and refresh requests, this input would receive the system clock. For asynchronous arbitration, this input must be tied HIGH.

## CHip SELECT, input

When CS is LOW, the MTC is enabled. A memory read/write cycle can only be performed when CS is active, while refresh cycles occur independent of CS. When CS is HIGH, all memory requests (HIGH-to-LOW transition of CYCREQ) will be interpreted as refresh requests ('Hidden" refresh).
CYCLE REQUEST, Input
When CS is LOW, this input will generate an internal memory request for the Am2970 on the HIGH-to-LOW transition of CYCREQ.
DTACK DATA TRANSFER ACKNOWLEDGE, Output The HIGH-to-LOW transition of DTACK informs the CPU that a write cycle has begun, or that data will be on the system bus at the correct time during a read cycle.
FR FORCED REFRESH, Input
This input is used to force a refresh cycle at user designated times. The falling edge of $\overline{F R}$ latches an internal refresh request. If the memory is busy, the refresh is done at the completion of the current cycle.
MC 1 MODE CONTROL, Output
This output should be connected to the $\mathrm{MC}_{1}$ input of the Am2970. MC $0_{0}$ of the Am2970 should be tied LOW. When MC ${ }_{1}$ is HIGH, the Am2970 will perform a read/write cycle; when LOW, refresh will be done.

## OSC OSCILLATOR, Input

This input signal is used to generate an internal refresh clock. It is this oscillator which initiates a refresh cycle if FR does not go active. The OSC signal may come from either external components (RC circuit) or a TTL clock source.
RASI ROW ADDRESS STROBE INPUT, Output
This output is connected to the RASI input of the Am2970 DMC. It is used to start a memory access for the DMC. The RASI output is also connected to the delay line to start the timing sequence. The rising edge of RASI initiates both actions.

## RM $\mathbf{M}_{0,1}$ REFRESH MODE, Input

These inputs control the type of refresh cycle the Am2970 is supposed to initiate, as specified in Table A.

R/W READ/WRITE, Input
This input indicates a memory read request when HIGH, and a write request when LOW.
SUP SUPPRESS, Input
When SUP is driven LOW, it will inhibit access to memory by disabling WE. It can be used to prevent illegal access in memory-access-protected systems.
T1-8 TIMING TAPS, Input
These inputs are the positive-edge triggered timing tap outputs from the timing reference (delay-line). They provide the necessary timing information for the Am2970 to control memory cycles. Definition of the eight timing taps is given in Table B.
WE
WRITE ENABLE, Output

When WE is LOW, it causes data to be written into memory. WE is inhibited if SUP is LOW.
table A. Refresh mode select table

| $\mathbf{R M}_{\mathbf{1}}$ | $\mathbf{R M}_{\mathbf{0}}$ | Refresh Mode |
| :---: | :---: | :---: |
| 0 | 0 | Not Burst (Distributed) |
| 0 | 1 | 128-Cycle Burst |
| 1 | 0 | $256-$ Cycle Burst |
| 1 | 1 | $512-$ Cycle Burst |

TABLE B. TIMING TAP DEFINITION TABLE

| Tap <br> $\#$ | Function |
| :---: | :--- |
| 1 | Controls when DTACK will go active during <br> read cycles. |
| 2 | Controls when $\overline{\text { DTACK }}$ will go active during <br> read-modity-write cycles. |
| 3 | Identifies when data is available on the memory <br> bus during write cycles. |
| 4 | Identifies when valid data is available on the <br> memory bus during read-modify-write cycles. |
| 5 | Indicates that valid data is available from mem- <br> ory during read cycles. |
| 6 | Identifies when a new memory cycle may begin <br> after a read or write cycle has been performed. |
| 7 | Controls when $\overline{\text { RAS outputs of DMC should go }}$ <br> HIGH for read-modify-write cycles. |
| 8 | Identifies when a new memory cycle may begin <br> after a read-modify-write cycle has been per- <br> formed. |

## APPLICATION

## ARCHITECTURE

The Am2970 MTC is designed to replace much of the MSI "glue" logic which is commonly necessary in controlling dynamic memory systems. It is responsible for controlling/ arbitrating memory access and refresh, and handshaking with the processor. The Am2970 also provides an extended (Read-Modify-Write) cycle which is needed for byte operations.

## ARBITRATION: SYNCHRONOUS vs ASYNCHRONOUS

The Am2970 arbitrates between processor (read/write) and refresh requests for a memory cycle. If both the refresh and processor cycle are requested at the same time, the processor request is serviced first, followed by the refresh request. A third type of access, memory initialization, is given priority over both processor and refresh requests. It is possible for the arbiter to be either synchronous with the system clock, or asynchronous. Synchronous arbitration requires that the inputs requesting memory, $\overline{\mathrm{FR}}$, and $\overline{\mathrm{CYCREQ}}$ be clocked into the Am2970 by using the CLK input. In this mode, $\overline{\text { CYCREQ }}$ and $\overline{F R}$ are examined on the negative edge of CLK. When CLK is not used (tied HIGH), the Am2970 detects its absence and enters the asynchronous mode. In this mode, the first memory request to occur will be serviced, but not until after an internal delay to avoid metastable states.

## REFRESH OPERATIONS

The Am2970 can support a variety of refresh schemes. The type of refresh is controlled via the $\mathrm{RM}_{0,1}$ inputs. Basic refresh
types include distributed, as well as 128-, 256-, or 512 -cycle burst.

The internal refresh request is controlled by $\overline{F R}$ input, or the output of the internal oscillator as follows:

- In the burst mode of operation, the $\overline{\mathrm{FR}}$ input is always the refresh clock.
- the $\overline{\mathrm{FR}}$ input can also be used as the refresh clock in the distributed refresh (non-burst) mode. However, the internal oscillator takes over as the refresh clock if it goes through three cycles without a LOW level appearing on the FR input. This provision allows the primary refresh clock ( $\overline{\mathrm{FR}}$ ) to be interrupted while it is in the HIGH logic state, and for refresh operations to be resumed at the internal oscillator frequency.
- It is also possible to use the on-chip oscillator as the refresh clock in distributed refresh mode. In this case, the $\overline{F R}$ input should be tied HIGH. However, since the on-chip oscillator is asynchronous to the external CLK input, it is necessary to provide a synchronous refresh clock via the $\overline{F R}$ input if synchronous arbitration is desired.
The Am2970 has the ability to increase memory bandwidth by inserting refresh requests when the processor is accessing other devices or performing I/O operations (CYCREQ = LOW, $\overline{\mathrm{CS}}=\mathrm{HIGH})$. A hidden refresh can only be performed once every refresh clock period, and occurs only with distributed refreshing. When a hidden refresh is performed, the Am2970 will skip the next refresh request. Figure 1 shows the timing involved to perform a hidden refresh cycle.
Depending on the system configuration and operation, it is possible for the DRAM to appear "static," providing that a hidden refresh can be performed every refresh clock period.

Figure 1. Hidden Refresh Cycle



## Am2971

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Twelve 32-bit programmable timing events, with registered outputs
- Resolution between events down to 10 ns
- Up to eight programmable starting addresses to pick first event occurrence
- Programmable clock output (Fo) frequency - 1/5 or 1/10 of internal 100 MHz clock
- Internal clock reference derived from either an external clock or crystal
- 24-pin, 0.3" space saving package


## GENERAL DESCRIPTION

The Am2971 is a high-performance Programmable Event Generator (PEG). The PEG is a digital replacement for an analog delay-line. It replaces several different delay-lines, because the resolution of the output signals is user selectable. The high-speed timing outputs may be used to control the Am2960 series of Dynamic Memory Support
circuits (Am2968 Dynamic Memory Controller, Am2969/70 Dynamic Memory Timing Controllers), as well as being capable of generating up to 12 unique digital timing waveforms. The main advantage of the Am2971 is that all of the events are user programmable, versus the fixed, single event of a delay-line's outputs.

## Am8163/Am8167

Dynamic Memory Timing, Refresh and EDC Controllers

## DISTINCTIVE CHARACTERISTICS

- Complete CPU to dynamic RAM control interface
- $\overline{\mathrm{RAS}} / \mathrm{MSEL} / \overline{\mathrm{CAS}}$ Sequencer to eliminate delay lines
- Complete EDC/data path controls for Word/Byte read or write
- Automatic write-back of corrected data and check bits when single errors are detected on any read cycle
- EDC error flag latches for error logging under software control
- Two timing configurations support a broad range of processors (Z80, Z8000, 8086, 8088, MC68000)


## GENERAL DESCRIPTION

The Am8163 and Am8167 are high speed bus interface controllers forming an integral part of the 8086 and AmZ8000* memory support chip set using dynamic MOS RAMs with Error Detection and Correction (EDC). The complete chip set includes the Am8284A and AmZ8127 Clock Generators, the Am2964B Dynamic Memory Controller, the Am2961/62 EDC Bus Buffers, the Am2960 EDC Unit and Am2965/66 RAM Drivers.
The Am8163 and Am8167 provide all of the control interface functions including $\overline{\mathrm{RAS}} /$ Address-MUX/ $\overline{\mathrm{CAS}}$ timing (without delay lines), refresh timing, memory request/
refresh arbitration and all EDC enables and controls. The enable controls are configured for both word and byte operations including the data controls for byte write with error correction. The Am8163/7 generates bus and operating mode controls for the Am8160 EDC Unit.

The Am8163/7 uses the AmZ8127 oscillator output to generate $\overline{\mathrm{RAS}} /$ Address MUX/ $\overline{\mathrm{CAS}}$ timing. An internal refresh interval timer generates the memory refresh request independent of the CPU to guarantee the proper refresh timing under all combinations of CPU and DMA memory requests.

BLOCK DIAGRAM


| RELATED PRODUCTS |  |  |  |
| :--- | :--- | :--- | :--- |
| Part No. | Description | Part No. | Description |
| Am2960 | 16-Bit Error Detection and Correction Unit | Am2964B | Dynamic Memory Controller |
| Am2968 | Dynamic Memory Controller | Am2961/62 | Error Correction Bus Buffers |
| Am2969/70 | Memory Timing Controllers | Am2965/66 | Octal Dynamic Memory Drivers |
| Am2971 | Memory Timing Controller |  |  |
|  |  |  |  |

Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Device type
Dynamic Memory Timing, Refresh, and EDC Controller
Am8163
Am8163
Am8167
Am8167
Am8167

| Valid Combinations |  |
| :--- | :--- |
| Am8163 | DC, DCB, DM, <br> DMB <br>  <br> XC, XM |
|  | DC, DCB <br> XC |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :---: | :--- | :--- | :--- |


| Bus Control |  |  |  |
| :---: | :---: | :---: | :---: |
| 28 | CLK | 1 | Clock. The CLK input determines memory cycle timing via the internal state machine from which the control outputs are derived. It is normally 16 MHz for the Am 8163 and 22 MHz for the Am8167. The clock can run at lower frequencies, but not higher, because of other memory timing constraints. |
| 14 | RCLK | 1 | Refresh Clock. This input determines the period of the internal refresh interval $\div 16$ timer and is normally 1 MHz . This results in a refresh cycle every 16 microseconds. This provides an internal refresh request to guarantee valid memory data independent of other system operating modes, (memory request, DMA, etc.). |
| 13 | FR | 1 | Force Refresh. FR is used to force a refresh cycle at user-designated times. One example is transparent refresh during I/O operations. The refresh interval timer is reset so the next refresh occurs 16 RCLK cycles later if no other $\overline{\mathrm{FR}}$ pulses occur. $\overline{\mathrm{FR}}$ can be used to minimize collisions with memory requests, thereby reducing the amount of time the CPU waits for refresh. |
| 26 | $\overline{\text { XACK }}$ | 0 | Transfer Acknowledge (open collector). This active LOW output indicates that corrected data has been latched in the Am8160 EDC output latch (as opposed to indicating data is valid on the system bus). |
| 25 | $\overline{\text { AACK }}$ | 0 | $\overline{\text { Advanced Acknowledge (open collector). This active LOW output indicates that a memory access has started. It can }}$ be used to run without wait states when the memory system timing is synchronous with the CPU clock. Multibus or asynchronous configuration should use XACK to control the CPU Ready input. |
| 11 | SUP | I | Suppress. This active LOW input inhibits access to the RAM in memory access protected systems. It must be valid before the HIGH-to-LOW transition of $\overline{\text { DS }}$ to suppress a read cycle. It must remain valid until after the cycle (RAS). This is required because SUP simply inhibits WE on a write and inhibits $\overline{O E B H}, \overline{O E B L}$, and $\overline{O E B W}$ on a read, without halting the internal state generator. |
| 12 | DS | 1 |  control when data is enabled onto the system data bus. |
| 33 | AO | 1 | Address ${ }^{\circ}$ Bit 0 . AO data input is latched internally on the LOW-to-HIGH transition of $\overline{\mathrm{AS}}$. It is used during byte operations to designate whether high byte or low byte data is being accessed. <br> $A 0=$ LOW for high byte operations and $A 0=H I G H$ for low byte operations with the AmZ8000 Family CPU's. AO phasing is opposite for 8086 and inversion can be avoided by interchanging the roles of $\overline{O E L}$ and $\overline{O E H}$ (and $\overline{O E B L}$ and OEBH). |
| 34 | $\overline{\text { AS }}$ | 1 | $\overline{\text { Address Strobe. The } \overline{A S}}$ input is used to control the A0 latch. When HIGH, A0 data is latched. For non-multiplexed buses, the $\overline{A S}$ input is tied LOW to make the latch transparent. |
| 15 | B/W | 1 | Byte/Word. This input designates a byte operation if HIGH and a word operation if LOW. It must be valid throughout the memory transaction. The Am8163/7 uses this input to determine $\overline{O E H}$ and OEL. |
| 16 | R/W | 1 | Read/Write. This input indicates a read operation when HIGH and a write operation when LOW. It must be valid throughout the memory transaction. The Am8163/7 uses this input to determine the outputs $\overline{\mathrm{OEH}}, \overline{\mathrm{OEL}}, \overline{\mathrm{OEBH}}, \overline{\mathrm{OEBL}}$, and OEBW. |
| 32 | $\mathrm{M} / \overline{\mathrm{IO}}$ | 1 | Memory/Input-Output. This signal serves as an active HIGH chip select for memory operations. It is used in conjunction with $\overline{\mathrm{CS}}$ to determine if STR is valid. It must be HIGH before the LOW-to-HIGH transition of STR if the STR input command is a pulse (AmZ8000). When using a level input (multibus) to start the cycle, M/ $\overline{\mathrm{OO}}$ must become valid no later than one clock period after the HIGH-to-LOW transition of STR. |
| 31 | CS | 1 | Chip Select. This active LOW input is one of the enables for the Am8163/7. It must be LOW before the LOW-to-HIGH transition of STR when using a pulse to start a memory access. When using a level input to start the cycle, CS must become valid no later than one clock period after the HIGH-to-LOW transition of STR. |
| 27 | STR | 1 | $\overline{\text { Start. This active LOW input can be a pulse or a level. It is used to indicate when memory access is requested. It must }}$ not extend past the LOW-to-HIGH transition of $\overline{\mathrm{DS}}$. |

Address Control

| 35 | LE | 0 | Latch Enable. This output controls the LATCH ENABLE input of the Dynamic Memory Controller. When LE is HIGH, the DMC address input latch is transparent. When LE is LOW, the address is latched. This signal is $\overline{A S}$ inverted. |
| :---: | :---: | :---: | :---: |
| 36 | $\overline{\text { RFSH }}$ | 0 | Refresh. This active LOW output indicates a refresh operation is to be done. The Dynamic Memory Controller uses this signal to select the refresh address output. |
| 37 | RAS | 0 | Row Address Strobe. This active LOW output strobes the row address into memory. The $\overline{\text { RAS }}$ HIGH-to-LOW transition occurs during to if STR, M/ $\overline{\mathrm{O}}$ and $\overline{\mathrm{CS}}$ have selected a memory cycle. Additionally, $\overline{\mathrm{RAS}}$ will be active one $t$-state after <br>  starts an internally timed RAS precharge time consisting of three t -states. |
| 39 | MSEL | 0 | Multiplexer Select. This output controls the row and column address selection in the DMC. When MSEL is HIGH, the row address is selected and when LOW, the column address is selected. MSEL is normally HIGH and goes LOW only during memory accesses. |
| 38 | $\overline{\text { CAS }}$ | 0 | Column Address Strobe. This active LOW output strobes the column address into memory. It is generated only during memory accesses. |
| Error Logging and Control |  |  |  |
| 19 | ERR | 1 | Error. This active LOW signal from the Am8160 EDC indicates when an error has occurred. The Am8163 samples this input just before the HIGH-to-LOW transition of LEO. Single errors cause an automatic write-back of corrected data. |
| 20 | MERR | 1 | Multiple Error. This active LOW signal from the EDC indicates when a multiple error has occurred. Write back to memory is inhibited if a MULTIPLE ERROR occurs on a read cycle. |
| 18 | LERR | 0 | Latched Error. This active HIGH output is set HIGH as a result of the ERR input becoming active. LERR HIGH indicates an error has occurred. LERR is normally used to control error logging. It is reset when ERRACK goes LOW. |
| 22 | LMERR | 0 | Latched Multiple Error. This active HIGH output is set HIGH as a result of the $\overline{\text { MERR }}$ input. When HIGH, it indicates a multiple error has occurred. It is reset when ERRACK goes low. |
| 17 | $\overline{\text { NTERR }}$ | 0 | Interrupt Error (open collector). This active LOW output is used to interrupt the CPU when an error occurs. This can be used for diagnostics or error logging. $\overline{\text { NTERR }}$ has high output drive capability in order to drive system buses. |


| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| Error Logging and Control (Cont.) |  |  |  |
| 23 | $\overline{\text { INTMERR }}$ | 0 | Interrupt Multiple Error (open collector). This active LOW output is used to interrupt the CPU when a multiple error occurs. This can be used for diagnostics or error logging. INTMERR has high output drive capability in order to drive system buses. |
| 24 | INTACK | 1 | Interrupt Acknowledge. This active LOW input resets both the , INTERR and INTMERR signals. |
| 21 | ERRACK | 1 | Error Acknowledge. This active LOW input resets the error logging flags, LERR and LMERR. It is only effective when INTACK has previously cleared the interrupt flags, INTERR and INTMERR. |
| EDC Control |  |  |  |
| 5 | LEB | 0 | Latch Enable Bus. LEB is used to latch corrected data in the external Am8161/2 EDC Data Bus Buffers. By latching data output to the system data bus, the CPU can be operated in a single-step mode. The data latch is required to capture data so the memory can be released for refresh immediately after a read (or write) cycle. |
| 1 | LEO | 0 | Latch Enable Output. LEO is used to latch corrected data in the Am8160 EDC data output latch. Correct data is then available to regenerate correct check bits for the write portion of the read-modify-write cycle. LEO can also control LEY of the Am8161/2 EDC Data Bus Buffers (the input latch from the system data bus). This is required in systems where the CPU removes data from the system data bus before the Am8163/7 has completed a write cycle. |
| 2 | LEI | 0 | Latch Enable Input. LEI is used to control the Am8160 EDC's input latch. It is normally LOW when a memory cycle is not in progress. This prevents transitions on the bus from toggling the EDC logic, thereby reducing power dissipation and system noise. LEI latches the input data so the EDC data bus (Y bus) can be TURNED AROUND WHILE the EDC is correcting the data. Cycle time is reduced by doing these functions in parallel. |
| 6 | S | 0 | Select. This output controls the multiplexer that selects EDC input data. It is normally HIGH to select data from the system bus. When LOW, it selects data from memory. Since all cycles are a read-modify-writes, S switches every cycle. All memory operations take the same number of internal $t$-states. There is no difference in the length of a cycle on read or write, error or no error. |
| 8 | $\overline{\text { OEBH }}$ | 0 | Output Enable Bus High. $\overline{\text { OEBH }}$ output enables the high byte data onto the system data bus during byte read operations. It is used when interfacing to 8 -bit data buses or the Multibus.* |
| 7 | $\overline{\text { OEBL }}$ | 0 | $\overline{\text { Output Enable Bus Low. } \overline{\text { OEBL }} \text { output enables the low byte of data onto the system data bus during Byte Read }}$ operations. It is used when interfacing to 8 -bit data buses or the Multibus. |
| 9 | OEBW | 0 | Output Enable Bus Word. $\overline{\text { OEBW }}$ output enables data onto the system data bus. It occurs on every read cycle independent of $B / \bar{W}$. It is used for 16 -bit systems or Multibus systems. |
| 4 | OEH | 0 | Output Enable High. $\overline{O E H}$ controls the high byte of the EDC data bus (Y bus). When $\overline{\mathrm{OEH}}$ is HIGH, the Am2961/62 are driving the bus. When OEH is LOW, the Am8160 EDC is driving the bus. OEH is HIGH during word writes and goes low on reads and byte writes. |
| 3 | OEL | 0 | Output Enable Low. ठEL controls the low byte of the EDC data bus (Y bus). When HIGH, the Am2961/62's are driving the bus. When LOW, the Am2960 is driving the bus. OEL is HIGH during word writes and goes LOW on reads and byte writes. |
| Other Controls |  |  |  |
| 40 | WE | 0 | $\overline{\text { Write Enable. }} \overline{\mathrm{WE}}$ controls the memory during a write operation. It is generated during a byte or word write and also during a read if a single error has occurred. WE always occurs at the end of the memory cycle. Thus, the RAM is always doing a late write. |
| 29 | $\overline{M C E}$ | 1 | Memory Cycle Extend. This input is normally not used and is pulled up internally to produce "normal' timing. When tied LOW it extends the memory cycle (adds $5 \mathrm{t}_{2}$ states for Am8163 and adds $4 \mathrm{t}_{3}$ states for Am8167). This allows use of slower RAMs. Note that MCE affects the refresh cycle as well as the normal cycle. By adding external logic, the user may extend the cycle by 1,2 or $3 t=$ states instead. This is done by keeping MCE low until 2,3 , or 4 clocks after MS for the 8163 or 2,3 , or 4 clocks after CAS for the 8167. |

*Multibus is a registered trademark of Intel Corporation.

## FUNCTION TABLES

## Am8163/8167

| R/W | B/W | AO | $\overline{\mathrm{OEH}}$ | $\overline{\text { OEL }}$ |
| :---: | :---: | :---: | :---: | :---: |
| L | L | L | H | H |
| L | L | H | H | H |
| L | H | L | H | L |
| L | H | H | L | H |
| H | L | L | L | L |
| H | L | H | L | L |
| H | H | L | L | L |
| H | H | H | L | L |

OEH and OEL are enabled by appropriate sequencer " T " states. (See Timing Diagram)

| $\overline{\text { DS }}$ | R/ $\overline{\mathbf{W}}$ | B/W | AO | $\overline{\text { OEBH }}$ | OEBL | OEBW |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | L | L | L | H | H | H |
| X | L | L | H | H | H | H |
| X | L | H | L | H | H | H |
| X | L | H | H | H | H | H |
| L | H | L | L | L | H | L |
| L | H | L | H | H | L | L |
| L | H | H | L | L | H | L |
| L | H | H | H | H | L | L |
| H | X | X | X | H | H | H |



DF000300

## Am8163/67 DETAILED DESCRIPTION

The Am8163/67 provides timing and control for Error Detection and Correction (EDC) using dynamic Random Access Memories (RAM) together with the Am2960 family of EDC devices. See Table 1 to determine which device (Am8163/67) is best suited to which processor.

The Am2960 family provides an optimized, but also flexible solution to the interface between MOS microprocessors and dynamic MOS RAMs.

The Am2960 performs the function of error detection and correction, using a modification of the well-known Hamming Code algorithm.

The Am2961 and Am2962 are bus buffers optimized for operation with the Am2960.

TABLE 1.


Note: Where X's appear in both columns, either device may be used.

The Am2964B performs address latching and multiplexing for the RAS/CAS sequence. It also contains a refresh counter that can be multiplexed onto the address outputs.
The Am2965 and Am2966 are octal memory address bus drivers, similar and pin-compatible to the popular 74LS240 and 74LS244, but with on-chip resistors that reduce the problem of undershoot on unterminated address lines.
None of the above-mentioned circuits contain timing elements. To achieve the greatest versatility, this function is concentrated in the Am8163.

The Am8163/67 performs two independent functions:

1. It provides timing and control to the Am2964B Dynamic Memory Controller, i.e., the RAS/CAS Refresh address multiplexer.
2. It provides timing and control for the 2960, 2961, or 2962 EDC circuits and interfaces with the microprocessor's interrupt lines and WAIT input.

## RAS/CAS and Refresh

The Am8163/67 accepts several control signals from the microprocessor (BYTE/WORD, READ/WRITE, Address Strobe, Data Strobe, Memory/IO) and a Refresh clock signal from the clock generator.

From these inputs, the Am8163/67 generates control signals for the 2964B RAS/CAS and Refresh multiplexer.

The LE output, when HIGH, makes the 2964B input latches transparent. The HIGH-to-LOW transition of LE latches address information into the 2964B.

The $\overline{R A S}$ output is activated when the appropriate combination of STR, M/ $\overline{\mathrm{IO}}$, and $\overline{\mathrm{CS}}$ occur or when a refresh operation
is to be performed. MSEL goes LOW one clock period after RAS goes LOW.

CAS goes LOW a short specified delay after MSEL goes LOW. $\overline{\text { RAS, MSEL and CAS go HIGH together, eight clock periods }}$ after RAS goes LOW. The RAS/CAS timing is thus derived from a high frequency ( 16 MHz clock) without any monostables or delay lines.
The Am8163 and Am8167 are comparable except for the CAS timing sequence.
The Am8163 timing is optimized for operation with a 4 MHz microprocessor clock, derived from a 16 MHz oscillator. The $\overline{\text { RAS }}$ to MS delay is one oscillator period (62ns) and the MS to CAS delay is combinatorial, 16 ns minimum.

The Am8167 timing is optimized for operation with a 5.5 MHz microprocessor clock, derived from a 22 MHz oscillator. The $\overline{\text { RAS }}$ to MS delay is one oscillator period (47ns) and the MS to CAS delay is also one oscillator period (47ns).

## Dynamic Memory Refresh

The proper sequencing of refresh operations can be performed either by the CPU (transparent refresh) or by the memory controller (stand-alone refresh).
Transparent refresh, as implemented in the Z80 and Z8000 microprocessors is simple and avoids all memory contention, but it wastes processor time and is not fully compatible with DMA operation.
"Stand-alone" refresh puts the responsibility of refresh address generation and timing on the memory controlier. The Am8163/67 performs the necessary timing and access arbitration. The internal refresh interval timer generates a refresh request after every 16 clock pulses on the RCLK refresh clock input (typically 1 MHz ). When FR (force refresh) goes LOW, the $\div 16$ counter is cleared and the internal refresh request is generated.
Refresh requests and memory requests are synchronized inside the Am8163/67 where the arbiter circuit resolves potential conflicts. If a refresh request occurs after a memory request or during a memory operation, this refresh request will be honored after the memory transaction is complete and the necessary additional precharge time has elapsed.

Similarly, if a memory request occurs after a refresh request or during a refresh operation, this memory request will not be acknowledged until the refresh operation is completed and the necessary precharge time has elapsed. When memory and refresh requests occur simultaneously, the arbiter favors the memory request.

## Error Detection/Correction

The other function of the Am8163/67 is timing and control for Error Detection and Correction using the 2960, 2961 or 2962 circuits.

The Am8163/67 drives the ECC Control Bus and receives ERROR or MULTIPLE ERROR inputs from the 2960 Error Detection and Correction Unit. The Am8163/67 also interfaces with the microcomputer interrupt structure and with the error-logging circuitry.

The 2960 can support two methods of error correction: "Correct Only On Error" and "Correct Always".
"Correct Only On Error" relies on the fact that error detection is faster than correction. Data read from the memory is fed directly to the processor. A read error will insert a wait state while the error is being corrected and data is also being written back into the memory. At reasonably low error rates, this
scheme achieves the highest possible throughput, but it is incompatible with all present microprocessors, since they sample their WAIT input too early in the cycle.
The Am8163/67 implements the other scheme- "Correct Always'-which is compatible with all modern microprocessors.

This scheme allocates time to insure that corrected data is sent to the CPU. Additionally, the Am8163/67 allows time after each memory read operation, to write the corrected result back into the memory. This write operation, however, is executed only if there was a single error; there is no need to write correct data back, and it is undesirable to write the wrong result of a double error.
the Am8163/67 also provides the proper control signals to allow byte write operation in 16-bit memory systems with Error Correction. The Am8163/67 automatically first performs a word read operation, retains the corrected unused byte in the 2960, and then writes the composite word and check bits into the memory. Outputs LEO, LEI, $\overline{\mathrm{OEH}}, \overline{\mathrm{OEL}}$ and S are responsible for this.

OEL is pulsed LOW during every read operation (byte or word) and during a byte write operation with $\mathrm{AO}=0$ (even address)
$\overline{\text { OEH }}$ is pulsed LOW during every read operation (byte or word) and during a byte write operation with $A O=1$ (odd address)
$\overline{\text { OEBW }}$ is pulsed LOW during every read operation
$\overline{\text { OEBL }}$ is pulsed LOW during every read operation with A $0=1$ (odd address)
$\overline{\mathrm{OEBH}}$ is pulsed LOW during every read operation with A $0=0$ (even address)

Note: The $\overline{\mathrm{OE}}$ and $\overline{\mathrm{OEB}}$ outputs interpret AO in opposite ways. This is consistent with 2960/61 operation.

| R/ | B/ | A0 | OEH | OEL |  | OEBW | OEBH |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\bar{W}$ | $\bar{W}$ | OEBL |  |  |  |  |  |
| $L$ | $L$ | $L$ | $H$ | $H$ | $H$ | $H$ | $H$ |
| $L$ | $L$ | $H$ | $H$ | $H$ | $H$ | $H$ | $H$ |
| $L$ | $H$ | $L$ | $H$ | $L$ | $H$ | $H$ | $H$ |
| $L$ | $H$ | $H$ | $L$ | $H$ | $H$ | $H$ | $H$ |
| $H$ | $L$ | $L$ | $L$ | $L$ | $L$ | $L$ | $H$ |
| $H$ | $L$ | $H$ | $L$ | $L$ | $L$ | $H$ | $L$ |
| $H$ | $H$ | $L$ | $L$ | $L$ | $L$ | $L$ | $H$ |
| $H$ | $H$ | $H$ | L | L | L | $H$ | $L$ |

$\overline{O E B W}, \overline{O E B H}$, and $\overline{O E B L}$ can be active
(LOW) only if: $\overline{\mathrm{DS}}=\overline{\mathrm{CS}}=\mathrm{L}$ AND $\overline{\mathrm{SUP}}=\mathrm{H}$
Note that 16-bit memory with EDC must always be initialized with word write operations in order to allow a later byte write operation. (An uninitialized memory would most likely read multiple errors and would then not allow byte write operation.)

## Error Interrupt Control

The Am8163/67 clocks in the ERROR and MULTIPLE ER$\overline{\mathrm{ROR}}$ signals coming from the 2960 and stores them in both the Interrupt Logic and in the Error Control Logic.
Interrupt Acknowledge clears both $\overline{\operatorname{NTERR}}$ and $\overline{\text { NTMERR }}$. The latter must therefore always be the higher priority interrupt.
The Error Logic Control circuit latches up the two bits in the Error Interrupt Control circuit. The LERR and LMERR outputs are cleared by ERRACK, provided that the interrupts have been cleared first. These signals are normally used to control updating of the syndrome latch or other diagnostic circuitry.

Am8163/67 APPLICATION WITH Am8086 CPU AND Am8127 CLOCK GENERATOR





## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ DC Voltage Applied to Outputs For High Output State $\qquad$ DC Input Voltage -0.5 V to $\mathrm{V}_{\mathrm{CC}}$ Max

DC Output Current, Into Outputs . -0.5 V to +5.5 V
DC Input Current.............................................. 30 mA to +5.0 mA

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage

$$
+4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V}
$$

Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

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 device reliability.

DC CHARACTERISTICS over operating range unless otherwise specified
(Group A, Subgroups 1, 2 and 3)

| Parameters | Description |  | Test Conditions (Note 1) |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | Output(s): <br> All except open collectors | $\mathrm{MIL}, \mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 |  |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{\mathbb{I H}} \text { or } V_{I L} \end{aligned}$ | Output(s): <br> LERR, LMERR | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  | 0.50 | Volts |
|  |  |  | CAS, $\overline{R A S}, \overline{\text { OEBH, }}$ OEBL | $\mathrm{lOL}=12 \mathrm{~mA}$ |  |  | 0.50 |  |
|  |  |  | $\overline{\text { OEH, }}$ OEL, $\overline{\text { OEBW, }}$, $\overline{\text { RFSH }}$ | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.50 |  |
|  |  |  | LEO, LEI, WE | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  |  | 0.50 |  |
|  |  |  | LEB, LE, S, MSEL | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  |  | 0.50 |  |
|  |  |  | INTMERR, $\overline{\text { NTERA }}$ | $1 \mathrm{OL}=16 \mathrm{~mA}$ |  |  | 0.50 |  |
|  |  |  | XACK, $\overline{\text { AACK }}$ | $\mathrm{IOL}=32 \mathrm{~mA}$ |  |  | 0.50 |  |
| $\mathrm{V}_{1} \mathrm{H}$ | Guaranteed Input Logical HIGH Voltage |  | Input(s): All |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Guaranteed Input Logical LOW Voltage |  | Input(s): All | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}$ | Input(s): All | $\mathbb{I N}_{\mathbb{N}}=-18 \mathrm{~mA}$ |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.5 V \end{aligned}$ | $\begin{aligned} & \text { Input(s): } \\ & \text { AO, M/II, RCLK, B/W, R/ } \overline{\mathrm{W}} \\ & \overline{\mathrm{STR}}, \overline{\mathrm{AS}}, \overline{\mathrm{INTACK}} \end{aligned}$ | MIL |  |  | -0.42 | mA |
|  |  |  |  | COM'L |  |  | -0.40 |  |
|  |  |  | $\overline{\text { FR, }}$, $\overline{S U P}$, ERRACK, $\overline{M C E}$ | MIL |  |  | -0.82 | mA |
|  |  |  |  | COM'L |  |  | -0.8 |  |
|  |  |  | $\overline{C L K}, \overline{C S}, \overline{\mathrm{DS}}, \overline{\mathrm{ERF}}$ | MIL |  |  | -2.1 | mA |
|  |  |  |  | COM'L |  |  | -2.0 |  |
|  |  |  | MERR | MIL |  |  | -2.6 | mA |
|  |  |  |  | COM'L |  |  | -2.4 |  |
| IIH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 V \end{aligned}$ | $\frac{\ln p u t(s):}{\text { MERR }}$ | MIL |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  |  | COM'L |  |  | 70 |  |
|  |  |  | CLK, $\overline{C S}, \overline{\mathrm{DS}}$, ERR | MIL |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | COM'L |  |  | 50 |  |
|  |  |  | $\overline{\text { FR, }}$ SUP, $\overline{M C E}$, ERRACK |  |  |  | 40 |  |
|  |  |  | M/IV, A0, RCLK, B/W, R/్̄W |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | $\overline{\text { AS, }}$ STR, $\overline{\text { NTACK }}$ |  |  |  | 20 |  |
| 1 | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ | Input(s): <br> CLK, CS, $\overline{\mathrm{DS}}, \overline{\mathrm{ERR}}, \overline{M E R R}$ |  |  |  | 1.0 | mA |
|  |  |  | SUP, MCE, FR |  |  |  | 1.0 |  |
|  |  | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=7.0 \mathrm{~V} \end{aligned}$ | $\mathrm{M} / \overline{\mathrm{O}}, \mathrm{AO}, \mathrm{RCLK}, \mathrm{B} / \overline{\mathrm{W}}, \mathrm{R} / \overline{\mathrm{W}}$ $\overline{\text { INTACK, }} \overline{\text { AS, }}, \overline{\text { STR }}$ |  |  |  | 0.10 |  |
|  |  |  | ERRACK |  |  |  | 0.20 |  |
| IOH | Output HIGH Current | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MIN} \\ & \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \end{aligned}$ | Output(s): INTMERR, $\overline{\text { INTERR }}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  | $\overline{\text { XACK, }} \overline{\text { AACK }}$ |  |  |  | 150 |  |


| Parameters | Description |  | Test Conditions (Note 1) |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| los | Output Short Circuit Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & +0.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ | Output(8): All (Note 3) |  | -15 |  | -85 | mA |
| ICC | Power Supply Current | 8163 | $25^{\circ} \mathrm{C}, 5 \mathrm{~V}$ |  |  | 280 |  | mA |
|  |  |  | 0 to $70^{\circ} \mathrm{C}$ | COM'L |  |  | 365 | mA |
|  |  | 8167 | 0 to $70^{\circ} \mathrm{C}$ |  |  |  | 390 | mA |
|  |  | 8163 | -55 to $+125^{\circ} \mathrm{C}$ | MIL |  |  | 385 | mA |
|  |  | 8167 | -55 to $+125^{\circ} \mathrm{C}$ |  |  |  | 420 | mA |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

INTERR,INT MERR


OTHER OUTPUTS


SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters |  | Description | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | ts | M/İT $\uparrow$ or $\overline{C S} \downarrow$ to CLK Setup Time | 0 | -4 |  | ns |
| 2 | ${ }_{\text {t }}$ | M/ $\overline{\mathrm{O}} \downarrow$ or $\overline{\mathrm{CS}} \uparrow$ to $\overline{\mathrm{RAS}} \uparrow$ Hold Time | 0 | -10 |  | ns |
| 3 | ts | $\overline{\text { FR }} \downarrow$ to CLK Setup Time | 5 | 2 |  | ns |
| 4 | tpWL | FR LOW Pulse Width | tp +5 | tp + 2 |  | ns |
| 5 | $\mathrm{t}_{\text {PLH }}$ | $\overline{\overline{A S}} \downarrow$ to $L E \uparrow$ Propagation Delay |  | 12 | 18 | ns |
| 6 | $\mathrm{t}_{\mathrm{PHL}}$ | $\overline{\text { AS }} \uparrow$ to LE $\downarrow$ Propagation Delay |  | 12 | 18 | ns |
| 7 | ts | A0 to $\overline{\mathrm{AS}} \uparrow \uparrow$ Setup Time | 1 | 0 |  | ns |
| 8 | ${ }_{\text {t }}$ | AO to $\overline{A S} \uparrow$ Hold Time | 9 | 5 |  | ns |
| 9 | tPWL | $\overline{\text { AS, }}$ STR LOW Pulse Width | 20 | 9 |  | ns |
| 10 | ts |  | 2 | 0 |  | ns |
| 11 | ts | CS $\downarrow$ to $\overline{\text { STR }} \downarrow$ Setup Time | -tp | -(tp + 10) |  | ns |
| 12 | ts | STR $\downarrow$ to CLK Setup Time | 10 | 6 |  | ns |
| 13 | $\mathrm{t}_{\text {PHL }}$ | CLK to $\overline{\mathrm{RAS}} \downarrow$ Propagation Delay |  | 36 | 41 | ns |
| 14 | $\mathrm{tPLH}^{\text {P }}$ | CLK to $\overline{\mathrm{RAS}} \uparrow$ Propagation Delay |  | 26 | 34 | ns |
| 15 | $\mathrm{tPHL}^{\text {che }}$ | CLK to MSEL $\downarrow$ Propagation Delay |  | 17 | 22 | ns |
| 16 | tPLH | CLK to MSEL $\dagger$ Propagation Delay |  | 21 | 26 | ns |
| 17a | tPHL |  | 18 | 23 |  | ns |
| 17b | $\mathrm{tPHL}^{\text {P }}$ | CLK to CAS $\downarrow$ Propagation Delay - 8167 |  | 17 | 22 | ns |
| 18a | $t_{\text {PLH }}$ | CLK to CAS $\uparrow$ Propagation Delay - 8163 |  | 34 | 43 | ns |
| 18b | ${ }_{\text {tPLH }}$ | CLK to CAS $\dagger$ Propagation Delay - 8167 |  | 21 | 26 | ns |
| 19 | $t_{\text {PLH }}$ | $\overline{\text { STR}} \downarrow$ to $\overline{\mathrm{AACK}} \uparrow$ Propagation Delay |  | 30 | 35 | ns |
| 20 | tPHL | CLK to $\overline{\text { AACK }} \downarrow$ Propagation Delay |  | 33 | 41 | ns |
| 21 | $\mathrm{t}_{\text {PHL }}$ | CLK to $\overline{W E} \downarrow$ Propagation Delay |  | 17 | 22 | ns |
| 22 | $\mathrm{tPLH}^{\text {P }}$ | CLK to $\overline{W E} \uparrow$ Propagation Delay |  | 20 | 26 | ns |
| 23 | tpHL | CLK to S! Propagation Delay |  | 16 | 22 | ns |
| 24a | $t_{\text {PLLH }}$ | LEI to St Propagation Delay - 8163 | 1.0 | 3.0 |  | ns |
| 24b | tPLH | CLK to St Propagation Delay - 8167 |  | 21 | 26 | ns |
| 25 | $t_{\text {PLH }}$ | CLK to LElf Propagation Delay |  | 20 | 26 | ns |
| 26 | tPHL | CLK to LEI $\downarrow$ Propagation Delay |  | 17 | 22 | ns |
| 27 | $\mathrm{tPLH}^{\text {L }}$ | LEO ! to LElt Propagation Delay | 15 | 20 |  | ns |
| 28a | ${ }_{\text {tPHL }}$ | LEI $\downarrow$ to $\overline{\mathrm{OEH}} \downarrow$, $\overline{\text { OEL }} \downarrow$ Propagation Delay -8163 | 4.5 | 7.0 |  | ns |
| 28b | ${ }_{\text {tPHL }}$ | CLK to $\overline{\text { OEH }} \downarrow$, $\overline{\text { OEL }} \downarrow$ Propagation Delay - 8167 |  | 24 | 30 | ns |
| 29 | tPL.H | CLK to $\overline{\mathrm{OEH}} \uparrow$, $\overline{\text { OEL }} \uparrow \uparrow$ Propagation Delay |  | 24 | 30 | ns |
| 30 | ts | R/产, B/W to $\overline{\mathrm{DS}} \downarrow$ Setup Time | 0 | -1.5 |  | ns |
| 31 | ${ }_{\text {H }}$ | R/पָ, B/产 to $\overline{\mathrm{WE}} \uparrow$ Hold Time | 0 | -10 |  | ns |
| 32 | tPHL | CLK to LEO \& Propagation Delay |  | 15 | 21 | ns |
| 33 | ${ }_{\text {tPL.H }}$ | CLK to LEO† Propagation Delay |  | 21 | 26 | ns |
| 34 | tPLH | CLK to LEB; Propagation Delay |  | 21 | 26 | ns |
| 35 | tPHL | CLK to LEB $\downarrow$ Propagation Delay |  | 24 | 30 | ns |
| 36 | tPHL | CLK to $\overline{\text { XACK }} \uparrow$ Propagation Delay |  | 29 | 36 | ns |
| 37 | $\mathrm{tPLH}^{\text {che }}$ | DS $\uparrow$ to $\overline{\text { XACK }} \uparrow$ Propagation Delay |  | 24 | 30. | ns |
| 38 | tPHL | DS $\downarrow$ to $\overline{\text { OEBL }}$, $\overline{\mathrm{OEBH}}{ }_{4}, \overline{\mathrm{OEBW}} \downarrow$ Propagation Delay |  | 13 | 18 | ns |


| Parameters |  | Description | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 39 | $\mathrm{tPLH}^{\text {che }}$ | DS $\uparrow$ to OEBL $_{\dagger}$, $\mathrm{OEBH}_{\dagger}$, OEBW $_{\dagger}$ Propagation Delay |  | 13 | 18 | ns |
| 40 | ts | ERR, प्MERR to LEO। Setup Time | 1.5 | 0 |  | ns |
| 41 | $\mathrm{th}_{\mathrm{H}}$ | ERR, MERR to LEO। Hold Time | 6.5 | 4 |  | ns |
| 42 | $\mathrm{tPHL}^{\text {chen }}$ | LEO $\downarrow$ to INTERR $_{1}$, $\overline{\text { NTTMERR }}$ ! Propagation Delay |  | 19 | 24 | ns |
| 43 | tPLH |  |  | 23 | 30 | ns |
| 44 | tpLH | LEO ${ }_{\text {do }}$ to LERR ${ }_{1}$, LMERR $\dagger$ Propagation Delay |  | 30 | 39 | ns |
| 45 | ${ }_{\text {tPHL }}$ | ERRACK $\downarrow$ to LERR $\downarrow$, LMERR $\downarrow$ Propagation Delay |  | 9 | 14 | ns |
| 46 | tPWL | INTACK LOW Pulse Width | 20 | 9 |  | ns |
| 47 | tpWL | ERRACK LOW Pulse Width | 20 | 9 |  | ns |
| 48 | ts | $\overline{\text { SUP }}$ ¢ to $\overline{\mathrm{DS}} \downarrow$ Setup Time | 0 | -5 |  | ns |
| 49 | ${ }_{H}$ | $\overline{\text { WE }} \uparrow$ to SUP $\uparrow$ Hold Time | 0 | -10 |  | ns |
| 50 | tPHL | CLK to $\overline{\text { RFSH }}$ ! Propagation Delay |  | 16 | 21 | ns |
| 51a | tpWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\text { MCE }}=\mathrm{HIGH}$ ) -8163 |  | 4tp |  |  |
| 51b | tPWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\mathrm{MCE}}=\mathrm{HIGH}$ ) -8167 |  | 5 tp |  |  |
| 52a | tpWL | R̄AS LOW Pulse Width During Refresh (MCE $=\mathrm{HIGH}$ ) -8163 |  | 3tp |  |  |
| 52b | tPWL | RAS LOW Pulse Width During Refresh (MCE $=\mathrm{HIGH})-8167$ |  | 4tp |  |  |
| 53a | tPWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\text { MCE }}=$ LOW $)-8163$ |  | 7 p |  |  |
| 53b | tpWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\mathrm{MCE}}=$ LOW) -8167 |  | 9tp |  |  |
| 54a | tPWL | RAS LOW Pulse Width During Refresh ( $\overline{M C E}=\mathrm{LOW}$ ) -8163 |  | 6tp |  |  |
| 54b | tPWL | ̄AS LOW Pulse Width During Refresh ( $\overline{\text { MCE }}=$ LOW $)-8167$ |  | 8tp |  |  |
| 55a | fosc | CLK Frequency - 8163 |  |  | 16 | MHz |
| 55b | fosc | CLK Frequency - 8167 |  |  | 22 | MHz |

Switching Characteristics (Cont.)

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters |  | Description | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 1 | ts |  | M/İ¢ $\uparrow$ or $\overline{\mathrm{CS}} \downarrow$ to CLK Setup Time | 5 |  | 5 |  | ns |
| 2 | $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{M} / \overline{\mathrm{OO}} \downarrow$ or $\overline{\mathrm{CS}} \uparrow$ to $\overline{\mathrm{RAS}} \uparrow$ Hold Time | 5 |  | 5 |  | ns |
| 3 | ts | $\overline{F R} \downarrow$ to CLK Setup Time | 9 |  | 9 |  | ns |
| 4 | tPWL | $\overline{F R}$ LOW Pulse Width | tp +10 |  | tp +10 |  | ns |
| 5 | tPLH | $\overline{\text { AS }} \downarrow$ to LE $\uparrow$ Propagation Delay |  | 22 |  | 22 | ns |
| 6 | tPHL | $\overline{\mathrm{AS}} \uparrow$ to LE $\downarrow$ Propagation Delay |  | 22 |  | 22 | ns |
| 7 | ${ }^{\text {ts }}$ | AO to $\overline{A S} \uparrow$ Setup Time | 1.5 |  | 1.5 |  | ns |
| 8 | $\mathrm{t}_{\mathrm{H}}$ | AO to $\overline{\text { AS }} \uparrow$ Hold Time | 10 |  | 10 |  | ns |
| 9 | tPWL | $\overline{\text { AS, STR }}$ LOW Pulse Width | 20 |  | 20 | . | ns |
| 10 | ts | M/ $\overline{\mathrm{O}_{\dagger} \dagger \text { or } \overline{\mathrm{CS}} \downarrow \text { to } \mathrm{STR}_{\dagger} \text { S Setup Time }}$ | 5 |  | 5 |  | ns |
| 11 | ts | $\overline{\text { CS }} \downarrow$ to STR $_{\downarrow}$ Setup Time | -tp |  | -tp |  | ns |
| 12 | ts | STR $\downarrow$ to CLK Setup Time | 10 | , | 12 |  | ns |
| 13 | $\mathrm{t}_{\mathrm{PHL}}$ | CLK to $\overline{\text { RAS }} \downarrow$ Propagation Delay |  | 45 |  | 45 | ns |
| 14 | tPLH | CLK to $\overline{\text { RAS }} \uparrow$ Propagation Delay |  | 40 |  | 40 | ns |
| 15 | tPHL | CLK to MSEL $\downarrow$ Propagation Delay |  | 25 |  | 25 | ns |
| 16 | tpLH | CLK to MSEL ${ }_{\uparrow}$ Propagation Delay |  | 30 |  | 30 | ns |
| 17a | tPHL | $\overline{\text { MSEL }} \downarrow$ to $\overline{\text { CAS }} \downarrow$ Propagation Delay - 8163 | 16 |  | 16 |  | ns |
| 17 b | $\mathrm{t}_{\text {PHL }}$ | CLK to $\overline{\text { CAS }} \downarrow$ Propagation Delay - 8167 |  | 25 |  | 25 | ns |
| 18a | tPLH | CLK to $\overline{\text { CAS }}_{\uparrow}$ Propagation Delay - 8163 |  | 50 |  | 50 | ns |
| 18 b | tPLH | CLK to CAS $\uparrow$ Propagation Delay - 8167 |  | 30 |  | 30 | ns |
| 19 | tple | $\overline{S T R}_{\downarrow}$ to $\overline{\text { AACK }}_{\uparrow}$ Propagation Delay |  | 40 |  | 40 | ns |
| 20 | tPHL | CLK to $\overline{\text { AACK }} \downarrow$ Propagation Delay |  | 46 |  | 46 | ns |
| 21 | tPHL | CLK to $\overline{\mathrm{WE}} \downarrow$ Propagation Delay |  | 25 |  | 25 | ns |
| 22 | tPLH | CLK to $\overline{\mathrm{WE}} \uparrow$ Propagation Delay |  | 30 |  | 30 | ns |
| 23 | $\mathrm{tPHL}^{\text {che }}$ | CLK to $S \downarrow$ Propagation Delay |  | 25 |  | 25 | ns |
| 24a | tpli | LEIf to S $\uparrow$ Propagation Delay - 8163 | 0 |  | 0 |  | ns |
| 24b | tpLH | CLK to St Propagation Delay - 8167 |  | 30 |  | 30 | ns |
| 25 | tpLH | CLK to LElt Propagation Delay |  | 30 |  | 30 | ns |
| 26 | tPHL | CLK to LElı Propagation Delay |  | 25 |  | 25 | ns |
| 27 | tpLH | LEO । to LEIt Propagation Delay | 10 |  | 10 |  | ns |
| 28 a | tpHL | LEI to $\overline{\mathrm{OEH}} \downarrow$, $\overline{\mathrm{OEL}} \downarrow$ Propagation Delay -8163 | 4.0 |  | 4.0 |  | ns |
| 28b | $\mathrm{t}_{\mathrm{PHL}}$ | CLK to $\overline{\text { OEH }}$, $\overline{\text { OEL } \downarrow \text { - } 8167}$ |  | 35 |  | 35 | ns |
| 29 | tPLH | CLK to $\overline{\mathrm{OEH}} \uparrow \uparrow$, $\overline{\text { OEL }} \uparrow$ Propagation Delay |  | 35 |  | 35 | ns |
| 30 | ts | $\mathrm{R} / \overline{\mathrm{W}}, \mathrm{B} / \overline{\mathrm{W}}$ to $\overline{\mathrm{DS}} \downarrow$ Setup Time | 0 |  | 1.0 |  | ns |
| 31 | $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{R} / \overline{\mathrm{W}}, \mathrm{B} / \overline{\mathrm{W}}$ to $\overline{\mathrm{WE}} \uparrow$ Hold Time | 0 |  | 0 |  | ns |
| 32 | tPHL | CLK to LEO $\downarrow$ Propagation Delay |  | 25 |  | 25 | ns |
| 33 | tPLH | CLK to LEO $\dagger$ Propagation Delay |  | 30 |  | 30 | ns |
| 34 | tPLH | CLK to LEB $\uparrow$ Propagation Delay |  | 30 |  | 30 | ns |
| 35 | tPHL | CLK to LEB $\downarrow$ Propagation Delay |  | 35 |  | 35 | ns |
| 36 | $\mathrm{t}_{\text {PHL }}$ | CLK to $\overline{\mathrm{XACK}} \uparrow$ Propagation Delay |  | 40 |  | 41 | ns |
| 37 | tpli | $\overline{\mathrm{DS}} \uparrow$ to $\overline{\mathrm{XACK}} \uparrow$ Propagation Delay |  | 35 |  | 35 | ns |
| 38 | tPHL | $\overline{\mathrm{DS}} \downarrow$ to $\overline{\mathrm{OEBL}_{\downarrow}}, \overline{\mathrm{OEBH}}_{\downarrow}, \overline{\mathrm{OEBW}} \downarrow$ Propagation Delay |  | 22 |  | 22 | ns |
| 39 | tPLH | $\overline{\mathrm{DS}} \uparrow$ to $\overline{\mathrm{OEBL}} \uparrow$, $\overline{\mathrm{OEBH}} \uparrow, \overline{\mathrm{OEBW}} \uparrow$ Propagation Delay |  | 22 |  | 22 | ns |
| 40 | ts | ERR, $\overline{\text { MERR }}$ to LEO $\downarrow$ Setup Time | 2.0 |  | 3.0 |  | ns |
| 41 | ${ }_{H}$ | ERR, $\overline{M E R R}$ to LEO $\downarrow$ Hold Time | 8.0 |  | 8.0 |  | ns |
| 42 | tPHL | LEO $\downarrow$ to $\overline{\text { INTERR }} \downarrow$, $\overline{\text { NTMERR }} \downarrow$ Propagation Delay |  | 28 |  | 28 | ns |
| 43 | tPLH | INTACK $\downarrow$ to $\overline{\text { NTERR }}^{1}$, $\overline{\text { NTMERR }} \uparrow$ Propagation Delay |  | 38 |  | 38 | ns |
| 44 | tPLH | LEO $\downarrow$ to LERR $\uparrow$, LMERR $\uparrow$ Propagation Delay |  | 46 |  | 46 | ns |
| 45 | tPHL | ERRACK $\downarrow$ to LERR $\downarrow$, LMERR $\downarrow$ Propagation Delay | - | 20 |  | 20 | ns |


| Parameters |  | Description | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| 46 | tPWL |  | $\overline{\text { INTACK }}$ LOW Pulse Width | 20 |  | 20 |  | ns |
| 47 | tpWL | ERRACK LOW Pulse Width | 20 |  | 20 |  | ns |
| 48 | ts | $\overline{\text { SUP }}$ \ to $\overline{\mathrm{DS}}$ ! Setup Time | 5 |  | 5 |  | ns |
| 49 | $\mathrm{t}_{\mathrm{H}}$ | $\overline{\text { WE }} \uparrow$ to SUP $\dagger$ Hold Time | 5 |  | 5 |  | ns |
| 50 | tpHL | CLK to $\overline{\mathrm{RFSH}} \downarrow$ Propagation Delay |  | 25 |  | 25 | ns |
| 51a | tPWL | $\overline{\text { RFSH LOW Pulse Width }}$ $(\overline{\mathrm{MCE}}=\mathrm{HIGH})-8163$ | 4tp-3ns |  | 4tp-3ns |  |  |
| 51b | tPWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\mathrm{MCE}}=\mathrm{HIGH}$ ) -8167 | 5tp-3ns |  | 5tp-3ns |  |  |
| 52a | tPWL | $\overline{\text { RAS }}$ LOW Pulse Width During Refresh $(\overline{\mathrm{MCE}}=\mathrm{HIGH})-8163$ | 3tp-3ns |  | 3tp-3ns |  |  |
| 52b | tPWL | $\overline{\text { RAS }}$ LOW Pulse Width During Refresh ( $\overline{\mathrm{MCE}}=\mathrm{HIGH}$ ) -8167 | 4tp-3ns |  | 4tp-3ns |  |  |
| 53a | tPWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\mathrm{MCE}}=\mathrm{LOW}$ ) -8163 | 7tp-3ns |  | 7tp-3ns |  |  |
| 53b | tPWL | $\overline{\text { RFSH }}$ LOW Pulse Width ( $\overline{\mathrm{MCE}}=\mathrm{LOW}$ ) -8167 | 9tp-3ns |  | 9tp-3ns |  |  |
| 54a | tPWL | $\overline{\text { RAS }}$ LOW Pulse Width During Refresh (MCE = LOW) -8163 | 6tp-3ns |  | 6tp-3ns |  |  |
| 54b | tPWL | $\overline{\text { RAS }}$ LOW Pulse Width During Refresh ( $\overline{\mathrm{MCE}}=\mathrm{LOW}$ ) -8167 | 8tp-3ns |  | 8tp-3ns |  |  |
| 55 a | tosc | CLK Frequency - 8163 |  | 16 |  | 16 | MHz |
| 55b | tosc | CLK Frequency - 8167 |  | 22 |  | 22 | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.




$$
\begin{aligned}
& \text { LEI } \\
& \overline{O E H} . \overline{O E L} \\
& \text { ~ } \\
& 837 \\
& \overline{X A C K} \\
& \text { ОЕв } \overline{\text { OEBL }} \text { OEBW } \\
& \text { हRR. MERB } \\
& \text { INTERR. INTMERR } \\
& \begin{array}{l}
\text { LMERR } \\
\hline \text { TIACK }
\end{array} \\
& \text { ERtack } \\
& \text { sup }
\end{aligned}
$$




## Am2900 <br> Processors and Peripherals Family Index

Am2901B/Am2901C
Am2902A
Four-Bit Bipolar Microprocessor Slice ..... 5-1Am2903AAm2904Am 2905
Am2906Am2907/Am2908Am2909A/2911AAm 2912Am 2913Am 2914Am2915AAm2916AAm2917AAm2918Am29LS18Am2910AAm2919Am2920
High-Speed Look-Ahead Carry Generator ..... 5-19
Four-Bit Bipolar Microprocessor Slice ..... 5-25
Status and Shift Control Unit ..... 5-48
Quad Two-Input OC Bus Transceiver with Three-State Receiver ..... 5-65
Quad Two-Input OC Transceiver with Parity ..... 5-73
Quad Bus Transceivers with Interface Logic ..... 5-81
Microprogram Sequencers ..... 5-93
Quad Bus Transceiver ..... 5-109
Priority Interrupt Expander ..... 5-115
Vectored Priority Interrupt Controller ..... 5-122
Quad Three-State Bus Transceiver with Interface Logic ..... 5-131
Quad Three-State Bus Transceiver with Interface Logic ..... 5-138
Quad Three-State Bus Transceiver with Interface Logic ..... 5-146
Quad D Register with Standard and Three-State Outputs ..... 5-154
Quad D Register with Standard and Three-State Outputs ..... 5-160
Microprogram Controller ..... 5-166
Quad Register with Dual Three-State Outputs ..... 5-184
Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control ..... 5-191
One-of-Eight Decoder with Three-State Outputs and Polarity Control ..... 5-197
Eight-Input Multiplexer with Control Register ..... 5-203
Eight-Input Multiplexer ..... 5-210
Three-Line to Eight-Line Decoder/Demuliplexer ..... 5-215
Clock Generator and Microcycle Length Controller ..... 5-220
Quad Three-State Bus Transceivers with Clock Enable ..... 5-236
Program Control Unit ..... 5-245
Program Control Unit/Push-Pop Stack ..... 5-257
DMA Address Generator ..... 5-268
Programmable Timer/Counter DMA Address Generator ..... 5-279
Octal Three-State Bidirectional Bus Transceivers ..... 5-291
Octal Three-State Bidirectional Bus Transceivers ..... 5-300
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-309
Eight-Bit Bidirectional I/O Ports with Handshake ..... 5-319
Octal Registers with Three-State Outputs ..... 5-326
Octal Latches with Three-State Outputs ..... 5-331
Four-Bit Bipolar Microprocessor Slice ..... 5-336
16-Way Branch Control Unit ..... 5-355

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry.
For specific testing details contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

## Am2901B／Am2901C

Four－Bit Bipolar Microprocessor Slice

## DISTINCTIVE CHARACTERISTICS

－Two－address architecture－
Independent simultaneous access to two working regis－ ters saves machine cycles．
－Eight－function ALU－
Performs addition，two subtraction operations，and five logic functions on two source operands．
－Expandable－
Connect any number of Am2901s together for longer word lengths．
－Left／right shift independent of ALU－
Add and shift operations take only one cycle．
－Four status flags－
Carry，overflow，zero，and negative．
－Flexible data source selection－
ALU data is selected from five source ports for a total of 203 source operand pairs for every ALU function．

## GENERAL DESCRIPTION

The Am2901 industry standard four－bit microprocessor slice is a high－speed cascadable ALU intended for use in CPUs，peripheral controllers，and programmable micropro－ cessors．The microinstruction flexibility of the Am2901 permits efficient emulation of almost any digital computing machine．

The device，as shown in the block diagram below，consists of a 16－word by 4－bit two－port RAM，a high－speed ALU，and the associated shifting，decoding and multiplexing circuitry． The nine－bit microinstruction word is organized into three
groups of three bits each and selects the ALU source operands，the ALU function，and the ALU destination register．The microprocessor is cascadable with full look ahead or with ripple carry，has three－state outputs，and provides various status flag outputs from the ALU．AMD＇s ion－implanted micro－oxide（IMOX）processing is used to fabricate the 40－lead LSI chip．

The Am2901C is a plug－in replacement for the Am2901B， but is $33 \%$ faster than the Am2901B．

MICROPROCESSOR SLICE BLOCK DIAGRAM


BD002120

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902 | Carry Look-Ahead Generator |
| Am2904 | Status and Shift Control Unit |
| Am2910 | Microprogram Controller |
| Am2914 | Vectored Priority Interrupt Controller |
| Am2917 | Bus Transceiver |
| Am2918 | Pipeline Register |
| Am2920 | Octal Register |
| Am2922 | Condition Code MUX |
| Am2925 | System Clock Generator |
| Am2940 | DMA Address Generator |
| Am2952 | Bidirectional I/O Port |
| Am27S35 | Registered PROM |

For applications information see Chapters III and IV of
Bit Slice Microprocessor Design,
by Mick and Brick, McGraw Hill Publishers.


## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 4, 3, 2, 1 | $\mathrm{A}_{0-3}$ | 1 | The four address inputs to the register stack used to select one register whose contents are displayed through the Aport. |
| $\begin{aligned} & 17,18 \\ & 19,20 \\ & \hline \end{aligned}$ | $\mathrm{B}_{0-3}$ | 1 | The four address inputs to the register stack used to select one register whose contents are displayed through the Bport and into which new data can be written when the clock goes LOW. |
|  | $\mathrm{l}_{0-8}$ | 1 | The nine instruction control lines. Used to determine what data sources will be applied to the ALU (l012), what function the ALU will perform (I $I_{345}$ ), and what data is to be deposited in the Q-register or the register stack ( $I_{678}$ ). |
| 16 | $Q_{3}$ RAM $_{3}$ | 1/0 | A shift line at the MSB of the Q register $\left(\mathrm{Q}_{3}\right)$ and the register stack $\left(\mathrm{RAM}_{3}\right)$. Electrically these lines are three-state outputs connected to TTL inputs internal to the device. When the destination code on 1678 indicates an up shift (octal 6 or 7) the three-state outputs are enabled and the MSB of the Q register is available on the Q ${ }_{3}$ pin and the MSB of the ALU output is available on the RAM 3 pin. Otherwise, the three-state outputs are electrically OFF (high-impedance) and the pins are electrically LS-TTL inputs. When the destination code calls for a down shift, the pins are used as the data inputs to the MSB of the Q register (octal 4) and RAM (octal 4 or 5). |
| 21, 9 | $Q_{0}$ RAM0 | 1/0 | Shift lines like $Q_{3}$ and $R A M_{3}$, but at the LSB of the Q-register and RAM. These pins are tied to the $Q_{3}$ and RAM 3 pins of the adjacent device to transfer data between devices for up and down shifts of the Q register and ALU data. |
| $\begin{aligned} & 25,24 \\ & 23,22 \\ & \hline \end{aligned}$ | $\mathrm{D}_{0-3}$ | 1 | Direct data inputs. A four-bit data field which may be selected as one of the ALU data sources for entering data into the device. $D_{0}$ is the LSB. |
| $\begin{aligned} & 36,37 \\ & 38,39 \\ & \hline \end{aligned}$ | $\mathrm{Y}_{0-3}$ | 0 | The four data outputs. These are three-state output lines. When enabled, they display either the four outputs of the ALU or the data on the A-port of the register stack, as determined by the destination code $\mathrm{I}_{678}$. |
| 40 | $\overline{O E}$ | 1 | Output Enable. When $\overline{\mathrm{OE}}$ is HIGH, the Y outputs are OFF; when $\overline{\mathrm{OE}}$ is LOW, the Y outputs are active (HIGH or LOW). |
| 32, 35 | $\overline{\mathrm{G}}, \overline{\mathrm{P}}$ | 0 | The carry generate and propagate outputs of the internal ALU. These signals are used with the Am2902 for carrylookahead. |
| 34 | OVR | 0 | Overflow. This pin is logically the Exclusive-OR of the carry-in and carry-out of the MSB of the ALU. At the most significant end of the word, this pin indicates that the result of an arithmetic two's complement operation has overflowed into the sign-bit. |
| 11 | $F=0$ | 0 | This is an open collector output which goes HIGH (OFF) if the data on the four ALU outputs $\mathrm{F}_{0-3}$ are all LOW. In positive logic, it indicates the result of an ALU operation is zero. |
| 31 | $\mathrm{F}_{3}$ | 0 | The most significant ALU output bit. |
| 29 | $\mathrm{C}_{\mathrm{n}}$ | 1 | The carry-in to the internal ALU. |
| 33 | $C_{n+4}$ | 0 | The carry-out of the internal ALU. |
| 15 | CP | 1 | The clock input. The Q register and register stack outputs change on the clock LOW-to-HIGH transition. The clock LOW time is internally the write enable to the $16 \times 4$ RAM which compromises the "master" latches of the register stack. While the clock is LOW, the "slave" latches on the RAM outputs are closed, storing the data previously on the RAM outputs. This allows synchronous master-slave operation of the register stack. |

DETAILED Am2901C MICROPROCESSOR BLOCK DIAGRAM


BD002050
Figure 2.

## ARCHITECTURE

A detailed block diagram of the bipolar microprogrammable microprocessor structure is shown in Figure 1. The circuit is a four-bit slice cascadable to any number of bits. Therefore, all data paths within the circuit are four bits wide. The two key elements in the Figure 1 block diagram are the 16 -word by 4 bit 2-port RAM and the high-speed ALU.

Data in any of the 16 words of the Random Access Memory (RAM) can be read from the A-port of the RAM as controlled by the 4-bit A address field input. Likewise, data in any of the 16 words of the RAM as defined by the B address field input can be simultaneously read from the B-port of the RAM. The same code can be applied to the A select field and B select field in which case the identical file data will appear at both the RAM A-port and B-port outputs simultaneously.

When enabled by the RAM write enable (RAM EN), new data is always written into the file (word) defined by the $B$ address field of the RAM. The RAM data input field is driven by a 3input multiplexer. This configuration is used to shift the ALU output data ( $F$ ) if desired. This three-input multiplexer scheme allows the data to be shifted up one bit position, shifted down one bit position, or not shifted in either direction.
The RAM A-port data outputs and RAM B-port data outputs drive separate 4-bit latches. These latches hold the RAM data while the clock input is LOW. This eliminates any possible race conditions that could occur while new data is being written into the RAM.

The high-speed Arithmetic Logic Unit (ALU) can perform three binary arithmetic and five logic operations on the two 4-bit input words $R$ and $S$. The $R$ input field is driven from a 2 -input multiplexer, while the $S$ input field is driven from a 3-input multiplexer. Both multiplexers also have an inhibit capability; that is, no data is passed. This is equivalent to a "zero" source operand.
Referring to Figure 2, the ALU R-input multiplexer has the RAM A-port and the direct data inputs (D) connected as inputs. Likewise, the ALU S-input multiplexer has the RAM Aport, the RAM B-port and the Q register connected as inputs.
This multiplexer scheme gives the capability of selecting various pairs of the $A, B, D, Q$ and ' 0 ' inputs as source operands to the ALU. These five inputs, when taken two at a time, result in ten possible combinations of source operand pairs. These combinations include $A B, A D, A Q, A O, B D, B Q$, $B 0, D Q, D 0$ and $Q 0$. It is apparent that $A D, A Q$ and $A 0$ are somewhat redundant with $B D, B Q$ and $B 0$ in that if the $A$ address and $B$ address are the same, the identical function results. Thus, there are only seven completely non-redundant source operand pairs for the ALU. The Am2901 microprocessor implements eight of these pairs. The microinstruction inputs used to select the ALU source operands are the $I_{0}, l_{1}$, and $\mathrm{I}_{2}$ inputs. The definition of $\mathrm{I}_{0}, \mathrm{I}_{1}$, and $\mathrm{I}_{2}$ for the eight source operand combinations are as shown in Figure 3. Also shown is the octal code for each selection.

The two source operands not fully described as yet are the D input and $Q$ input. The $D$ input is the four-bit wide direct data field input. This port is used to insert all data into the working registers inside the device. Likewise, this input can be used in the ALU to modify any of the internal data files. The Q register is a separate 4-bit file intended primarily for multiplication and division routines but it can also be used as an accumulator or holding register for some applications.

The ALU itself is a high-speed arithmetic/logic operator capable of performing three binary arithmetic and five logic functions. The $I_{3}, I_{4}$, and $I_{5}$ microinstruction inputs are used to select the ALU function. The definition of these inputs is
shown in Figure 4. The octal code is also shown for reference. The normal technique for cascading the ALU of several devices is in a look-ahead carry mode. Carry generate, $\bar{G}$, and carry propagate, $\overline{\mathrm{P}}$, are outputs of the device for use with a carry-look-ahead-generator such as the Am2902. A carry-out, $\mathrm{C}_{n}+4$, is also generated and is available as an output for use as the carry flag in a status register. Both carry-in $\left(\mathrm{C}_{n}\right)$ and carry-out $\left(\mathrm{C}_{n}+4\right)$ are active HIGH.

The ALU has three other status-oriented outputs. These are $F_{3}, F=0$, and overflow (OVR). The $F_{3}$ output is the most significant (sign) bit of the ALU and can be used to determine positive or negative results without enabling the three-state data outputs. $F_{3}$ is non-inverted with respect to the sign bit output $Y_{3}$. The $F=0$ output is used for zero detect. It is an open-collector output and can be wire OR'ed between microprocessor slices. $F=0$ is HIGH when all $F$ outputs are LOW. The overflow output (OVR) is used to flag arithmetic operations that exceed the available two's complement number range. The overflow output (OVR) is HIGH when overflow exists. That is, when $C_{n+3}$ and $C_{n+4}$ are not the same polarity.

The ALU data output is routed to several destinations. It can be a data output of the device and it can also be stored in the RAM or the $Q$ register. Eight possible combinations of ALU destination functions are available as defined by the $I_{6}, I_{7}$, and $I_{8}$ microinstruction inputs. These combinations are shown in Figure 5.

The four-bit data output field $(\mathrm{Y})$ features three-state outputs and can be directly bus organized. An output control ( $\overline{\mathrm{OE}}$ ) is used to enable the three-state outputs. When $\overline{\mathrm{OE}}$ is HIGH, the $Y$ outputs are in the high-impedance state.

A two-input multiplexer is also used at the data output such that either the A-port of the RAM or the ALU outputs (F) are selected at the device $Y$ outputs. This selection is controlled by the $I_{6}, I_{7}$, and $I_{8}$ microinstruction inputs. Refer to Figure 12 for the selected output for each microinstruction code combination.

As was discussed previously, the RAM inputs are driven from a three-input multiplexer. This allows the ALU outputs to be entered non-shifted, shifted up one position (X2) or shifted down one position ( $\div 2$ ). The shifter has two ports; one is labeled RAM ${ }_{0}$ and the other is labeled RAM R $_{3}$. Both of these ports consist of a buffer-driver with a three-state output and an input to the multiplexer. Thus, in the shift up mode, the RAM 3 buffer is enabled and the RAM $M_{0}$ multiplexer input is enabled. Likewise, in the shift down mode, the RAM 0 buffer and RAM 3 input are enabled. In the no-shift mode, both buffers are in the high-impedance state and the multiplexer inputs are not selected. This shifter is controlled from the $I_{6}, I_{7}$ and $1_{8}$ microinstruction inputs as defined in Figure 5.

Similarly, the Q register is driven from a 3-input multiplexer. In the no-shift mode, the multiplexer enters the ALU data into the $Q$ register. In either the shift-up or shift-down mode, the multiplexer selects the $Q$ register data appropriately shifted up or down. The $Q$ shifter also has two ports; one is labeled $Q_{0}$ and the other is $Q_{3}$. The operation of these two ports is similar to the RAM shifter and is also controlled from $\mathrm{I}_{6}, \mathrm{I}_{7}$, and $\mathrm{I}_{8}$ as shown in Figure 5.

The clock input to the Am2901 controls the RAM, the Q register, and the $A$ and $B$ data latches. When enabled, data is clocked into the $Q$ register on the LOW-to-HIGH transition of the clock. When the clock input is HIGH, the A and B latches are open and will pass whatever data is present at the RAM outputs. When the clock input is LOW, the latches are closed and will retain the last data entered. If the RAM-EN is enabled, new data will be written into the RAM file (word) defined by the $B$ address field when the clock input is LOW.

| Nnemonic | MICRO CODE |  |  | ALU SOURCE <br> OPERANDS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | I2 $_{2}$ | I $_{1}$ | Io | Octal <br> Code | R | S |
|  | L | L | L | 0 | A | Q |
| AB | L | L | H | 1 | A | B |
| ZQ | L | H | L | 2 | 0 | Q |
| ZB | L | H | H | 3 | 0 | B |
| ZA | H | L | L | 4 | 0 | A |
| DA | H | L | H | 5 | D | A |
| DQ | H | H | L | 6 | D | Q |
| DZ | H | H | H | 7 | D | 0 |

Figure 3. ALU Source Operand Control.

| Mnemonic | MICRO CODE |  |  |  | ALU Function | SYMBOL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{I}_{5}$ | 14 | $\mathrm{I}_{3}$ | Octal Code |  |  |
| ADD | L | L | L | 0 | R Plus S | $R+S$ |
| SUBR | L | L | H | 1 | S Minus R | $S-R$ |
| SUBS | L | H | L | 2 | R Minus S | R-S |
| OR | L | H | H | 3 | R OR S | $R \vee S$ |
| AND | H | L | L | 4 | $R$ AND S | $R \wedge S$ |
| NOTRS | H | L | H | 5 | $\bar{R}$ AND S | $\bar{R} \wedge S$ |
| EXOR | H | H | L | 6 | $R$ EX-OR S | RVS |
| EXNOR | H | H | H | 7 | R EX-NOR S | $\overline{R \nabla S}$ |

Figure 4. ALU Function Control.

| Mnemonic | MICRO CODE |  |  |  | RAM FUNCTION |  | Q-REG. FUNCTION |  | $\begin{gathered} \mathbf{Y} \\ \text { OUTPUT } \end{gathered}$ | RAM SHIFTER |  | Q SHIFTER |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{I}_{8}$ | 17 | $\mathrm{I}_{6}$ | Octal Code | Shift | Load | Shift | Load |  | RAM0 | $\mathrm{RAM}_{3}$ | $Q_{0}$ | $Q_{3}$ |
| QREG | L | L | L | 0 | X | NONE | NONE | $F \rightarrow 0$ | F | X | X | X | X |
| NOP | L. | L | H | 1 | X | NONE | X | NONE | F | X | X | X | X |
| RAMA | L | H | L | 2 | NONE | $F \rightarrow B$ | X | NONE | A | X | X | X | X |
| RAMF | L | H | H | 3 | NONE | $F \rightarrow B$ | X | NONE | F | X | X | X | X |
| RAMQD | H | L | L | 4 | DOWN | $\mathrm{F} / 2 \rightarrow \mathrm{~B}$ | DOWN | $\mathrm{Q} / 2 \rightarrow \mathrm{Q}$ | F | Fo | $\mathrm{IN}_{3}$ | $Q_{0}$ | $\mathrm{IN}_{3}$ |
| RAMD | H | L | H | 5 | DOWN | $\mathrm{F} / 2 \rightarrow \mathrm{~B}$ | X | NONE | F | $\mathrm{F}_{0}$ | $\mathrm{iN}_{3}$ | $\mathrm{Q}_{0}$ | X |
| RAMQU | H | H | L | 6 | UP | $2 \mathrm{~F} \rightarrow \mathrm{~B}$ | UP | $2 \mathrm{Q} \rightarrow \mathrm{Q}$ | F | $\mathrm{IN}_{0}$ | $\mathrm{F}_{3}$ | $1 \mathrm{~N}_{0}$ | $Q_{3}$ |
| RAMU | H | H | H | 7 | UP | $2 \mathrm{~F} \rightarrow \mathrm{~B}$ | X | NONE | F | $\mathrm{IN}_{0}$ | F3 | X | $\mathrm{Q}_{3}$ |

$X=$ Don't care. Electrically, the shift pin is a TTL input internally connected to a three-state output which is in the high-impedance state.
$B=$ Register Addressed by B inputs.
UP is toward MSB, DOWN is toward LSB.
Figure 5. ALU Destination Control.


[^4]Figure 6. Source Operand and ALU Function Matrix.

## SOURCE OPERANDS AND ALU FUNCTIONS

There are eight source operand pairs available to the ALU as selected by the $I_{0}, I_{1}$, and $I_{2}$ instruction inputs. The ALU can perform eight functions; five logic and three arithmetic. The $\mathrm{I}_{3}$, $\mathrm{I}_{4}$, and $\mathrm{I}_{5}$ instruction inputs control this function selection. The carry input, $\mathrm{C}_{\mathrm{n}}$, also affects the ALU results when in the arithmetic mode. The $\mathrm{C}_{\mathrm{n}}$ input has no effect in the logic mode. When $I_{0}$ through $I_{5}$ and $C_{n}$ are viewed together, the matrix of

Figure 6 results. This matrix fully defines the ALU/source operand function for each state.

The ALU functions can also be examined on a 'task' basis, i.e., add, subtract, AND, OR, etc. In the arithmetic mode, the carry will affect the function performed while in the logic mode, the carry will have no bearing on the ALU output. Figure 7 defines the various logic operations that the Am2901 can perform and Figure 8 shows the arithmetic functions of the device. Both carry-in LOW $\left(\mathrm{C}_{\mathrm{n}}=0\right)$ and carry-in HIGH $\left(\mathrm{C}_{\mathrm{n}}=1\right)$ are defined in these operations.

| $\begin{gathered} \text { Octal } \\ 1_{543}, I_{210} \\ \hline \end{gathered}$ | Group | Function |
| :---: | :---: | :---: |
| $\begin{aligned} & 40 \\ & 41 \\ & 45 \\ & 46 \end{aligned}$ | AND | $A \wedge Q$ <br> $A \wedge B$ <br> D^A <br> D^Q |
| $\begin{array}{ll} 3 & 0 \\ 3 & 1 \\ 3 & 5 \\ 3 & 6 \end{array}$ | OR | AvQ <br> AvB <br> DvA <br> DvQ |
| $\begin{array}{ll} 6 & 0 \\ 6 & 1 \\ 6 & 5 \\ 6 & 6 \end{array}$ | EX-OR | $A \nabla Q$ <br> $A D B$ <br> DVA <br> DVQ |
| $\begin{array}{ll} 7 & 0 \\ 7 & 1 \\ 7 & 5 \\ 7 & 6 \end{array}$ | EX-NOR | $\begin{aligned} & \overline{\overline{A V Q}} \\ & \overline{A \nabla B} \\ & \overline{D \nabla A} \\ & \overline{D V Q} \end{aligned}$ |
| $\begin{aligned} & 72 \\ & 73 \\ & 74 \\ & 77 \end{aligned}$ | INVERT | $\begin{aligned} & \bar{Q} \\ & \bar{B} \\ & \bar{A} \\ & \bar{D} \end{aligned}$ |
| $\begin{aligned} & 62 \\ & 6 \\ & 6 \\ & 64 \\ & 67 \end{aligned}$ | PASS | $\begin{aligned} & \text { Q } \\ & \text { B } \\ & \text { A } \\ & \text { D } \end{aligned}$ |
| $\begin{aligned} & 32 \\ & 3 \\ & 3 \\ & 3 \end{aligned}$ | PASS | $\begin{aligned} & \mathrm{Q} \\ & \mathrm{~B} \\ & \mathrm{~A} \\ & \mathrm{D} \end{aligned}$ |
| $\begin{array}{ll} 4 & 2 \\ 4 & 3 \\ 4 & 4 \\ 4 & 7 \end{array}$ | 'ZERO'' | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ |
| $\begin{array}{ll} 5 & 0 \\ 5 & 1 \\ 5 & 5 \\ 5 & 6 \end{array}$ | MASK | $\begin{aligned} & \bar{A} \wedge Q \\ & \bar{A} \wedge B \\ & \bar{D} \wedge A \\ & \bar{D} \wedge Q \end{aligned}$ |

Figure 7. ALU Logic Mode Functions.

| Octal <br> 1543, <br> $\mathbf{I}_{210}$ | $C_{n}=\mathbf{L}$ |  | $C_{n}=H$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Group | Function | Group | Function |
| $\begin{array}{ll} 0 & 0 \\ 0 & 1 \\ 0 & 5 \\ 0 & 6 \end{array}$ | ADD | $\begin{aligned} & A+Q \\ & A+B \\ & D+A \\ & D+Q \end{aligned}$ | ADD plus one | $\begin{aligned} & A+Q+1 \\ & A+B+1 \\ & D+A+1 \\ & D+Q+1 \end{aligned}$ |
| $\begin{array}{ll} 0 & 2 \\ 0 & 3 \\ 0 & 4 \\ 0 & \end{array}$ | PASS | $\begin{aligned} & \hline Q \\ & B \\ & A \\ & D \end{aligned}$ | Increment | $\begin{aligned} & Q+1 \\ & B+1 \\ & A+1 \\ & D+1 \end{aligned}$ |
| $\begin{aligned} & 12 \\ & 13 \\ & 14 \\ & 27 \end{aligned}$ | Decrement | $\begin{aligned} & Q-1 \\ & B-1 \\ & A-1 \\ & D-1 \end{aligned}$ | PASS | $\begin{aligned} & \mathrm{Q} \\ & \mathrm{~B} \\ & \mathrm{~A} \\ & \mathrm{D} \end{aligned}$ |
| $\begin{aligned} & 22 \\ & 23 \\ & 24 \\ & 17 \end{aligned}$ | 1's Comp. | $\begin{aligned} & -Q-1 \\ & -B-1 \\ & -A-1 \\ & -D-1 \end{aligned}$ | 2's Comp. (Negate) | $\begin{aligned} & -Q \\ & -B \\ & -A \\ & -D \end{aligned}$ |
| $\begin{array}{ll} 1 & 0 \\ 1 & 1 \\ 1 & 5 \\ 1 & 6 \\ 2 & 0 \\ 2 & 1 \\ 2 & 5 \\ 2 & 6 \end{array}$ | Subtract (1's Comp) | $\begin{aligned} & \mathrm{Q}-\mathrm{A}-1 \\ & B-A-1 \\ & A-D-1 \\ & Q-D-1 \\ & A-Q-1 \\ & A-B-1 \\ & D-A-1 \\ & D-Q-1 \end{aligned}$ | Subtract (2's Comp) | $\begin{aligned} & \text { Q-A } \\ & B-A \\ & A-D \\ & Q-D \\ & A-Q \\ & A-B \\ & D-A \\ & D-Q \end{aligned}$ |

Figure 8. ALU Arithmetic Mode Functions.

## LOGIC FUNCTIONS FOR G, P, $\mathrm{C}_{\mathrm{n}}+4$, AND OVR

The four signals $G, P, C_{n+4}$, and $O V R$ are designed to indicate carry and overflow conditions when the Am2901 is in the add or subtract mode. The table below indicates the logic equations for these four signals for each of the eight ALU functions. The R and S inputs are the two inputs selected according to Figure 3.

## Definitions (+ = OR)

| $P_{0}=R_{0}+S_{0}$ | $G_{0}=R_{0} S_{0}$ |
| :--- | :--- |
| $P_{1}=R_{1}+S_{1}$ | $G_{1}=R_{1} S_{1}$ |
| $P_{2}=R_{2}+S_{2}$ | $G_{2}=R_{2} S_{2}$ |
| $P_{3}=R_{3}+S_{3}$ | $G_{3}=R_{3} S_{3}$ |

$\mathrm{C}_{4}=\mathrm{G}_{3}+\mathrm{P}_{3} \mathrm{G}_{2}+\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{G}_{1}$
$+\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1} \mathrm{G}_{0}+\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1} \mathrm{P}_{0} \mathrm{C}_{\mathrm{n}}$
$\mathrm{C}_{3}=\mathrm{G}_{2}+\mathrm{P}_{2} \mathrm{G}_{1}+\mathrm{P}_{2} \mathrm{P}_{1} \mathrm{G}_{0}+\mathrm{P}_{2} \mathrm{P}_{1} \mathrm{P}_{0} \mathrm{C}_{\mathrm{n}}$

| 1543 | Function | $\overline{\mathbf{P}}$ | $\overline{\mathbf{G}}$ | $C_{n+4}$ | OVR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | R+S | $\overline{P_{3} P_{2} P_{1} P_{0}}$ | $\overline{G_{3}+P_{3} G_{2}+P_{3} P_{2} G_{1}+P_{3} P_{2} P_{1} G_{0}}$ | $\mathrm{C}_{4}$ | $\mathrm{C}_{3} \nabla \mathrm{VC}_{4}$ |
| 1 | $S-R$ | $\longleftarrow$ Same as $R+S$ equations, but substitute $\overline{R_{i}}$ for $R_{i}$ in definitions $\longrightarrow$ |  |  |  |
| 2 | R-S | $\downarrow$ Same as $R+S$ equations, but substitute $\bar{S}_{\mathbf{i}}$ for $\mathrm{S}_{\mathrm{i}}$ in definitions $\longrightarrow$ |  |  |  |
| 3 | RvS | LOW | $\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1} \mathrm{P}_{0}$ | $\overline{P_{3} P_{2} P_{1} P_{0}}+C_{n}$ | $\bar{P}_{3} P_{2} P_{1} P_{0}+C_{n}$ |
| 4 | R^S | LOW | $\overline{G_{3}+G_{2}+G_{1}+G_{0}}$ | $\mathrm{G}_{3}+\mathrm{G}_{2}+\mathrm{G}_{1}+\mathrm{G}_{0}+\mathrm{C}_{\mathrm{n}}$ | $\mathrm{G}_{3}+\mathrm{G}_{2}+\mathrm{G}_{1}+\mathrm{G}_{0}+\mathrm{C}_{\mathrm{n}}$ |
| 5 | $\overline{\mathrm{R}} \wedge \mathrm{S}$ | LOW | $\longrightarrow$ Same as R^S equations, but substitute $\bar{R}_{i}$ for $R_{i}$ in definitions $\longrightarrow$ |  |  |
| 6 | R $V$ S | $\longleftarrow$ Same as $\overline{\mathrm{RVS}}$, but substitute $\overline{\bar{R}_{i}}$ for $R_{i}$ in definitions $\longrightarrow$ |  |  |  |
| 7 | $\overline{\text { RVS }}$ | $\mathrm{G}_{3}+\mathrm{G}_{2}+\mathrm{G}_{1}+\mathrm{G}_{0}$ | $\mathrm{G}_{3}+\mathrm{P}_{3} \mathrm{G}_{2}+\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{G}_{1}+\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1} \mathrm{P}_{0}$ | $\frac{\overline{G_{3}+P_{3} G_{2}+P_{3} P_{2} G_{1}}}{+P_{3} P_{2} P_{1} P_{0}\left(G_{0}+\bar{C}_{n}\right)}$ | See note |

Note: $\left[\bar{P}_{2}+\bar{G}_{2} \bar{P}_{1}+\bar{G}_{2} \bar{G}_{1} \bar{P}_{0}+\bar{G}_{2} \bar{G}_{1} \bar{G}_{0} C_{n}\right] \nabla$
$\left[\bar{P}_{3}+\bar{G}_{3} \bar{P}_{2}+\bar{G}_{3} \bar{G}_{2} \bar{P}_{1}+\bar{G}_{3} \bar{G}_{2} \bar{G}_{1} \bar{P}_{0}+\bar{G}_{3} \bar{G}_{2} \bar{G}_{1} \bar{G}_{0} C_{n}\right]$

Figure 9.

## MINIMUM CYCLE TIME CALCULATIONS FOR 16-BIT SYSTEMS

Speeds used in calculations for parts other than Am2901C are representative for available MSI parts.


AF001621

Pipelined System. Add without Simultaneous Shift.

| DATA LOOP |  |  | CONTROL LOOP |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (1)Register | Clock to Output | 9 | (1)Register | Clock to Output | 9 |
| +(22901C | A, B to $\bar{G}, \bar{P}$ | 37 | + (6MUX | Select to Output | 13 |
| + (3)2902A | $\bar{G}_{0}, \bar{P}_{0}$ to $\mathrm{C}_{\mathrm{n}}$ | 7 | + (72910A | CC to Output | 30 |
| +(4)2901C | $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{\mathrm{n}}+4, \mathrm{OVR}$, | 25 | + (8)PROM | Access Time | 40 |
| +(5)Register | F3, Setup Time | 2 | +(1)Register | Setup Time | 2 |
|  |  | 80 | $\mathrm{d}=94 \mathrm{~ns}$ |  | 94ns |



Pipelined System．Simultaneous Add and Shift Down．

| Clock to Output | 9 |
| :---: | :---: |
| A，B to $\overline{\mathrm{G}}, \overline{\mathrm{P}}$ | 37 |
| $\bar{G}_{0}, \bar{P}_{0}$ to $\mathrm{C}_{\mathrm{n}}+\mathrm{z}$ | 7 |
| $\mathrm{C}_{n}$ to $\mathrm{F}_{3}, \mathrm{OVR}$ | 22 |
|  | 21 |
| RAM3 Setup | 12 |
|  | 108n |

CONTROL LOOP

| （1）Register |
| :--- |
| $+(22901 \mathrm{C}$ |
| $+(32902 \mathrm{~A}$ |
| $+(42901 \mathrm{C}$ |
| $+(5) X O R$ and MUX |
| + （8） 2901 C |


| CONTROL LOOP |  |  |
| :--- | :--- | ---: |
| （1）Register | Clock to Output | 9 |
| ＋（6MUX | Select to Output | 13 |
| ＋（2）2910A | CC to Output | 30 |
| ＋8PROM | Access Time | 40 |
| ＋（1）Register | Setup Time | 2 |
|  |  | 94 ns |

Figure 10.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
plied to Outputs For...............................
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to +7.0 V DC Input Voltage. -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Output Cuge $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . .0 .5 \mathrm{~V}$ to +5.5 V
DC Input Current
Into Outputs
................ 30mA

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage 4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V
Operating ranges define those limits over which the function- ality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


| Parameters | Description | Test Conditions (Note 1) |  |  |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| $\begin{aligned} & \mathrm{lozH} \\ & \text { lozi } \end{aligned}$ | Off State (High Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ |  | $\begin{aligned} & Y_{0}, Y_{1}, \\ & Y_{2}, Y_{3} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  | -50 |  |
|  |  |  |  | RAM $_{0,3}$ $Q_{0,3}$ | $\begin{aligned} & \mathrm{VO}_{\mathrm{O}}=2.4 \mathrm{~V} \\ & \text { (Note 3) } \\ & \hline \end{aligned}$ |  | 100 |  |
|  |  |  |  | $\begin{array}{\|l\|} \hline \mathrm{VO}_{\mathrm{O}}=0.5 \mathrm{~V} \\ \text { (Note 3) } \\ \hline \end{array}$ |  | -800 |  |
| los | Output Short Circuit Current (Note 2) | $\mathrm{V}_{C C}=\mathrm{MAX}+0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | $Y_{0}, Y_{1}, Y^{\prime}$ | 3. $\overline{\mathrm{G}}$ | -30 | -85 | mA |
|  |  |  |  | $\mathrm{C}_{\mathrm{n}+4}$ |  | -30 | -85 |  |  |
|  |  |  |  | OVR, $\overline{\mathrm{P}}$ |  | -30 | -85 |  |  |
|  |  |  |  | F3 |  | -30 | -85 |  |  |
|  |  |  |  | $\mathrm{RAM}_{0}$, 3, |  | -30 | -85 |  |  |
| ICC | Power Supply Current (Note 5) | $V_{C C}=$ MAX | COM'L Only (Note 4) | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ | $+70^{\circ} \mathrm{C}$ |  | 265 | mA |  |
|  |  |  |  | $T_{A}=+70$ |  |  | 220 |  |  |
|  |  |  | MIL Only (Note 4) | $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  | 280 |  |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 198 |  |  |

1. VCC conditions shown as MIN or MAX, refer to the military ( $\pm 10 \%$ ) or commercial ( $\pm 5 \%$ ) VCC limits.
2. Not more than one output should be stored at a time. Duration of the short circuit test should not exceed one second.
3. These are three-state outputs internally connected to TTL inputs. Input characteristics are measured with $\mathrm{l}_{678}$ in a state such that the three-state output is OFF.
4. 'MIL" = Am2901CXM, DM, FM, LM, "COM'L" = Am2901CXC, PC, DC, LC.
5. Worst case ICC is measured at the lowest temperature in the specified operating range.
6. These input levels provide zero noise immunity and should only be static tested in a noise-free environment, (not functionally tested).

## I. Am2901B Guaranteed Commercial Range Performance

The tables below specify the guaranteed performance of the Am2901B over the commercial operating range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{CC}}$ from 4.75 V to 5.25 V . All data are in ns. with inputs switching between 0 V and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.

This data applies to the following part numbers: Am2901BPC Am2901BDC
A. Cycle Time and Clock Characteristics.

| Read-Modify-Write Cycle (from selection of A, <br> B registers to end of cycle.) | 69 ns |
| :--- | :---: |
| Maximum Clock Frequency to shift Q (50\% <br> duty cycle. $=432$ or 632$)$ | 16 MHz |
| Minimum Clock LOW Time | 30 ns |
| Minimum Clock HIGH Time | 30 ns |
| Minimum Clock Period | 69 ns |

B. Combinational Propagation Delays. (Note 1) $C_{L}=50 \mathrm{pF}$

|  | To Output |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From Input | $\mathbf{Y}$ | F3 | Cn+4 | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | F=0 | OVR | RAMO RAM3 | $\begin{aligned} & \text { Q0 } \\ & \text { Q3 } \end{aligned}$ |
| A, B Address | 60 | 61 | 59 | 50 | 70 | 67 | 71 | - |
| D | 38 | 36 | 40 | 33 | 48 | 44 | 45 | - |
| Cn | 30 | 29 | 20 | - | 37 | 29 | 38 | - |
| 1012 | 50 | 47 | 45 | 45 | 56 | 53 | 57 | - |
| 1345 | 51 | 52 | 52 | 45 | 60 | 49 | 53 | - |
| 1678 | 28 | - | - | - | - | - | 35 | 35 |
| A Bypass ALU ( $\mathrm{I}=2 \mathrm{XX}$ ) | 37 | - | - | - | - | - | - | - |
| Clock 5 | 49 | 48 | 47 | 37 | 58 | 55 | 59 | 29 |

C. Set-up and Hold Times Relative to Clock (CP) Input. (Note 1)

| Input | CP: <br> Set-up Time Before H $\rightarrow$ L | Hold Time After $\mathbf{H} \rightarrow \mathbf{L}$ | Set-up Time Before L $\rightarrow$ H | Hold Time After L $\rightarrow \mathbf{H}$ |
| :---: | :---: | :---: | :---: | :---: |
| A, B Source Address | 20 | 0 (Note 3) | 69 (Note 4) | 0 |
| B Destination Address | 15 | Do Not | (Note 2) | 0 |
| D | - | - | 51 | 0 |
| Cn | - | - | 39 | 0 |
| 1012 | - | - | 56 | 0 |
| 1345 | - | - | 55 | 0 |
| 1678 | 11 | Do Not Change (Note 2) |  | 0 |
| RAMO, 3, Q0, 3 | - | - | 16 | 0 |

## D. Output Enable/Disable Times.

Output disable tests performed with $C_{L}=5 p F$ and measured to 0.5 V change of output voltage level.

| Input | Output | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 35 | 25 |

NOTES: 1. A dash indicates a propagation delay path or set-up time constraint does not exist.
2. Certain signals must be stable during the entire clock LOW time to avoid erroneous operation. This is indicated by the phrase "do not change".
3. Source addresses must be stable prior to the clock $H \rightarrow L$ transition to allow time to access the source data before the latches close. The A address may then be changed. The B address could be changed if it is not a destination: i.e., if data is not being written back into the RAM. Normally A and B are not changed during the clock LOW time.
4. The set-up time prior to the clock $L \rightarrow H$ transition is to allow time for data to be accessed, passed through the ALU, and returned to the RAM. It indicates all the time from stable $A$ and $B$ addresses to the clock $L \rightarrow H$ transition, regardless of when the clock $H \rightarrow L$ transition occurs.

## II．Am2901B Guaranteed Military Range Performance

The tables below specify the guaranteed performance of the Am2901B over the military operating range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ，with $\mathrm{V}_{\mathrm{CC}}$ from 4.5 V to 5.5 V ．All data are in ns ，with inputs switching between 0 V and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measure－ ments made at 1.5 V ．All outputs have maximum DC load．

This data applies to the following part numbers：Am2901BDM Am2901BFM

A．Cycle Time and Clock Characteristics．

| Read－Modify－Write Cycle（from selection of A， <br> B registers to end of cycle．） | 88 ns |
| :--- | :---: |
| Maximum Clock Frequency to shift Q（50\％ <br> duty cycle． $1=432$ or 632$)$ | 15 MHz |
| Minimum Clock LOW Time | 30 ns |
| Minimum Clock HIGH Time | 30 ns |
| Minimum Clock Period | 88 ns |

B．Combinational Propagation Delays．（Note 1） $C_{L}=50 \mathrm{pF}$

|  | To Output |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From Input | $\mathbf{Y}$ | $\mathbf{F 3}$ | $\mathbf{C n}+\mathbf{4}$ | $\overline{\mathbf{G}, \mathbf{P}}$ | $\mathbf{F}=\mathbf{0}$ | $\mathbf{O V R}$ | RAMM <br> RAM3 | Q0 <br> Q3 |  |
| A，B Address | 82 | 84 | 80 | 70 | 90 | 86 | 94 | - |  |
| D | 44 | 38 | 40 | 34 | 50 | 45 | 48 | - |  |
| Cn | 34 | 32 | 24 | - | 38 | 31 | 39 | - |  |
| 1012 | 53 | 50 | 47 | 46 | 65 | 55 | 58 | - |  |
| 1345 | 58 | 58 | 58 | 48 | 64 | 56 | 55 | - |  |
| 1678 | 29 | - | - | - | - | - | 27 | 27 |  |
| A Bypass ALU <br> （I＝2XX） | 50 | - | - | - | - | - | - | - |  |
| Clock $\boldsymbol{F}$ | 53 | 50 | 49 | 41 | 63 | 58 | 61 | 31 |  |



## D．Output Enable／Disable Times．

Output disable tests performed with $C_{L}=5 p F$ and measured to 0.5 V change of output voltage level．

| Input | Output | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 40 | 25 |

NOTES：1．A dash indicates a propagation delay path or set－up time constraint does not exist
2．Certain signals must be stable during the entire clock LOW time to avoid erroneous operation．This is indicated by the phrase＂do not change＂
3．Source addresses must be stable prior to the clock $H \rightarrow L$ transition to allow time to access the source data before the latches close．The A address may then be changed．The B address could be changed if it is not a destina－ tion：i．e．，if data is not being written back into the RAM．Normally A and B are not changed during the clock LOW time．
4．The set－up time prior to the clock $L \rightarrow H$ transition is to allow time for data to be accessed，passed through the $A L U$ ，and returned to the RAM．It includes all the time from stable $A$ and $B$ addresses to the clock $L \rightarrow H$ transition，regardless of when the clock $\mathrm{H} \rightarrow \mathrm{L}$ transition occurs．

## III. Am2901C Guaranteed Commercial Range Performance

The tables below specify the guaranteed performance of the Am2901C over the commercial operating range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{Cc}}$ from 4.75 V to 5.25 V . All data are in ns , with inputs switching between 0 V and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.
This data applies to the following part numbers: Am2901CPC
Am2901CDC Am2901CLC

## A. Cycle Time and Clock Characteristics.

| Read-Modify-Write Cycle (from selection of A, <br> B registers to end of cycle.) | 31 ns |
| :--- | :---: |
| Maximum Clock Frequency to shift Q ( $50 \%$ <br> duty cycle, $1=432$ or 632$)$ | 32 MHz |
| Minimum Clock LOW Time | 15 ns |
| Minimum Clock HIGH Time | 15 ns |
| Minimum Clock Period | 31 ns |

B. Combinational Propagation Delays. (Note 1) $C_{L}=50 \mathrm{pF}$

|  | To Output |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From Input | $\mathbf{Y}$ | $\mathbf{F 3}$ | $\mathbf{C n}+4$ | $\mathbf{G}, \overline{\mathbf{P}}$ | $\mathbf{F}=\mathbf{0}$ | OVR | RAM0 <br> RAM3 | Q0 <br> Q3 |
| A, B Address | 40 | 40 | 40 | 37 | 40 | 40 | 40 | - |
| D | 30 | 30 | 30 | 30 | 38 | 30 | 30 | - |
| Cn | 22 | 22 | 20 | - | 25 | 22 | 25 | - |
| 1012 | 35 | 35 | 35 | 37 | 37 | 35 | 35 | - |
| 1345 | 35 | 35 | 35 | 35 | 38 | 35 | 35 | - |
| 1678 | 25 | - | - | - | - | - | 26 | 26 |
| A Bypass ALU <br> $(I=2 X X)$ | 35 | - | - | - | - | - | - | - |
| Clock $\boldsymbol{F}$ | 35 | 35 | 35 | 35 | 35 | 35 | 35 | 28 |

C. Set-up and Hold Times Relative to Clock (CP) Input. (Note 1)

| Input | CP: <br> Set-up Time Before H $\rightarrow$ L | Hold Time After $\mathbf{H} \rightarrow \mathbf{L}$ | Set-up Time Before L $\rightarrow$ H | Hold Time After L $\rightarrow$ H |
| :---: | :---: | :---: | :---: | :---: |
| A, B Source Address | 15 | 1 (Note 3) | $\begin{gathered} \text { 30, } 15+\text { TpWL } \\ \text { (Note 4) } \end{gathered}$ | 1 |
| B Destination Address | 15 | Do Not | (Note 2) | 1 |
| D | - | - | 25 | 0 |
| Cn | - | - | 20 | 0 |
| 1012 | - | - | 30 | 0 |
| 1345 | - | - | 30 | 0 |
| 1678 | 10 | Do Not Change (Note 2) |  | 0 |
| RAMO, 3, Q0, 3 | - | - | - 12 | 0 |

D. Output Enable/Disable Times.

Output disable tests performed with $C_{L}=5 p F$ and measured to 0.5 V change of output voltage level.

| Input | Output | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 23 | 23 |

NOTES: 1. A dash indicates a propagation delay path or set-up time constraint does not exist.
2. Certain signals must be stable during the entire clock LOW time to avoid erroneous operation. This is indicated by the phrase "do not change".
3. Source addresses must be stable prior to the clock $H \rightarrow L$ transition to allow time to access the source data before the latches close. The A address may then be changed. The B address could be changed if it is not a destination; i.e., if data is not being written back into the RAM. Normally A and B are not changed during the clock LOW time.
4. The set-up time prior to the clock $L \rightarrow H$ transition is to allow time for data to be accessed, passed through the ALU, and returned to the RAM. It includes all the time from stable A and B addresses to the clock $L \rightarrow H$ transition, regardless of when the clock $\mathrm{H} \rightarrow \mathrm{L}$ transition occurs.

## IV．Am2901C Guaranteed Military Range Performance

The tables below specify the guaranteed performance of the Am2901C over the military operating range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ，with $\mathrm{V}_{\mathrm{CC}}$ from 4.5 V to 5.5 V ．All data are in ns，with inputs switching between OV and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measure－ ments made at 1.5 V ．All outputs have maximum DC load．

This data applies to the following part numbers：Am2901CDM
Am2901CFM
Am2901CLM

A．Cycle Time and Clock Characteristics．

| Read－Modify－Write Cycle（from sélection of A， <br> B registers to end of cycle．） | 32 ns |
| :--- | :---: |
| Maximum Clock Frequency to shift Q（50\％ <br> duty cycle， $1=432$ or 632$)$ | 31 MHz |
| Minimum Clock LOW Time | 15 ns |
| Minimum Clock HIGH Time | 15 ns |
| Minimum Clock Period | 32 ns |


| Input | CP： <br> Set－up Time Before H $\rightarrow$ L | Hold Time After $\mathbf{H} \rightarrow \mathrm{L}$ | Set－up Time Before L $\rightarrow$ H | Hold Time <br> After L $\rightarrow$ H |
| :---: | :---: | :---: | :---: | :---: |
| A，B Source Address | 15 | 2 （Note 3） | $\begin{gathered} 30,15+\text { TpWL } \\ (\text { Note 4) } \end{gathered}$ | 2 |
| B Destination Address | 15 | Do Not | （Note 2） | 2 |
| D | － | － | 25 | 0 |
| Cn | － | － | 20 | 0 |
| 1012 | － | － | 30 | 0 |
| 1345 | － | － | 30 | 0 |
| 1678 | 10 | Do Not Change（Note 2） |  | 0 |
| RAMO，3，Q0， 3 | － | － | 12 | 0 |

D．Output Enable／Disable Times．
Output disable tests performed with $C_{L}=5 p F$ and measured to 0.5 V change of output voltage level．

| Input | Output | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 25 | 25 |

NOTES：1．A dash indicates a propagation delay path or set－up time constraint does not exist
2．Certain signals must be stable during the entire clock LOW time to avoid erroneous operation．This is indicated by the phrase＂do not change＂．
3．Source addresses must be stable prior to the clock $H \rightarrow L$ transition to allow time to access the source data before the latches close．The A address may then be changed．The B address could be changed if it is not a destina－ tion；i．e．，if data is not being written back into the RAM．Normally A and B are not changed during the clock LOW time．
4．The set－up time prior to the clock $L \rightarrow H$ transition is to allow time for data to be accessed，passed through the $A L U$ ，and returned to the RAM．It includes all the time from stable A and B addresses to the clock $L \rightarrow H$ transition，regardless of when the clock $\mathrm{H} \rightarrow \mathrm{L}$ transition occurs．

## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS
c. OPEN-COLLECTOR OUTPUTS



$$
\begin{array}{cc}
R_{2}=\frac{2.4 V}{1 O H} \\
R_{1}=\frac{5.0-V_{B E}-V_{O L}}{1 \mathrm{OL}+\mathrm{V}_{\mathrm{OL}} / 1 \mathrm{~K}} & \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{OL}+\mathrm{V}_{\mathrm{OL}} / R_{2}} \quad \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{OL}}}{\mathrm{lOL}}
\end{array}
$$

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for $t_{P Z H}$ test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2901C (DIP)

| Pin \# | Pin Label | Test Circuit | $\mathbf{R}_{1}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 8 | RAM $_{3}$ | A | 560 | 1 K |
| 9 | RAM $_{0}$ | A | 560 | 1 K |
| 11 | $\mathrm{~F}=0$ | C | 270 | - |
| 16 | $\mathrm{Q}_{3}$ | A | 560 | 1 K |
| 21 | $\mathrm{Q}_{0}$ | A | 560 | 1 K |
| 31 | $\mathrm{~F}_{3}$ | B | 620 | 3.9 K |
| 32 | G | B | 220 | 1.5 K |
| 33 | $\mathrm{C}_{\mathrm{n}}+4$ | B | 360 | 2.4 K |
| 34 | OVR | B | 470 | 3 K |
| 35 | P | B | 470 | 3 K |
| $36-39$ | $\mathrm{Y}_{0-3}$ | A | 220 | 1 K |




## LIFE TEST AND BURN-IN CIRCUIT FOR MILITARY CLASS B PARTS.



## (Contact Factory for Commercial Burn-in Conditions)

Figure 12.

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful.

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100's of millivolts momentarily.
4. Use extreme care in defining input levels for $A C$ tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled. AMD recommends using $V_{\mathrm{IL}} \leqslant O \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

For additional information on testing, see section
''Guidelines on Testing Am2900 Family Devices'
in the Bipolar Microprocessor Logic and Interface Data Book.

## Am2902A

High-Speed Look-Ahead Carry Generator

## DISTINCTIVE CHARACTERISTICS

- Provides look-ahead carries across a group of four Am2901 or Am2903 microprocessor ALU's
- Capability of multi-level look-ahead for high-speed arithmetic operation over large word lengths
- Typical carry propagation delay of 4.5 ns


## GENERAL DESCRIPTION

The Am2902A is a high-speed, look-ahead carry generator which accepts up to four pairs of carry propagate and carry generate signals and a carry input and provides anticipated carries across four groups of binary ALU's. The device also has carry propagate and carry generate outputs which may be used for further levels of look-ahead.

The Am2902A is generally used with the Am2901 bipolar microprocessor unit to provide look-ahead over word lengths of more than four bits. The look-ahead carry generator can be used with binary ALU's in an active LOW
or active HIGH input operand mode by reinterpreting the carry functions. The connections to and from the ALU to the look-ahead carry generator are identical in both cases.

The logic equations provided at the outputs are:

$$
\begin{aligned}
C_{n+x} & =G_{0}+P_{0} C_{n} \\
C_{n+y} & =G_{1}+P_{1} G_{0}+P_{1} P_{0} C_{n} \\
C_{n+z} & =G_{2}+P_{2} G_{1}+P_{2} P_{1} G_{0}+P_{2} P_{1} P_{0} C_{n} \\
G & =G_{3}+P_{3} G_{2}+P_{3} P_{2} G_{1}+P_{3} P_{2} P_{1} G_{0} \\
P & =P_{3} P_{2} P_{1} P_{0}
\end{aligned}
$$

| Part No. | Description |
| :--- | :--- |
| Am2901 | 4-Bit Microprocessor Slice |
| Am2903 | 4-Bit Microprocessor Slice |
| Am29203 | Improved 2903 |
| Am29501 | Multiport Pipelined Processor |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Am2902A |  |
| :---: | :---: |
| Device Typ <br> Look-Ah | Generator |

Look-Ahead Carry Generator


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | $1 / 0$ | Description |
| ${ }^{13}$ | ${ }^{c_{n}}$ | 1 | Carry-in. The carry-in input to the look-ahead generator. Also the carry-in input to the nth Am2901 microprocessor ALU input. |
| 12, 11, 9 | $c_{n+1}$ | - |  microprocessor ALU slices. |
| ${ }^{12-6,14,15}$ | $\overline{\sigma_{i} \overline{p_{i}}}$ | 1 | Generate and propagate inputs respectively ( $i=0,1,2,3$ ). The carry generate and carry propagate inputs from the $n$ $\mathrm{n}+1, \mathrm{n}+2$ and $\mathrm{n}+3$ microprocessor ALU slices |
| 10, 7 | ब, ¢ | - | Generate and propagate outputs respectively. The carry generate and carry propagate outputs that can be used with the next higher level of carry look-ahead if used. |

## TRUTH TABLE



H = HIGH Voltage Level
L $=$ LOW Voltage Level
X = Don't Care


AF001331

## 16-BIT CARRY LOOK-AHEAD CONNECTION.



32-BIT ALU, THREE LEVEL CARRY LOOK-AHEAD.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature
....................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature with
Applied Powers ............................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ......................................-0.5V to +7.0V
DC Voltage Applied to Outputs For
High Output State
-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage.. .. -0.5 V to +5.5 V
DC Output Current, Into Outputs ............. 30 mA
DC Input Current .............................. -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vor | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-1 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{\text {IL }} \end{aligned}$ | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  | COM | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N, I_{0}=20 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all <br> inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for allinputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \operatorname{liN}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| IL | Input LOW Current | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=0.5 \mathrm{~V}$ | $\mathrm{C}_{n}$ |  |  | -2 | mA |
|  |  |  | $\bar{P}_{3}$ |  |  | -4 |  |
|  |  |  | $\overline{\mathrm{P}}_{2}$ |  |  | -6 |  |
|  |  |  | $\overline{\mathrm{P}}_{0}, \overline{\bar{P}}_{1}, \overline{\mathrm{G}}_{3}$ |  |  | -8 |  |
|  |  |  | $\overline{\mathrm{G}}_{0}, \overline{\mathrm{G}}_{2}$ |  |  | -14 |  |
|  |  |  | $\overline{\mathrm{G}}_{1}$ |  |  | -16 |  |
| $\mathrm{IH}_{\mathrm{H}}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ | $\mathrm{C}_{\mathrm{n}}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\bar{P}_{3}$ |  |  | 100 |  |
|  |  |  | $\overline{\mathrm{P}}_{2}$ |  |  | 150 |  |
|  |  |  | $\overline{\mathrm{P}}_{0}, \overline{\overline{1}}_{1}, \overline{\mathrm{G}}_{3}$ |  |  | 200 |  |
|  |  |  | $\overline{\mathrm{G}}_{0}, \overline{\mathrm{G}}_{2}$ |  |  | 350 |  |
|  |  |  | $\overline{\mathrm{G}}_{1}$ |  |  | 400 |  |
| 11 | Input HIGH Current | $V_{C C}=$ MAX, $V_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Isc | Output Short Circuit (Note 3) | $V_{\text {CC }}=$ MAX, $V_{\text {OUT }}=0.0 \mathrm{~V}$ |  | -40 |  | -100 | mA |
| Icc | Power Supply Current | $\begin{aligned} & V_{C C}=\text { MAX } \\ & \text { All Outputs LOW } \end{aligned}$ | MIL |  | 69 | 99 | mA |
|  |  |  | COM'L |  | 69 | 109 |  |
|  |  | $V_{C C}=M A X$ <br> All Outputs HIGH | MIL |  | 35 |  | mA |
|  |  |  | COM'L |  | 35 |  |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpl | $C_{n}$ to $C_{n+x}, C_{n+y}$, or $C_{n+z}$ | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =280 \Omega \end{aligned}$ |  | 6.5 | - 10 | ns |
| tPHL |  |  |  | 7 | 10.5 |  |
| tPLH | $\bar{P}_{i}$ or $\bar{G}_{j}$ to $C_{n+x}, C_{n+y}$, or $C_{n+z}$ |  |  | 4.5 | 7 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 4.5 | 7 |  |
| tpLH | $\bar{P}_{i}$ or $\bar{G}_{i}$ to $\bar{G}$ |  |  | 5 | 7.5 | ns |
| tPHL |  |  |  | 7 | 10.5 |  |
| tPLH | $\bar{P}_{i}$ to $\bar{P}$ |  |  | 4.5 | 6.5 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 6.5 | 10 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMM | CIAL | MIL | ARY | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2902A |  | Am2902A |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tpLH | $C_{n}$ to $C_{n+x}, C_{n+y}$ or $C_{n+z}$ | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & R_{L}=280 \Omega \end{aligned}$ |  | 13 |  | 15 | ns |
| tPHL |  |  |  | 14 |  | 16.5 | ns |
| tplH | $\bar{P}_{i}$ or $\bar{G}_{i}$ to $C_{n+x}, C_{n+y}$, or $C_{n+z}$ |  |  | 8 |  | 9.5 | ns |
| $t_{\text {PHL }}$ |  |  |  | 9 |  | 11.5 | ns |
| tplH | $\bar{P}_{i}$ or $\bar{G}_{i}$ to $\bar{G}$ |  |  | 12 |  | 16.5 | ns |
| tPHL |  |  |  | 12 |  | 13.5 | ns |
| tPLH | $\bar{P}_{i}$ to $\bar{P}$ |  |  | 9.5 |  | 11.5 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 11 |  | 12 | ns |

[^5]
## Am2903A

Four-Bit Bipolar Microprocessor Slice

## DISTINCTIVE CHARACTERISTICS

- Expandable Register File -

The Am2903A includes the necessary 'hooks' to expand the register file externally to any number of registers.

- Built-in Parity Generation and Sign Extension Circuitry Can supply parity across the entire ALU output and provide sign extension at any slice boundary.
- Built-in Division Logic -

Executes non-restoring, multiple-length division with correction of the quotient.

- Built-in Normalization Logic -

The mantissa and exponent of a floating-point number can be developed using a single microcycle per shift. Status flags indicate when the operation is complete.

- Built-in Multiplication and Division Logic Performs unsigned multiplication, two's complement multiplication and the last cycle of a two's complement multiplication.


## GENERAL DESCRIPTION

The Am2903A is a four-bit expandable bipolar microprocessor slice. The Am2903A performs all functions performed by the industry standard Am2901 and, in addition, provides a number of significant enhancements that are especially useful in arithmetic-oriented processors. Infinitely expandable memory and three-port, three-address architecture are
provided by the Am2903A. In addition to its complete arithmetic and logic instruction set, the Am2903A provides a special set of instructions which facilitate the implementation of multiplication, division, normalization, and other previously time-consuming operations. The Am2903A is identical to the Am2903A but up to $30 \%$ faster.


BD002784

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902A | Carry Look-Ahead Generator |
| Am2904 | Status and Shift Control Unit |
| Am2910A | Microprogram Controller |
| Am2914 | Vectored Priority Interrupt Controller |
| Am2918 | Pipeline Register |
| Am2920 | Octal Register |
| Am2922 | Condition Code MUX |
| Am2925 | System Clock Generator |
| Am2940 | DMA Address Generator |
| Am2952 | Bidirectional I/O Port |
| Am29705A | Two-Port RAM |
| Am27S35 | Registered PROM |



ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2903A | DC, DCB, DMB |
|  | FMB |
|  | LC, LMB |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


Device Type
Four-Bit Microprocessor Slice


## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{0-3}$ | 1 | Four RAM address inputs which contain the address of the RAM word appearing at the RAM A output port. |
|  | $\mathrm{B}_{0-3}$ | 1 | Four RAM address inputs which contain the address of the RAM word appearing at the RAM B output port and into which new data is written when the $\overline{W E}$ input and the CP input are LOW. |
| 37 | $\overline{W E}$ | 1 | The RAM write enable input. If $\overline{\text { WE }}$ is LOW, data at the $Y$ I/O port is written into the RAM when the CP input is LOW. When WE is HiGH, writing daia into the RAMM is inhibited. |
|  | DA0-3 | 1 | A four-bit external data input which can be selected as one of the Am2903A ALU operand sources; DA ${ }_{0}$ is the least significant bit. |
| 2 | EA | 1 | A control input which, when HIGH selects $D A_{0-3}$ as the ALU R operand, and, when LOW, selects RAM output A as the ALU R operand and the $\mathrm{DA}_{0-3}$ output data. |
|  | $\mathrm{DB}_{0-3}$ | I/O | A four-bit external data input/output. Under control of the $\overline{\mathrm{OE}_{\mathrm{B}}}$ input, RAM output port B can be directly read on these lines, or input data on these lines can be selected as the ALU S operand. |
| 31 | $\overline{\overline{O E}_{B}}$ | 1 | A control input which, when LOW, enables RAM output $B$ onto the $\mathrm{DB}_{0-3}$ lines and, when HIGH, disables the RAM output B tri-state buffers. |
| 10 | $\mathrm{C}_{\mathrm{n}}$ | 1 | The carry-in input to the Am2903A ALU. |
|  | 10-8 | 1 | The nine instruction inputs used to select the Am2903A operation to be performed. |
| 38 | IEN | 1 | The instruction enable input which, when LOW, allows the Q Register and the Sign Compare flip-flop to be written. When IEN is HIGH, the Q Register and Sign Compare flip-flop are in the hold mode. IEN also controls WRITE. |
| 11 | $\mathrm{C}_{n}+4$ | 0 | This output generally indicates the carry-out of the Am2903A ALU. Refer to Table 5 for an exact definition of this pin. |
| 14 | $\overline{\mathrm{G}} / \mathrm{N}$ | 0 | A multi-purpose pin which indicates the carry generate, $\bar{G}$, function at the least significant and intermediate slices, and generally indicates the sign, N , of the ALU result at the most significant slice. Refer to Table 5 for an exact definition of this pin. |
| 12 | $\overline{\text { P/OVR }}$ | 0 | A multi-purpose pin which indicates the carry propagate, $\overline{\mathrm{P}}$, function at the least significant and intermediate slices, and indicates the conventional two's complement overflow, OVR, signal at the most significant slice. Refer to Table 5 for an exact definition of this pin. |
| 22 | Z | 1/0 | An open-collector input/output pin which, when HIGH, generally indicates the outputs are all LOW. For some Special Functions, $\mathbf{Z}$ is used as an input pin. Refer to Table 5 for an exact definition of this pin. |
| 20, 21 | $\mathrm{SiO}_{0}$ $\mathrm{SIO}_{3}$ | 1/O | Bidirectional serial shift inputs/outputs for the ALU shifter. During a shift-up operation, $\mathrm{SIO}_{0}$ is an input and $\mathrm{SIO}_{3}$ an output. During a shift-down operation, $\mathrm{SIO}_{3}$ is an input and $\mathrm{SIO}_{0}$ is an output. Refer to Tables 3 and 4 for an exact definition of these pins. |
| 1, 48 | $\begin{array}{\|l} \mathrm{QIO}_{0} \\ \mathrm{QiO}_{3} \\ \hline \end{array}$ | I/O | Bidirectional serial shift inputs/outputs for the Q shifter which operate like $\mathrm{SIO}_{0}$ and $\mathrm{SIO}_{3}$. Refer to Tables 3 and 4 for an exact definition of these pins. |
| 39 | LSS | 1 | An input pin which, when tied LOW, programs the chip to act as the least significant slice (LSS) of an Am2903A array and enables the WRITE output onto the WRITE/MSS pin. When LSS is tied HIGH, the chip is programmed to operate as either an intermediate or most significant slice and the WRITE output buffer is disabled. |
| 40 | $\frac{\overline{\text { WRITE/ }}}{\mathrm{MSS}}$ | 1/0 | When [SS is tied LOW, the WRITE output signal appears at this pin; the WRITE signal is LOW when an instruction which writes data into the RAM is being executed. When LSS is tied HIGH, WRITE/MSS is an input pin; tying it HIGH programs the chip to operate as an intermediate slice (IS) and tying it LOW programs the chip to operate as the most significant slice (MSS). |
|  | $\mathrm{Y}_{0-3}$ | 1/0 | Four data inputs/outputs of the Am2903A. Under control of the $\overline{W_{Y}}$ input, the ALU shifter output data can be enabled onto these lines, or these lines can be used as data inputs when external data is written directly into the RAM. |
| 15 | $\overline{\text { OEY }}$ | 1 | A control input which, when LOW, enables the ALU shifter output data onto the $\mathrm{Y}_{0-3}$ lines and, when HIGH, disables the $\mathrm{Y}_{0-3}$ three-state output buffers. |
| 43 | CP | 1 | The clock input to the Am2903A. The Q Register and Sign Compare flip-flop are clocked on the LOW-to-HIGH transition of the CP signal. When enabled by $\overline{W E}$, data is written in the RAM when CP is LOW. |

## ARCHITECTURE OF THE Am2903A

The Am2903A is a high-performance, cascadable, four-bit bipolar microprocessor slice designed for use in CPU's, peripheral controllers, microprogrammable machines, and numerous other applications. The microinstruction flexibility of the Am2903A allows the efficient emulation of almost any digital computing machine. The nine-bit microinstruction selects the ALU sources, function and destination. The Am2903A is cascadable with full lookahead or ripple carry, has three-state outputs, and provides various ALU status flag outputs. Advanced Low-Power Schottky processing is used to fabricate this 48-pin LSI circuit.

All data paths within the device are four bits wide. As shown in the block diagram, the device consists of a 16 -word by 4 -bit, two-port RAM with latches on both output ports, a highperformance ALU and shifter, a multi-purpose Q Register with shifter input, and a nine-bit instruction decoder.

## Two-Port RAM

Any two RAM words addressed at the $A$ and $B$ address ports can be read simultaneously at the respective RAM $A$ and $B$
output ports. Identical data appear at the two output ports when the same address is applied to both address ports. The latches at the RAM output ports are transparent when the clock input, CP, is HIGH and they hold the RAM output data when CP is LOW. Under control of the $\overline{O E}_{B}$ three-state output enable, RAM data can be read directly at the Am2903A DB (I/O) port.

External data at the Am2903A Y I/O port can be written directly into the RAM, or ALU shifter output data can be enabled onto the Y I/O port and entered into the RAM. Data is written into the RAM at the B address when the write enable input, $\overline{W E}$, is LOW and the clock input, CP, is LOW.

## Arithmetic Logic Unit

The Am2903A high-performance ALU can perform seven arithmetic and nine logic operations on two 4-bit operands. Multiplexers at the ALU inputs provide the capability to select various pairs of ALU source operands. The $\overline{E_{A}}$ input selects either the DA external data input or RAM output port A for use as one $A L U$ operand and the $\overline{O_{B}}$ and $I_{0}$ inputs select RAM output port B, DB external data input, or the Q Register content for use as the second ALU operand. Also, during
some ALU operations, zeroes are forced at the ALU operand inputs. Thus, the Am2903A ALU can operate on data from two external sources, from an internal and external source, or from two internal sources. Table I shows all possible pairs of ALU source operands as a function of the $\overline{E_{A}}, \overline{O_{B}}$, and $I_{0}$ inputs.

When instruction bits $l_{4}, l_{3}, l_{2}, l_{1}$, and $l_{0}$ are LOW, the Am2903A executes special functions. Table 4 defines these special functions and the operation which the ALU performs for each. When the Am2903A executes instructions other than the nine special functions, the ALU operation is determined by instruction bits $\mathrm{I}_{4}, \mathrm{I}_{3}, \mathrm{I}_{2}$, and $\mathrm{I}_{1}$. Table 2 defines the ALU operation as a function of these four instruction bits.

## TABLE 1. ALU OPERAND SOURCES

| $\overline{\mathbf{E}_{\mathbf{A}}}$ | $\mathbf{I}_{\mathbf{0}}$ | $\overline{\mathbf{O E}_{\mathbf{B}}}$ | ALU Operand $\mathbf{R}$ | ALU Operand $\mathbf{S}$ |
| :---: | :---: | :---: | :---: | :---: |
| L | L | L | RAM Output A | RAM Output B |
| L | L | H | RAM Output A | DB $_{0-3}$ |
| L | H | X | RAM Output A | Q Register |
| H | L | L | DA |  |
| H | L | H | DA $_{0-3}$ | RAM Output $B$ |
| H | H | X | DA $_{0-3}$ | DB |

L=LOW $\quad H=$ HIGH $\quad X=$ Don't Care
TABLE 2. Am2903A ALU FUNCTIONS

| 14 | 13 | $\mathrm{I}_{2}$ | 11 | Hex Code | ALU FUNCTIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | L | 0 | $\mathrm{I}_{0}=\mathrm{L}$ Special Functions |
|  |  |  |  |  | $\begin{array}{ll}\mathrm{I}_{0}=\mathrm{H} & \mathrm{F}_{\mathrm{i}}=\mathrm{HIGH}\end{array}$ |
| L | L | L | H | 1 | F = S Minus R Minus 1 plus $\mathrm{C}_{\mathrm{n}}$ |
| L | L | H | L | 2 | $\mathrm{F}=\mathrm{R}$ Minus S Minus 1 Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | L | H | H | 3 | $\mathrm{F}=\mathrm{R}$ Plus S Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | L | L | 4 | $F=S$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | L | H | 5 | $\mathrm{F}=\overline{\mathrm{S}}$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | H | L | 6 | $F=R$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | H | H | 7 | $\mathrm{F}=\overline{\mathrm{R}}$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| H | L | L | L | 8 | $\mathrm{F}_{\mathrm{i}}=$ LOW |
| H | L | L | H | 9 | $\mathrm{F}_{\mathrm{I}}=\overline{\mathrm{R}}_{\mathrm{i}}$ AND $\mathrm{S}_{\mathrm{i}}$ |
| H | L | H | L | A | $F_{i}=R_{i}$ EXCLUSIVE NOR $S_{i}$ |
| H | L | H | H | B | $F_{1}=R_{i}$ EXCLUSIVE OR $S_{i}$ |
| H | H | L | L | C | $F_{i}=R_{i}$ AND $S_{i}$ |
| H | H | L | H | D | $F_{i}=R_{i}$ NOR $S_{i}$ |
| H | H | H | L | E | $F_{i}=R_{i}$ NAND $S_{i}$ |
| H | H | H | H | F | $\mathrm{F}_{\mathrm{i}}=\mathrm{R}_{\mathrm{i}}$ OR $\mathrm{S}_{\mathrm{i}}$ |

Am2903As may be cascaded in either a ripple carry or lookahead carry fashion. When a number of Am2903As are cascaded, each slice must be programmed to be a most significant slice (MSS), intermediate slice (IS), or least significant slice (LSS) of the array. The carry generate, G, and carry propagate, P , signals required for a lookahead carry scheme
are generated by the Am2903A and are available as outputs of the least significant and intermediate slices.
The Am2903A also generates a carry-out signal, $\mathrm{C}_{\mathrm{n}}+4$, which is generally available as an output of each slice. Both the carry-in, $C_{n}$, and carry-out, $C_{n+4}$, signals are active HIGH. The ALU generates two other status outputs. These are negative, $N$, and overflow, OVR. The $N$ output is generally the most significant (sign) bit of the ALU output and can be used to determine positive or negative results. The OVR output indicates that the arithmetic operation being performed exceeds the available two's complement number range. The N and OVR signals are available as outputs of the most significant slice. Thus, the multipurpose $\bar{G} / \mathrm{N}$ and $\overline{\mathrm{P}} /$ OVR outputs indicate $\bar{G}$ and $\overline{\mathrm{P}}$ at the least significant and intermediate slices, and sign and overflow at the most significant slice. To some extent, the meaning of the $\mathrm{C}_{\mathrm{n}}+4, \overline{\mathrm{P}} /$ OVR, and $\overline{\mathrm{G}} / \mathrm{N}$ signals vary with the ALU function being performed. Refer to Table 5 for an exact definition of these four signals as a function of the Am2903A instruction.

## ALU Shifter

Under instruction control, the ALU shifter passes the ALU output (F) non-shifted, shifts it up one bit position (2F), or shifts it down one bit position (F/2). Both arithmetic and logical shift operations are possible. An arithmetic shift operation shifts data around the most significant (sign) bit position of the most significant slice, and a logical shift operation shifts data through this bit position (see Figure A). $\mathrm{SIO}_{0}$ and $\mathrm{SIO}_{3}$ are bidirectional serial shift inputs/outputs. During a shift-up operation, $\mathrm{SIO}_{0}$ is generally a serial shift input and $\mathrm{SIO}_{3}$ a serial shift output. During a shift-down operation, $\mathrm{SIO}_{3}$ is generally a serial shift input and $\mathrm{SIO}_{0}$ a serial shift output.
To some extent, the meaning of the $\mathrm{SiO}_{0}$ and $\mathrm{SiO}_{3}$ signals is instruction dependent. Refer to Tables 3 and 4 for an exact definition of these pins.

The ALU shifter also provides the capability to sign extend at slice boundaries. Under instruction control, the $\mathrm{SIO}_{0}$ (sign) input can be extended through $Y_{0}, Y_{1}, Y_{2}, Y_{3}$ and propagated to the $\mathrm{SIO}_{3}$ output.

A cascadable, five-bit parity generator/checker is designed into the Am2903A ALU shifter and provides ALU error detection capability. Parity for the $\mathrm{F}_{0}, \mathrm{~F}_{1}, \mathrm{~F}_{2}, \mathrm{~F}_{3}$ ALU outputs and $\mathrm{SiO}_{3}$ input is generated and, under instruction control, is made available at the $\mathrm{SIO}_{0}$ output. Refer to the Am2903A applications section for a more detailed description of the Am2903A sign extension and parity generation/checking capability.

The instruction inputs determine the ALU shifter operation. Table 4 defines the special functions and the operation the ALU shifter performs for each. When the Am2903A executes instructions other than the special functions, the ALU shifter operation is determined by instruction bits $\mathrm{I}_{8}, \mathrm{I}_{7}, \mathrm{I}_{6}, \mathrm{I}_{5}$. Table 3 defines the ALU shifter operation as a function of these four bits.

## Q Register

The Q Register is an auxiliary four-bit register which is clocked on the LOW-to-HIGH transition of the CP input. It is intended primarily for use in multiplication and division operations; however, it can also be used as an accumulator or holding register for some applications. The ALU output, F, can be loaded into the Q Register, and/or the Q Register can be selected as the source for the ALU S operand. The shifter at the input to the $Q$ Register provides the capability to shift the $Q$ Register contents up one bit position (2Q) or down one bit position ( $\mathrm{Q} / 2$ ). Only logical shifts are performed. $\mathrm{QlO}_{0}$ and $\mathrm{QiO}_{3}$ are bidirectional shift serial inputs/outputs. During a Q

Register shift-up operation, $\mathrm{QIO}_{0}$ is a serial shift input and $\mathrm{QOO}_{3}$ is a serial shift output. During a shift-down operation, $\mathrm{QO}_{3}$ is a serial shift input and $\mathrm{QIO}_{0}$ is a serial shift output.

Figure A.
Am2903A Arithmetic Shift Path


## Am2903A Logical Shift Path



## DF000420

Double-length arithmetic and logical shifting capability is provided by the Am2903A. The double-length shift is performed by connecting $\mathrm{QIO}_{3}$ of the most significant slice to $\mathrm{SIO}_{0}$ of the least significant slice, and executing an instruction which shifts both the ALU output and the Q Register.

The Q Register and shifter are controlled by the instruction inputs. Table 4 defines the Am2903A special functions and the operations which the Q Register and shifter perform for each. When the Am2903A executes instructions other than the special functions, the Q Register and shifter operation is controlled by instruction bits $I_{8}, I_{7}, I_{6}, I_{5}$. Table 3 defines the $Q$ Register and shifter operation as a function of these four bits.

## Output Buffers

The DB and Y ports are bidirectional I/O ports driven by threestate output buffers with external output enable controls. The Y output buffers are enabled when the $\overline{\mathrm{OE}}$ Y input is LOW and are in the high impedance state when OEY is HIGH. The DB output buffers are enabled when the $\overline{O E_{B}}$ input is LOW.

TABLE 3. ALU DESTINATION CONTROL FOR $\mathrm{l}_{0} O R \mathrm{l}_{1} O R \mathrm{I}_{2} O R \mathrm{l}_{3}=\mathrm{HIGH}, \overline{\mathrm{EN}}=\mathrm{LOW}$.

| $\begin{array}{lllll}l_{8} & l_{7} & l_{6} & l_{5}\end{array}$ | Hex <br> Code | ALU Shifter Function | $\mathrm{SIO}_{3}$ |  | $\mathrm{Y}_{3}$ |  | $\mathrm{Y}_{2}$ |  | $\mathrm{Y}_{1}$ | $Y_{0}$ | $\mathrm{SIO}_{0}$ | Write | Q Reg \& Shifter Function | $\mathrm{ClO}_{3}$ | $\mathbf{Q l O}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{gathered} \text { Most Sig } \\ \text { Slice } \end{gathered}$ | Other Slices | $\begin{gathered} \text { Most Sig } \\ \text { Slice } \end{gathered}$ | Other Slices | $\begin{array}{\|l} \text { Most Sig } \\ \text { Slice } \end{array}$ | Other Slices |  |  |  |  |  |  |  |
| L L L L | 0 | Arith. F/2 $\rightarrow$ Y | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{SiO}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | Hi-Z |
| $L L L H$ | 1 | Log. $F / 2 \rightarrow Y$ | Input | Input | $\mathrm{SIO}_{3}$ | $\mathrm{SiO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $F_{1}$ | Fo | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | Hi-Z |
| L L H L | 2 | Arith. F/2 $\rightarrow$ Y | Input | Input | $F_{3}$ | $\mathrm{SiO}_{3}$ | $\mathrm{SIO}_{3}$ | $F_{3}$ | $F_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | L | $\operatorname{log.~}_{2 \rightarrow Q} \text { Q/ }$ | Input | $Q_{0}$ |
| L L H H | 3 | Log. F/2 $\rightarrow$ Y | Input | Input | $\mathrm{SIO}_{3}$ | $\mathrm{SIO}_{3}$ | $F_{3}$ | $F_{3}$ | $F_{2}$ | $F_{1}$ | $F_{0}$ | L | $\operatorname{log.~}_{2 \rightarrow Q}$ | Input | $Q_{0}$ |
| L HLL | 4 | $\mathrm{F} \rightarrow \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $F_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Parity | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | Hi-Z |
| L H L H | 5 | $\mathrm{F} \rightarrow \mathrm{Y}$ | Input | Input | $F_{3}$ | $F_{3}$ | $F_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{0}$ | Parity | H | $\log _{2 \rightarrow Q}^{\text {Log }} \text { Q/ }$ | Input | $Q_{0}$ |
| L H H L | 6 | $\mathrm{F} \rightarrow \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Parity | H | $\mathrm{F} \rightarrow \mathrm{Q}$ | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ |
| L H H H | 7 | $\mathrm{F} \rightarrow \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Parity | L | $F \rightarrow Q$ | Hi-Z | Hi-Z |
| H L L L | 8 | Arith. $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{1}$ | $F_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | Hi-Z | $\mathrm{Hi}-\mathrm{Z}$ |
| H L L H | 9 | Log. $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{1}$ | $\mathrm{F}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | Hi-Z | Hi-Z |
| H L H L | A | Arith. $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{2}$ | $F_{3}$ | $F_{3}$ | $F_{2}$ | $F_{1}$ | $F_{1}$ | Fo | $\mathrm{SIO}_{0}$ | Input | L | $\underset{2 Q \rightarrow Q}{\text { Log. }_{\text {P }}}$ | $Q_{3}$ | Input |
| H L H H | B | Log. $2 F \rightarrow Y$ | $\mathrm{F}_{3}$ | $F_{3}$ | $\mathrm{F}_{2}$ | $F_{2}$ | $F_{1}$ | $F_{1}$ | Fo | $\mathrm{SIO}_{0}$ | Input | L | $\begin{aligned} & \log _{.} \\ & 2 Q \rightarrow Q \end{aligned}$ | $Q_{3}$ | Input |
| H H L L | C | $F \rightarrow Y$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | Hi-Z | H | Hold | Hi-Z | Hi-Z |
| H H L H | D | $F \rightarrow Y$ | $F_{3}$ | $F_{3}$ | $F_{3}$ | $\mathrm{F}_{3}$ | $F_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | F0 | Hi-Z | H | $\begin{aligned} & \text { Log. } \\ & 2 \mathrm{Q} \rightarrow \mathrm{Q} \end{aligned}$ | $Q_{3}$ | Input |
| H H H L | E | $\begin{aligned} & \mathrm{SIO}_{0} \rightarrow \mathrm{Y}_{0} \\ & \mathrm{Y}_{1}, \mathrm{Y}_{2}, \mathrm{Y}_{3} \end{aligned}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | Hi-Z |
| H HHH | F | $\mathrm{F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | Hi-Z | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | Hi-Z |
| $\begin{aligned} & \text { Parity }=\mathrm{F}_{3} \nabla \mathrm{~F}_{2} \nabla \mathrm{~F}_{1} \nabla \mathrm{~F}_{0} \nabla \mathrm{SIO}_{3} \\ & \nabla=\text { Exclusive OR } \end{aligned}$ |  |  |  | $\begin{aligned} & L=L O W \\ & H=H I G H \end{aligned}$ |  |  | Hi-Z $=$ High Impedance |  |  |  |  |  |  |  |  |

TABLE 4. SPECIAL FUNCTIONS FOR $I_{4}=I_{3}=I_{2}=I_{1}=I_{0}=$ LOW (Note 4)

| $\begin{gathered} \text { (Hex) } \\ \mathrm{I}_{8} \mathrm{I}_{7} \mathrm{I}_{6} \mathrm{I}_{5} \end{gathered}$ | Special Function | ALU Function | ALU Shifter Function | $\mathrm{SIO}_{3}$ |  | $\mathrm{SIO}_{0}$ | Q Reg \& Shifter Function | $\mathrm{QlO}_{3}$ | Q1O0 | WRITE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Most Sig Slice | Other Slices |  |  |  |  |  |
| 0 | Unsigned Multiply | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=R+S+C_{n} \text { if } Z=H \end{aligned}$ | $\begin{array}{\|l\|} \hline \log F / 2 \rightarrow Y \\ \text { (Note 1) } \\ \hline \end{array}$ | Hi-Z | Input | Fo | $\underset{\rightarrow Q}{\log Q / 2}$ | Input | $Q_{0}$ | L |
| 1 | (Note 5) |  |  |  |  |  |  |  |  |  |
| 2 | Two's Complement Multiply | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=R+S+C_{n} \text { if } Z=H \end{aligned}$ | $\begin{aligned} & \begin{array}{l} \log F / 2 \rightarrow Y \\ \text { Note 2) } \end{array} \\ & \hline \end{aligned}$ | $\mathrm{Hi}-\mathrm{Z}$ | input | F0 | $\underset{\rightarrow Q}{\log Q / 2}$ | Input | $Q_{0}$ | L |
| 3 | (Note 5) |  |  |  |  |  |  |  |  |  |
| 4 | Increment by One or Two | $F=S+1+C_{n}$ | $F \rightarrow Y$ | Input | Input | Parity | Hold | Hi-Z | Hi-Z | L |
| 5 | Sign/Magnitude Two's Complement | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=S+C_{n} \text { if } Z=H \end{aligned}$ | $\begin{aligned} & F \rightarrow Y \\ & \text { (Note 3) } \\ & \hline \end{aligned}$ | Input | Input | Parity | Hold | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ | L |
| 6 | Two's Complement Multiply, Last Cycle | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $\begin{aligned} & \begin{array}{l} \log F / 2 \rightarrow Y \\ \text { (Note 2) } \end{array} \end{aligned}$ | $\mathrm{Hi}-\mathrm{Z}$ | Input | F0 | $\log _{\rightarrow \mathrm{Q}}^{\mathrm{Q} / 2}$ | Input | $Q_{0}$ | L |
| 7 | (Note 5) |  |  |  |  |  |  |  |  |  |
| 8 | Single Length Normalize | $F=S+C_{n}$ | $F \rightarrow Y$ | $F_{3}$ | $F_{3}$ | $\mathrm{Hi}-\mathrm{Z}$ | $\underset{\substack{\log 2 Q}}{\substack{2}}$ | $Q_{3}$ | Input | L |
| 9 | (Note 5) |  |  |  |  |  |  |  |  |  |
| A | Double Length Normalize and First Divide Op | $F=S+C_{n}$ | $\log 2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{R}_{3} \vee \mathrm{~F}_{3}$ | $F_{3}$ | Input | $\underset{\rightarrow Q}{\log 2 Q}$ | $Q_{3}$ | Input | L |
| B | (Note 5) |  |  |  |  |  |  |  |  |  |
| C | Two's Complement Divide | $\begin{aligned} & F=S+R+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $\log 2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\overline{R_{3} \nabla F}$ | $F_{3}$ | Input | $\underset{\sim}{\log 2 Q}$ | $Q_{3}$ | Input | L |
| D | (Note 5) |  |  |  |  |  |  |  |  |  |
| $E$ | Two's Complement Divide Correction and Remainder | $\begin{aligned} & F=S+R+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $F \rightarrow Y$ | $F_{3}$ | $F_{3}$ | $\mathrm{Hi}-\mathrm{Z}$ | $\underset{\rightarrow Q}{\log 2 Q}$ | $Q_{3}$ | Input | L |
| F | (Note 5) |  |  |  |  |  |  |  |  |  |

Notes: 1. At the most significant slice only, the $C_{n+4}$ signal is internally gated to the $Y_{3}$ output.
2. At the most significant slice only, $F_{3} \nabla$ OVR is internally gated to the $Y_{3}$ output.
3. At the most significant slice only, $S_{3} \nabla F_{3}$ is generated at the $Y_{3}$ output.
4. The Q Register cannot be used explicitly as an operand for any Special Functions. It is defined implicitly within the functions.
5. Not valid.

| $L=$ LOW | Hi-Z | $=$ High Impedance |
| :--- | :--- | :--- |
| $H=H I G H$ | $\nabla$ | $=$ Exclusive OR |
| $X=$ Don't Care | Parity | $=$ SIO $_{3} \nabla F_{3} \nabla F_{2} \nabla F_{1} \nabla F_{0}$ |

The zero, $Z$, pin is an open collector input/output that can be wire-OR'ed between slices. As an output it can be used as a zero detect status flag and generally indicates that the $\mathrm{Y}_{0-3}$ pins are all LOW. To some extent the meaning of this signal varies with the instruction being performed. Refer to Table 5 for an exact definition of this signal as a function of the Am2903A instructions.

## Instruction Decoder

The Instruction Decoder generates required internal control signals as a function of the nine instruction inputs, $\mathrm{I}_{0-8}$; the Instruction Enable input, IEN; the LSS input; and the WRITE/ MSS input/output.

The WRITE output is LOW when an instruction which writes data into the RAM is being executed. Refer to Tables 3 and 4 for a definition of the WRITE output as a function of the Am2903A instruction inputs.

On the Am2903A, when IEN is HIGH, the WRITE output is forced HIGH and the Q Register and Sign Compare Flip-Flop contents are preserved. When IEN is LOW, the WRITE output is enabled and the Q Register and Sign Compare Flip-Flop can be written according to the Am2903A instruction. The Sign Compare Flip-Flop is an on-chip flip-flop which is used during an Am2903A divide operation (see Figure B).

## Programming the Am2903A Slice Position

Tying the $\overline{\text { LSS }}$ input LOW programs the slice to operate as a least significant slice (LSS) and enables the WRITE output signal onto the $\overline{\text { WRITE }} / \overline{M S S}$ bidirectional I/O pin. When $\overline{L S S}$ is tied HIGH, the $\overline{W R I T E} / \overline{M S S}$ pin becomes an input pin; tying the $\overline{\text { WRITE }} / \overline{\mathrm{MSS}}$ pin HIGH programs the slice to operate as an intermediate slice (IS) and tying it LOW programs the slice to operate as a most significant slice (MSS). The WRITE/MSS pin must be tied HIGH through a resistor. $\overline{\text { WRITE }} / \overline{M S S}$ and $\overline{\mathrm{LSS}}$ should not be connected together.

## TABLE 5. Am2903A STATUS OUTPUTS

| (Hex) <br> $\mathrm{I}_{8} \mathrm{I}_{7} \mathrm{I}_{6} \mathrm{I}_{5}$ | $\begin{gathered} (H e x) \\ 1_{4} I_{3} I_{2} I_{1} \end{gathered}$ | $\mathrm{I}_{0}$ | $\begin{gathered} \text { Gi } \\ (1=0 \text { to } 3) \end{gathered}$ | $\begin{gathered} P i \\ (i=0 \text { to } 3) \end{gathered}$ | $C_{n+4}$ | $\overline{\text { P/OVR }}$ |  | $\overline{\mathbf{G}} / \mathbf{N}$ |  | $\mathbf{Z}\left(\overline{O E}_{Y}=\right.$ LOW $)$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | Most Sig Slice | Other <br> Slices | Most Sig Slice | Other Slices | Most Sig Slice | Intermediate Slice | Least Sig Slice |
| X | 0 | H | 0 | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 1 | X | $\bar{R}_{i} \wedge \mathrm{~S}_{\mathrm{i}}$ | $\overline{R_{i}} \vee S_{i}$ | $\begin{aligned} & \hline \begin{array}{l} G v \\ P C_{n} \end{array} \end{aligned}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}$ | $\overline{\mathbf{P}}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 2 | X | $\mathrm{R}_{\mathrm{i}} \wedge \bar{S}_{\mathbf{i}}$ | $\mathrm{R}_{\mathbf{i}} \vee \bar{S}_{\mathbf{i}}$ | $\begin{array}{\|l\|l\|} \hline G v \\ P C_{n} \end{array}$ | $\begin{aligned} & C_{n+3}{ }^{\nabla} \\ & C_{n+4} \\ & \hline \end{aligned}$ | $\overline{\text { P }}$ | $F_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 3 | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \mathrm{S}_{\mathrm{i}}$ | $\begin{aligned} & \hline \mathrm{Gv} \\ & \mathrm{PC} \\ & \hline \end{aligned}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \\ & \hline \end{aligned}$ | $\overline{\mathbf{P}}$ | $F_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 4 | X | 0 | $S_{i}$ | $\begin{aligned} & \hline \mathrm{G} v \\ & \mathrm{PC} \mathrm{C}_{\mathrm{n}} \\ & \hline \end{aligned}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \\ & \hline \end{aligned}$ | $\overline{\mathrm{P}}$ | $F_{3}$ | $\overline{\mathrm{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{4} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 5 | X | 0 | $\bar{s}_{i}$ | $\begin{aligned} & \hline \mathrm{Gv} \\ & \mathrm{PC}_{\mathrm{n}} \end{aligned}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}$ | $\overline{\text { P }}$ | F3 | $\overline{\mathrm{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 6 | X | 0 | $\mathrm{R}_{\mathrm{i}}$ | $\begin{array}{\|l\|l} \hline \mathrm{G} v \\ P C_{n} \\ \hline \end{array}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}$ | $\overline{\text { P }}$ | $F_{3}$ | G | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 7 | X | 0 | $\bar{R}_{i}$ | $\begin{aligned} & \hline \mathrm{G} v \\ & P C_{n} \end{aligned}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}$ | $\overline{\text { P }}$ | $F_{3}$ | $\underline{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 8 | X | 0 | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | 9 | X | 硡^ $\mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | A | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $R_{i} \vee S_{i}$ | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | B | X | $\overline{\bar{R}}_{i} \wedge S_{i}$ | $R_{i} \vee S_{i}$ | 0 | 0 | 0 | $F_{3}$ | $\overline{\mathrm{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | C | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathbf{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | D | X | $\overline{\mathrm{R}}_{\mathrm{i}} \wedge \bar{S}_{i}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | E | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| X | F | X | $\bar{R}_{i} \wedge \bar{S}_{i}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | G | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{\gamma}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| 0 | 0 | L | $\left\lvert\, \begin{aligned} & 0 \text { if } Z=L \\ & R_{i} \wedge S_{i} \text { if } Z=H \end{aligned}\right.$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \end{aligned}$ | $\left\lvert\, \begin{aligned} & \mathrm{G} v \\ & P C_{n} \end{aligned}\right.$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}$ | $\overline{\mathrm{P}}$ | $F_{3}$ | $\overline{\mathbf{G}}$ | Input | Input | $Q_{0}$ |
| 1 | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| 1 | 8 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| 2 | 0 | L | $\left\lvert\, \begin{aligned} & 0 \text { if } Z=L \\ & R_{i} \wedge S_{i} \text { if } Z=H \end{aligned}\right.$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \end{aligned}$ | $\mathrm{CG}_{\mathrm{P}}^{\mathrm{G} v}$ | $\left\lvert\, \begin{aligned} & C_{n+3} \nabla . \\ & C_{n+4} \end{aligned}\right.$ | $\overline{\mathbf{P}}$ | $F_{3}$ | $\mathbf{G}$ | Input | Input | $Q_{0}$ |
| 3 | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| 4 | 0 | L | (Note 1) | (Note 2) | $\begin{array}{\|l} \hline \mathrm{G} v \\ \mathrm{PC}_{n} \\ \hline \end{array}$ | $\begin{aligned} & C_{n+3} \cdot \\ & C_{n+4} \\ & \hline \end{aligned}$ | $\overline{\text { P }}$ | $\mathrm{F}_{3}$ | G | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\bar{Y}_{0} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ |
| 5 | 0 | L | 0 | $\begin{aligned} & S_{i} \text { if } Z=L \\ & S_{i} \text { if } Z=H \end{aligned}$ | $\left.\right\|_{P C_{n}} ^{G}$ | $\left\lvert\, \begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}\right.$ | $\overline{\mathbf{P}}$ | $\begin{gathered} F_{3} \text { if } Z=L \\ F_{3} \nabla S_{3} \text { if } \\ Z=H \end{gathered}$ | G | $S_{3}$ | Input | Input |
| 6 | 0 | L | $\frac{0}{\bar{R}_{i}} \text { if } Z=L=L=H$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \end{aligned}$ | $\begin{array}{\|l\|} \hline G v \\ P C_{n} \\ \hline \end{array}$ | $\begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \\ & \hline \end{aligned}$ | $\overline{\mathbf{P}}$ | $F_{3}$ | G | Input | Input | $Q_{0}$ |
| 7 | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| 8 | 0 | L | 0 | $S_{i}$ | (Note 3) | $\mathrm{Q}_{2} \nabla \mathrm{Q}_{1}$ | $\overline{\bar{P}}$ | $\mathrm{Q}_{3}$ | $\bar{G}$ | $\bar{Q}_{0} \overline{\mathrm{Q}}_{1} \overline{\mathrm{Q}}_{2} \overline{\mathrm{Q}}_{3}$ | $\overline{\mathrm{Q}}_{0} \overline{\mathrm{Q}}_{1} \overline{\mathrm{Q}}_{2} \overline{\mathrm{Q}}_{3}$ | $\overline{\mathrm{Q}}_{0} \overline{\mathrm{Q}}_{1} \overline{\mathrm{Q}}_{2} \overline{\mathrm{Q}}_{3}$ |
| 9 | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| 9 | 8 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| A | 0 | L | 0 | $s_{i}$ | (Note 4) | $F_{2} \nabla F_{1}$ | $\overline{\mathbf{p}}$ | F3 | $\overline{\mathrm{G}}$ | (Note 5) | (Note 5) | (Note 5) |
| B | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| C | 0 | L | $\left\lvert\, \begin{aligned} & R_{i} \wedge S_{i} \text { if } Z=L \\ & R_{i} \wedge S_{i} \text { if } Z=H \end{aligned}\right.$ | $\begin{aligned} & R_{i} v S_{i} \text { if } \\ & Z=L L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \\ & \hline \end{aligned}$ | $\left\lvert\, \begin{aligned} & \mathrm{G} v \\ & P C_{n} \end{aligned}\right.$ | $\left\lvert\, \begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}\right.$ | $\overline{\mathbf{P}}$ | $F_{3}$ | $\overline{\mathbf{G}}$ | Sign Compare FF Output | Input | Input |
| D | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |
| $E$ | 0 | L | $\left\lvert\, \begin{aligned} & R_{i} \wedge S_{i} \text { if } Z=L \\ & R_{i} \wedge S_{i} \text { if } Z=H \end{aligned}\right.$ | $\begin{aligned} & R_{i} v S_{i} \text { if } \\ & Z=L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \end{aligned}$ | $\mathrm{GC}_{n} \mathrm{~V}$ | $\left\lvert\, \begin{aligned} & C_{n+3} \nabla \\ & C_{n+4} \end{aligned}\right.$ | $\overline{\mathbf{P}}$ | $F_{3}$ | $\overline{\mathbf{G}}$ | $\underset{\substack{\text { Sign } \\ \text { Compare FFut }}}{\text { Outp }}$ | Input | Input |
| F | 0 | L | (Note 6) |  |  |  |  |  |  |  |  |  |

Notes:1. If LSS is LOW, $G_{0}=S_{0}$ and $G_{1}, 2,3=0$. If LSS is HIGH, $G_{0}, 1,2,3=0$.
2. If $L S S$ is LOW, $P_{0}=1$ and $P_{1}, 2,3=S_{1}, 2$, 3. If LSS is HIGH, $P_{i}=S_{i}$.
3. At the most significant slice, $C_{n}+4=Q_{3} V_{2}$. At other slices, $C_{n}+4=G$ PC
3. At the most significant slice, $C_{n+4}=Q_{3} \vee Q_{2}$. At other slices, $C_{n}+4=G \vee P C_{n}$.
4. At the most significant slice, $C_{n}+4=F_{3} \nabla F_{2}$. At other slices, $C_{n+4}=G \vee P C_{n}$.
5. $Z=\bar{Q}_{0} \bar{Q}_{1} \bar{Q}_{2} \bar{Q}_{3} \bar{F}_{0} \bar{F}_{1} \bar{F}_{2} \bar{F}_{3}$.
6. Not valid.
$L=L O W=0$
$H=H I G H=1$
$\mathrm{v}=\mathrm{OR}$
$\hat{\nabla}=$ AND
$\nabla=E X C L U S I V E O R$
$P=P_{3} P_{2} P_{1} P_{0}$
$\begin{aligned} & C_{n+3}=G_{3} \vee \vee G_{2} P_{3} \vee G_{1} P_{2} \vee P_{2} P_{3} \vee G_{0} P_{1} P_{2} \vee P_{1} P_{2} P_{3} \\ & C_{n} P_{0} P_{1} P_{2}\end{aligned}$

## Am2903A SPECIAL FUNCTIONS

The Am2903A provides nine Special Functions which facilitate the implementation of the following operations:

- Single- and Double-Length Normalization
- Two's Complement Division
- Unsigned and Two's Complement Multiplication
- Conversion Between Two's Complement and Sign/Magnitude Representation
- Incrementation by One or Two

Table 4 defines these Special Functions.
The Single-Length and Double-Length Normalization functions can be used to adjust a single-precision or double-precision floating point number in order to bring its mantissa within a specified range.
Three Special Functions which can be used to perform a two's complement, non-restoring divide operation are provided by the Am2903A. These functions provide both single- and double-precision divide operations and can be performed in " $n$ " clock cycles, where " $n$ " is the number of bits in the quotient.

The Unsigned Multiply Special Function and the two Two's Complement Multiply Special Functions can be used to multiply two $n$-bit, unsigned or two's complement numbers, respectively, in $n$ clock cycles. These functions utilize the conditional add and shift algorithm. During the last cycle of the two's complement multiplication, a conditional subtraction, rather than addition, is performed because the sign bit of the multiplier carries negative weight.

The Sign/Magnitude-Two's Complement Special Function can be used to convert number representation systems. A number expressed in Sign/Magnitude representation can be converted to the Two's Complement representation, and vice-versa, in one clock cycle.

The Increment by One or Two Special Function can be used to increment an unsigned or two's complement number by one or two. This is useful in 16-bit word, byte-addressable machines, where the word addresses are multiples of two.

Refer to Am2903A applications section for a more detailed description of these Special Functions.

## CYCLE TIMES FOR 16-BIT SYSTEM FOR COMMON OPERATIONS

The illustration below shows a typical configuration using 4 Am2903A Superslices, an Am2902A carry lookahead chip, and the Am2904 for shift multiplexers, status registers, and carry-in control. For the system enclosed within the dashed lines, there are four major switching paths whose values for various kinds of cycles are summarized below, and shown on the timing waveform.

1. MICROCYCLE TIME (TCHCH).

The minimum time which must elapse between a LOW-TO-HIGH clock transition and the next LOW-TOHIGH clock transition.
2. DATA SET-UP TIME (TDVCH).

The minimum time which must be allowed between valid, stable data on the D inputs and the clock LOW-TO-HIGH transition.
3. D TO Y (TDVYV).

The maximum time required to obtain valid $Y$ output data after the D inputs are valid. This is the combinational delay through the parts from $D$ to $Y$.
4. CP TO Y (TCHYV).

The maximum time required to obtain valid $Y$ outputs after a clock LOW-TO-HIGH transition.

The types of cycles for which data is summarized are as
follows:

1. Logic - Any logical operation without a shift.
2. Logic Rotate - Any logic operation with a rotate or shift.
3. Arithmetic - An add or subtract with no shift.
4. Multiply - The first cycle of a 2 's complement multiply instruction. Subsequent cycles require less instruction. Subsequent cycles require less
time.
5. Divide - The iterative divide cycle. The first divide instruction and the last divide (correction) instruction require less time.

## Time in ns Over Commercial Operating Range

| CYCLE | TCHCH | TDVCH | TDVYV | TCHYV |
| :--- | :---: | :---: | :---: | :---: |
| LOGIC | 99 | 79 | 59 | 81 |
| LOGIC ROTATE | 118 | 99 | 79 | 98 |
| ARITHMETIC | 130 | 109 | 91 | 112 |
| MULTIPLY | 152 | 113 | 95 | 135 |
| DIVIDE | 139 | 113 | 95 | 121 |

Figure B. Sign Compare Flip-Flop


DF000400
The sign compare signal appears at the $Z$ output of the most significant slice during special functions C and E . Refer to Table 5.

16-Bit System with Am2903A, Am2902A, Am2904


Timing Waveforms for Data in, Clock, and Y Out


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$
DC Voltage Applied to Outputs For High Output State -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage. $\qquad$ $\ldots . .-0.5 \mathrm{~V}$ to +5.5 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | $\begin{aligned} & \mathrm{OH}=-1.6 \mathrm{~mA} \\ & \mathrm{Y}_{0}-\mathrm{Y}_{3}, \mathrm{G} / \mathrm{N} \end{aligned}$ | 2.4 |  |  |  |
|  |  |  |  | $\begin{aligned} & \mathrm{IOH}=-800 \mu \mathrm{~A} \\ & \mathrm{DB}_{0-3}, \overline{\mathrm{P} / O V R} \\ & \mathrm{SIO}_{0}, \mathrm{SIO}_{3}, \mathrm{QIO}_{0}, \mathrm{QIO}_{3}, \\ & \text { WRITE, } \mathrm{C}_{\mathrm{n}}+4 \\ & \hline \end{aligned}$ | 2.4 |  |  | Volts |
| ICEX | Output Leakage Current for Z Output (Note 4) | $\begin{aligned} & V_{C C}=M I N, V_{O H}=5.5 \mathrm{~V} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  |  | 250 | $\mu \mathrm{A}$ |
| 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}$ | $\begin{aligned} & Y_{0}, Y_{1}, Y_{2} \\ & Y_{3}, Z \end{aligned}$ | $1 \mathrm{OL}=20 \mathrm{~mA}$ (COM'L) |  |  |  | Volts |
|  |  |  |  | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ (MIL) |  |  | 0.5 |  |
|  |  |  | $\begin{aligned} & \mathrm{DB}_{0}, \mathrm{DB}_{1}, \\ & \mathrm{DB}_{2}, \mathrm{DB}_{3} \\ & \hline \end{aligned}$ | $\mathrm{I}^{\mathrm{OL}}=12 \mathrm{~mA}$ (COM'L) |  |  |  |  |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA}$ (MIL) |  |  | 0.5 |  |
|  |  |  | $\overline{\mathrm{G}} / \mathrm{N}$ | $\mathrm{lOL}=18 \mathrm{~mA}$ |  |  | 0.5 |  |
|  |  |  | $\overline{\text { P/OVR }}$ | $\mathrm{IOL}=10 \mathrm{~mA}$ |  |  | 0.5 |  |
|  |  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{n}}+4, \mathrm{SIO}_{0} \\ & \mathrm{SiO}_{3}, \mathrm{QIO}_{0} \\ & \mathrm{QIO}_{3}, \overline{\text { WRITE }} \end{aligned}$ | $\mathrm{lOL}=8.0 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathbf{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs (Note 6) |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs (Note 6) |  |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, V_{I N}=0.5 V \\ & (\text { Note 4) } \end{aligned}$ |  |  |  |  | -3.6 | mA |
|  |  |  |  | $Y_{1}, Y_{2}, Y_{3}$ |  |  | -1.13 |  |
|  |  |  |  | $\begin{aligned} & 1, I_{2}, I_{3}, I_{4} \\ & \text { h, } D A_{1}, D A_{2}, D A_{3} \end{aligned}$ |  |  | -0.72 |  |
|  |  |  |  | , $\mathrm{SIO}_{3}, \mathrm{QlO}_{0}$, <br> , MSS, $\mathrm{DB}_{0}, \mathrm{DB}_{1}$ <br> , $\mathrm{DB}_{3}$ |  |  | -0.77 |  |
|  |  |  |  | other inputs |  |  | -0.36 |  |
| IIH | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 V$ <br> (Note 4) |  |  |  |  | 200 | $\mu \mathrm{A}$ |
|  |  |  |  | $Y_{1}, Y_{2}, Y_{3}$ |  |  | 110 |  |
|  |  |  |  | , $\mathrm{DA}_{0}-\mathrm{DA}_{3}$ |  |  | 40 |  |
|  |  |  |  | $\begin{aligned} & \mathrm{SIO}_{3}, \mathrm{QIO}_{0}, \\ & \mathrm{DB}_{0-3}, \end{aligned}$ |  |  | 90 |  |
|  |  |  |  | other inputs |  |  | 20 |  |


| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | - Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| $\begin{aligned} & \mathrm{lozH} \\ & \mathrm{loZL} \end{aligned}$ | Off State (HIGH Impedance) Output Current | $\begin{aligned} & V_{C C}=M A X, \\ & \text { (Note 4) } \end{aligned}$ | $Y_{0}-Y_{3}$ |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 110 | $\mu \mathrm{A}$ |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -1130 |  |
|  |  |  | $\mathrm{DB}_{0-3}, \mathrm{QiO}_{0}, \mathrm{QiO}_{3}$, <br> $\mathrm{SiO}_{0}, \mathrm{SiO}_{3}, \overline{\text { WRITE }} / \overline{\mathrm{MSS}}$ |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 90 |  |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -770 |  |
| Ios | Output Short Circuit Current (Note 3) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}+0.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -30 |  | -85 | mA |
| Icc | Power Supply Current (Note 5) | $V_{C C}=\operatorname{MAX}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  |  | 220 | 335 | mA |
|  |  |  | COM'L | $\mathrm{T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}$ |  |  |  | 350 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  |  | 291 |  |
|  |  |  | MIL | $\mathrm{T}_{\mathrm{C}}=-55$ | (o $125^{\circ} \mathrm{C}$ |  |  | 395 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=125^{\circ}$ |  |  |  | 258 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not axceed one second.
4. $\mathrm{Y}_{0-3}, \mathrm{DB}_{0-3}, \mathrm{SIO}_{0,3}, \mathrm{QIO}_{0,3}$ and WRITE/MSS are three state outputs internally connected to TTL inputs. Z is an open-collector output internally connected to a TTL input. Input characteristics are measured under conditions such that the outputs are in the OFF state.
5. Worst case ICC is at minimum temperature.
6. These input levels provide zero noise immunity and should only be static tested in a noise-free environment (not functionally tested)

Am2903A Burn-in and Life Teśt Circuit


TC001061

## I. Am2903A GUARANTEED COMMERCIAL RANGE PERFORMANCE

The Am2903A switching characteristics are a function of the power supply voltage, the temperature, and the operating
mode of the devices. The data has been condensed onto the tables below. All numbers in the tables are in ns.

INDEX TO SWITCHING TABLES

| Table | Data Type | Conditions | Applicable to |
| :---: | :---: | :---: | :---: |
| A | Clock and Write Pulse | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| B | Enable/Disable Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| C | Setup and Hold Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| $1-2$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Standard Function and Incre- <br> ment by 1 or 2 |
| $1-3$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Multiply Instructions |
| $1-4$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Divide Instructions |
| $1-5$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Sign Magnitude to Two's <br> Complement Conversion |
| $1-6$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Single Length Normalization |

## I-1. Am2903A GUARANTEED COMMERCIAL RANGE PERFORMANCE

The tables below specify the guaranteed performance of the Am2903A over the commercial operating range of 0 to $+70^{\circ} \mathrm{C}$ with $V_{C C}$ from 4.75 to 5.25 V . All data are in ns, with inputs switching between 0 and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.

TABLE A. CLOCK AND WRITE PULSE CHARACTERISTICS ALL FUNCTIONS

| Minimum Clock Low Time | 30 ns |
| :--- | :---: |
| Minimum Clock High Time | 30 ns |
| Minimum Time CP and WE both Low to Write | 15 ns |

TABLE B. ENABLE/DISABLE TIMES ALL FUNCTIONS

| From | To | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\overline{\mathrm{OEY}}$ | Y | 25 | 21 |
| $\overline{\mathrm{OEB}}$ | DB | 25 | 21 |
| $\overline{\mathrm{OEA}}$ | DA | 25 | 21 |
| $\mathrm{I}_{8}$ | SIO | 25 | 21 |
| $\mathrm{I}_{8}$ | Q 1 O | 38 | 38 |
| $\mathrm{I}_{8765}$ | QIO | 38 | 38 |
| $\mathrm{I}_{43210}$ | QIO | 38 | 38 |
| $\overline{\mathrm{LSS}}$ | $\overline{\mathrm{WR}}$ | 25 | 21 |

Note: $C_{L}=5.0 \mathrm{pF}$ for output disable tests. Measurement is made to a 0.5 V change on the output.

TABLE C. SETUP AND HOLD TIMES ALL FUNCTIONS

|  |  | HIGH-to-LOW |  | LOW-to-HIGH |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From | With Respect to | Setup | Hold | Setup | Hold | Comments |
| Y | CP | Don't Care | Don't Care | 14 | 3 | Store Y in RAM/Q (Note 1) |
| WE High | CP | 15 |  | wl | 0 | Prevent Writing |
| WE LOW | CP | Don't Care | Don't Care | 15 | 0 | Write into RAM |
| A, B Source | CP | 20 | 3 | Don't Care | Don't Care | Latch Data from RAM Out |
| B Destination | CP | 6 |  | wl | 3 | Write Data into B Address |
| $\mathrm{QIO}_{0,3}$ | CP. | Don't Care | Don't Care | 17 | 3 | Shift Q |
| 18765 | CP | 12 | - | 20 | 0 | Write into Q (Note 2) |
| IEN High | CP | - |  |  | 0 | Prevent Writing into Q |
| IEN Low | CP | Don't Care | Don't Care | 21 | 0 | Write into Q |
| 143210 | CP | 18 | - | 32 | 0 | Write into Q (Note 2) |

Note 1: The internal Y-bus to RAM setup condition will be met 5 ns after valid $Y$ output ( $\overline{\mathrm{OEY}}=0$ ).
Note 2: The setup time with respect to CP falling edge is to prevent writing. The setup time with respect to CP rising edge is to enable writing.
Note 3: For all other set up conditions not specified in this table, the set up time should be the delay to stable Y output plus the Y to RAM internal setup time. Even if the RAM is not being loaded, this set up condition ensures valid writing into the Q register and sign compare flip flop.
Note 4: $\bar{W} E$ controls writing into the RAM. IEN controls writing into $Q$ and, indirectly, controls $\overline{\text { WE }}$ through the $\overline{\text { WRITE }} / \overline{M S S}$ output. To prevent writing, IEN and WE must go HIGH during the entire clock LOW time. They may go LOW after the clock has gone LOW to cause a write provided the WE LOW and IEN LOW set-up times are met. Having gone LOW, they should not be returned HIGH until after the clock has gone HIGH.
Note 5: A and B addresses must be set-up prior to the clock HIGH-to-LOW transition to latch data at the RAM output.
Note 6: Writing occurs when CP and WE are both LOW. The B address should be stable during this entire period.
Note 7: Because l8765 controls the writing or not writing of data into RAM and Q, they should be stable during the entire clock LOW time unless IEN is HIGH, which prevents writing.
Note 8: The set-up time prior to the clock LOW-to-HIGH transition occurs in parallel with the set-up time prior to the clock HIGH-toLOW transition and the clock LOW time. The actual set-up time requirement on $I_{43210}$ relative to the clock LOW-to-HIGH transition is the longer of (1) the set-up time prior to clock $L \rightarrow H$, and (2) the sum of the set-up time prior to clock $H \rightarrow L$ and the clock LOW time.

SWITCHING CHARACTERISTICS over the COMMERCIAL operating range unless otherwise specified.

I-2 STANDARD FUNCTIONS AND INCREMENT BY ONE OR TWO INSTRUCTIONS (SF 4)

|  | To |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From | Y | $C_{n+4}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | Z | N | OVR | DB | $\begin{array}{\|c\|} \hline \text { WRITE/ } \\ \text { MSS } \end{array}$ | $\mathrm{QIO}_{0,3}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{3}$ | $\mathrm{SIO}_{0}$ <br> Parity |
| A, B Addr | 67 | 55 | 52 | 74 | 61 | 67 | 28 | - | - | 41 | 62 | 78 |
| DA, DB | 58 | 50 | 40 | 65 | 54 | 58 | - | - | - | 35 | 59 | 65 |
| Cn | 33 | 18 | - | 35 | 28 | 26 | - | - | - | 23 | 30 | 38 |
| 18-0 | 64 | 64 | 50 | 72 | 61 | 62 | - | 34 | 26 | 50 | 62 | 74 |
| CP | 58 | 42 | 43 | 61 | 54 | 58 | 22 | - | 22 | 37 | 54 | 60 |
| $\mathrm{SiO}_{0,3}$ | 23 | - | - | 29 | - | - | - | - | - | - | 29 | 19 |
| MSS | 44 | - | 44 | 44 | 44 | 44 | - | - | - | 44 | 44 | 44 |

Notes: 1. A " - " means the delay path does not exist.
Standard Functions: See Table 2
Increment SF 4: $F=S+1+C n$
$Y \rightarrow Z=17(\overline{O E Y}=H)$
$\overline{\mid E N} \rightarrow \overline{\text { WRITE }} / \overrightarrow{M S S}=20$
EA $\rightarrow$ OUTPUT $=$ DA $\rightarrow$ OUTPUT

I-3 MULTIPLY INSTRUCTIONS (SF 0, SF 2, SF 6)

| From | To |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | $\mathbf{Y}$ | $C_{n+4}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z | N | OVR |  | $\begin{array}{\|l\|} \hline \text { WRITE/ } \\ \text { MSS } \end{array}$ | $\mathrm{QlO}_{0,3}$ | SIO ${ }_{0}$ |
| A, B Addr | MSS | 67 | 55 | - | - | 61 | 67 | 28 | - | - | 41 |
|  | IS | 67 | 55 | 52 | - | - | - | 28 | - | - | 41 |
|  | LSS | 67 | 55 | 52 | - | - | - | 28 | - | - | 41 |
| DA, DB | MSS | 58 | 50 | - | - | 54 | 58 | - | - | - | 35 |
|  | IS | 58 | 50 | 40 | - | - | - | - | - | - | 35 |
|  | LSS | 58 | 50 | 40 | - | - | - | - | - | - | 35 |
| Cn | MSS | 35 | 18 | - | - | 28 | 27 | - | - | - | 23 |
|  | IS | 33 | 18 | - | - | - | - | - | - | - | 23 |
|  | LSS | 33 | 18 | - | - | - | - | - | - | - | 23 |
| $18-0$ | MSS | 94 | 75 | - | - | 88 | 88 | - | - | 26 | 73 |
|  | IS | 94 | 75 | 71 | - | - | - | - | - | 26 | 73 |
|  | LSS | 94 | 75 | 71 | 30 | - | - | - | 34 | 26 | 73 |
| CP | MSS | 58 | 42 | - | - | 54 | 58 | 22 | - | 22 | 37 |
|  | IS | 58 | 42 | 43 | - | - | - | 22 | - | 22 | 37 |
|  | LSS | 90 | 71 | 67 | 26 | - | - | 22 | - | 22 | 69 |
| Z | MSS | 64 | 45 | - | - | 58 | 58 | - | - | - | 43 |
|  | IS | 64 | 45 | 41 | - | - | - | - | - | - | 43 |
|  | LSS | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SIO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - |

Notes: 1. A "-" means the delay path does not exist.

Unsigned Multiply
SF 0: $F=S+C n$ if $Z=0$
$F=S+R+C n$ if $Z=1$
$Y=$ Log. F/2
$\mathrm{Q}=$ Log. $\mathrm{Q} / 2$
$Y_{3}=C_{n+4}$ (MSS)
$Z=Q_{0}$ (LSS)

Two's Complement Multiply
SF 2: $F=S+C n$ if $Z=0$
$F=R+S+C n$ if $Z=1$
$Y=$ Log. $F / 2$
$\mathrm{Q}=$ Log. $\mathrm{Q} / 2$
$Y_{3}=F_{3} \oplus$ OVR (MSS)

Two's Complement Multiply Last Cycle
SF 6: $F=S+C n$ if $Z=0$
$\mathrm{F}=\mathrm{S}-\mathrm{R}-1+\mathrm{Cn}$ if $\mathrm{Z}=1$
$Y=$ Log. $F / 2$
$Q=$ Log. $Q / 2$
$Y_{3}=O V R \oplus(M S S)$
$Z=Q_{0}$ (LSS)

SWITCHING CHARACTERISTICS over the COMMERCIAL operating range unless otherwise specified.
I-4 DIVIDE INSTRUCTIONS (SF A, SF C, SF E)

| From | To |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $\mathrm{C}_{\mathrm{n}}+4$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z | N | OVR | DB | WR | $\mathbf{Q l O}_{0,3}$ | $\mathrm{SIO}_{3}$ |
| A, B Addr | MSS | 67 | 61/55 | - | 74/- | 61 | 67 | 28 | - | - | 62 |
|  | IS | 67 | 55 | 52 | 74/- | - | - | 28 | - | - | 62 |
|  | LSS | 67 | 55 | 52 | 74/- | - | - | 28 | - | - | 62 |
| DA, DB | MSS | 58 | 55/50 | - | 65/- | 54 | 58 | - | - | - | 59 |
|  | IS | 58 | 50 | 40 | 65/- | - | - | - | - | - | 59 |
|  | LSS | 58 | 50 | 40 | 65/- | - | - | - | - | - | 59 |
| Cn | MSS | 33 | 33/18 | - | 35/- | 28 | 27 | - | - | - | 32 |
|  | IS | 33 | 18 | - | 35/- | - | - | - | - | - | 30 |
|  | LSS | 33 | 18 | - | 35/- | - | - | - | - | - | 30 |
| $18-0$ | MSS | 64/84 | 75/68 | - | 72/29 | 61/77 | 62/77 | - | - | 26 | 63/83 |
|  | 1 S | 64/84 | 64/68 | 50/70 | 72/- | - | - | - | - | 26 | 62/83 |
|  | LSS | 64/84 | 64/68 | 50/70 | 72/- | - | - | - | 34 | 26 | 62/83 |
| CP | MSS | 58/80 | 46/64 | - | 61/25 | 54/66 | 58/66 | 22 | - | 22 | 54/79 |
|  | IS | 58 | 42 | 43 | 61/- | - | - | 22 | - | 22 | 54 |
|  | LSS | 58 | 42 | 43 | 61/- | - | - | 22 | - | 22 | 54 |
| z | MSS | - | - | - | - | - | - | - | - | - | - |
|  | IS | -/55 | -/39 | -/41 | - | - | - | - | - | - | -154 |
|  | LSS | -/55 | -139 | -/41 | - | - | - | - | - | - | -/54 |
| $\mathrm{SiO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - |

Notes: 1. A "-" means the delay path does not exist.
Double Length Normalize and First Divide Op
SF A: $F=S+C n$
$Y=$ Log. F/2
$Q=$ Log. $Q / 2$
$\mathrm{SIO}_{3}=\mathrm{F}_{3} \oplus \mathrm{R}_{3}$ (MSS)
$\mathrm{C}_{n+4}=\mathrm{F}_{3} \oplus \mathrm{~F}_{2}$ (MSS)
$O V R=F_{2} \oplus F_{1}$ (MSS)
$Z=\bar{Q}_{0} \bar{Q}_{1} \bar{Q}_{2} \bar{Q}_{3} \overline{F_{0}} \overline{F_{1}} \bar{F}_{2} \overline{F_{3}}$
Two's Complement Divide
SF $C: F=R+S+C n$ if $Z=0$
$F=S-R-1+C n$ if $Z=1$
$Y=$ Log. $F / 2$
$Q=$ Log. $Q / 2$
$\mathrm{SIO}_{3}=\overline{\mathrm{F}_{3} \oplus \mathrm{R}_{3}}$ (MSS)
$Z=\overline{F_{3} \oplus R_{3}}$ (MSS) from previous cycle
Two's Complement Divide Correction and Remainder
$S F E: F=R+S+C n$ if $Z=0$
$F=S-R-1+C n$ if $Z=1$
$Y=F$
$Q=$ Log. $Q / 2$
$Z=\overline{F_{3} \oplus R_{3}}$ (MSS) from previous cycle

SWITCHING CHARACTERISTICS over the COMMERCIAL operating range unless otherwise specified. I-5 SIGN MAGNITUDE TO TWO'S COMPLEMENT CONVERSION (SF 5)

| From | To |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $C_{n+4}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z | N | OVR | DB | $\begin{array}{\|c\|} \hline \text { WRITE/ } \\ \hline \text { MSS } \\ \hline \end{array}$ | $\mathrm{QlO}_{0,3}$ | $\mathrm{SIO}_{3}$ |
| A, B Addr | MSS | 97 | 81 | - | 42 | 89 | 89 | 28 | - |  | 102 |
|  | IS | 67 | 55 | 52 | - | - | - | 28 | - |  | 78 |
|  | LSS | 67 | 55 | 52 | - | - | - | 28 | - |  | 78 |
| DA, DB | MSS | 94 | 76 | - | 37 | 84 | 84 | - | - |  | 97 |
|  | IS | 58 | 50 | 40 | - | - | - | - | - |  | 65 |
|  | LSS | 58 | 50 | 40 | - | - | - | - | - |  | 65 |
| Cn | MSS | 33 | 18 | - | - | 32 | 27 | - | - |  | 38 |
|  | IS | 33 | 18 | - | - | - | - | - | - |  | 38 |
|  | LSS | 33 | 18 | - | - | - | - | - | - |  | 38 |
| $\mathrm{I}_{8}-0$ | MSS | 85 | 67 | - | 28 | 82 | 73 | - | - | 26 | 88 |
|  | IS | 85 | 67 | 63 | - | - | - | - | - | 26 | 88 |
|  | LSS | 85 | 67 | 63 | - | - | - | - | 34 | 26 | 88 |
| CP | MSS | 94 | 76 | - | 37 | 84 | 84 | 22 | - | 22 | 97 |
|  | IS | 58 | 42 | 43 | - | - | - | 22 | - | 22 | 60 |
|  | LSS | 58 | 42 | 43 | - | - | - | 22 | - | 22 | 60 |
| $z$ | MSS | - | - | - | - | - | - | - | - | - | - |
|  | IS | 57 | 39 | 35 | - | - | - | - | - | - | 60 |
|  | LSS | 57 | 39 | 35 | - | - | - | - | - | - | 60 |
| $\mathrm{SIO}_{0-3}$ | Any | - | - | - | - | - | - | - | - | - | - |

I-6 SINGLE LENGTH NORMALIZATION (SF 8)

| From | To |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $C_{n+4}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | $\mathbf{z}$ | N | OVR | DB | $\frac{\text { WRITE/ }}{\text { MSS }}$ | $\mathrm{ClO}_{0,3}$ | $\mathrm{SIO}_{3}$ |
| A, B Addr | MSS | 67 | - | - | - | - | - | 28 | - | - | 62 |
|  | IS | 67 | 55 | 52 | - | - | - | 28 | - | - | 62 |
|  | LSS | 67 | 55 | 52 | - | - | - | 28 | - | - | 62 |
| DA, DB | MSS | 58 | - | - | - | - | - | - | - | - | 59 |
|  | IS | 58 | 50 | 40 | - | - | - | - | - | - | 59 |
|  | LSS | 58 | 50 | 40 | - | - | - | - | - | - | 59 |
| Cn | MSS | 33 | - | - | - | - | - | - | - | - | 30 |
|  | IS | 33 | 18 | - | - | - | - | - | - | - | 30 |
|  | LSS | 33 | 18 | - | - | - | - | - | - | - | 30 |
| $18-0$ | MSS | 64 | 37 | - | 29 | 24 | 24 | - | - | 26 | 62 |
|  | IS | 64 | 64 | 50 | 29 | - | - | - | - | 26 | 62 |
|  | LSS | 64 | 64 | 50 | 29 | - | - | - | 34 | 26 | 62 |
| CK | MSS | 58 | 29 | - | 26 | 26 | 29 | 22 | - | 22 | 54 |
|  | IS | 58 | 42 | 43 | 26 | - | - | 22 | - | 22 | 54 |
|  | LSS | 58 | 42 | 43 | 26 | - | - | 22 | - | 22 | 54 |
| Z | MSS | - | - | - | - | - | - | - | - | - | - |
|  | IS | - | - | - | - | - | - | - | - | - | - |
|  | LSS | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SIO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - |
| Notes: 1. A "-" mean $\text { SF 8: } \begin{aligned} F & =S+C n \\ N & =Q_{3}(M S S) \\ Y & =F \\ Q & =\text { Log. } Q / 2 \end{aligned}$ | $C_{n+4}=\frac{Q_{3}}{Z}=\frac{Q_{0}}{Q_{1}} Q_{2} \text { (MSS) }$ |  |  |  |  | $\mathrm{OVR}=\mathrm{Q}_{2} \oplus \mathrm{Q}_{1}(\mathrm{MSS})$ |  |  |  |  |  |

## II. Am2903A GUARANTEED MILITARY RANGE PERFORMANCE

The Am2903A switching characteristics are a function of the power supply voltage, the temperature, and the operating
mode of the devices. The data has been condensed onto the tables below. All numbers are in ns.

INDEX TO SWITCHING TABLES

| Table | Data Type | Conditions | Applicable to |
| :---: | :---: | :---: | :---: |
| A | Clock and Write Pulse | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| B | Enable/Disable Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| C | Setup and Hold Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| $1-2$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Standard Function and Incre- <br> ment by 1 or 2 |
| $1-3$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Multiply Instructions |
| $1-4$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Divide Instructions |
| $1-5$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Sign Magnitude to Two's <br> Complement Conversion |
| $1-6$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Single Length Normalization |

## II-1. Am2903A GUARANTEED MILITARY RANGE PERFORMANCE

The tables below specify the guaranteed performance of the Am2903A over the military operating range of 0 to $+70^{\circ} \mathrm{C}$, with $V_{\mathrm{CC}}$ from 4.75 to 5.25 V . All data are in ns , with inputs switching between 0 and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.
table a. Clock and write pulse characTERISTICS ALL FUNCTIONS

| Minimum Clock Low Time | 30 ns |
| :--- | :--- |
| Minimum Clock High Time | 30 ns |
| Minimum Time CP and WE both Low to Write | 30 ns |

TABLE B. ENABLE/DISABLE TIMES ALL FUNCTIONS

| From | To | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\overline{\mathrm{OEY}}$ | Y | 25 | 21 |
| $\overline{\mathrm{OEB}}$ | DB | 25 | 21 |
| $\overline{\mathrm{OEA}}$ | DA | 25 | 21 |
| $\mathrm{I}_{8}$ | SIO | 25 | 21 |
| $\mathrm{I}_{8}$ | QIO | 38 | 38 |
| $\mathrm{I}_{8765}$ | QIO | 38 | 38 |
| $\mathrm{I}_{43210}$ | QIO | 38 | 35 |
| $\overline{\mathrm{LSS}}$ | $\overline{\mathrm{WR}}$ | 30 | 25 |

Note: $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests. Measurement is made to a 0.5 V change on the output.

| TABLE C. SETUP AND HOLD TIMES ALL FUNCTIONS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | HIGH-to-LOW |  | LOW-to-HIGH |  |  |
|  |  | Tpwl |  |  |  |  |
| From | With Respect to | Setup | Hold | Setup | Hold | Comments |
| $Y$ | CP | Don't Care | Don't Care | 14 | 3 | Store Y in RAM/Q (Note 1) |
| WE High | CP | 15 |  | wl | 0 | Prevent Writing |
| WE LOW | CP | Don't Care | Don't Care | 15 | 0 | Write into RAM |
| A, B Source | CP | 20 | 3 | Don't Care | Don't Care | Latch Data from RAM Out |
| $B$ Destination | CP | 6 |  | wl | 3 | Write Data into B Address |
| $\mathrm{QiO}_{0,3}$ | CP | Don't Care | Don't Care | 17 | 3 | Shift Q |
| $\mathrm{I}_{8765}$ | CP | 12 | - | 20 | 0 | Write into Q (Note 2) |
| IEN High | CP | 24 |  |  | 0 | Prevent Writing into Q |
| IEN Low | CP | Don't Care | Don't Care | 21 | 0 | Write into Q |
| 143210 | CP | 18 | - | 32 | 0 | Write into Q (Note 2) |

Note 1: The internal Y-bus to RAM setup condition will be met 5 ns after valid Y output ( $\overline{\mathrm{OEY}}=0$ ).
Note 2: The set-up time with respect to CP falling edge is to prevent writing. The setup time with respect to CP rising edge is to enable writing.
Note 3: For all other set up conditions not specified in this table, the set up time should be the delay to stable $Y$ output, plus the $Y$ to RAM internal setup time. Even if the RAM is not being loaded, this set up condition ensures valid writing into the $\mathbf{Q}$ register and sign compare flip flop.
Note 4: $\overline{\mathrm{WE}}$ controls writing into the RAM. IEN controls writing into $Q$ and, indirectly, controls $\overline{\mathrm{WE}}$ through the $\overline{\text { WRITE }} / \overline{\mathrm{MSS}}$ output. To prevent writing, IEN and $\overline{\text { WE }}$ must go HIGH during the entire clock LOW time. They may go LOW after the clock has gone LOW to cause a write provided the WE LOW and IEN LOW set-up times are met. Having gone LOW, they should not be returned HIGH until after the clock has gone HIGH.
Note 5: A and B addresses must be set-up prior to the clock HIGH-to-LOW transition to latch data at the RAM output.
Note 6: Writing occurs when CP and $\overline{W E}$ are both LOW. The $B$ address should be stable during this entire period.
Note 7: Because $\mathrm{l}_{8765}$ controls the writing or not writing of data into RAM and $Q$, they should be stable during the entire clock LOW time unless IEN is HIGH, which prevents writing.
Note 8: The set-up time prior to the clock LOW-to-HIGH transition occurs in parallel with the set-up time prior to the clock HIGH-to-LOW transition and the clock LOW time. The actual set-up time requirement on $\mathrm{I}_{43210}$ relative to the clock LOW-toHIGH transition is the longer of (1) the set-up time prior to clock L $\rightarrow \mathrm{H}$, and (2) the sum of the set-up time prior to clock H $\rightarrow \mathrm{L}$ and the clock LOW time.

SWITCHING CHARACTERISTICS over the MILITARY operating range unless otherwise specified.
II-2 STANDARD FUNCTIONS AND INCREMENT BY ONE OR TWO INSTRUCTIONS (SF 4)

| From | To |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{Y}$ | $C_{n+4}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z | N | OVR | DB | $\overline{\text { WRITE }}$ | $\mathrm{QIO}_{0,3}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{3}$ | $\mathrm{SIO}_{0}$ Parity |
| A, B Addr | 70 | 58 | 52 | 78 | 68 | 67 | 28 | - | - | 47 | 71 | 84 |
| DA, DB | 60 | 52 | 40 | 66 | 55 | 58 | - | - | - | 35 | 61 | 74 |
| Cn | 35 | 19 | - | 41 | 31 | 29 | - | - | - | 23 | 33 | 40 |
| $18-0$ | 72 | 69 | 56 | 80 | 71 | 69 | - | 36 | 26 | 58 | 75 | 89 |
| CP | 60 | 42 | 43 | 67 | 55 | 58 | 22 | - | 25 | 41 | 61 | 66 |
| $\mathrm{SIO}_{0,3}$ | 26 | - | - | 29 | - | - | - | - | - | - | 29 | 19 |
| MSS | 44 | - | 44 | 44 | 44 | 44 | - | - | - | 44 | 44 | 44 |

Notes: 1. A "-" means the delay path does not exist.
Standard Functions: See Table 2
Increment SF 4: $\mathrm{F}=\mathrm{S}+1+\mathrm{Cn}$
$Y \rightarrow Z=17(\overline{\mathrm{OEY}}=\mathrm{H})$
$\stackrel{Y}{\text { IEN }^{2} \rightarrow \overline{\text { WRITE }} / \overline{\mathrm{MSS}}=20}$
EA $\rightarrow$ OUTPUT $=$ DA $\rightarrow$ OUTPUT

II-3 MULTIPLY INSTRUCTIONS (SF 0, SF 2, SF 6)

| From | To |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $C_{n+4}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | Z | N | OVR | DB | WRITE/ <br> MSS | $\mathrm{QlO}_{0,3}$ | $\mathrm{SIO}_{0}$ |
| A, B Addr | MSS | 72 | 58 | - | - | 68 | 67 | 28 | - | - | 47 |
|  | IS | 72 | 58 | 52 | - | - | - | 28 | - | - | 47 |
|  | LSS | 72 | 58 | 52 | - | - | - | 28 | - | - | 47 |
| DA, DB | MSS | 62 | 52 | - | - | 55 | 58 | - | - | - | 35 |
|  | IS | 60 | 52 | 40 | - | - | - | - | - | - | 35 |
|  | LSS | 60 | 52 | 40 | - | - | - | - | - | - | 35 |
| Cn | MSS | 40 | 19 | - | - | 31 | 29 | - | - | - | 23 |
|  | IS | 35 | 19 | - | - | - | - | - | - | - | 23 |
|  | LSS | 35 | 19 | - | - | - | - | - | - | - | 23 |
| $\mathrm{I}_{8}-0$ | MSS | 108 | 84 | - | - | 98 | 98 | - | - | 26 | 81 |
|  | IS | 108 | 84 | 80 | - | - | - | - | - | 26 | 81 |
|  | LSS | 108 | 84 | 80 | 33 | - | - | - | 36 | 26 | 81 |
| CP | MSS | 62 | 42 | - | - | 55 | 58 | 22 | - | 25 | 41 |
|  | IS | 60 | 42 | 43 | - | - | - | 22 | - | 25 | 41 |
|  | LSS | 104 | 80 | 74 | 29 | - | - | 22 | - | 25 | 77 |
| z | MSS | 75 | 51 | - | - | 65 | 65 | - | - | - | 48 |
|  | IS | 75 | 51 | 47 | - | - | - | - | - | - | 48 |
|  | LSS | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SiO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - |

Notes: 1. A " - " means the delay path does not exist.

$$
\begin{aligned}
& \text { Unsigned Multiply } \\
& \text { SF } 0: F=S+C n \text { if } Z=0 \\
& F
\end{aligned}=S+R+C n \text { if } Z=1 .
$$

Two's Complement Multiply SF 2: $F=S+C n$ if $Z=0$

$$
F=R+S+C n \text { if } Z=1
$$

$Y_{3}=F_{3} \oplus$ OVR (MSS)
$Y_{3}=\mathrm{F}_{3} \oplus \mathrm{Q}_{0}$ (LSS)
$\mathrm{Y}=\mathrm{Q}_{0}$ (LSI)
$Z=Q_{0}(L S S)$
$Y=L o g . F / 2$
$Y=$ Log. $F / 2$
$Q=$ Log. $Q / 2$

Two's Complement Multiply Last Cycle SF 6: $F=S+C n$ if $Z=0$

$$
\begin{aligned}
F & =S-R-1+C n \text { if } Z=1 \\
Y_{3} & =O V R \oplus F_{3}(M S S) \\
Z & =Q_{0}(L S S) \\
Y & =\text { Log. } F / 2 \\
Q & =\text { Log. } Q / 2
\end{aligned}
$$




## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS
C. OPEN-COLLECTOR OUTPUTS



$R_{2}=\frac{2.4 V}{1 O H}$
TC001091


Notes: 1. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in hand in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all A.C. tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for $t_{P Z L}$ test.
4. $C_{L}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2903A (DIP)

| Pin \# | Pin Label | Test Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{QIO}_{0}$ | A | 458 | 1 K |
| 11 | $\mathrm{C}_{n}+4$ | B | 478 | 3 K |
| 12 | $\overline{\mathrm{P} / O V R}$ | B | 383 | 3 K |
| 14 | $\overline{\mathrm{G}} / \mathrm{N}$ | B | 212 | 1.5 K |
| $16-19$ | $\mathrm{Y}_{0-3}$ | A | 241 | 1 K |
| 20 | $\mathrm{SIO}_{0}$ | A | 458 | 1 K |
| 21 | $\mathrm{SIO}_{3}$ | A | 458 | 1 K |
| 22 | $Z$ | C | 281 | - |
| $23-26$ | $\mathrm{DB}_{0-3}$ | A | 458 | 1 K |
| 40 | $\overline{\mathrm{WRITE} / \overline{\mathrm{MSS}}}$ | A | 458 | 1 K |
| 48 | $\mathrm{QIO}_{3}$ | A | 458 | 1 K |

For additional information on testing, see section
'"Guidelines on Testing Am2900 Family Devices.'"

## Am2904

## DISTINCTIVE CHARACTERISTICS

- Replaces most MSI used around any ALU including the Am2901, Am2903, Am29203 and MSI ALUs.
- Generates Carry-in to the ALU -

Carry signal is selectable from 7 different sources.

- Contains shift linkage multiplexers -

Connects to shift lines at the ends of an Am2901, Am2903, or Am29203 array to implement single and double length arithmetic and logical shifts and rotates 32 different modes in all.

- Contains two edge-triggered status registers Use for foreground/background registers in controllers or as microlevel and machine level status registers. Bit manipulating instructions are provided.
- Condition Code Multiplexer on chip -

Single cycle tests for any of 16 different conditions. Tests can be performed on either of the two status registers or directly on the ALU output.

## GENERAL DESCRIPTION

The Am2904 is designed to perform all the miscellaneous functions which are usually performed in MSI around an ALU. These include the generation of the carry-in signal to the ALU and carry lookahead unit; the interconnection of the data path, auxiliary register, and carry flip-flop during shift operations; and the storage and testing of ALU status flags. These tasks are accomplished in the Am2904 by three nearly independent blocks of logic. The carry-in is
generated by a multiplexer. The shift linkages are established by four three-state multiplexers. There are two registers for storing the carry, overflow, zero, and negative status flags. The condition code multiplexer on the Am2904 can look at true or complement of any of the four status bits and certain combinations of status bits from either of the storage registers or directly from the ALU.


BASIC FEATURES OF Am2904
BD001852
All the logic shown except the array of 2901s, 2903s, or 29203 s is contained in the Am2904.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2901 | 4-Bit Microprocessor Slice |
| Am2903 | Advanced 4-Bit Bipolar Microprocessor Slice |
| Am29203 | 4-Bit Bipolar Microprocessor Slice |
| Am2910 | Microprogram Controller |
| Am29811 | Next Address Control Unit for 2909A/11A |

For additional applications refer to Chapter 4 of Bit Slice Microprocessor Design, Mick \& Brick, McGraw Hill Publications.

CONNECTION DIAGRAM Top View

D-40


CD004130

F-42-1


CD004140

## Chip-Pak ${ }^{\text {TM }}$

L-44-1


CD004150

Note: Pin 1 is marked for orientation
NC $=$ No Connection.


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type
Status and Shift Control Unit

| Valid Combinations |  |
| :--- | :--- |
| Am2904 | DC, DCB, DMB |
|  | FMB |
|  | LC, LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## PIN DESCRIPTION

| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| 9 | Iz | 1 | Zero status input pin, intended for connection to the Z outputs of the Am2903 or the F=0 outputs of the Am2901. |
| 12 | IC | 1 | Carry status input pin, intended for connection to the $\mathrm{C}_{n}+4$ output of the most significant ALU slice. |
| 14 | IN | 1 | Sign status input pin, intended for connection to the most significant ALU slice. The connection is to the $\mathbf{N}$ pin on the Am2903, and the F3 pin on the Am2901. |
| 16 | lova | 1 | Overflow status input pin, intended for connection to the OVR pin on the most significant ALU slice. |
|  | $1_{0-12}$ | 1 | The thirteen instruction pins which select the operation the Am2904 is to perform. |
| 7 | $\overline{\mathrm{CE}} \mathrm{M}$ | 1 | This pin, used in conjunction with $\overline{E_{Z}}, \overline{E_{C}}, \overline{\overline{E N}_{N}}, \overline{\overline{E O V R}^{\prime}}$ acts as the overall enable for the Machine Status Register. When the pin is LOW, MSR bits may be modified, according to the states of $\bar{E}_{Z}, \bar{E}_{\mathrm{C}}, \bar{E}_{\mathrm{N}}, \mathrm{E}_{\mathrm{OVR}}$. When HIGH, the MSR will retain the present state, regardless of the state of $\overline{\bar{E}_{Z}}, \overline{E_{C}}, \overline{E_{N}}, \overline{E_{O V R}}$. |
| $\begin{aligned} & 8,11,13, \\ & 15 \end{aligned}$ | $\bar{E}_{Z}, \bar{E}_{C}$ $\mathrm{EN}_{\mathrm{N}}$, EOVR | 1 | These pins, when LOW, enable the corresponding bits in the Machine Status Register. When HIGH, they will prevent the corresponding bits from changing state. By using these pins together with the $\overline{\mathrm{C}} \mathrm{E}_{\mathrm{M}}$ pin, MSR bits can be selectively modified. |
| 2 | $\overline{\mathrm{CE} \mu}$ | 1 | This pin, when LOW, enables all four bits of the Micro Status Register. When this pin is HIGH, the $\mu$ SR will not change state. |
| $\begin{aligned} & 32,31,29, \\ & 28 \end{aligned}$ | $Y_{Z}, Y_{C}$, <br> $Y_{N}$, <br> YOVR | 1/0 | These pins form a three-state bidirectional bus over which MSR and $\mu$ SR status can be read out or the MSR can be loaded in parallel. |
| 20 | ОЕ्Y | 1 | When LOW, this pin enables the Y pins as outputs. When HIGH, the Y outputs are in the high impedance state. |
| 27 | CT | 0 | The conditional test output. The output of the Condition Code multiplexer appears here. |
| 26 | $\overline{\text { OECT }}$ | 1 | When this pin is LOW, the CT pin is active. When HIGH the CT pin is in the high impedance state. |
| $\begin{aligned} & 36,35,34, \\ & 33 \end{aligned}$ | $\mathrm{SIO}_{0}$, $\mathrm{SIO}_{n}$ $\mathrm{QIO}_{0}$ $\mathrm{QlO}_{n}$ | 1/0 | These pins complete the linking for the various shift and rotate conditions. $\mathrm{SIO}_{0}$ is intended for connection to the $\mathrm{SIO}_{0}$ pin of the least significant Am2903 slice (RAM ${ }_{0}$ for Am2901). $\mathrm{SIO}_{n}$ connects to the $\mathrm{SIO}_{3}$ pin of the most significant Am2903 slice, (RAM 3 for Am2901). $\mathrm{QiO}_{0}$ connects to the $\mathrm{QIO}_{0}$ pin of the least significant Am2903 slice ( $\mathrm{Q} \mathrm{IO}_{0}$ for Am2901) and $\mathrm{QIO}_{n}$ connects to the $\mathrm{QiO}_{3}$ pin of the most significant Am2903 slice ( $\mathrm{Q}_{3}$ for Am2901). |
| 37 | $\overline{\text { SE }}$ | 1 | This pin controls the state of the shift outputs. When LOW, the shift outputs are enabled. When HIGH, the shift outputs are in the high impedance state. |
| 25 | $\mathrm{C}_{0}$ | 0 | This pin is the output of the Carry-In Control Multiplexer. It connects to the $\mathrm{C}_{\mathrm{n}}$ input of the least significant ALU slice, and the $\mathrm{C}_{\mathrm{n}}$ input of the Am2902A. |
| 24 | $C^{\prime}$ | 1 | This pin is used as an input to the Carry-In Control Multiplexer which can route it to the $\mathrm{C}_{0}$ pin. The $\mathrm{C}_{x}$ pin is intended for connection to the Z output of the Am2903 to facilitate some of the Am2903 special instructions. |
| 17 | CP | 1 | The clock input to the device. The $\mu$ SR and MSR are modified on the LOW to HIGH transition of the clock input. All other portions of the Am2904 are combinational and are unaffected by CP. |

## Am2904 ARCHITECTURE

The Am2904 Status and Shift Control Unit provides four functions which are included in all processors. These are: a) Status Register, b) Condition Code Multiplexer, c) Shift Linkages and d) Carry-in Control. The architecture and instruction codes have been designed to complement the flexibility of the 2900 Family.

## Status Register

The Am2904 contains two four-bit registers which can store the status outputs of an ALU: Carry (C), Negative (N), Zero (Z), and Overflow (OVR). They are designated Micro Status Register ( $\mu \mathrm{SR}$ ) and Machine Status Register (MSR). Each register can be independently controlled. The registers use edge-triggered D-type flip-flops which change state on the LOW to HIGH transition of the Clock Input.

The $\mu \mathrm{SR}$ can be loaded from the four status inputs $\left(I_{C}, I_{N}, I_{Z}\right.$, $l_{\text {OVR }}$ ) or from the MSR under instruction control ( $I_{0-5}$ ). The bits in the $\mu \mathrm{SR}$ can also be individually set or reset under instruction control ( $\mathrm{I}_{0-5}$ ). When the $\overline{\mathrm{CE} \mu}$ input is HIGH, the $\mu \mathrm{SR}$ is inhibited from changing, independent of the $\mathrm{l}_{0-5}$ inputs.
The MSR can be loaded from the four status inputs ( $I_{C}, I_{N}, I_{Z}$, loVR), from the $\mu \mathrm{SR}$, and from the four parallel input/output pins ( $Y_{C}, Y_{N}, Y_{Z}, Y_{O V R}$ ) under instruction control ( $l_{0-5}$ ). The MSR can also be set, reset or complemented under instruction control ( $l_{0-5}$ ). The bits in the MSR can be selectively updated by controlling the four bit-enable inputs ( $\left.\overline{E_{Z}}, \overline{E_{N}}, \overline{E_{C}}, \overline{E_{O V R}}\right)$ and the $\overline{\mathrm{CE}} \mathrm{E}_{\mathrm{M}}$ input. A LOW on both the $\overline{\mathrm{CE}}_{\mathrm{M}}$ input and the bit enable input for a specific bit enables updating that bit. A HIGH on a given bit enable input prevents the corresponding bit changing in the MSR. A HIGH on $\overline{\mathrm{CE}}$ M prevents any bits changing in the MSR.
The four parallel bidirectional input/output pins $\left(Y_{Z}, Y_{N}, Y_{C}\right.$, YOVR) allow the contents of both the $\mu$ SR and the MSR to be transferred to the system data bus and also allows the MSR to be loaded from the system data bus. This capability is used to save and restore the status registers during certain subroutines and when servicing interrupts.

## Condition Code Multiplexer

The Condition Code Multiplexer output, CT, can be selected from 16 different functions. These include the true and complemented state of each of the status bits and combinations of these bits to detect such conditions as 'greater than'', 'greater than or equal to', ''less than" or ''less than or equal to" for unsigned or two's complement numbers.

The Am2904 can perform these tests on the contents of the $\mu S R$, the MSR or the direct status inputs, ( $I_{\mathrm{Z}}, \mathrm{I}_{\mathrm{N}}, \mathrm{I}_{\mathrm{C}}, l_{O V R}$ ). The CT output is used as the test (CC) input of the Am2910 and is provided with an output enable, $\overline{O E}_{\mathrm{CT}}$ to make the addition of other condition inputs to this point easy.

## Shift Linkage Multiplexer

The Shift Linkage Multiplexer generates the necessary linkages to allow the ALU to perform 32 different shift and rotate functions. Both single length and double length shifts and rotates, with and without carry ( $\mathrm{M}_{\mathrm{C}}$ ), are provided. When the $\overline{\mathrm{SE}}$ input is HIGH , the four input/output pins $\left(\mathrm{SIO}_{0}, \mathrm{SIO}_{\mathrm{n}}\right.$, $\mathrm{QIO}_{0}, \mathrm{QIO}_{n}$ ) are disabled. The $\mathrm{SIO}_{0}, \mathrm{SIO}_{\mathrm{n}}, \mathrm{QIO}_{0}, \mathrm{QIO}_{\mathrm{n}}$ pins of the Am2904 are intended to be directly connected to the $R A M_{0}, R A M_{3}, Q_{0}$ and $Q_{3}$ pins of the AM2901 or the $\mathrm{SIO}_{0}$, $\mathrm{SIO}_{3}, \mathrm{QIO}_{0}, \mathrm{QIO}_{3}$ pins of the Am2903.

## Carry-In Control Multiplexer

The Carry-In Control Multiplexer generates the $C_{0}$ output which can be selected from 7 functions $\left(0,1, C_{X}, \mu_{C}, M_{C}, \bar{\mu}_{C}\right.$,
$\overline{\mathrm{MC}_{\mathrm{C}}}$ ). These functions allow easy implementation of both single length and double length addition and subtraction. The $\mathrm{C}_{\mathrm{X}}$ input is intended to be connected to the $Z$ output of the Am2903 to facilitate execution of some of the Am2903 special instructions. The $C_{0}$ pin is to be connected to the $C_{n}$ pin of the least significant Am2901 or Am2903 and the $C_{n}$ pin of the Am2902A.

## Am2904 INSTRUCTION SET

The Am2904 is controlled by manipulating the 13 instruction lines, $1_{0-12}$, together with the nine enable lines, $\overline{\mathrm{CE}}_{\mathrm{M}}, \overline{\mathrm{CE}}_{\mu}, \overline{\mathrm{E}_{Z}}$, $\overline{E_{C}}, \overline{E_{N}}, \overline{E_{O V R}}, \overline{\mathrm{OE}_{Y}}, \overline{\mathrm{OE}} \overline{\mathrm{CT}}, \overline{\mathrm{SE}}$. Most systems will save on microword bits by tying some of these lines to a fixed level or by connecting certain lines together, or by decoding microinstructions to generate appropriate Am2904 controls.

## Status Registers

Instruction lines $I_{5}, I_{4}, I_{3}, I_{2}, I_{1}, I_{0}$ control the Status Registers. Below, these lines are referred to as two octal digits.

## Micro Status Register ( $\mu$ SR)

The instruction codes for the Micro Status Register fall into three groups: Bit Operations, Register Operations and Load Operations (See Table 1 and Map 1). All operations require that $\overline{\mathrm{CE}}_{\mu}$ be LOW to operate.

TABLE 1. MICRO STATUS REGISTER
INSTRUCTION CODES.

| Bit Operations |  |  |
| :---: | :--- | :--- |
| $\mathbf{I}_{\mathbf{5 4 3 2 1 0}}$ <br> Octal | $\mu$ SR <br> Operation | Comments |
| 10 | $0 \rightarrow \mu \mathrm{Z}$ | RESET ZERO BIT |
| 11 | $1 \rightarrow \mu \mathrm{Z}$ | SET ZERO BIT |
| 12 | $0 \rightarrow \mu \mathrm{C}$ | RESET CARRY BIT |
| 13 | $1 \rightarrow \mathrm{C}_{\mathrm{C}}$ | SET CARRY BIT |
| 14 | $0 \rightarrow \mu_{\mathrm{N}}$ | RESET SIGN BIT |
| 15 | $1 \rightarrow \mu_{\mathrm{N}}$ | SET SIGN BIT |
| 16 | $0 \rightarrow \mu_{\text {OVR }}$ | RESET OVERFLOW BIT |
| 17 | $1 \rightarrow \mu$ OVR | SET OVERFLOW BIT |


| Register Operations |  |  |
| :---: | :---: | :---: |
| $\begin{gathered} \text { I }_{543210} \\ \text { Octal } \end{gathered}$ | $\mu$ SR Operation | Comments |
| $\begin{aligned} & 00 \\ & 01 \\ & 02 \\ & 03 \end{aligned}$ | $\begin{gathered} M x \rightarrow \mu x \\ 1 \rightarrow \mu X \\ M x \rightarrow \mu X \\ 0 \rightarrow \mu X \end{gathered}$ | LOAD MSR TO $\mu$ SR SET $\mu$ SR REGISTER SWAP RESET $\mu$ SR |


| Load Operations |  |  |
| :---: | :---: | :---: |
| $\begin{gathered} I_{543210} \\ \text { Octal } \end{gathered}$ | $\mu$ SR Operation | Comments |
| 06, 07 | $\begin{aligned} & \mathrm{IZ} \rightarrow \mu \mathrm{Z} \\ & \mathrm{l} \rightarrow \mu \mathrm{C} \\ & \mathrm{l} \rightarrow \mu_{\mathrm{N}} \\ & \mathrm{lovR}+\mu_{\mathrm{OVR}} \rightarrow \mu_{\mathrm{OVR}} \\ & \hline \end{aligned}$ | LOAD WITH OVERFLOW RETAIN |
| $\begin{aligned} & 30,31 \\ & 50,51 \\ & 70,71 \end{aligned}$ | $\begin{aligned} & \mathrm{Z} \rightarrow \mu \mathrm{Z} \\ & \mathrm{IC} \rightarrow \mu_{C} \\ & \mathrm{lN} \rightarrow \mu_{N} \\ & \mathrm{loVR}_{\mathrm{N}} \rightarrow \mu_{\mathrm{OVR}} \\ & \hline \end{aligned}$ | LOAD WITH CARRY INVERT |
| $\begin{gathered} 04,05 \\ 20-27 \\ 32-47 \\ 52-67 \\ 72-77 \end{gathered}$ | $\begin{aligned} & \operatorname{lZ} \rightarrow \mu Z \\ & \mathrm{l} \rightarrow \mu_{C} \\ & \mathrm{l}_{\mathrm{C}} \rightarrow \mu_{N} \\ & \operatorname{loVR}^{2} \rightarrow \mu_{\mathrm{OVR}} \end{aligned}$ | LOAD DIRECTLY <br> FROM <br> Iz, Ic, IN, Iovr |

Note: The above tables assume $\overline{\mathrm{CE}} \mu$ is LOW.

## MAP 1. MICRO STATUS REGISTER INSTRUCTION CODES.



Notes: 1. All unmarked locations are a load direct from $\mathrm{I}_{\mathrm{Z}}, \mathrm{I}_{\mathrm{C}}, \mathrm{I}_{\mathrm{N}}$, lovr.

Instruction Codes 108 to 178 are BIT operations. These operations set or reset the individual bits in the $\mu \mathrm{SR}$.

Instruction Codes $00_{8}$ to $03_{8}$ are REGISTER operations. These operations affect all bits in the $\mu \mathrm{SR}$.
$00_{8} \quad$ This instruction loads the $\mu \mathrm{SR}$ with the contents of the MSR while loading the MSR from the $Y$ inputs and is further explained under 'INTERRUPTS'.

018 This instruction SETS all $\mu$ SR bits.

This instruction SWAPS the contents of the $\mu$ SR and the MSR. It will also COPY one register to the other if the register to be copied is not enabled.
$03_{8} \quad$ This instruction RESETS all $\mu$ SR bits.
All instruction codes except those mentioned in the above two sections cause a LOAD operation from the $\mathrm{I}, \mathrm{I}_{\mathrm{c}}, \mathrm{I}_{\mathrm{N}}$, l lovr inputs. $^{\text {. }}$
$06_{8}, 07_{8}$ When a series of arithmetic operations are being executed sometimes it is not necessary to test for an overflow condition after each operation, but rather it is sufficient simply to know that an overflow occurred during any one of the operations. Use of these instructions captures the overflow condition by loading the $\mu \mathrm{SR}$ overflow bit with the LOGICAL OR of its present state and lovr. Thus, once an overflow occurs, $\mu$ OVR will remain set throughout the remaining operations.
$30_{8}, 31_{8}$, These instructions cause a load from the 1 inputs,
$50_{8}, 51_{8}$, but invert the carry bit. The reason for this is
$708,71_{8}$ explained more fully under the "BORROW SAVE' section.

All
others
The remaining instructions load the $\mu$ SR directly from the $\mathrm{I}, \mathrm{I}_{\mathrm{C}}, \mathrm{I}_{\mathrm{N}}$, love inputs.

## Machine Status Register (MSR)

The instruction codes for the MSR fall into two groups; REGISTER Operations and LOAD Operations. All operations require that $\overline{\mathrm{CE}}_{\mathrm{M}}$ be LOW to operate (See Table 2 and Map 2). BIT operations are accomplished by the use of Register or Load Operations with the $\overline{\mathrm{E}_{\mathrm{Z}}}, \overline{\mathrm{E}_{\mathrm{C}}}, \overline{\bar{E}_{\mathrm{N}}}, \overline{\mathrm{E}_{\mathrm{OV}}}$ inputs selectively set LOW.

Instruction codes $00_{8}-03_{8}$ and $05_{8}$ are REGISTER operations. They affect only those bits enabled by $\overline{E_{Z}}, \overline{E_{C}}, \overline{E_{N}}, \overline{E_{O V R}}$.
$00_{8} \quad$ This instruction loads the MSR from the $Y$ inputs while transferring the present contents to the $\mu$ SR. The use of this instruction is further explained under 'INTERRUPTS'.
$01_{8}$ This instruction SETS all enabled MSR bits.
028 This instruction SWAPS the contents of the $\mu$ SR and the MSR. It will also COPY one register to the other if the register to be copied is not enabled.

This instruction RESETS all enabled MSR bits.
This instruction COMPLEMENTS all enabled MSR bits.

All instruction codes except those mentioned in the above section cause a LOAD operation from the $\mathrm{I}_{\mathrm{Z}}, \mathrm{I}_{\mathrm{C}}, \mathrm{I}_{\mathrm{N}}$, love inputs.
048
The Am2904 Shift Linkage Multiplexer allows for shifts and rotates through the MSR CARRY bit. Some machines require a shift or rotate through the OVERFLOW bit. By using this code, which swaps the contents of the MSR CARRY bit (MC) and OVERFLOW bit (Movr), the shift or rotate can be made to appear to take place through the OVERFLOW bit. The procedure is to swap the bits, shift or rotate (any number or positions) then swap the bits again.

TABLE 2．MACHINE STATUS REGISTER INSTRUCTION CODES

| Register Operations |  |  |
| :---: | :--- | :--- |
| $\mathbf{I}_{543210}$ <br> Octal | MSR <br> Operation | Comments |
| 00 | $Y_{X \rightarrow M X}$ | LOAD YZ，YC，$Y_{N}$, |
| 01 | $1 \rightarrow M_{X}$ | YOVR TO MSR |
| 02 | $\mu_{X} \rightarrow M_{X}$ | SET MSR |
| 03 | REGISTER SWAP |  |
| 05 | $M_{X} \rightarrow M_{X}$ | RESET MSR |


| Load Operations |  |  |
| :---: | :---: | :---: |
| $\begin{gathered} \text { I }_{543210} \\ \text { Octal } \end{gathered}$ | MSR Operation | Comments |
| 04 | $\begin{aligned} & l_{Z \rightarrow M_{Z}} \\ & M_{O V R} \rightarrow M_{C} \\ & I_{N \rightarrow M_{N}} \\ & M_{C \rightarrow} \rightarrow M_{O V R} \end{aligned}$ | LOAD FOR SHIFT THROUGH OVERFLOW OPERATION |
| $\begin{aligned} & 10,11 \\ & 30,31 \\ & 50,51 \\ & 70,71 \end{aligned}$ | $\begin{aligned} & \operatorname{lz} \rightarrow \mathrm{Mz}_{2} \\ & \mathrm{IC} \rightarrow \mathrm{MC}_{\mathrm{C}} \\ & \mathrm{l}_{\mathrm{N} \rightarrow \mathrm{M}_{\mathrm{N}}} \\ & \mathrm{l}_{\mathrm{OVR} \rightarrow \mathrm{MOVR}^{2}} \end{aligned}$ | LOAD WITH CARRY INVERT |
| $\begin{gathered} 06,07 \\ 12-27 \\ 32-47 \\ 52-67 \\ 72-77 \end{gathered}$ |  | LOAD DIRECTLY FROM Iz，Ic in，lovr |

Notes：1．The above tables assume $\overline{\mathrm{CE}_{\mathrm{M}}}, \overline{\mathrm{E}_{\mathrm{Z}}}, \overline{\mathrm{E}_{\mathrm{C}}}, \overline{\mathrm{E}_{\mathrm{N}}}$ ， EOVR are LOW．
2．A shift－through－carry instruction loads $\mathrm{M}_{\mathrm{C}}$ irre－ spective of $\mathrm{I}_{5}-\mathrm{I}_{0}$ ．

MAP 2．MACHINE STATUS REGISTER IN－ STRUCTION CODES．

$06_{8}, 078$
$128-278$
$328-478$
$528-67_{8}$
$72_{8}-77_{8}$
108,118 $30_{8},{ }^{31} 8$
$50_{8}, 518$
708,718

These instructions load the MSR directly from the $\mathrm{I} Z, \mathrm{I}_{\mathrm{C}}, \mathrm{I}_{\mathrm{N}}$ ，lovr inputs．

These instructions cause a load from the I inputs but invert the CARRY bit．The reason for this is explained more fullu under the＇BORROW SAVE＇ section．

TABLE 3．Y OUTPUT INSTRUCTION CODES．

| $\overline{\text { OEY }}$ | $\mathrm{I}_{5}$ | $\mathrm{I}_{4}$ | Y Output | Comment |
| :---: | :---: | :---: | :---: | :---: |
| H | X | X | Z | Output Off High Impedance |
| L | L | X | $\mu_{i \rightarrow} Y_{i}$ | See Note 1 |
| L | H | L | $M_{i} \rightarrow Y_{i}$ |  |
| L | H | H | $i_{i \rightarrow} Y_{i}$ |  |

Notes：1．For the conditions：
$I_{5}, I_{4}, I_{3}, I_{2}, I_{1}, I_{0}$ are LOW，$Y$ is an input． $\overline{O_{Y}}$ is＂Don＇t Care＂for this condition．
2． X is＂Don＇t Care＂condition．

The more complex operations are intended to follow the calculation A－B to give an indication of which is the larger（A，B unsigned）or more positive（ $A, B$ in 2＇s complement form）．See Table 5.

Instruction codes $16_{8}$ and $17_{8}$ form the EXCLUSIVE－OR and the EXCLUSIVE－NOR functions of $M_{N}$ and $I_{N}$ ．The use of these instructions is explained under＂NORMALIZING＂．

TABLE 4. CONDITION CODE OUTPUT (CT) INSTRUCTION CODES.
TABLE 4. CONDITION CODE OUTPUT (CT) INSTRUCTION CODES.

| $\begin{aligned} & I_{3}-0 \\ & \text { HEX } \end{aligned}$ | $\mathrm{I}_{3}$ | $I_{2}$ | $l_{1}$ | 10 | $I_{5}=I_{4}=0$ | $I_{5}=0, I_{4}=1$ | $I_{5}=1, I_{4}=0$ | $I_{5}=I_{4}=1$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $\left(\mu_{N} \oplus \mu^{\prime} \mathrm{OVR}\right)+\mu_{Z}$ | $\left(\mu_{N} \oplus \mu^{\prime} \mathrm{OVR}\right)+\mu_{\mathrm{Z}}$ | $\left(M_{N} \oplus M_{\text {OVR }}\right)+M_{Z}$ | $(\mathrm{l} \oplus \oplus$ OVRR) + IZ |
| 1 | 0 | 0 | 0 | 1 |  | $\left(\mu_{N} \odot \mu_{O L V}\right)^{\prime} \bar{\mu}_{Z}$ | $\left(M_{N} \bigcirc M_{\text {OVR }}\right) \cdot \overline{M_{Z}}$ |  |
| 2 | 0 | 0 | 1 | 0 | $\mu_{N} \oplus \mu^{\prime} \mathrm{OVR}$ | $\mu_{N} \oplus \mu^{\prime} \mathrm{OVR}$ | $\mathrm{M}_{\mathrm{N}} \oplus \mathrm{MOVRR}^{\text {a }}$ | In $\oplus$ lovr |
| 3 | 0 | 0 | 1 | 1 | $\mu_{N} \odot \mu^{\prime} \mathrm{OVR}$ | $\mu_{N} \odot^{\prime} \mu_{\text {OVR }}$ | M $\bigcirc^{\text {© Movr }}$ | In N Oovr |
| 4 | 0 | 1 | 0 | 0 | $\underline{\mu}$ | $\underline{\mu}_{Z}$ | Mz |  |
| 5 | 0 | 1 | 0 | 1 | $\bar{\mu}_{Z}$ | $\bar{\mu}_{Z}$ | $\bar{M}_{z}$ | Iz |
| 6 | 0 | 1 | 1 | 0 | $\underline{\mu}{ }^{\text {O }}$ OR | $\underline{\mu} \mathrm{OVR}$ | Movr | lovr |
| 7 | 0 | 1 | 1 | 1 | $\bar{\mu}_{\text {OVR }}$ | $\bar{\mu}$ OVR | Movr | İova |
| 8 | 1 | 0 | 0 | 0 | $\mu_{C}+\mu_{Z}$ | $\mu_{\mathrm{C}}+\mu_{\mathrm{Z}}$ | $\mathrm{Mc}_{\mathrm{c}}+\mathrm{Mz}$ | $\overline{\mathrm{C}}+\mathrm{lz}(2)$ |
| 9 | 1 | 0 | 0 | 1 | $\bar{\mu}^{C} \cdot \bar{\mu}_{Z}$ | $\bar{\mu}^{\prime} \cdot \bar{\mu}_{Z}$ | $\bar{M}_{C} \cdot \bar{M}_{Z}$ | Ic.Iz (2) |
| A | 1 | 0 | 1 | 0 | ${ }^{\mu} \mathrm{C}$ | $\underline{\mu} \mathrm{C}$ | $\mathrm{Mc}_{\mathrm{M}}$ | ${ }^{\text {Ic }}$ |
| B | 1 | 0 | 1 | 1 | $\bar{\mu}_{C}$ | $\underline{\mu}_{\underline{C}}$ | $\bar{M}{ }_{c}$ | $\stackrel{\text { c }}{\text { c }}$ |
| C | 1 | 1 | 0 | 0 | $\bar{\mu}_{C} \pm \mu_{Z}$ | $\bar{\mu}_{C} \pm \mu_{Z}$ | $\bar{M}_{C}+M_{z}$ | $\overline{\mathrm{C}}+\mathrm{lz}$ |
| D | , | 1 | 0 | 1 | $\mu{ }^{\prime} \cdot \bar{\mu}_{Z}$ | $\mu \mathrm{C} \cdot \bar{\mu}_{\mathrm{z}}$ | $\mathrm{Mc}^{\prime} \cdot \bar{M}_{\mathrm{Z}}$ | $1 \mathrm{c} \cdot \overline{\mathrm{I}}$ |
| E | 1 | 1 | 1 | 0 | ${ }^{\prime} \mathrm{N} \oplus \mathrm{M}_{\mathrm{N}}$ | $\underline{\mu}^{N}$ | $\mathrm{M}_{\mathrm{N}}$ | IN |
| F | 1 | 1 | 1. | 1 |  | $\bar{\mu}_{N}$ | $\bar{M}_{N}$ | in |

NOTES: 1. $\oplus$ Represents EXCLUSIVE-OR
2. Correct code as stated.
$\odot$ Represents EXCLUSIVE-NOR or coincidence.
TABLE 5. CRITERIA FOR COMPARING TWO NUMBERS FOLLOWING "A MINUS B" OPERATION.

| Relation | For Unsigned Numbers |  |  | For 2's Complement Numbers |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Status | I3-0 |  | Status | 13-0 |  |
|  |  | $\mathbf{C T}=\mathrm{H}$ | $\mathbf{C T}=\mathbf{L}$ |  | $\mathbf{C T}=\mathrm{H}$ | $C T=L$ |
| $A=B$ | $z=1$ | 4 | 5 | $\mathrm{Z}=1$ | 4 | 5 |
| $A \neq B$ | $\mathrm{Z}=0$ | 5 | 4 | $\mathrm{Z}=0$ | 5 | 4 |
| $A \geqslant B$ | $\mathrm{C}=1$ | A | B | $N \odot O V R=1$ | 3 | 2 |
| $A<B$ | $\mathrm{C}=0$ | B | A | $N \oplus$ OVR $=1$ | 2 | 3 |
| $A>B$ | $C \cdot \bar{Z}=1$ | D | C | $(\mathrm{N} \bigcirc O \mathrm{OR}) \cdot \bar{Z}=1$ | 1 | 0 |
| $A \leqslant B$ | $\overline{\mathrm{C}}+\mathrm{Z}=1$ | C | D | $(\mathrm{N} \oplus \mathrm{OVR})+\mathrm{Z}=1$ | 0 | 1 |
| $\begin{array}{lll} \oplus=\text { Exclusive } O R & H=H I G H & \text { Note: For Am2910, the } C C \text { input is active LOW, so use } \\ \odot=\text { Exclusive NOR } & L=L O W & \\ I_{3-0} \text { code to produce } C T=L \text { for the desired test. } \end{array}$ |  |  |  |  |  |  |

## Shift Linkage Multiplexer

The five instruction lines $I_{10}, I_{9}, I_{8}, I_{7}, I_{6}$ control the SHIFT LINKAGE multiplexer. All instructions set up the linkages for both the ALU shifter (RAM shifter on the Am2901A) and the Q register.
UP and DOWN shifts are decided by $\mathrm{I}_{10}$ which should be connected to $I_{8}$ of the Am2903's instruction lines or $I_{7}$ of the Am2901's instruction lines. A wide range of input and output connections are provided, allowing for single or double length shifting or rotating with or without the use of the MSR CARRY or SIGN bits (See Table 6).
In the following discussion of some of the shifts the instruction codes are given as two octal digits $A B ; A$ represents $I_{10}, 19, B^{\prime}$ represents $\mathrm{I}_{8}, \mathrm{I}_{7}, \mathrm{I}_{6}$.
When adding and down shifting on the same microcycle, (i.e. when doing multiplication or averaging) the shifter input must be the present CARRY, IC, rather than the carry resulting from the last cycle ( $\mathrm{MC}_{\mathrm{C}}$ ). Instruction Code $13_{8}$ accomplishes this for unsigned arithmetic. For 2's complement arithmetic, the required shifter input is: $I_{N} \oplus$ loVR. This is provided by $^{\text {Instruction }}$ Code 168.
Instruction Codes $14_{8}, 15_{8}, 11_{8}$ provide the RIGHT. ROTATE THROUGH CARRY, ROTATE BRANCH CARRY and ROTATE WITHOUT CARRY functions respectively.
Instruction Codes $34_{8}, 35_{8}, 37_{8}$ provide the LEFT ROTATE THROUGH CARRY, ROTATE BRANCH CARRY and ROTATE WITHOUT CARRY functions respectively.

The shift outputs are in the high impedance state unless $\overline{\mathrm{SE}}$ is LOW.

Loading of the $M_{C}$ bit by a shift operation overrides any loading or holding of the $M_{C}$ bit by MSR Instructions ( $I_{0-5}, \overline{C E}_{M}$ and EC ).

## "CARRY-IN" Control Multiplexer

The two instruction lines $\mathrm{I}_{12}, \mathrm{l}_{11}$ control the source of the CARRY output ( $\mathrm{C}_{0}$ ).

When $I_{12}=0 \quad C_{0}=I_{11}$
When $l_{12}=1$ and $l_{11}=0$, the external carry input $C_{x}$ is presented to the carry output.

When $I_{1_{2}}=l_{11}=1$ the carry output is selected from $\mu_{C}, \overline{\mu_{C}}$, $M_{C}$ or $\overline{M_{C}}$ as defined by $I_{5}, I_{3}, I_{2}, I_{1}$ (See Table 7).

## APPLICATIONS INFORMATION

## Borrow - Save

One of the capabilities of the Am2900 Family is the complete emulation of other processing machines. One requirement of an emulator is that, when a calculation is being performed, not only must the answer obtained from the Am2900 chips be the same as that from the machine being emulated, but after each machine level instruction, the status bits must be identical.

TABLE 6．SHIFTLINKAGE MULTIPLEXER INSTRUCTION CODES．

| $l_{10}$ | 19 | 18 | 17 | 16 | Mc | RAM | Q | $\mathbf{S I O}_{0}$ | $\mathbf{S I O}$ | $\mathbf{Q I O}_{0}$ | Q10n | Loaded into MC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 |  | $\begin{gathered} \text { LSB } \\ -7 \end{gathered}$ |  | z | 0 | z | 0 |  |
| 0 | 0 | 0 | 0 | 1 |  | － |  | z | 1 | z | 1 |  |
| 0 | 0 | 0 | 1 | 0 |  | －1 |  | $z$ | 0 | z | $M_{n}$ | $\mathrm{SIO}_{0}$ |
| 0 | 0 | 0 | 1 | 1 |  | － |  | z | 1 | z | $\mathrm{SIO}_{0}$ |  |
| 0 | 0 | 1 | 0 | 0 |  | － |  | z | Mc | z | $\mathrm{SIO}_{0}$ |  |
| 0 | 0 | 1 | 0 | 1 |  | $\rightarrow$ |  | z | $M_{N}$ | Z | $\mathrm{SIO}_{0}$ |  |
| 0 | 0 | 1 | 1 | 0 |  | $\rightarrow$ |  | Z | 0 | z | $\mathrm{SIO}_{0}$ |  |
| 0 | 0 | 1 | 1 | 1 |  | $\checkmark$ |  | z | 0 | z | $\mathrm{SIO}_{0}$ | Q10 |
| 0 | 1 | 0 | 0 | 0 |  | －1 |  | Z | $\mathrm{SIO}_{0}$ | $z$ | Q1O。 | $\mathrm{SIO}_{0}$ |
| 0 | 1 | 0 | 0 | 1 |  | 1 |  | Z | Mc | Z | Q1O。 | $\mathrm{SIO}_{0}$ |
| 0 | 1 | 0 | 1 | 0 |  | － |  | Z | $\mathrm{SIO}_{0}$ | Z | $\mathrm{QlO}_{0}$ |  |
| 0 | 1 | 0 | 1 | 1 |  | $-1$ |  | z | Ic | Z | $\mathrm{SIO}_{0}$ |  |
| 0 | 1 | 1 | 0 | 0 |  | － |  | z | Mc | Z | $\mathrm{SIO}_{0}$ | Q10 |
| 0 | 1 | 1 | 0 | 1 |  | 1 |  | Z | $\mathrm{QlO}_{0}$ | Z | $\mathrm{SIO}_{0}$ | $\mathrm{QIO}_{0}$ |
| 0 | 1 | 1 | 1 | 0 |  |  |  | z | IN $\oplus$ lovr | z | $\mathrm{SiO}_{0}$ |  |
| 0 | 1 | 1 | 1 | 1 |  |  |  | z | Q1O。 | Z | $\mathrm{SIO}_{0}$ |  |
| 1 | 0 | 0 | 0 | 0 |  | $\begin{aligned} & \text { si } \\ & 1-0 \end{aligned}$ |  | 0 | z | 0 | z | $\mathrm{SIO}_{\mathrm{n}}$ |
| 1 | 0 | 0 | 0 | 1 |  | －1 |  | 1 | z | 1 | z | $\mathrm{SIO}_{n}$ |
| 1 | 0 | 0 | 1 | 0 |  | $7^{-0}$ |  | 0 | z | 0 | z |  |
| 1 | 0 | 0 | 1 | 1 |  | －1 |  | 1 | z | 1 | Z |  |
| 1 | 0 | 1 | 0 | 0 |  |  |  | $\mathrm{QOO}_{n}$ | Z | 0 | Z | $\mathrm{SIO}_{\mathrm{n}}$ |
| 1 | 0 | 1 | 0 | 1 |  | 7． |  | $\mathrm{QlO}_{n}$ | z | 1 | Z | $\mathrm{SIO}_{\mathrm{n}}$ |
| 1 | 0 | 1 | 1 | 0 |  |  |  | $\mathrm{QIO}_{n}$ | Z | 0 | Z |  |
| 1 | 0 | 1 | 1 | 1 |  |  |  | QIOn | Z | 1 | Z |  |
| 1 | 1 | 0 | 0 | 0 |  |  |  | $\mathrm{SIO}_{\mathrm{n}}$ | Z | $\mathrm{QIO}_{n}$ | Z | $\mathrm{SIO}_{n}$ |
| 1 | 1 | 0 | 0 | 1 |  | ） |  | Mc | Z | $\mathrm{QO}_{n}$ | Z | $\mathrm{SIO}_{\mathrm{n}}$ |
| 1 | 1 | 0 | 1 | 0 |  | , |  | $\mathrm{SIO}_{n}$ | z | QIOn | z |  |
| 1 | 1 | 0 | 1 | 1 |  |  |  | $\mathrm{Mc}_{\mathrm{C}}$ | z | 0 | z |  |
| 1 | 1 | 1 | 0 | 0 |  |  |  | $\mathrm{QIO}_{n}$ | z | MC | z | $\mathrm{SIO}_{n}$ |
| 1 | 1. | 1 | 0 | 1 |  |  |  | QIOn | z | $\mathrm{SIO}_{n}$ | z | $\mathrm{SIO}_{\mathrm{n}}$ |
| 1 | 1 | 1 | 1 | 0 |  | $7$ |  | $\mathrm{QIO}_{n}$ | Z | MC | Z |  |
| 1 | 1 | 1 | 1 | 1 |  |  |  | QIOn | 2 | $\mathrm{SIO}_{3}$ | z |  |

2．Outputs enabled and $M_{C}$ loaded only if $\overline{S E}$ is LOW
．Loading of $\mathrm{M}_{\mathrm{C}}$ from $\left.\right|_{10-6}$ overrides control from $\mathrm{I}_{5-0}, \overline{\mathrm{CE}}_{\mathrm{M}}, \overline{\mathrm{E}}_{\mathrm{C}}$ ．

## TABLE 7. CARRY-IN CONTROL

 MULTIPLEXER INSTRUCTION CODES.| $I_{12}$ | $I_{11}$ | $I_{5}$ | $I_{3}$ | $I_{2}$ | $I_{1}$ | $C_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $X$ | $X$ | $X$ | $X$ | 0 |
| 0 | 1 | $X$ | $X$ | $X$ | $X$ | 1 |
| 1 | 0 | $X$ | $X$ | $X$ | $X$ | $C_{X}$ |
| 1 | 1 | 0 | 0 | $X$ | $X$ | $\mu_{C}$ |
| 1 | 1 | 0 | $X$ | 1 | $X$ | $\mu C$ |
| 1 | 1 | 0 | $X$ | $X$ | 1 | $\mu_{C}$ |
| 1 | 1 | 0 | 1 | 0 | 0 | $\bar{\mu}_{C}$ |
| 1 | 1 | 1 | 0 | $X$ | $X$ | $M_{C}$ |
| 1 | 1 | 1 | $X$ | 1 | $X$ | $M_{C}$ |
| 1 | 1 | 1 | $X$ | $X$ | 1 | $M_{C}$ |
| 1 | 1 | 1 | 1 | 0 | 0 | $\bar{M}_{C}$ |

There are alternative methods for subtracting in a digital machine and the state of the CARRY after the calculation depends on the method. For instance, the subtraction of 0100 from 1010 by the 2's complement add method generates a result of 0110 with a CARRY. Direct subtraction however, yields an answer of 0110 with no BORROW.

Many machines store the state of the CARRY for subtract operations, and this is the recommended method for maximum effective use of the Am2904, but, to allow those machines which store the BORROW to be efficiently emulated; the Am2904 has allocated special instructions. Using these codes causes the CARRY bit to be inverted before storage in the status registers and also re-inverts these status bits before using them as carry inputs. These codes are $10_{8}$, $11_{8}, 30_{8}, 31_{8}, 50_{8}, 51_{8}, 70_{8}, 71_{8}\left({ }_{5}-0\right)$.
Notice that when these codes are used to load the inverted CARRY to either of the status registers, the CT output selected by the Condition Code Multiplexer assumes the CARRY is inverted and still defines whether $A>B$ or $A \leqslant B$ (See Table 4).

Similarly, when doing a compare on a machine which saves the BORROW, testing for $A>B, A \leqslant B$ forces the complement of the CARRY to be stored in the status registers (See Tables 1 and 2).

## Normalizing

Normalizing is the process of stripping off all leading sign bits until the two most significant bits are complementary. The Am2904 facilitates both single and double length normaliza-
tion in the Am2901 and the Am2903. When using the NORMALIZE special instructions with the Am2903, the EXCLUSIVE - OR of the most significant two bits is generated at the $\mathrm{C}_{\mathrm{n}+4}$ pin of the most significant Am2903. The EXCLUSIVE - OR of the two bits next to the most significant bit is also generated at the OVR pin. The procedure for normalizing then is to loop on the normalize instruction with a branch condition on the $\mathrm{C}_{\mathrm{n}+4}$ state or the OVR state, depending on the architecture employed. The $C_{n+4}$ or OVR output is routed to the Am2910 CC input through the Am2904 Condition Code multiplexer. As the contents of the status registers always refer to the last cycle, not the present one, the last operation in normalizing is to downshift, bringing the sign bit ( $\mathrm{M}_{\mathrm{N}}$ ) back into the most significant bit position. This is achieved using the shift operations $05_{8}\left(l_{10-6}\right)$ for double length normalizing, and 028 for single length normalizing. For more details regarding normalizing with the Am2903 see the Am2903 data sheet.

The Am2901 does not have the EXCLUSIVE - OR gates to help with normalizing, so the Am2904 includes in the Condition Code multiplexer the EXCLUSIVE - OR and EXCLUSIVE NOR functions of $M_{N}$ (the sign bit resulting from the last operation) and $I_{N}$ (the sign bit resulting from the present operation). Instruction codes $16_{8}$ and $17_{8}\left(1_{5-0}\right)$ form the EXCLUSIVE-OR and EXCLUSIVE-NOR functions of $M_{N}$ and ${ }_{1} \mathrm{~N}$.

## Interrupts

Some machines allow interrupts only at the machine instruction level while others allow them at the microinstruction level. The Am2904 is designed to handle both cases.
When the machine is interrupted, it is necessary to store the contents of either the MSR (machine instruction level interrupts) or both the status registers (micro instruction level interrupts) into an external store. This transfer is intended to take place over the Y input/output pins (See Table 3).

After the interrupt has been serviced the registers must be restored to their pre-interrupt state. This is accomplished by two operations of instruction $0_{8}\left({ }^{(5-0}\right)$ which loads the MSR from the $Y$ inputs while loading the $\mu$ SR from the MSR. Thus, the pre-interrupt contents of the $\mu \mathrm{SR}$ are first loaded to the MSR (first instruction $00_{8}$ ), then this data is transferred to the $\mu \mathrm{SR}$ while the MSR is restored to its pre-interrupt state (second instruction $00_{8}$ ).
In controllers and some other microprogrammed machines the applications program itself is often in the microprogram memory; that is, there is no macroinstruction set. These machines require only a microstatus register since there is no separate machine status. The MSR in the Am2904 can be used as a one-level stack on the microstatus register. When an interrupt occurs, the $\mu \mathrm{SR}$ and the MSR are simply swapped ( $\mathrm{I}_{5-0}=02_{8}$ ).




## SWITCHING CHARACTERISTICS

The tables below define the Am2904 switching characteristics. Tables A are set-up and hold times relative to the clock LOW-toHIGH transition. Tables B are combinational delays. Tables $C$ are clock requirements. All measurements are made at 1.5 V with input levels at $O V$ or $3 V$. All values are in ns. All outputs have maximum DC loading.

GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE
( $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $\left.+5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)$.
A. Set-up and Hold Times (ns)

| Input | $t_{8}$ | $t_{\text {h }}$ |
| :---: | :---: | :---: |
| $\mathrm{l}, \mathrm{l} \mathrm{I}^{\prime}$, lovr | 14 | 5 |
| $\mathrm{lc}_{C}\left(l_{1} \mathrm{l}_{2} \mathrm{l}_{3}=001\right)$ | 27 | 5 |
| Ic ( $\left.l_{1} \quad l_{2} l_{3} \neq 001\right)$ | 14 | 5 |
| $\overline{\mathrm{CE}} \mu$ | 18 | 3 |
| $\overline{\mathrm{CE}}_{\mathrm{M}}$ | 23 | 3 |
| $\bar{E}_{\mathrm{Z}}, \bar{E}_{\mathrm{C}}, \bar{E}_{\mathrm{N}}, \bar{E}_{\text {OVR }}$ | 22 | 3 |
| $10-15$ | 41 | 1 |
| $I_{6}-I_{10}$ | 40 | 1 |
| SE | 36 | 0 |
| $\begin{aligned} & Y_{Z}, Y_{C}, Y_{N}, Y_{O V R} \\ & \left(I_{0-5}=L O W\right) \end{aligned}$ | 15 | 5 |
| $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{n} \\ & \mathrm{QIO}_{0}, \mathrm{QIO}_{n} \end{aligned}$ | 20 | 5 |

B. Combinational Delays (ns)

| From (Input) | To (Output) | $\mathrm{t}_{\text {pd }}$ |
| :---: | :---: | :---: |
|  | $Y_{Z}, Y_{C}, Y_{N}, Y_{\text {OVR }}$ | 38 |
| CP | $Y_{Z}, Y_{C}, Y_{N}, Y_{\text {OVR }}$ | 41 |
| $\mathrm{I}_{4}, \mathrm{I}_{5}$ | $Y_{Z}, Y_{C}, Y_{N}, Y_{O V R}$ | 35 |
| $\mathrm{lz}, \mathrm{I}_{\mathrm{c},} \mathrm{IN}, \mathrm{l}$ lovr | CT | 33 |
| CP | CT | 36 |
| $\mathrm{I}_{0}-\mathrm{I}_{5}$ | CT | 33 |
| $\mathrm{C}_{\mathrm{x}}$ | $\mathrm{Co}_{0}$ | 20 |
| CP | $\mathrm{C}_{0}$ | 27 |
| 1, 2, 3, 5, 11, 12 | $\mathrm{C}_{0}$ | 39 |
| $\mathrm{SIO}_{n}, \mathrm{QlO}_{n}$ | $\mathrm{SIO}_{0}$ | 19 |
| $\mathrm{SIO}_{0}, \mathrm{QlO}_{0}$ | $\mathrm{SIO}_{n}$ | 19 |
| $\mathrm{Ic}_{\mathrm{c}, \mathrm{IN},}$ lova | $\mathrm{SIO}_{n}$ | 26 |
| $\mathrm{SIO}_{n}, \mathrm{QIO}_{n}$ | $\mathrm{QO}_{0}$ | 19 |
| $\mathrm{SIO}_{\mathrm{o}}, \mathrm{QlO}_{0}$ | $\mathrm{QIO}_{n}$ | 19 |
| CP | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{\mathrm{n}}, \mathrm{QIO}_{0}, \\ & \mathrm{QiO}_{\mathrm{n}} \end{aligned}$ | 30 |
| ${ }_{16-10}$ | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{n}, \mathrm{QIO}_{0}, \\ & \mathrm{QIO}_{\mathrm{n}} \end{aligned}$ | 26 |

## C. Clock Requirements (ns)

| Minimum Clock LOW Time | 20 |
| :--- | :--- |
| Minimum Clock HIGH Time | 20 |

## D. Enable/Disable Times (ns)

$C_{L}=5.0 \mathrm{pF}$ for output disable tests
measured to 0.5 V change of output voltage level.

| From <br> (Input) | To <br> (Output) | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\mathrm{OE}_{\mathrm{CT}}$ | CT | 23 | 18 |
| SE | $\mathrm{SIO}_{\mathrm{O}}, \mathrm{SIO}_{\mathrm{n}}$ <br> $\mathrm{QOO}_{\mathrm{O}}, \mathrm{QIO}_{\mathrm{n}}$ | 30 | 12 |
| $\mathrm{I}_{10}$ | $\mathrm{SIO}_{\mathrm{O}}, \mathrm{SIO}_{\mathrm{n}}$ <br> $\mathrm{QO}_{\mathrm{O}}, \mathrm{QIO}_{\mathrm{n}}$ | 39 | 29 |
| OE | $\mathrm{Y}_{\mathrm{Z}}, \mathrm{Y}_{\mathrm{C}}, \mathrm{Y}_{\mathrm{N}}, \mathrm{Y}_{\mathrm{OVR}}$ | 26 | 21 |
| $\mathrm{I}_{\mathrm{O}}-\mathrm{I}_{5}$ | $\mathrm{Y}_{\mathrm{Z}}, \mathrm{Y}_{\mathrm{C}}, \mathrm{Y}_{\mathrm{N}}, \mathrm{Y}_{\mathrm{OVR}}$ | 28 | 40 |

## GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE

$$
\left(\mathrm{T}_{\mathrm{C}}=-55 \text { to }+125^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.5 \text { to }+5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

A. Set-up and Hold Times (ns)
B. Combinational Delays (ns)

| Input | $t_{s}$ | $t_{\text {h }}$ |
| :---: | :---: | :---: |
| $\mathrm{lz}, \mathrm{I}_{\mathrm{N}}$, lovr | 15 | 5 |
| IC ( $I_{1} \mathrm{I}_{2} \mathrm{I}_{3}=001$ ) | 28 | 5 |
| IC ( $l_{1} \mathrm{l}_{2} \mathrm{l}_{3} \neq 001$ ) | 15 | 5 |
| $\overline{\mathrm{CE}} \mu$ | 20 | 3 |
| $\overline{C E}_{M}$ | 23 | 4 |
| $\bar{E}_{\mathrm{Z}}, \bar{E}_{\mathrm{C}}, \overline{\mathrm{E}}_{\mathrm{N}}, \overline{\mathrm{E}}_{\text {OVR }}$ | 23 | 4 |
| $\mathrm{I}_{0}-\mathrm{I}_{5}$ | 48 | 2 |
| $I_{6}-I_{10}$ | 44 | 2 |
| $\overline{\text { SE }}$ | 40 | 0 |
| $\begin{aligned} & Y_{Z}, Y_{C}, Y_{N}, Y_{O V R} \\ & \left(I_{0-5}=\text { LOW }\right) \end{aligned}$ | 16 | 6 |
| $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{\mathrm{n}} \\ & \mathrm{QIO}_{\mathrm{o}}, \mathrm{QIO}_{\mathrm{n}} \end{aligned}$ | 20 | 5 |


| From (Input) | To (Output) | $t_{\text {pd }}$ |
| :---: | :---: | :---: |
| $\mathrm{Iz}, \mathrm{I}_{\mathrm{c}}, \mathrm{I}_{\mathrm{N}}, \mathrm{lovr}$ | $Y_{Z}, Y_{C}, Y_{N}, Y_{\text {OVR }}$ | 40 |
| CP | $Y_{Z}, Y_{C}, Y_{N}, Y_{\text {OVR }}$ | 45 |
| $1_{4}, I_{5}$ | $Y_{Z}, Y_{C}, Y_{N}, Y_{O V R}$ | 38 |
| $\mathrm{l}, \mathrm{l}, \mathrm{I}^{\prime} \mathrm{I}_{\mathrm{N},}$ l lovr | CT | 44 |
| CP | CT | 40 |
| $\mathrm{l}_{0}-\mathrm{l}_{5}$ | CT | 41 |
| $\mathrm{C}_{\mathrm{X}}$ | $\mathrm{C}_{\mathrm{O}}$ | 22 |
| CP | $\mathrm{Co}_{0}$ | 28 |
| $\mathrm{I}_{1}, 2,3,5,11,12$ | $\mathrm{C}_{0}$ | 42 |
| $\mathrm{SIO}_{\mathrm{n}}, \mathrm{QIO}_{\mathrm{n}}$ | $\mathrm{SIO}_{0}$ | 20 |
| $\mathrm{SIO}_{0}, \mathrm{QlO}_{0}$ | $\mathrm{SIO}_{n}$ | 20 |
| Ic, In, lovr | $\mathrm{SIO}_{n}$ | 29 |
| $\mathrm{SIO}_{\mathrm{n}}, \mathrm{QIO}_{n}$ | $\mathrm{QO}_{0}$ | 20 |
| $\mathrm{SIO}_{0}, \mathrm{QlO}_{0}$ | $\mathrm{QIO}_{n}$ | 20 |
| CP | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}} \mathrm{SIO}_{n}, \mathrm{QIO}_{\mathrm{o}}, \\ & \mathrm{QiO}_{n} \end{aligned}$ | 32 |
| $\mathrm{I}_{6}-110$ | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}, \mathrm{QIO}_{\mathrm{o}}, \\ & \mathrm{QIO}_{\mathrm{n}} \end{aligned}$ | 31 |

## C. Clock Requirements (ns)

| Minimum Clock LOW Time | 25 |
| :--- | :--- |
| Minimum Clock HIGH Time | 25 |

## D. Enable/Disable Times (ns)

$C_{L}=5.0 \mathrm{pF}$ for output disable tests
measured to 0.5 V change of output voltage level.

| From (Input) | To (Output) | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\mathrm{OE}_{C T}$ | CT | 25 | 18 |
| SE | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{\mathrm{n}} \\ & \mathrm{QIO}_{\mathrm{o}}, \mathrm{QIO}_{n} \end{aligned}$ | 35 | 16 |
| 110 | $\begin{aligned} & \mathrm{SIO}_{\mathrm{o}}, \mathrm{SIO}_{\mathrm{n}} \\ & \mathrm{QIO}_{\mathrm{o}}, \mathrm{QIO}_{\mathrm{n}} \end{aligned}$ | 43 | 32 |
| OEY | $\begin{aligned} & Y_{Z}, Y_{C}, Y_{N} \\ & Y_{O V R} \end{aligned}$ | 28 | 23 |
| $10-15$ | $\begin{aligned} & Y_{Z}, Y_{C}, Y_{N}, \\ & Y_{O V R} \end{aligned}$ | 30 | 41 |

## SWITCHING TEST CIRCUIT

## A. THREE-STATE OUTPUTS <br> B. NORMAL OUTPUTS



TC001120

$$
R_{1}=\frac{5.0-V_{B E}-V_{O L}}{1 \mathrm{OL}+V_{\mathrm{OL}} / 1 \mathrm{~K}}
$$



$$
\begin{array}{r}
\mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{IOH}} \\
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}} / \mathrm{R}_{2}}
\end{array}
$$

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in text fixture.
2. $\mathrm{S}_{1}, \mathrm{~S}_{2}, \mathrm{~S}_{3}$ are closed during function all tests and AC tests except output enable tests.
3. $\mathrm{S}_{1}$ and $\mathrm{Z}_{3}$ are closed while $\mathrm{S}_{2}$ is open for tpzH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2904

| Pin \# <br> (DIP) | Pin Label | Test Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 25 | $\mathrm{C}_{0}$ | B | 470 | 3 K |
| 27 | CT | A | 430 | 1 K |
| 28 | $\mathrm{Y}_{\mathrm{OVR}}$ | A | 220 | 1 K |
| 29 | $\mathrm{Y}_{\mathrm{N}}$ | A | 220 | 1 K |
| 31 | $\mathrm{Y}_{\mathrm{C}}$ | A | 220 | 1 K |
| 32 | $\mathrm{Y}_{\mathrm{Z}}$ | A | 220 | 1 K |
| 33 | $\mathrm{QIO}_{\mathrm{N}}$ | A | 430 | 1 K |
| 34 | $\mathrm{QIO}_{0}$ | A | 430 | 1 K |
| 35 | $\mathrm{SIO}_{\mathrm{N}}$ | A | 430 | 1 K |
| 36 | $\mathrm{SIO}_{0}$ | A | 430 | 1 K |

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathbb{I H}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

For additional information on testing, see section
"Guidelines on Testing Am2900 Family Devices."

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus-transceiver
- Open-collector bus driver output can sink 100 mA at 0.8 V max
- Two-port input to D-type register on driver
- Receiver has output latch for pipeline operation
- Three-state receiver outputs sink 12 mA
- Advanced low-power Schottky processing


## GENERAL DESCRIPTION

The Am2905 is a high-performance, low-power Schottky bus transceiver intended for bipolar or MOS microprocessor system applications. The device consists of four D-type edge-triggered flip-flops with a built-in two-input multiplexer on each. The flip-flop outputs are connected to four opencollector bus drivers. Each bus driver is internally connected to one input of a differential amplifier in the receiver. The four receiver differential amplifier outputs drive four D-type latches that feature three-state outputs.

This LSI bus transceiver is fabricated using advanced lowpower Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The open-collector bus output can sink up to 100 mA at 0.8 V maximum. The BUS input differential amplifier contains disconnect protection diodes such that the bus is fail-safe when power is not applied. The bus enable input ( $\overline{\mathrm{BE}}$ ) is used to force the driver outputs to the high-impedance state. When $\overline{B E}$ is HIGH, the driver is disabled. The open-collector structure of the driver allows wired-OR operations to be performed on the bus.

The input register consists of four D-type flip-flops with a buffered common clock and a two-input multiplexer at the input of each flip-flop. A common select input (S) controls the four multiplexers. When $S$ is LOW, the $A_{i}$ data is stored in the register and when $S$ is HIGH, the $B_{i}$ data is stored. The buffered common clock (DRCP) enters the data into this driver register on the LOW-to-HIGH transition.

Data from the $A$ or $B$ inputs is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{\mathrm{RLE}})$ input. When the $\overline{\mathrm{RLE}}$ input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted and $\overline{O E}$ LOW). When the $\overline{R L E}$ input is HIGH, the latch will close and retain the present data regardless of the bus input. The four latches have threestate outputs and are controlled by a buffered common three-state control ( $\overline{\mathrm{OE}}$ ) input. When $\overline{\mathrm{OE}}$ is HIGH, the receiver outputs are in the high-impedance state.



CD002090

Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2905
```



```
Blank - Standard processing
B - Burn-in
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) )
M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-24-pin CERDIP
F-24-pin flatpak
P -24-pin plastic DIP
X-Dice
Device type
OC Bus Transceiver
```



Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
| 4, 8, 16, 20 | $\begin{array}{ll} A_{0}, & A_{1}, \\ A_{2}, & A_{3} \\ \hline \end{array}$ | 1 | The " A " word data input into the two input multiplexer of the driver register. |
| 3, 9, 15, 21 | $\begin{array}{ll} \mathrm{B}_{0}, & \mathrm{~B}_{1} \\ \mathrm{~B}_{2}, & \mathrm{~B}_{3} \\ \hline \end{array}$ | 1 | The " B " word data input into the two input multiplexers of the driver register. |
| 13 | S | 1 | Select. When the select input is LOW, the A data word is applied to the driver register. When the select input is HIGH, the B word is applied to the driver register. |
| 23 | DRCP | 1 | Driver Clock Pulse. Clock pulse for the driver register. |
| 11 | $\overline{B E}$ | 1 | Bus Enable. When the Bus Enable is HIGH, the four drivers are in the high impedance state. |
| $\begin{aligned} & \hline 5 \\ & 7 \\ & 17,19 \end{aligned}$ | BUS $_{0}$, <br> BUS $_{1}$ <br> BUS $_{2}$, <br> BUS $_{3}$ | 1/0 | The four driver outputs and receiver inputs (data is inverted). |
| $\begin{aligned} & 2,10 \\ & 14,22 \end{aligned}$ | $\mathrm{R}_{0}, \mathrm{R}_{1}$, $\mathrm{R}_{2}, \mathrm{R}_{3}$ | 0 | The four receiver outputs. Data from the bus is inverted while data from the A or B inputs is non-inverted. |
| 1 | RLE | 0 | Receiver Latch Enable. When $\overline{\text { RLE }}$ is LOW, data on the BUS inputs is passed through the receiver latches. When RLE is HIGH, the receiver latches are closed and will retain the data independent of all other inputs. |
| 12 | $\overline{\text { OE }}$ | 1 | Output Enable. When the $\overline{O E}$ input is HIGH, the four three state receiver outputs are in the high-impedance state. |

FUNCTION TABLE

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|c|}{INPUTS} \& \multicolumn{2}{|l|}{INTERNAL TO DEVICE} \& BUS \& OUTPUT \& <br>
\hline S \& $A_{i}$ \& Bi \& DRCP \& BE \& $\overline{\text { RLE }}$ \& $\overline{O E}$ \& $\mathrm{D}_{\mathrm{i}}$ \& $Q_{1}$ \& BUS $_{\text {i }}$ \& RI \& FUNCTION <br>
\hline X \& X \& X \& X \& H \& X \& X \& X \& X \& Z \& X \& Driver output disable <br>
\hline X \& X \& X \& X \& X \& X \& H \& X \& X \& X \& Z \& Receiver output disable <br>
\hline $$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$ \& $$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$ \& X \& $$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$ \& $$
\begin{aligned}
& \mathrm{H} \\
& \mathrm{H}
\end{aligned}
$$ \& $$
\stackrel{L}{L}
$$ \& $$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{~L}
\end{aligned}
$$ \& $$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$ \& $$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{H}
\end{aligned}
$$ \& $$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{H}
\end{aligned}
$$ \& $$
\begin{gathered}
H \\
L
\end{gathered}
$$ \& Driver output disable and receive data via Bus input <br>
\hline X \& X \& X \& X \& X \& H \& X \& X \& NC \& X \& X \& Latch received data <br>
\hline $L$
$L$
$H$
$H$
$H$ \& $$
\begin{array}{|l}
\hline L \\
H \\
X \\
X
\end{array}
$$ \& X
X
L

$H$ \& \[
$$
\begin{aligned}
& \uparrow \\
& \uparrow \\
& \uparrow
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x} \\
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{X} \\
& \mathrm{X} \\
& \mathrm{x} \\
& \mathrm{X}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x} \\
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$
\] \& L

H
L

$H$ \& $$
\begin{aligned}
& x \\
& x \\
& x \\
& x \\
& x
\end{aligned}
$$ \& X

X
X
x

X \& $$
\begin{aligned}
& \mathrm{X} \\
& \mathrm{x} \\
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$ \& Load driver register <br>

\hline | X |
| :--- |
| X |
| X | \& \[

$$
\begin{array}{|l|}
\hline x \\
x
\end{array}
$$

\] \& X \& \[

$$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{H}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{NC} \\
& \mathrm{NC}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$
\] \& No driver clock restrictions <br>

\hline | X |
| :--- |
|  | \& X \& | X |
| :--- |
| $\times$ |
| $\times$ | \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{~L}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{L} \\
& \mathrm{H}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

\underset{\mathrm{H}}{\mathrm{H}}

\] \& \[

$$
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
$$
\] \& Drive Bus <br>

\hline
\end{tabular}

$H=H I G H \quad Z=H I G H$ Impedance $\quad X=$ Don't care $\quad i=0,1,2,3$

L = LOW $\quad N C=$ No change $\quad \uparrow=$ LOW to HIGH transition


AF001350
The Am2905 is a universal Bus Transceiver useful for many system data, address, control and timing input/output interfaces.

| ABSOLUTE MAXIMUM RATINGS | OPERATING RANGES |
| :---: | :---: |
| Storage Temperature ...................... $-65^{\circ} \mathrm{C}$ to +15 | Commercial (C) Devices |
| (Ambient) Temperature Under Bias ....... $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Temperature ................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential | Supply Voltage ......................... + 4.75V to +5.25 V |
| Continuous ................................ -0.5 V to +7.0 V | Military (M) Devices |
| DC Voltage Applied to Outputs for ${ }_{\text {HIGH Output }}$ State ${ }^{\text {d }}$ | Temperature ............................-55 ${ }^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| HIGH Output State................... -0.5 V to +VCC max | Supply Voltage .................................+4.5V to +5.5V |
| DC Input Voltage ............................... -0.5 V to +7 V | Operating ranges define those limits over which the function- |
| Dextput Current, Into Outputs | ality of the device is guaranteed. |
| DC Output Current, Into Bus........................... 200 mA |  |
| DC Input Current ..........................-30mA to + 5.0 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 device |  |
| reliability. |  |

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver Output HIGH Voltage | $\begin{aligned} & V_{C C}=V_{I N} \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{IOH}^{\prime}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| Vol | Receiver Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | $\mathrm{IOL}=$ |  |  | 0.27 | 0.4 | Volts |
|  |  |  | $\mathrm{l}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.32 | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=M I N, I^{\prime} N=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{I N}=0.4 V$ |  |  |  |  | -0.36 | mA |
| IIH | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{1 N}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{1 N}=5.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| 10 | Receiver Off-State Output Current | $V_{C C}=\mathrm{MAX}$ |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |
| ISC | Receiver Output Short Circuit Current | $V_{C C}=$ MAX |  |  | -12 |  | -65 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, All inputs = GND |  |  |  | 69 | 105 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OL}}$ | Bus Output LOW Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$ | $\mathrm{IOL}=40 \mathrm{~m}$ |  |  | 0.32 | 0.5 | Volts |
|  |  |  | $\mathrm{IOL}=70 \mathrm{~mA}$ |  |  | 0.41 | 0.7 |  |
|  |  |  | $1 \mathrm{OL}=100 \mathrm{~mA}$ |  |  | 0.55 | 0.8 |  |
| 10 | Bus Leakage Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ | MIL |  |  | 200 |  |
|  |  |  |  | COM'L |  |  | 100 |  |
| loff | Bus Leakage Current (Power OFF) | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {TH }}$ | Receiver Input HIGH Threshold | Bus Enable $=2.4 \mathrm{~V}$ |  | MIL | 2.4 | 2.0 |  | Volts |
|  |  |  |  | COM'L | 2.3 | 2.0 |  |  |
| $V_{\text {TL }}$ | Receiver Input LOW Threshold | Bus enable $=2.4 \mathrm{~V}$ |  | MIL |  | 2.0 | 1.5 | Volts |
|  |  |  |  | COM'L |  | 2.0 | 1.6 |  |

## Bus Output Low Voltage

 Versus Ambient Temperature

OP001340

Receiver Threshold Variation Versus Ambient Temperature


## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2905 |  |  | Am2905 |  |  |  |
|  |  |  | Min | Typ (Note 1) | Max | Min | Typ (Note 1) | Max |  |
| tPHL | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=50 \Omega \end{aligned}$ |  | 21 | 36 |  | 21 | 40 | ns |
| ${ }_{\text {tPLH }}$ |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tPHL | Bus Enable ( $\overline{\mathrm{BE}})$ to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| tplH |  |  |  | 13 | 23 |  | 13 | 26 |  |
| $\mathrm{t}_{5}$ | Data Inputs ( A or B ) | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 23 |  |  | 25 |  |  | ns |
| $t_{\text {h }}$ |  |  | 7.0 |  |  | 8.0 |  |  |  |
| $t_{s}$ | Select input (S) |  | 30 |  |  | 33 |  |  | ns |
| $t_{n}$ |  |  | 7.0 |  |  | 8.0 |  |  |  |
| tpw | Driver Clock (DRCP) Pulse Width (HIGH) |  | 25 |  |  | 28 |  |  | ns |
| tplH | Bus to Receive Output (Latch Enable) |  |  | 18 | 34 |  | 18 | 37 | ns |
| tPHL |  |  |  | 18 | 34 |  | 18 | 37 |  |
| tpLH | Latch Enable to Receiver Output |  |  | 21 | 34 |  | 21 | 37 | ns |
| tPHL |  |  |  | 21 | 34 |  | 21 | 37 |  |
| $\mathrm{t}_{\text {s }}$ | Bus to Latch Enable ( $\overline{\text { RLE }}$ ) |  | 18 |  |  | 21 |  |  | ns |
| th |  |  | 5.0 |  |  | 7.0 |  |  |  |
| tzH | Output Control to Receiver Output |  |  | 14 | 25 |  | 14 | 28 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 14 | 25 |  | 14 | 28 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Control to Receiver Output |  |  | 14 | 25 |  | 14 | 28 | ns |
| tLZ |  |  |  | 14 | 25 |  | 14 | 28 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

SWITCHING TEST CIRCUIT



Note: Bus to Receiver output delay is measured by clocking data into the driver register and measuring the BUS to R combinatorial delay.

# Am2906 

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus transceiver.
- Open-collector bus driver output can sink 100 mA at 0.8 V max.
- Two-port input to D-type register on driver.
- Internal 4-bit odd parity checker/generator.
- Receiver has output latch for pipeline operation.
- Receiver outputs sink 12 mA .


## GENERAL DESCRIPTION

The Am2906 is a high-performance, low-power Schottky bus transceiver intended for bipolar or MOS microprocessor system applications. The device consists of four D-type edge-triggered flip-flops with a built-in two-input multiplexer on each. The flip-flop outputs are connected to four opencollector bus drivers. Each bus driver is internally connected to one input of a differential amplifier in the receiver. The four receiver differential amplifier outputs drive four D-type latches. The device also contains a four-bit odd parity checker/generator.

This LSI bus transceiver is fabricated using advanced lowpower Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The open-collector bus output can sink up to 100 mA at 0.8 V maximum. The BUS input differential amplifier contains disconnect protection diodes such that the bus is fail-safe when power is not applied. The bus enable input $(\overline{\mathrm{BE}})$ is used to force the driver outputs to the high-impedance state. When $\overline{B E}$ is HIGH, the driver is disabled. The open-collector structure of the driver allows wired-OR operations to be performed on the bus.

The input register consists of four D-type flip-flops with a buffered common clock and a two-input multiplexer at the input of each flip-flop. A common select input (S) controls
the four multiplexers. When $S$ is LOW, the $A_{i}$ data is stored in the register and when $S$ is HIGH, the $B_{i}$ data is stored. The buffered common clock (DRCP) enters the data into this driver register on the LOW-to-HIGH transition.
Data from the $A$ or $B$ input is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{\mathrm{RLE}}$ ) input. When the $\overline{\mathrm{RLE}}$ input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted). When the RLE input is HIGH, the latch will close and retain the present data regardless of the bus input.
The Am2906 features a built-in four-bit odd parity checker/ generator. The bus enable input ( $\overline{\mathrm{BE}}$ ) controls whether the parity output is in the generate or check mode. When the bus enable is LOW (driver enabled), odd parity is generated based on the $A$ or $B$ field data input to the driver register. When $\overline{B E}$ is HIGH, the parity output is determined by the four latch outputs of the receiver. Thus, if the driver is enabled, parity is generated and if the driver is in the highimpedance state, the BUS parity is checked.


## CONNECTION DIAGRAM Top View

## D-24-1



CD003000
Note: Pin 1 is marked for orientation


ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| Am2906 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
| $\begin{aligned} & 4,8 \\ & 16,20 \end{aligned}$ | $A_{0}, A_{1},$ $A_{2}, A_{3}$ | 1 | The " A " word data input into the two input multiplexer of the driver register. |
| $\begin{aligned} & 3,9 \\ & 15,21 \end{aligned}$ | $\begin{array}{ll} B_{0}, & B_{1}, \\ B_{2}, & B_{3} \\ \hline \end{array}$ | 1 | The " B ' word data input into the two input multiplexers of the driver register. |
| 13 | S | 1 | Select. When the select input is LOW, the A data word is applied to the driver register. When the select input is HIGH, the B word is applied to the driver register. |
| 23 | DRCP |  | Driver Clock Pulse. Clock pulse for the driver register. |
| 11 | $\overline{B E}$ |  | Bus Enable. When the Bus Enable is HIGH, the four drivers are in the high impedance state. |
| $\begin{aligned} & \hline 5 \\ & 7 \\ & 17,19 \end{aligned}$ | $\begin{array}{\|l} \hline \overline{\mathrm{BUS}}_{0}, \\ \mathrm{BUS}_{1} \\ \mathrm{BUS}_{2}, \\ \mathrm{BUS}_{3} \\ \hline \end{array}$ | 0 | The four driver outputs and receiver inputs (data is inverted). |
| $\begin{aligned} & 2,10 \\ & 14,22 \end{aligned}$ | $\begin{aligned} & \mathrm{R}_{0}, \\ & \mathrm{R}_{1}, \\ & \mathrm{R}_{2}, \\ & \mathrm{R}_{3} \end{aligned}$ | 0 | The four receiver outputs. Data from the bus is inverted while data from the $A$ or $B$ inputs is non-inverted. |
| 1 | R'LE | 0 | Receiver Latch Enable. When $\overline{\operatorname{RLE}}$ is LOW, data on the BUS inputs is passed through the receiver latches. When $\overline{\operatorname{RLE}}$ is HIGH, the receiver latches are closed and will retain the data independent of all other inputs. |
| 12 | ODD | 0 | Odd parity output. Generates parity with the driver enabled, checks parity with the driver in high-impedance state. |


| INPUTS |  |  |  |  |  | INTERNAL TO DEVICE |  | $\begin{array}{\|l\|} \hline \text { BUS } \\ \hline \overline{\text { USS }}_{\mathrm{i}} \\ \hline \end{array}$ | OUTPUTS |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S | $\mathrm{A}_{1}$ | $\mathrm{B}_{\mathrm{i}}$ | DRCP | BE | RLE | $\mathrm{D}_{1}$ | $Q_{i}$ |  | R ${ }_{1}$ | ODD |  |
| X | x | X | X | H | X | X | X | Z | X | PQ | Driver output disable |
| X | $x$ | x | X | L | X | X | X | X | X | PD | Driver output enable |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{array}{\|l} x \\ x \end{array}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | Driver output disable and receive data via Bus input |
| X | X | X | X | X | H | X | NC | X | NC | X | Latch received data |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{\|l\|} \hline L \\ H \\ X \\ X \end{array}$ | $\begin{array}{\|l\|} \hline X \\ X \\ \text { L } \\ H \end{array}$ | $\begin{aligned} & \uparrow \\ & \uparrow \\ & \uparrow \\ & \uparrow \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | Load driver register |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{array}{\|l} x \\ x \\ x \end{array}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | No driver clock restrictions |
| X <br>  <br> X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{array}{\|l\|} \hline x \\ x \end{array}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | Drive Bus |
| $H=$ HIGH $X=$ Don't care NC $=$ No change <br> $L=$ LOW $i=0,1,2,3$ $P D=$ Parity of $D$ flip flops <br> $Z=$ HIGH Impedance $i=$ LOW to HIGH transition $P Q=$ Parity of $Q$ latches |  |  |  |  |  |  |  |  |  |  |  |

## PARITY OUTPUT FUNCTION TABLE

| $\overline{B E}$ | ODD PARITY OUTPUT |
| :---: | :--- |
| $L$ | ODD $=I_{0} \oplus I_{1} \oplus I_{2} \oplus I_{3}$ |
| $H$ | $O D D=Q_{0} \oplus Q_{1} \oplus Q_{2} \oplus Q_{3}$ |
| $\mathrm{I}_{\mathrm{i}}=$ Selected input $A_{i}$ or $B_{i}$ |  |



| ABSOLUTE MAXIMUM RATINGS | OPERATING RANGES |
| :---: | :---: |
| Storage Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . \ldots 5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Commercial (C) Devices |
| (Ambient) Temperature Under Bias ...... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Temperature ................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential <br> Continuous $\qquad$ -0.5 V to +7.0 V | Supply Voltage....................... +4.75 V to +5.25 V |
| DC Voltage Applied to Outputs for <br> HIGH Output State......................-0.5V to $+\mathrm{V}_{\mathrm{CC}} \max$ | Military (M) Devices <br> Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| DC Input Voltage.................................-0.5V to +5.5 V | Supply Voltage ............................ +4.5 V to +5.5 V |
| DC Output Current, Into Bus........................... 200 mA | Operating ranges define those limits over which the functionality of the device is guaranteed. |
| DC Output Current, Into Outputs <br> (Except Bus).................................................. 30 mA |  |
| DC Input Current ..........................-30mA to + 5.0 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 device reliability. |  |

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\mathrm{OH}}$ | Receiver Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL | $\mathrm{l}^{\mathrm{OH}}=-1.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Voits |
|  |  |  | COM'L | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  | Parity Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-660 \mu \mathrm{~A} \\ & V_{I N}=V_{J H} \text { or } V_{\text {IL }} \end{aligned}$ |  | MIL | 2.5 | 3.4 |  |  |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| VOL | Output LOW voltage (Except Bus) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{\mathbb{I L}} \text { or } V_{\mathbb{I H}} \end{aligned}$ | $\mathrm{IOL}^{2}=4 \mathrm{~mA}$ |  |  | 0.27 | 0.4 |  |
|  |  |  | $\mathrm{lOL}^{\prime}=8 \mathrm{~mA}$ |  |  | 0.32 | 0.45 | Volts |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{I N}=5.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| ISC | Output Short Circuit Current (Except Bus) (Note 3) | $V_{C C}=M A X$ |  |  | -12 |  | -65 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{All}$ inputs $=\mathrm{GND}$ |  |  |  | 72 | 105 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range


## TYPICAL PERFORMANCE CURVES

Bus Output Low Voltage Versus Ambient Temperature


OP001340

Receiver Threshold Variation Versus Ambient Temperature


## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000340

Note: Actual current flow direction shown.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2906 |  |  | Am2906 |  |  |  |
|  |  |  | Min | Typ (Note 1) | Max | Min | Typ (Note 1) | Max |  |
| tPHL | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=50 \Omega \end{aligned}$ |  | 21 | 36 |  | 21 | 40 |  |
| tplH |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tpHL | Bus Enable ( $\overline{\mathrm{BE}})$ to BUS |  |  | 13 | 23 |  | 13 | 26 | ns |
| tpLH |  |  |  | 13 | 23 |  | 13 | 26 | ns |
| $\mathrm{t}_{\text {s }}$ | Data Inputs (A or B) | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 23 |  |  | 25 |  |  | ns |
| $t_{n}$ |  |  | 7.0 |  |  | 8.0 |  |  | ns |
| $\mathrm{t}_{\text {s }}$ | Select Inputs (S) |  | 30 |  |  | 33 |  |  | ns |
| $t_{1}$ |  |  | 7.0 |  |  | 8.0 |  |  | ns |
| tpW | Clock Pulse Width (HIGH) |  | 25 |  |  | 28 |  |  | ns |
| tplH | Bus to Receiver Output (Latch Enabled) |  |  | 18 | 34 |  | 18 | 37 | ns |
| tpHL |  |  |  | 18 | 34 |  | 18 | 37 |  |
| tPLH | Latch Enable to Receiver Output |  |  | 21 | 34 |  | 21 | 37 | ns |
| tPHL |  |  |  | 21 | 34 |  | 21 | 37 |  |
| $\mathrm{t}_{\text {s }}$ | Bus to Latch Enable ( $\overline{\mathrm{RLE}}$ ) |  | 18 |  |  | 21 |  |  | ns |
| $t_{n}$ |  |  | 5.0 |  |  | 7.0 |  |  |  |
| tpLH | A or B Data to Odd Parity Output (Driver Enabled) |  |  | 21 | 36 |  | 21 | 40 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 21 | 36 |  | 21 | 40 |  |
| ${ }_{\text {tPLH }}$ | Bus to Odd Parity Output (Driver Inhibited, Latch Enabled) |  |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tplH | Latch Enable ( $\overline{\mathrm{RLE}}$ ) to Odd Parity Output |  |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |

[^6]SWITCHING TEST CIRCUIT


TC000820


Note: Bus to Receiver output delay is measured by clocking data into the driver register and measuring the $\overline{B U S}$ to $R$ combinatorial delay.

# Am2907/Am2908 

Quad Bus Transceivers with Interface Logic

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus-transceiver
- D-type driver register with open-collector bus driver output can sink 100 mA at 0.8 V max.
- Internal 4-bit odd parity checker/generator
- Receiver has output latch for pipeline operation
- Three-state receiver outputs sink 12 mA
- Am2907 has 2.0V input receiver threshold; Am2908 is 'DECQ or LSI-II bus compatible' with 1.5 V receiver threshold


## GENERAL DESCRIPTION

The Am2907 and Am2908 are high-performance bus transceivers intended for bipolar or MOS microprocessor system applications. The Am2908 is Digital Equipment Corporation "Q or LSI-II bus compatible" while the Am2907 features a 2.0V receiver threshold. These devices consist of four Dtype edge-triggered flip-flops. The flip-flop outputs are connected to four open-collector bus drivers. Each bus driver is internally connected to one input of a differential amplifier in the receiver. The four receiver differential amplifier outputs drive four D-type latches, that feature three-state outputs. The devices also contain a four-bit odd parity checker/generator.
These LSI bus transceivers are fabricated using advanced low-power Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The open-collector bus output can sink up to 100 mA at 0.8 V maximum. The BUS input differential amplifier contains disconnect protection diodes such that the bus is fail-safe when power is not applied. The bus enable input ( $\overline{\mathrm{BE}}$ ) is used to force the driver outputs to the high-impedance state. When $\overline{B E}$ is HIGH, the driver is disabled. The open-collector structure of the driver allows wired-OR operations to be performed on the bus.
The input register consists of four D-type flip-flops with a buffered common clock. The buffered common clock (DRCP) enters the $A_{i}$ data into this driver register on the LOW-to-HIGH transition.

Data from the $A$ input is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{\mathrm{RLE}}$ ) input. When the $\overline{\mathrm{RLE}}$ input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted and $\overline{O E}$ LOW). When the RLE input is HIGH, the latch will close and retain the present data regardless of the bus input. The four latches have threestate outputs and are controlled by a buffered common three-state control ( $\overline{\mathrm{OE}}$ ) input. When $\overline{\mathrm{OE}}$ is HIGH, the receiver outputs are in the high-impedance state.

The Am2907 and Am2908 feature a built-in four-bit odd parity checker/generator. The bus enable input ( $\overline{\mathrm{BE}}$ ) controls whether the parity output is in the generate or check mode. When the bus enable is LOW (driver enabled), odd parity is generated based on the A field data input to the driver register. When $\overline{\mathrm{BE}}$ is HIGH , the parity output is determined by the four latch outputs of the receiver. Thus, if the driver is enabled, parity is generated and if the driver is in the high-impedance state, the BUS parity is checked.

The Am2907 has receiver threshold typically of 2.0 V while the Am2908 threshold is typically 1.5 V .

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type
Quad Bus Transceivers

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am2907 | DC, DCB, DM, |
| Am2908 | DMB |
|  | FM, FMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No． | Name | 1／0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 3,7 \\ & 13,17 \end{aligned}$ | $\begin{array}{ll} A_{0}, & A_{1} \\ A_{2}, & A_{3} \end{array}$ | 1 | The four driver register inputs． |
| 19 | DRCP | 1 | Driver Clock Pulse：Clock pulse for the driver register． |
| 9 | EE | 1 | Bus Enable．When the Bus Enable is HIGH．The four drivers are in the high impedance state． |
| $\begin{aligned} & \hline 4 \\ & 6 \\ & 14 \\ & 16 \end{aligned}$ | BUS $_{0}$, <br> BUS $_{1}$, <br> BUS $_{2}$, <br> BUS $_{3}$ | 1／0 | The four driver outputs and receiver inputs（data is inverted）． |
| 2，8，12， 18 | $\begin{array}{ll} R_{0}, & R_{1}, \\ R_{2}, & R_{3} \end{array}$ | 0 | The four receiver outputs．Data from the bus is inverted while data from the A inputs is non－inverted． |
| 1 | RLE | 0 | Receiver Latch Enable．When $\overline{\text { RLE }}$ is LOW，data on the BUS inputs is passed through the receiver latches．When RLE is HIGH，the receiver latches are closed and will retain the data independent of all other inputs． |
| 10 | ODD | 0 | Odd parity output．Generates parity with the driver enabled，checks parity with the driver in the high－impedance state． |
| 11 | $\overline{O E}$ | I | Output Enable．When the $\overline{O E}$ input is HIGH ，the four three－state receiver outputs are in the high－impedance state． |

## TRUTH TABLE

| INPUTS |  |  |  |  | INTERNAL TO DEVICE |  | BUS | OUTPUT |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $A_{1}$ | DRCP | BE | RLE | $\overline{O E}$ | $\mathrm{D}_{1}$ | $Q_{1}$ | $\mathrm{B}_{1}$ | $\mathrm{R}_{\mathbf{I}}$ | FUNCTION |
| X | X | H | X | X | X | $x$ | H | X | Driver output disable |
| X | X | X | X | H | x | X | X | Z | Receiver output disable |
| $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\mathrm{L}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | Driver output disable and receive data via Bus input |
| X | X | X | H | X | X | NC | X | X | Latch received data |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | Load driver register |
| $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \text { NC } \\ & \text { NC } \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | No driver clock restrictions |
| X | X | L | X | X | H | X | L | X | Drive Bus |

$H=H I G H$
$Z=$ HIGH Impedance
$X=$ Don＇t care
$=0,1,2,3$
L＝LOW
$\mathrm{NC}=$ No change
$\uparrow=$ LOW to HIGH transition

## PARITY OUTPUT FUNCTION TABLE

| $\overline{B E}$ | ODD PARITY OUTPUT |
| :---: | :---: |
| $L$ | $O D D=A_{0} \oplus A_{1} \oplus A_{2} \oplus A_{3}$ |
| $H$ | $O D D=\mathbf{a}_{0} \oplus \mathbf{Q}_{1} \oplus \mathbf{Q}_{\mathbf{2}} \oplus \mathbf{a}_{3}$ |

The Am2907 can be used as an I/O Bus Transceiver and Main Memory I/O Transceiver in high-speed Microprocessor Systems.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs for High Output State to Outputs for .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage $\qquad$ -0.5 V to +5.5 V
DC Output Current, Into Bus $\qquad$
DC Output Current, Into Outputs (Except Bus)
$\qquad$
$\qquad$ .30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL: $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L: $\mathrm{IOH}^{\prime}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| VOH | Parity <br> Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-660 \mu \mathrm{~A} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| VOL | Output LOW voltage (Except Bus) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | $\mathrm{lOL}^{=}=4 \mathrm{~mA}$ |  |  | 0.27 | 0.4 | Volts |
|  |  |  | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.32 | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Except Bus)( | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=\mathrm{MIN}, \mathrm{I}^{\prime} \mathrm{N}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{I N}=0.4 V$ |  |  |  |  | -0.36 | mA |
| 1 IH | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{1 N}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{I N}=5.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Except Bus) | $V_{C C}=M A X$ |  |  | -12 |  | -65 | mA |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, All inputs $=$ GND |  | Am2907 |  | 75 | 110 |  |
|  |  |  |  | Am2908 |  | 80 | 120 | mA |
| 10 | Off-State Output Current (Receiver Outputs) | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 |  |

BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | $\begin{aligned} & \text { Typ } \\ & \text { (Note 1) } \end{aligned}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Bus Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | $\mathrm{lOL}=40 \mathrm{~mA}$ |  |  | 0.32 | 0.5 | Volts |
|  |  |  | $\mathrm{lOL}=70 \mathrm{~mA}$ |  |  | 0.41 | 0.7 |  |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=100 \mathrm{~mA}$ |  |  | 0.55 | 0.8 |  |
| 10 | Bus Leakage Current | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ | MIL |  |  | 200 |  |
|  |  |  |  | COM'L |  |  | 100 |  |
| loff | Bus Leakage Current (Power Off) | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {TH }}$ | Receiver Input HIGH Threshold | Bus Enable $=2.4 \mathrm{~V}$ | Am2907 | MIL | 2.4 | 2.0 |  | Volts |
|  |  |  |  | COM'L | 2.3 | 2.0 |  |  |
|  |  |  | Am2908 | MIL | 1.9 | 1.5 |  |  |
|  |  |  |  | COM'L | 1.7 | 1.5 |  |  |
| $V_{T L}$ | Receiver Input LOW Threshold | Bus Enable $=2.4 \mathrm{~V}$ | Am2907 | MIL |  | 2.0 | 1.5 | Volts |
|  |  |  |  | COM'L |  | 2.0 | 1.6 |  |
|  |  |  | Am2908 | MIL |  | 1.5 | 1.1 |  |
|  |  |  |  | COM'L |  | 1.5 | 1.3 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |

## TYPICAL PERFORMANCE CURVES

Bus Output Low Voltage Versus Ambient Temperature


OP001340

Am2907 Receiver Threshold Variation Versus Ambient Temperature


OP001330

Am2908 Receiver Threshold Variation Versus Ambient Temperature


OP001420


Note: Actual current flow direction shown.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2907 |  |  | Am2907 |  |  |  |
|  |  |  | Min | Typ (Note 1) | Max | Min | Typ (Note 1) | Max |  |
| tPHL | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=50 \Omega \end{aligned}$ |  | 21 | 36 |  | 21 | 40 |  |
| tplH |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tphi | Bus Enable ( $\overline{\mathrm{BE}}$ ) to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| tpLH |  |  |  | 13 | 23 |  | 13 | 26 |  |
| $t_{s}$ | Data Inputs | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 15 |  |  | 18 |  |  |  |
| th |  |  | 7.0 |  |  | 8.0 |  |  | ns |
| tpw | Clock Pulse Width (HIGH) |  | 25 |  |  | 28 |  |  | ns |
| tpLH | Bus to Receiver Output (Latch Enabled) |  |  | 18 | 34 |  | 18 | 37 | ns |
| tphL |  |  |  | 18 | 34 |  | 18 | 37 |  |
| $\mathrm{t}_{\text {PLH }}$ | Latch Enable to Receiver Output |  |  | 21 | 34 |  | 21 | 37 | ns |
| tPHL |  |  |  | 21 | 34 |  | 21 | 37 |  |
| $\mathrm{t}_{\text {s }}$ | Bus to Latch Enable ( $\overline{\mathrm{RLE}}$ ) |  | 18 |  |  | 21 |  |  | ns |
| $t_{\text {h }}$ |  |  | 5.0 |  |  | 7.0 |  |  |  |
| tPLH | Data to Odd Parity Out (Driver Enabled) |  |  | 21 | 36 |  | 21 | 40 | ns |
| tpHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tpLH | Bus to Odd Parity Out (Driver Inhibit) |  |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tplH | Latch Enable ( $\overline{\mathrm{RLE}}$ ) to Odd Parity Output |  |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Control to Output |  |  | 14 | 25 |  | 14 | 28 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 14 | 25 |  | 14 | 28 |  |
| $\mathrm{thz}^{\text {H }}$ | Output Control to Output | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 14 | 25 |  | 14 | 28 | ns |
| tLz |  |  |  | 14 | 25 |  | 14 | 28 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2908 |  |  | Am2908 |  |  |  |
|  |  |  | Min | Typ （Note 1） | Max | Min | Typ （Note 1） | Max |  |
| tphL． | Driver Clock（DRCP）to Bus | $\begin{gathered} C_{L}(B U S)=50 \mathrm{pF} \\ R_{L}(B U S): \\ 91 \Omega \text { to } V_{C C} \\ 200 \Omega \text { to GND } \end{gathered}$ |  | 21 | 36 |  | 21 | 40 | ns |
| tplH |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tPHL | Bus Enable（ $\overline{\mathrm{BE}})$ to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| tple |  |  |  | 13 | 23 |  | 13 | 26 |  |
| $\mathrm{t}_{\mathrm{r}}$ | Bus Output Rise Time |  | 7 | 10 |  | 5 | 10 |  | ns |
| $\mathrm{t}_{\mathrm{f}}$ | Bus Output Fall Time |  | 4 | 6 |  | 3 | 6 |  | ns |
| $\mathrm{t}_{\mathbf{s}}$ | Data Inputs |  | 15 |  |  | 18 |  |  | ns |
| $t_{\text {h }}$ |  |  | 7.0 |  |  | 8.0 |  |  |  |
| tpW | Clock Pulse Width（HIGH） |  | 25 |  |  | 28 |  |  | ns |
| tPLH | Bus to Receiver Output （Latch Enabled） | $\begin{gathered} C_{L}=50 \mathrm{pF} \\ R_{L}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 18 | 35 |  | 18 | 38 | ns |
| tPHL |  |  |  | 18 | 35 |  | 18 | 38 |  |
| tplH | Latch Enable to Receiver Output |  |  | 21 | 35 |  | 21 | 38 | ns |
| tPHL |  |  |  | 21 | 35 |  | 21 | 38 |  |
| $t_{s}$ | Bus to Latch Enable（ $\overline{\mathrm{RLE}}$ ） |  | 18 |  |  | 21 |  |  | ns |
| $t_{\text {h }}$ |  |  | 5.0 |  |  | 7.0 |  |  |  |
| tplH | Data to Odd Parity Out （Driver Enabled） | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tplH | Bus to Odd Parity Out （Driver Inhibit） |  |  | 21 | 36 |  | 21 | 40 | ns |
| tPHL |  |  |  | 21 | 36 |  | 21 | 40 |  |
| tplH | Latch Enable（ $\overline{\mathrm{RLE}}$ ）to Odd Parity Output |  |  | 21 | 36 |  | 21 | 40 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 21 | 36 |  | 21 | 40 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Control to Output |  |  | 14 | 25 |  | 14 | 28 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 14 | 25 |  | 14 | 28 |  |
| $\mathrm{thz}^{\text {H }}$ | Output Control to Output | $\begin{aligned} & C_{\mathrm{L}}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 14 | 25 |  | 14 | 28 | ns |
| tLZ |  |  |  | 14 | 25 |  | 14 | 28 |  |

Notes：1．Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading．
2．For conditions shown as MIN or MAX，use the appropriate value specified under Operating Ranges for the applicable device type．

SWITCHING WAVEFORMS


INPUT SET－UP AND HOLD TIMES．


## SWITCHING TEST CIRCUIT



Note: $C_{L}=15 p F$ for Am2907
$C_{L}=50 \mathrm{pF}$ for Am2908
Am2907/08 RECEIVER SWITCHING TEST CIRCUIT.




## Am2909A/Am2911A

Microprogram Sequencers

## DISTINCTIVE CHARACTERISTICS

- 4-bit slice cascadable to form longer word width
- Branch input for N -way branches
- $4 \times 4$ file with stack pointer and push pop control for nesting microsubroutines
- Zero input for returning to the zero microcode word
- Individual OR input for each bit for branching to higher microinstructions (Am2909 only)
- Am2909 in 28-pin package \& Am2911A in 20-pin package


## GENERAL DESCRIPTION

The Am2909A is a four-bit wide address controller intended for sequencing through a series of microinstructions contained in a ROM or PROM. Two Am2909As may be interconnected to generate an eight-bit address (256 words), and three may be used to generate a twelve-bit address (4K words).

The Am2909A can select an address from any of four sources. They are: 1) a set of external direct inputs (D); 2) external data from the $R$ inputs, stored in an internal register; 3) a four-word deep push/pop stack; or 4) a program counter register (which usually contains the last
address plus one). The push/pop stack includes certain control lines so that it can efficiently execute nested subroutine linkages. Each of the four outputs can be OR'ed with an external input for conditional skip or branch instructions, and a separate line forces the outputs to all zeroes. The outputs are three-state.

The Am2911A is an identical circuit to the Am2909A, except the four OR inputs are removed and the $D$ and $R$ inputs are tied together. The Am2911A is in a 20-pin, 0.3" centers package.

MICROPROGRAM SEQUENCER BLOCK DIAGRAM


## CONNECTION DIAGRAM <br> Top View

P-28, D-28


CD004332


CD004311

Note: Pin 1 is marked for orientation

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2918 | Pipeline Register |
| Am2922 | Condition Code MUX |
| Am29803A | 16-Way Branch Control Unit |
| Am29811A | Next Address Control |
| Am25LS163 | 4-Bit Counter |
| Am27S35 | Registered PROM |

For applications information, see Chapter 11 of Bit Slice Microprocessor Design, Mick \& Brick, McGraw Hill Publications.

ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).



Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

Note: Pin 1 is marked for orientation
CONNECTION DIAGRAM
Top View

CD004321


CD004301



DIE SIZE $86 \times 98$ Mils


| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
| 17, 16/11, 10 | $\mathrm{s}_{1}, \mathrm{~s}_{0}$ | 1 | Control lines for address source selection. |
| 25, 26/19, 20 | $\overline{\mathrm{FE}, \text { PUP }}$ | 1 | Control lines for push/pop stack. |
| 1/3 | $\overline{\text { RE }}$ | 1 | Enable line for internal address register. |
| 6, 8, 10, 12 | $\mathrm{OR}_{\mathrm{i}}$ | 1 | Logic OR inputs on each address output line. (2909A ONLY) |
| 5/9 | ZERO | 1 | Logic AND input on the output lines. |
| 22/16 | $\overline{\mathrm{OE}}$ | 1 | Output Enable. When $\overline{\text { EE }}$ is HIGH, the Y outputs are OFF (high impedance). |
| 3/17 | $\mathrm{c}_{\mathrm{n}}$ | 1 | Carry-in to the incrementer. |
| 2, 3, 4, 5 | $\mathrm{R}_{\mathrm{i}}$ | 1 | Inputs to the internal address register. (2909A ONLY) |
| 7, 9, 11, 13/4-7 | $\mathrm{D}_{\mathrm{i}}$ | 1 | Direct inputs to the multiplexer. |
| $27 / 1$ | CP | 1 | Clock input to the AR and $\mu$ PC register and Push-Pop stack. |
| 18-21/12-15 | $Y_{i}$ | - | Address outputs from Am2909A. (Address inputs to control memory.) |
| 24/18 | $\mathrm{c}_{\mathrm{n}+4}$ | 0 | Carry out from the incrementer |

## ARCHITECTURE OF THE Am2909A/ Am2911A

The Am2909A/Am2911A are bipolar microprogram sequencers intended for use in high-speed microprocessor applications. The device is a cascadable 4-bit slice such that two devices allow addressing of up to 256 -words of microprogram and three devices allow addressing of up to 4 K words of microprogram. A detailed logic diagram is shown in Figure 1.

The device contains a four-input multiplexer that is used to select either the address register, direct inputs, microprogram counter, or file as the source of the next microinstruction address. This multiplexer is controlled by the $\mathrm{S}_{0}$ and $\mathrm{S}_{1}$ inputs.

The address register consists of four D-type, edge triggered flip-flops with a common clock enable. When the address register enable is LOW, new data is entered into the register on the clock LOW-to-HIGH transition. The address register is available at the multiplexer as a source for the next microinstruction address. The direct input is a four-bit field of inputs to the multiplexer and can be selected as the next microinstruction address. On the Am2911A, the direct inputs are also used as inputs to the register. This allows an N -way branch where N is any word in the microcode.

The Am2909A/Am2911.A contains a microprogram counter ( $\mu \mathrm{PC}$ ) that is composed of a 4-bit incrementer followed by a 4 bit register. The incrementer has carry-in $\left(\mathrm{C}_{n}\right)$ and carry-out $\left(C_{n}+4\right)$ such that cascading to larger word lengths is straightforward. The $\mu \mathrm{PC}$ can be used in either of two ways. When the least significant carry-in to the incrementer is HIGH, the microprogram register is loaded on the next clock cycle with the current $Y$ output word plus one $(Y+1 \rightarrow \mu \mathrm{PC}$.) Thus sequential microinstructions can be executed. If this least significant $C_{n}$ is LOW, the incrementer passes the $Y$ output word unmodified and the microprogram register is loaded with the same $Y$ word on the next clock cycle ( $\mathrm{Y} \rightarrow \mu \mathrm{PC}$ ). Thus, the same microinstruction can be executed any number of times by using the least significant $C_{n}$ as the control.

The last source available at the multiplexer input is the $4 \times 4$ file (stack). The file is used to provide return address linkage when executing microsubroutines. The file contains a built-in stack pointer (SP) which always points to the last file word written. This allows stack reference operations (looping) to be performed without a push or pop.
The stack pointer operates as an up/down counter with separate push/pop and file enable inputs. When the file enable input is LOW and the push/pop input is HIGH, the PUSH operation is enabled. This causes the stack pointer to increment and the file to be written with the required return linkage - the next microinstruction address following the subroutine jump which initiated the PUSH.
If the file enable input is LOW and the push/pop control is LOW, a POP operation occurs. This implies the usage of the return linkage during this cycle and thus a return from subroutine. The next LOW-to-HIGH clock transition causes the stack pointer to decrement. If the file enable is HIGH, no action is taken by the stack pointer regardless of any other input.
The stack pointer linkage is such that any combination of pushes, pops or stack references can be achieved. One microinstruction subroutines can be performed. Since the stack is 4 words deep, up to four microsubroutines can be nested.
The ZERO input is used to force the four outputs to the binary zero state. When the ZERO input is LOW, all Y outputs are LOW regardless of any other inputs (except $\overline{\mathrm{OE}}$ ). Each Y output bit also has a separate OR input such that a conditional logic one can be forced at each $Y$ output. This allows jumping to different microinstructions on programmed conditions.

The Am2909A/Am2911A feature three-state $Y$ outputs. These can be particularly useful in designs requiring external equipment to provide automatic checkout of the microprocessor. The internal control can be placed in the high-impedance state, and preprogrammed sequences of microinstructions can be executed via external access to the control ROM/ PROM.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential

Continuous $\qquad$
DC Voltage Applied to Outputs For
High Output State $\qquad$ 0.5 V 0 V max

DC Input Voltage $\qquad$ $\ldots .-0.5 \mathrm{~V}$ to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current .................................30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .............................. +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\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}$ | MIL | $1 \mathrm{OH}=-1.0 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  | COM'L | $\mathrm{IOH}=-2.6 \mathrm{~mA}$ | 2.4 |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | 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{I}^{\prime} \mathrm{L}=16 \mathrm{~mA}, 2909 \mathrm{~A} / 11 \mathrm{~A}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL, 2909A/11A |  |  | 0.7 | Volts |
|  |  |  |  | All others |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.4 V \end{aligned}$ | $\mathrm{C}_{n}$ |  |  |  | -1.08 | mA |
|  |  |  | Push/Pop, $\overline{\mathrm{OE}}$ |  |  |  | -0.72 |  |
|  |  |  | Others (Note 6) |  |  |  | -0.36 |  |
| IIH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | $\mathrm{C}_{\mathrm{n}}$ |  |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | Push/Pop, $\overline{\mathrm{OE}}$ |  |  |  | 40 |  |
|  |  |  | Others (Note 6) |  |  |  | 20 |  |
| 1 | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{\text {IN }}=7.0 \mathrm{~V} \end{aligned}$ | C $n$, Push/Pop |  |  |  | 0.2 | mA |
|  |  |  | Others (Note 6) |  |  |  | 0.1 |  |
| Ios | Output Short Circuit Current (Note 3) | $\begin{aligned} & V_{C C}=6 \mathrm{~V} \\ & V_{\text {OUT }}=0.5 \mathrm{~V} \end{aligned}$ |  | $Y_{0}-Y_{3}$ | -30 |  | -100 | mA |
|  |  |  |  | $\mathrm{C}_{\mathrm{n}+4}$ | -30 |  | -85 |  |
| Icc | Power Supply Current | $\begin{aligned} & V_{C C}=M A X \\ & \text { (Note 4) } \end{aligned}$ | COM'L Only | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |  |  | 130 | mA |
|  |  |  | MIL Only | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |  |  | 140 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 110 |  |
| Iozl | Output OFF Current | $\begin{aligned} & V_{C C}=M A X, \\ & O E=2.7 \end{aligned}$ | $Y_{0}-3$ | $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| IOZH |  |  |  | $\mathrm{V}_{\text {OUT }}=2.7 \mathrm{~V}$ |  |  | 20 |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Apply GND to $C_{n}, R_{0}, R_{1}, R_{2}, R_{3}, O R_{0}, O R_{1}, O R_{2}, O R_{3}, D_{0}, D_{1}, D_{2}$ and $D_{3}$. Other inputs high. All outputs open. Measured after a LOW-to-HIGH clock transition.
5. For the Am2911A, $D_{i}$ and $R_{i}$ are internally connected. Loading is doubled (to same values as Push/Pop).

## Am2909A／Am2911A SWITCHING CHARACTERISTICS OVER OPERATING RANGE

Tables I，II and III below define the timing characteristics of the Am2909A／Am2911A over the operating voltage and tempera－ ture range．The tables are divided into three types of parame－ ters；clock characteristics，combinational delays from inputs to outputs，and set－up and hold time requirements．The latter table defines the time prior to the end of the cycle（i．e．，clock LOW－to－HIGH transition）that each input must be stable to guarantee that the correct data is written into one of the internal registers．

Measurements are made at 1.5 V with $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}$ ．For three－state disable tests， $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ and measurement is to 0.5 V change on output voltage level．All outputs have maximum DC loading．

TABLE I
CYCLE TIME AND CLOCK CHARACTERISTICS

| Time | COMMERCIAL | MILITARY |
| :---: | :---: | :---: |
| Minimum Clock LOW Time | 20 | 20 |
| Minimum Clock HIGH Time | 20 | 20 |

TABLE II
MAXIMUM COMBINATIONAL PROPAGATION DELAYS
（all in $\mathrm{ns}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$（except output disable tests））

| From Input | COMMERCIAL |  | MILITARY |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathbf{Y}$ | $\mathbf{C}_{\mathbf{n}}+4$ | $\mathbf{Y}$ | $\mathbf{C}_{\mathbf{n}}+4$ |
| $\mathrm{D}_{\mathrm{i}}$ | 17 | 22 | 20 | 25 |
| $\mathrm{~S}_{0}, \mathrm{~S}_{1}$ | 29 | 34 | 29 | 34 |
| OR $_{\mathrm{i}}$ | 17 | 22 | 20 | 25 |
| $\mathrm{C}_{\mathrm{n}}$ | - | 14 | - | 16 |
| $\overline{Z E R O}$ | 29 | 34 | 30 | 35 |
| OE LOW（enable） | 25 | - | 25 | - |
| OE HIGH（disable）＊ | 25 | - | 25 | - |
| Clock $\uparrow \mathrm{S}_{1} \mathrm{~S}_{0}=\mathrm{LH}$ | 39 | 44 | 45 | 50 |
| Clock $\uparrow \mathrm{S}_{1} \mathrm{~S}_{0}=\mathrm{LL}$ | 39 | 44 | 45 | 50 |
| Clock $\uparrow \mathrm{S}_{1} \mathrm{~S}_{0}=\mathrm{HL}$ | 44 | 49 | 53 | 58 |

${ }^{*} \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$

TABLE III
GUARANTEED SET－UP AND HOLD TIMES（all in ns）（Note 1）

| From Input | Notes | COMMERCIAL |  | MILITARY |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Set－Up Time | Hold Time | Set－Up Time | Hold Time |
| $\overline{\mathrm{RE}}$ |  | 19 | 4 | 19 | 5 |
| $\mathrm{R}_{\mathrm{i}}$ | 2 | 10 | 4 | 12 | 5 |
| PUP |  | 25 | 4 | 27 | 5 |
| $\overline{\text { FE }}$ |  | 25 | 4 | 27 | 5 |
| $\mathrm{C}_{\mathrm{n}}$ |  | 18 | 4 | 18 | 5 |
| $\mathrm{D}_{1}$ |  | 25 | 0 | 25 | 0 |
| $\mathrm{OR}_{\mathrm{i}}$ |  | 25 | 0 | 25 | 0 |
| $\mathrm{S}_{0}, \mathrm{~S}_{1}$ |  | 25 | 0 | 29 | 0 |
| ZERO |  | 25 | 0 | 29 | 0 |

Notes：1．All times relative to clock LOW－to－HIGH transition
2．On Am2911A，$R_{i}$ and $D_{i}$ are internally connected together and labeled $D_{i}$ ．Use $R_{i}$ set－up and hold times when $D$ inputs are used to load register．


## OPERATION OF THE Am2909A/Am2911A

Figure 2 lists the select codes for the multiplexer. The two bits applied from the microword register (and additional combinational logic for branching) determine which data source contains the address for the next microinstruction. The contents of the selected source will appear on the $Y$ outputs. Figure 2 also shows the truth table for the output control and

## Address Selection

| $\mathbf{S}_{\mathbf{1}}$ | $\mathbf{S}_{\mathbf{0}}$ | SOURCE FOR Y OUTPUTS | SYMBOL |
| :---: | :--- | :--- | :---: |
| L | L | Microprogram Counter | $\mu$ PC |
| L | H | Address/Holding Register | AR |
| H | L | Push-Pop stack | STKO |
| H | H | Direct inputs | $D_{i}$ |

for the control of the push/pop stack. Figure 3 shows in detail the effect of $\mathrm{S}_{0}, \mathrm{~S}_{1}, \overline{\mathrm{FE}}$ and PUP on the Am2909A. These four signals define what address appears on the Y outputs and what the state of all the internal registers will be following the clock LOW-to-HIGH edge. In this illustration, the microprogram counter is assumed to contain initially some word J , the address register some word K , and the four words in the push/ pop stack contain $\mathrm{R}_{\mathrm{a}}$ through $\mathrm{R}_{\mathrm{d}}$.

Output Control

| $\mathbf{O R}_{\mathbf{i}}$ | $\overline{\mathbf{Z E R O}}$ | $\overline{\mathbf{O E}}$ | $\mathbf{Y}_{\mathbf{i}}$ |
| :---: | :---: | :---: | :---: |
| $X$ | $X$ | $H$ | $Z$ |
| $X$ | $L$ | $L$ | $L$ |
| $H$ | $H$ | $L$ | $H$ |
| $L$ | $H$ | $L$ | Source selected by $S_{0} S_{1}$ |

$Z=$ High Impedance

Synchronous Stack Control

| FE | PUP | PUSH-POP STACK CHANGE |
| :---: | :---: | :--- |
| H | X | No change <br> Increment stack pointer, then <br> push current PC onto STKO |
| L | L | Pop stack (decrement stack <br> pointer) |

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

Figure 2.

| CYCLE | $\mathbf{S}_{1}, \mathrm{~S}_{\mathbf{0}}, \overline{\mathrm{FE}}, \mathrm{PUP}$ | $\mu \mathrm{PC}$ | REG | STK0 | STK1 | STK2 | STK3 | YOUT | COMMENT | PRINCIPLE USE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | L L L L | $\underset{J+1}{J}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Rb} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rd} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{Rd} \\ & \mathrm{Ra} \\ & \hline \end{aligned}$ | J | Pop Stack | $\begin{array}{\|l\|} \hline \begin{array}{l} \text { End } \\ \text { Loop } \end{array} \\ \hline \end{array}$ |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | LLLH | $\begin{gathered} \mathrm{J} \\ \mathrm{~J}+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \\ & \hline \end{aligned}$ | $\underset{\mathrm{Ja}}{\mathrm{Ra}}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{Rd} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | J | Push $\mu$ PC | Set-up Loop |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | L L H X | $\stackrel{J}{J+1}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Ra} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rb} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rc} \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rd} \\ & \hline \end{aligned}$ | J | Continue | Continue |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | L HLL | $\begin{gathered} J \\ k+1 \end{gathered}$ | $\begin{aligned} & \hline \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rc} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rd} \end{aligned}$ | $\begin{aligned} & \hline \text { Rd } \\ & \text { Ra } \end{aligned}$ | K | Pop Stack; Use AR for Address | $\begin{aligned} & \text { End } \\ & \text { Loop } \\ & \hline \end{aligned}$ |
| $\begin{gathered} \mathrm{N} \\ \mathrm{~N}+1 \end{gathered}$ | L HL ${ }_{-}$ | $\begin{gathered} J \\ K+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{gathered} \mathrm{Ra} \\ \mathrm{~J} \end{gathered}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | K | Push $\mu \mathrm{PC}$; Jump to Address in AR | JSR AR |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | L H H X | $\stackrel{J}{K+1}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \text { Ra } \\ & \text { Ra } \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rb} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rc} \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rd} \end{aligned}$ | K | Jump to Address in AR | JMP AR |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | HLLL | $\stackrel{J}{R a+1}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rc} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rd} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{Rd} \\ & \mathrm{Ra} \end{aligned}$ | $\mathrm{Ra}$ | Jump to Address in STKO; Pop Stack | RTS |
| $\frac{N}{N+1}$ | HLLH | $R a+1$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\underset{\mathrm{Ja}}{\mathrm{Ra}}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{Rd} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | $\mathrm{Ra}$ | Jump to Address in STKO; Push $\mu$ PC |  |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | HLHX | $\begin{gathered} \mathrm{J} \\ \mathrm{Ra}+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rd} \\ & \hline \end{aligned}$ | Ra | Jump to Address in STKO | Stack Ref (Loop) |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | H HLL | $\begin{gathered} J \\ D+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rd} \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Ra} \end{aligned}$ | $\mathrm{D}$ | Pop Stack; Jump to Address on D | End Loop |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | $\mathrm{HHLH}$ | $\begin{gathered} \mathrm{J} \\ \mathrm{D}+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \end{aligned}$ | $\begin{gathered} \mathrm{Ra} \\ \mathrm{~J} \end{gathered}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rb} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | D | Jump to Address on D; Push $\mu$ PC | JSR D |
| $\begin{gathered} N \\ N+1 \end{gathered}$ | HHHX | $\begin{gathered} \mathrm{J} \\ \mathrm{D}+1 \end{gathered}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{~K} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Ra} \\ & \mathrm{Ra} \end{aligned}$ | $\begin{aligned} & \mathrm{Rb} \\ & \mathrm{Rb} \end{aligned}$ | $\begin{aligned} & \mathrm{Rc} \\ & \mathrm{Rc} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Rd} \\ & \mathrm{Rd} \\ & \hline \end{aligned}$ | D | Jump to Address on D | JMP D |

$X=$ Don't care, $0=L O W, 1=H I G H$, Assume $C_{n}=H I G H$
Note: STKO is the deation addressed by the stack pointer.
Figure 3. Output and Internal Next-Cycle Register States for Am2909A/Am2911A.

Figure 4 illustrates the execution of a subroutine using the Am2909A．The configuration of Figure 6 is assumed．The instruction being executed at any given time is the one contained in the microword register（ $\mu \mathrm{WR}$ ）．The contents of the $\mu \mathrm{WR}$ also control（indirectly，perhaps）the four signals $\mathrm{S}_{0}$ ， $S_{1}, \overline{F E}$ ，and PUP．The starting address of the subroutine is applied to the D inputs of the Am2909A at the appropriate time．

In the columns on the left is the sequence of microinstructions to be executed．At address $\mathrm{J}+2$ ，the sequence control portion of the microinstruction contains the command＂Jump to subroutine at $A^{\prime}$ ．At the time $T_{2}$ ，this instruction is in the $\mu W R$ ，
and the Am2909A inputs are set－up to execute the jump and save the return address．The subroutine address $A$ is applied to the $D$ inputs from the $\mu \mathrm{WR}$ and appears on the $Y$ outputs． The first instruction of the subroutine，$I(A)$ ，is accessed and is at the inputs of the $\mu \mathrm{WR}$ ．On the next clock transition， $\mathrm{I}(\mathrm{A})$ is loaded into the $\mu \mathrm{WR}$ for execution，and the return address $J+3$ is pushed onto the stack．The return instruction is executed at $\mathrm{T}_{5}$ ．Figure 5 is a similar timing chart showing one subroutine linking to a second，the latter consisting of only one microinstruction．

CONTROL MEMORY

| Execute <br> Cycle | Mlcroprogram |  |
| :---: | :---: | :---: |
|  | Address | Sequencer <br> Instruction |
| $T_{0}$ | $J-1$ | - |
| $T_{1}$ | $J+1$ | - |
| $T_{2}$ | $J+2$ | $J S R$ |
| $T_{6}$ | $J+3$ | - |
| $T_{7}$ | $J+4$ | - |
|  | - | - |
|  | - | - |
|  | - | - |
| $T_{3}$ | - | - |
| $T_{4}$ | $A+1$ | $I(A)$ |
| $T_{5}$ | $A+2$ | - |
|  | - | - |
|  | - | - |
|  | - | - |
|  | - | - |
|  | - | - |


| Execute Cycle | $\mathbf{T}_{\mathbf{0}}$ | $\mathbf{T}_{\mathbf{1}}$ | $\mathbf{T}_{\mathbf{2}}$ | $\mathbf{T}_{\mathbf{3}}$ | $\mathbf{T}_{\mathbf{4}}$ | $\mathbf{T}_{\mathbf{5}}$ | $\mathbf{T}_{\mathbf{6}}$ | $\mathbf{T}_{\mathbf{7}}$ | $\mathbf{T}_{\mathbf{8}}$ | $\mathbf{T}_{\mathbf{9}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock <br> Signals |  |  |  |  |  |  |  |  |  |  |  |

Figure 4．Subroutine Execution．

## CONTROL MEMORY

| Execute <br> Cycle | Microprogram |  |
| :---: | :---: | :---: |
|  | Address | Sequencer <br> Instruction |
| $\mathrm{T}_{0}$ | $\mathrm{~J}-1$ | - |
| $\mathrm{T}_{1}$ | $\mathrm{~J}+1$ | - |
| $\mathrm{T}_{2}$ | $\mathrm{~J}+2$ | JSR A |
| $\mathrm{T}_{9}$ | $\mathrm{~J}+3$ | - |
|  | - | - |
|  | - | - |
|  | - | - |
| $\mathrm{T}_{3}$ | $\bar{A}$ | - |
| $\mathrm{T}_{4}$ | $\mathrm{~A}+1$ | - |
| $\mathrm{T}_{5}$ | $\mathrm{~A}+2$ | JSR B |
| $\mathrm{T}_{7}$ | $\mathrm{~A}+3$ | - |
| $\mathrm{T}_{8}$ | $\mathrm{~A}+4$ | RTS |
|  | - | - |
|  | - | - |
|  | - | - |
| $\mathrm{T}_{6}$ | - | - |
|  | - | RTS |
|  | - | - |

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{Execute Cycle} \& T0 \& T1 \& $\mathrm{T}_{2}$ \& T3 \& $\mathrm{T}_{4}$ \& T \& T6 \& $\mathrm{T}_{7}$ \& T8 \& T9 <br>
\hline \multicolumn{12}{|l|}{Clock Signals} <br>
\hline Am2909A Inputs （from $\mu \mathrm{WR}$ ） \& $$
\begin{gathered}
\hline \mathrm{S}_{1}, \mathrm{~S}_{0} \\
\mathrm{FE} \\
\mathrm{PUP} \\
\mathrm{D}
\end{gathered}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& H \\
& X \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& H \\
& X \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 3 \\
& \mathrm{~L} \\
& \mathrm{H} \\
& \mathrm{~A}
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& H \\
& X \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& H \\
& X \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 3 \\
& \mathrm{~L} \\
& \mathrm{H} \\
& \mathrm{~B}
\end{aligned}
$$ \& $$
\begin{aligned}
& 2 \\
& L \\
& L \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& \mathrm{H} \\
& \mathrm{X} \\
& \mathrm{X}
\end{aligned}
$$ \& $$
\begin{aligned}
& 2 \\
& L \\
& L \\
& X
\end{aligned}
$$ \& $$
\begin{aligned}
& \hline 0 \\
& H \\
& X \\
& X
\end{aligned}
$$ <br>
\hline Internal Registers \& $$
\begin{aligned}
& \mu \mathrm{PC} \\
& \text { STKO } \\
& \text { STK1 } \\
& \text { STK2 } \\
& \text { STK3 }
\end{aligned}
$$ \& $x$
$J+1$
-
-
-

- \& J＋ 2
- 
- 
- \& J＋ 3
- 
- 
- \& X

$A+1$
$J+3$
-

- \& A +2
$J+3$
- 
- \& A＋

$J+3$
-

- \& B +1
$A+3$
$J+3$
- \& $X$
$A+4$
$J+3$
- 
- \& $X$
$A+5$
$J+3$
- 
- 
- \& | J＋ |
| :---: |
| - |
| - |
| - |
| - | <br>

\hline Am2909A Output \& Y \& $J+1$ \& $J+2$ \& A \& A＋ 1 \& A＋ 2 \& B \& A＋ 3 \& A＋ 4 \& $J+3$ \& $J+4$ <br>
\hline ROM Output \& （Y） \& $1(J+1)$ \& JSR A \& I（A） \& $1(A+1)$ \& JSR B \& RTS \& $1(A+3)$ \& RTS \& $1(J+3)$ \& $1(J+4)$ <br>
\hline Contents of $\mu \mathrm{WR}$ （Instruction being executed） \& $\mu \mathrm{WR}$ \& I（J） \& $1(J+1)$ \& JSR A \& （ $(\mathrm{A})$ \& $1(A+1)$ \& JSR B \& RTS \& $1(A+3)$ \& RTS \& $1(J+3)$ <br>
\hline
\end{tabular}

Figure 5．Two Nested Subroutines．Routine B is Only One Instruction．

## USING THE Am2909A AND Am2911A

The Am2909A and Am2911A are four-bit slice sequencers which are cascaded to form a microprogram memory address generator. Both products make available to the user several lines which are used to directly control the internal holding register, multiplexer and stack. By appropriate control of these lines, the user can implement any desired set of sequence control functions; by cascading parts he can generate any desired address length. These two qualities set the Am2909A and Am2911A apart from the Am2910, which is architecturally similar, but is fixed at 12 bits in length and has a fixed set of 16 sequence control instructions. The Am2909A or Am2911A should be selected instead of the Am2910 under the following conditions:

- Address less than 8 bits and not likely to be expanded
- Address longer than 12 bits
- More complex instruction set needed than is available on Am2910


## Architecture of the Control Unit

The recommended architecture using the Am2909A or Am2911A is shown in Figure 6. Note that the path from the pipeline register output through the next address logic, multiplexer, and microprogram memory is all combinational. The pipeline register contains the current microinstruction being executed. A portion of that microinstruction consists of a sequence control command such as "continue', 'loop', 'return-from-subroutine', etc. The bits representing this sequence command are logically combined with bits representing such things as test conditions and system state to generate the required control signals to the Am2909A or Am2911A. The block labeled 'next address logic" may consist of simple gates, a PROM or a PLA, but it should be all combinational.


Figure 6. Recommended Computer Control Unit Architecture Using the Am2911A or Am2909A.

The Am29811A is a combinational circuit which implements 16 sequence control instructions；it may be used with either an Am2909A or an Am2911A．The set of instructions is nearly identical to that implemented internally in the Am2910．

Figure 7 shows the CCU of Figure 6 with the Am29811A in place．The Am29811A，in addition to controlling the Am2911A，
also controls a loop counter and several branch address sources．The instructions which are implemented by the Am29811A are shown in Figure 8，along with the Am29811A outputs for each instruction．Generating any instruction set consists simply of writing a truth table and designing combina－ tional logic to implement it．For more detailed information refer to＇The Microprogramming Handbook＇．


AF001641
Figure 9．Twelve Bit Sequencer．


AF001511
Figure 10．Branch Address Structures．

## Expansion of the Am2909A or Am2911A

Figure 9 shows the interconnection of three Am2911A's to form a 12 -bit sequencer. Note that the only interconnection between packages, other than the common clock and control lines, is the ripple carry between $\mu \mathrm{PC}$ incrementors. This carry path is not in the critical speed path if the Am2911A Y outputs drive the microprogram memory, because the ripple carry occurs in parallel with the memory access time. If, on the other hand, a micro-address register is placed at the Am2911A output, then the carry may lie in the critical speed path, since the last carry-in must be stable for a set-up time prior to the clock.

## Selecting Between the Am2909A and Am2911A

The difference between the Am2909A and the Am2911A involves two signals: the data inputs to the holding register
and the "OR" inputs. In the Am2909A, separate four-bit fields are provided for the holding register and the direct branch inputs to the multiplexer. In the Am2911A, these fields are internally tied together. This may affect the design of the branch address system, as shown in Figure 10. Using the Am2909A, the register inputs may be connected directly to the microprogram memory; the internal register replaces part of the pipeline register. The direct (D) inputs may be tied to the mapping logic which translates instruction op codes into microprogram addresses. While the same technique might be used with the Am2911A, it is more common to connect the Am2911A's D inputs to a branch address bus onto which various sources may be enabled. Shown in Figure 10 is a pipeline register and a mapping ROM. Other sources might also be applied to the same bus. The internal register is used only for temporary storage of some previous branch address.

| MNEMONIC | FUNCTION | INPUTS |  |  |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 13 | 12 | 11 | 10 | TEST | NEXT <br> ADDR <br> SOURCE <br> $S_{1}$ <br> $S_{0}$$\|$ |  | FILE <br> FE PUP |  | COUNTER <br> LOAD EN |  | MAP E | $\overline{\text { PLE }}$ |
|  | PIN NO. | 14 | 13 | 12 | 11 | 10 | 4 | 5 | 3 | 2 | 6 | 7 | 1 | 9 |
| JZ | JUMP ZERO | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\bar{L}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \bar{L} \\ & \underline{L} \end{aligned}$ |
| cJs | CON JSB PL | L | $\begin{aligned} & L \\ & L \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | L H | $\begin{array}{r} \mathrm{L} \\ \mathrm{H} \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| JMAP | JUMP MAP | L | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & \hline \end{aligned}$ | H <br> H | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ |
| GJP | COND JUMP PL | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | L | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\bar{L}$ |
| PUSH | PUSH/COND LD CNTR | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\bar{L}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | L | $\begin{aligned} & \bar{L} \\ & L \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\underset{\mathrm{L}}{\mathrm{~L}}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| JSRP | COND JSB R/PL | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| CVJ | COND JUMP VECTOR | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ |
| JRP | COND JUMP R/PL | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| RFCT | REPEAT LOOP, CTR \# 0 | H | L | $L$ | L | H | L | L | L | $L$ | H | H | H | L |
| RPCT | REPEAT PL, CTR \# 0 | $\begin{array}{\|l} H \\ H \\ \hline \end{array}$ | $L$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & H \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ |
| CRTN | COND RTN | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \bar{L} \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\bar{L}$ | $\underset{\mathrm{L}}{\mathrm{~L}}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ |
| CJPP | COND JUMP PL \& POP | $\begin{array}{\|l\|} \hline H \\ H \end{array}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\underset{\mathrm{H}}{\mathrm{H}}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| LDCT | LD CNTR \& CONTINUE | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| LOOP | TEST END LOOP | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\bar{L}$ | $\stackrel{H}{\mathrm{H}}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| CONT | CONTINUE | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & \hline L \\ & H \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L |
| JP | JUMP PL | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | L |

Figure 8. AM29811A TRUTH TABLE


Figure 9. Twelve Bit Sequencer.


Figure 10. Branch Address Structures.

The second difference between the Am2909A and Am2911A is that the Am2909A has OR inputs available on each address output line. These pins can be used to generate multi-way single-cycle branches by simply tying several test conditions into the OR lines. See Figure 11. Typically, a branch is taken to an address with zeroes in the least significant bits. These bits are replaced with 1 's or 0 's by test conditions applied to the OR lines. In Figure 11, the states of the two test conditions $X$ and $Y$ result in a branch to 1100, 1101, 1110, or 1111.


AF001610
Figure 11. Use of OR Inputs to Obtain 4 - Way Branch.

The Am29803A has been designed to selectively apply any or all of four different test conditions to an Am2909A. Figure 12 shows the truth table for this device. A nice trade off between flexibility and board space is achieved by using a single 28 -pin Am2909A for the least significant four bits of a sequencer, and using the space-saving 20 -pin Am2911A's for the remainder of the bits. A detailed logic design for such a system is contained in "The Microprogramming Handbook."


Figure 12.

How to Perform Some Common Functions with the Am2909A or Am2911A

1. CONTINUE

| MUX/YOUT | STACK | $C_{n}$ | $S_{1}$ | $S_{0}$ | FE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PUP |  |  |  |  |  |
|  | HOLD | H | L | L | H |

Contents of PC placed on $Y$ outputs; PC incremented.

## 2. BRANCH

| MUX/YOUT | STACK | $C_{n}$ | $S_{1}$ | $S_{0}$ | FE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PUP |  |  |  |  |  |
| D | HOLD | H | H | H | H |

Feed data on D inputs straight through to memory address lines. Increment address and place in PC.

## 3. JUMP-TO-SUBROUTINE

| MUX/YOUT | STACK | $\mathrm{C}_{n}$ | $S_{1} S_{0} \overline{\text { FE }}$ PUP |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D | PUSH | H | H H | L | $\cdot \mathrm{H}$ |

Subroutine address fed from $D$ inputs to memory address. Current PC is pushed onto stack, where it is saved for the return.

## 4. RETURN-FROM-SUBROUTINE

| MUX/YOUT | STACK | $C_{n}$ | $S_{1}$ | $S_{0}$ | FE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| STACK | POP | H | H L | L | L |

The address at the top of the stack is applied to the microprogram memory, and is incremented for PC on the next cycle. The stack is popped to remove the return address.

## Am29803 FUNCTION TABLE

|  | BRANCH ON | $\begin{array}{llllll}13 & l_{2} & l_{1} & l_{0}\end{array}$ | $\mathrm{OR}_{3}$ | $\mathrm{OR}_{2}$ | $\mathrm{OR}_{1}$ | $\mathrm{OR}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NONE | NONE | L L L L | L | L | L | L |
| Two-way <br> Branches | T0 | L L L H | L | L | L | T0 |
|  | $\mathrm{T}_{1}$ | L L H L | L | L | L | $\mathrm{T}_{1}$ |
|  | $\mathrm{T}_{2}$ | L H L L | L | L | L | T2 |
|  | $\mathrm{T}_{3}$ | H L L L | L | L | L | T3 |
| Four-Way <br> Branches | $T_{1} \& T_{0}$ | L L H H | L | L | T1 | To |
|  | $T_{2} \& T_{0}$ | L H L H | L | L | $\mathrm{T}_{2}$ | T0 |
|  | $T_{3} \& T_{0}$ | H L L H | L | L | T3 | T0 |
|  | $T_{2} \& T_{1}$ | L H H L | L | L | T2 | $\mathrm{T}_{1}$ |
|  | $T_{3} \& T_{1}$ | H L H L | L | L | T3 | $\mathrm{T}_{1}$ |
|  | $T_{3} \& T_{2}$ | H H L L | L | L | $\mathrm{T}_{3}$ | $\mathrm{T}_{2}$ |
| Eight-Way <br> Branches | $\mathrm{T}_{2}, \mathrm{~T}_{1}, \mathrm{~T}_{0}$ | L H H H | L | T2 | $\mathrm{T}_{1}$ | T0 |
|  | $\mathrm{T}_{3}, \mathrm{~T}_{1}, \mathrm{~T}_{0}$ | H L H H | L | $\mathrm{T}_{3}$ | $\mathrm{T}_{1}$ | $\mathrm{T}_{0}$ |
|  | $\mathrm{T}_{3}, \mathrm{~T}_{2}, \mathrm{~T}_{0}$ | H H L H | L | T3 | $T_{2}$ | T0 |
|  | $T_{3}, T_{2}, T_{1}$ | H H H L | L | T3 | T2 | $\mathrm{T}_{1}$ |
| SixteenWay Branch | $T_{3}, T_{2}, T_{1}, T_{0}$ | H H H H | $T_{3}$ | $T_{2}$ | T ${ }_{1}$ | To |

## Burn－In Circuit for Am2909A（Flatpack and CERDIP）

Notes：
Max．$I_{C C}=200 \mathrm{~mA}$
$\mathrm{T}_{\mathrm{A}}=+125^{\circ} \mathrm{C}$
Resistors $= \pm 5 \%$
$R_{1}=390 \Omega$
$\mathrm{R}_{2}=560 \Omega$
$R_{3}=1 \mathrm{k} \Omega$
$\mathrm{f}_{\text {in }}=100 \mathrm{kHz}, 50 \%$ duty－cycle， $0-3 \mathrm{~V}$
$\mathrm{V}_{\text {CC }} \min .=5.0 \mathrm{~V}$
$V_{\text {CC }}$ max．$=5.1 \mathrm{~V}$


This circuit conforms to MIL－STD－883，Method 1005 and 1015，Condition D．Parallel excitation．

Burn－in Circuit for Am2911A

Notes：
Max．$I_{C c}=200 \mathrm{~mA}$
$\mathrm{T}_{\mathrm{A}}=+125^{\circ} \mathrm{C}$
Resistors $= \pm 5 \%$
$R_{1}=390 \Omega$
$R_{2}=560 \Omega$
$R_{3}=1 k \Omega$
$f_{\text {in }}=100 \mathrm{kHz}, 50 \%$ duty－cycle， $0-3 \mathrm{~V}$
From clock buffer on each board：
$V_{\text {cc }}$ min．$=5.0 \mathrm{~V}$
$V_{\text {cec }} \max .=5.1 \mathrm{~V}$


This circuit conforms to MIL－STD－883，Method 1005 and 1015，Condition D．Parallel excitation．

## A．THREE－STATE OUTPUTS



TC001140

$$
R_{1}=\frac{5.0-V_{\mathrm{BE}}-V_{\mathrm{OL}}}{l_{\mathrm{OL}}+\mathrm{V}_{\mathrm{OL}} / 1 \mathrm{~K}}
$$

B．NORMAL OUTPUTS


$$
\begin{gathered}
\mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{I}_{\mathrm{OH}}} \\
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\mathrm{l}_{\mathrm{OL}}+\mathrm{V}_{\mathrm{OL}} / \mathrm{R}_{2}}
\end{gathered}
$$

Notes：1． $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ includes scope probe，wiring and stray capacitances without device in text fixture．
2． $\mathrm{S}_{1}, \mathrm{~S}_{2}, \mathrm{~S}_{3}$ are closed during function tests all and $A C$ tests except output enable tests．
3．$S_{1}$ and $3_{3}$ are closed while $S_{2}$ is open for tPZH test．
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test．
4．$C_{L}=5.0 \mathrm{pF}$ for output disable tests．

## TEST OUTPUT LOADS

|  |  | Am2909A |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Pin \＃ | Pin Label | Test Circuit | $\mathbf{R}_{1}$ | $\mathbf{R}_{\mathbf{2}}$ |
| $18-21$ | $Y_{0-3}$ | $A$ | 220 | 1 K |
| 24 | $C_{n+4}$ | $B$ | 220 | 2.4 K |

TEST OUTPUT LOADS

|  |  | Am2911A |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Pin \＃ | Pin Label | Test Circuit | $\mathbf{R}_{1}$ | $\mathbf{R}_{\mathbf{2}}$ |
| $12-15$ | $\mathrm{Y}_{0-3}$ | A | 220 | 1 K |
| 18 | $\mathrm{C}_{n}+4$ | B | 220 | 2.4 K |

## Notes on Testing

Incoming test procedures on this device should be carefully planned，taking into account the high complexity and power levels of the part．The following notes may be useful：

1．Insure the part is adequately decoupled at the test head． Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes．

2．Do not leave inputs floating during any tests，as they may start to oscillate at high frequency．

3．Do not attempt to perform threshold tests at high speed． Following an input transition，ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$ ．Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily．

4．Use extreme care in defining input levels for AC tests．Many inputs may be changed at once，so there will be significant noise at the device pins and they may not actually reach $V_{I L}$ or $V_{1 H}$ until the noise has settled．AMD recommends using $V_{I L} \leqslant 0 \mathrm{~V}$ and $V_{I H} \geqslant 3.0 \mathrm{~V}$ for $A C$ tests．
5．To simplify failure analysis，programs should be designed to perform DC，Function，and AC tests as three distinct groups of tests．

6．To assist in testing，AMD offers complete documentation on our test procedures and，in most cases，can provide Fairchild Sentry programs，under license．

# Am2912 

Quad Bus Transceiver

## DISTINCTIVE CHARACTERISTICS

- Input to bus is inverting
- Quad high-speed open collector bus transceiver
- Driver outputs can sink 100 mA at 0.8 V maximum
- Bus compatible with Am2905, Am2906, Am2907
- Advanced Schottky processing
- PNP inputs to reduce input loading


## GENERAL DESCRIPTION

The Am2912 is a quad Bus Transceiver consisting of four high-speed bus drivers with open-collector outputs capable of sinking 100 mA at 0.8 volts and four high-speed bus receivers. Each driver output is connected internally to the high-speed bus receiver in addition to being connected to the package pin. The receiver has a Schottky TTL output capable of driving 10 Schottky TTL unit loads.

An active LOW enable gate controls the four drivers so that outputs of different device drivers can be connected together for party-line operation. The enable input can be conveniently driven by active LOW decoders such as the Am25LS139.

The bus output high-drive capability in the LOW state allows party-line operation with a line impedance as low as $100 \Omega$. The line can be terminated at both ends, and still give considerable noise margin at the receiver. The receiver typical switching point is 2.0 volts.

The Am2912 features advanced Schottky processing to minimize propagation delay. The device package also has two ground pins to improve ground current handling and allow close decoupling between $\mathrm{V}_{\mathrm{CC}}$ and ground at the package. Both $\mathrm{GND}_{1}$ and $\mathrm{GND}_{2}$ should be tied to the ground bus external to the device package.


BD002130

## CONNECTION DIAGRAM Top View

D-16-1


CD004260

Note: Pin 1 is marked for orientation

LOGIC SYMBOL


LS000890

METALLIZATION AND PAD LAYOUT


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type
Quad Bus Transceiver


Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


TYPICAL APPLICATION


AF001550

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ $-0.5 V$ to $+V_{C C} \max$ DC Input Voltage..................................-0.5V to +5.5V
DC Output Current, Into Bus
DC Output Current, Into Outputs
(Except Bus) $\qquad$ .30 mA DC Input Current .............................-30mA to +5.0 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 exterded periods may affect device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage (Receiver Outputs) | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-1.0 \mathrm{~mA} \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  | COM'L | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage (Receiver Outputs) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IOL}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IL}} \text { or } \mathrm{V}_{\mathrm{IH}} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $V_{14}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=M I N, I^{\prime}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{\text {I }}=0.4 V$ | Enable |  |  | -0.36 |  |
|  |  |  | Data |  |  | -0.54 | mA |
| IIH | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{\mathbb{N}}=2.7 \mathrm{~V}$ | Enable |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | Data |  |  | 30 |  |
| 11 | Input HIGH Current (Except Bus) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| ISC | Output Short Circuit Current (Except Bus) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ (Note 3) | MIL | -20 |  | -55 | mA |
|  |  |  | COM'L | -18 |  | -60 |  |
| ICCL | Power Supply Current (All Bus Outputs LOW) | $\begin{aligned} & \mathrm{VCC}=\mathrm{MAX} \\ & \text { Enable }=\mathrm{GND} \end{aligned}$ |  |  | 45 | 70 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating. Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

BUS INPUT／OUTPUT CHARACTERISTICS over operating temperature range

| Parameters | Description | Test Conditions（Note 2） |  |  | Min | Typ （Note 1） | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VoL | Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | MIL | $\mathrm{IOL}=40 \mathrm{~mA}$ |  | 0.33 | 0.5 | Volts |
|  |  |  |  | $\mathrm{l} \mathrm{OL}=70 \mathrm{~mA}$ |  | 0.42 | 0.7 |  |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=100 \mathrm{~mA}$ |  | 0.51 | 0.8 |  |
|  |  |  | COM＇L | $\mathrm{ILL}=40 \mathrm{~mA}$ |  | 0.33 | 0.5 |  |
|  |  |  |  | $\mathrm{l} \mathrm{OL}=70 \mathrm{~mA}$ |  | 0.42 | 0.7 |  |
|  |  |  |  | $\mathrm{l}^{\mathrm{OL}}=100 \mathrm{~mA}$ |  | 0.51 | 0.8 |  |
| 10 | Bus Leakage Current | $V_{C C}=\mathrm{MAX}$ |  | $\mathrm{V}_{\mathrm{O}}=0.8 \mathrm{~V}$ |  |  | －50 |  |
|  |  |  | MIL | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 200 |  |
|  |  |  | COM＇L | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| IOFF | Bus Leakage Current（Power Off） | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| $V_{\text {TH }}$ | Receiver Input HIGH Threshold | $\begin{aligned} & \text { Bus Enable }=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{MAX} \end{aligned}$ |  | MIL | 2.4 | 2.0 |  | Volts |
|  |  |  |  | COM＇L | 2.25 | 2.0 |  |  |
| $V_{\text {TL }}$ | Receiver Input LOW Threshold | $\begin{aligned} & \text { Bus Enable }=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{MIN} \end{aligned}$ |  | MIL |  | 2.0 | 1.6 | Volts |
|  |  |  |  | COM＇L |  | 2.0 | 1.75 |  |

Notes：1．Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading．
2．For conditions shown as MIN or MAX，use the appropriate value specified under Operating Ranges for the applicable device type． 3．Not more than one output should be shorted at a time．Duration of the short circuit test should not exceed one second．

## TYPICAL PERFORMANCE CURVES

Typical Bus Output Low Voltage Versus Ambient Temperature


OP001460


Receiver Threshold Variation


Versus Ambient Temperature


OP001470

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Data Input to Bus | $\begin{gathered} R_{B}=50 \Omega \\ C_{B}=50 \mathrm{pF}(\text { Note } 1) \end{gathered}$ |  | 10 | 15 |  |
| tpHL |  |  |  | 10 | 15 | ns |
| tplH | Enable Input to Bus |  |  | 14 | 18 | ns |
| tPHL |  |  |  | 13 | 18 |  |
| tplH | Bus to Receiver Out | $R_{B}=50 \Omega, R_{L}=280 \Omega$ <br> $C_{B}=50 \mathrm{pF}($ Note 1$), C_{L}=15 \mathrm{pF}$ |  | 10 | 15 | ns |
| tphL |  |  |  | 10 | 15 |  |
| $t_{r}$ | Bus | $\begin{gathered} R_{B}=50 \Omega \\ C_{B}=50 \mathrm{pF} \text { (Note 1) } \end{gathered}$ | 4.0 | 10 |  | ns |
| ${ }_{4}$ | Bus |  | 2.0 | 4.0 |  | ns |

Note 1．Includes probe and jig capacitance．

## SWITCHING TEST CIRCUIT



TC001180
Note 1．Include Probe and Jig Capacitance．

## SWITCHING WAVEFORMS



## Am2913

Priority Interrupt Expander

## DISTINCTIVE CHARACTERISTICS

- Encodes eight lines to three-line binary
- Expands use of Am2914
- Cascadable
- Similar in function to Am54LS/74LS/25LS148/2513
- Gated three-state output
- Advanced Low-Power Schottky processing


## GENERAL DESCRIPTION

The Low-Power Schottky Priority Interrupt Expander is an extention of the Am2900 series of Bipolar Processor family and is used to expand and prioritize the output of the Am2914 Priority Interrupt circuit. Affording an increase of vectored priority interrupt in groups of eight, this unit accepts active LOW inputs and produces a three-state active HIGH output prioritized from active $\bar{I}_{7}$ to $\bar{I}_{0}$. The
output is gated by five control signals, three active LOW and two active HIGH. Also provided is a cascade input (EI) and Enable Output ( $\overline{\mathrm{EO}}$ ).

One Am2913 will accept and encode group signal lines from up to 8 Am2914's ( 64 levels of interrupt). Additional Am2913's may be used to encode more interrupt levels.

## BLOCK DIAGRAM



## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2914 | Vectored Priority Interrupt Controller |
| Am25LS2513 | 8 to 3 Line Priority Encoder |

## CONNECTION DIAGRAM Top View

P-20, D-20


CD002030

## L-20-1



F-20 pin configuration identical to D-20, P-20.
Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am2913


Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
Package
D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless chip carrier
P - 20-pin plastic DIP
$X$-Dice
Device type
Priority Interrupt Expander

| Valid Combinations |  |
| :--- | :--- |
| Am2913 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Inputs | Outputs |
| :---: | :---: |
|  | $\mathbf{A}_{0} A_{1} A_{2}$ EO |
| H X X X X X X X X | L L H |
| L H H H H H H H H | L L L |
| L X X X X X X X L | H H H H |
| L X X X X X X L H | H H H |
| L X X X X X L H H | H L H H |
| L X X X X L H H H | L H H |
| LXXXLHHHH | H H L H |
| L X X L H H H H H | L H L H |
| LXLHHHHHH | H L L H |
| L L H H H H H H H | H |


| G1 | G2 | G3 | G4 | $\overline{\text { G5 }}$ | $A_{0}$ | $\mathrm{A}_{1}$ | $A_{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | L | L | L | Enabled |  |  |
| L | X | X | X | X | Z | Z | Z |
| X | L | X | X | x | Z | z | Z |
| X | X | H | X | X | Z | Z | Z |
| X | X | X | H | X | z | z | Z |
| X | X | X | X | H | Z | Z | Z |

$Z=$ HIGH Impedance
$\mathrm{H}=\mathrm{HIGH}$ Voltage Level
L = LOW Voltage Level
$\mathrm{X}=$ Don't Care
For $G_{1}=H, G_{2}=H, G_{3}=L, G_{4}=L, G_{5}=L$


Shown above is the connection of the instruction lines and vector output lines in a 64 -input priority interrupt system. The Am2913 is used to encode the most significant bits associated with the vector output.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
Voltage Applied to Outputs For
High Output State ....................... -0.5V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage..................................-0.5V to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ...................... +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
. 4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M_{I N} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL, $\mathrm{l}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{I}^{\text {OH }}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.2 |  |  |
|  |  |  | $E \mathrm{EO}, 1 \mathrm{OH}=-440 \mu \mathrm{~A}$ | MIL | 2.5 | 3.4 |  |  |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| $\mathrm{VOL}_{\text {O }}$ | 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{lOL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}\left(\mathrm{~A}_{n}\right.$ Outputs) |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH Voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{\text {IN }}=0.4 \mathrm{~V} \end{aligned}$ | $\overline{E I}, \mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}, \bar{I}_{0}$ |  |  |  | 0.4 | mA |
|  |  |  | All others |  |  |  | 0.8 |  |
| IIH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 V \end{aligned}$ | En, $\mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}, \bar{T}_{0}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | All others |  |  |  | 40 |  |
| 11 | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=7.0 \mathrm{~V} \end{aligned}$ | EI, $\mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathbf{G}}_{4}, \overline{\mathrm{G}}_{5}, \bar{I}_{0}$ |  |  |  | 0.1 | mA |
|  |  |  | All others |  |  |  | 0.2 |  |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$$\mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  | 15 | 24 | mA |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All inputs and outputs open.


IC000710
Note: Actual current flow direction shown.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | $\bar{T}_{i}$ to $A_{n}$ ( (n-phase) | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 17 | 25 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 17 | 25 |  |
| tPLH | $\bar{F}_{i}$ to $A_{n}$ (Out-phase) |  |  | 11 | 17 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 12 | 18 |  |
| tPLH | $\bar{i}$ to $\overline{E O}$ |  |  | 7.0 | 11 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 24 | 36 |  |
| tplH | El to EO |  |  | 11 | 17 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 23 | 34 |  |
| tplH | El to $A_{n}$ |  |  | 12 | 18 | ns |
| tpHL |  |  |  | 14 | 21 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to $A_{n}$ |  |  | 23 | 40 | ns |
| tzL |  |  |  | 20 | 37 |  |
| $\mathrm{t}_{\mathrm{Z}} \mathrm{H}$ | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 20 | 30 | ns |
| tzL |  |  |  | 18 | 27 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to $\mathrm{A}_{\mathrm{n}}$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 17 | 27 | ns |
| tLz |  |  |  | 19 | 28 |  |
| thz | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 16 | 24 | ns |
| tLZ |  |  |  | 18 | 27 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | $\begin{array}{\|c\|} \hline \text { COMMERCIAL } \\ \hline \text { Am2913 } \\ \hline \end{array}$ |  | $\begin{array}{\|c\|} \hline \text { MILITARY } \\ \hline \text { Am2913 } \end{array}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tplH | $\mathrm{I}_{\mathrm{i}}$ to $\mathrm{A}_{n}$ ( n -phase) | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 31 |  | 37 | ns |
| tPHL |  |  |  | 30 |  | 34 |  |
| tplH | $i_{i}$ to $A_{n}$ (Out-phase) |  |  | 22 |  | 27 | ns |
| tpHL |  |  |  | 22 |  | 25 |  |
| tpli | $\bar{i}_{i}$ to EO |  |  | 15 |  | 18 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 48 |  | 60 |  |
| tplu | El to EO |  |  | 19 |  | 21 | ns |
| tpHL |  |  |  | 46 |  | 57 |  |
| tplH | El to $A_{n}$ |  |  | 22 |  | 25 | ns |
| $t_{\text {P PHL }}$ |  |  |  | 27 |  | 32 |  |
| tz | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to $\mathrm{A}_{\mathrm{n}}$ |  |  | 42 |  | 49 | ns |
| tzL |  |  |  | 43 |  | 49 |  |
| tz | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 36 |  | 43 | ns |
| tzL |  |  |  | 35 |  | 43 |  |
| ${ }_{\text {thz }}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to $\mathrm{A}_{\mathrm{n}}$ | $\begin{aligned} & C_{\mathrm{L}}=5.0 \mathrm{pF} \\ & R_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 34 |  | 40 | ns |
| tiz |  |  |  | 34 |  | 40 | ns |
| thz | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 30 |  | 35 | ns |
| tLz |  |  |  | 31 |  | 35 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.
Note: $\mathrm{i}=0$ to 7
$\mathrm{n}=0$ to 2

## Am2914

## Vectored Priority Interrupt Controller

## DISTINCTIVE CHARACTERISTICS

- Accepts 8 interrupt inputs -

Interrupts may be pulses or levels and are stored internally

- Built-in mask register -

Six different operations can be performed on mask register

- Built-in status register -

Status register holds code for lowest allowed interrupt

- Vectored output -

Output is binary code for highest priority unmasked interrupt

- Expandable -

Any number of Am2914's may be stacked for large interrupt systems

- Microprogrammable -

Executes 16 different microinstructions Instruction enable pin aids in vertical microprogramming

## GENERAL DESCRIPTION

The Am2914 is a high-speed, eight-bit priority interrupt unit that is cascadable to handle any number of priority interrupt request levels. The high-speed of the Am2914 makes it ideal for use in Am2900 family microcomputer designs, but it can also be used with the Am9080A MOS microprocessor.

The Am2914 receives interrupt requests on 8 interrupt input lines ( $\mathrm{P}_{0}-\mathrm{P}_{7}$ ). A LOW level is a request. An internal latch may be used to catch pulses on these lines, or the latch may be bypassed so the request lines drive the leveltriggered interrupt register directly. An 8-bit mask register is used to mask individual interrupts. Considerable flexibility is provided for controlling the mask register. Requests in the interrupt register are ANDed with the corresponding bits in the mask register and the results are sent to an 8 -input priority encoder, which produces a three bit encoded vector representing the highest numbered input which is not masked.

An internal status register is used to point to the lowest priority at which an interrupt will be accepted. The contents of the status register are compared with the output of the priority encoder, and an interrupt request output will occur if the vector is greater than or equal to status. Whenever a vector is read from the Am2914 the status register is automatically updated to point to one level higher than the vector read. (The status register can be loaded externally or read out at any time using the $S$ pins.) Signals are provided for moving the status upward across devices (Group Advance Send and Group Advance Receive) and for inhibiting lower priorities from higher order devices (Ripple Disable, Parallel Disable, and Interrupt Disable). A status overflow output indicates that an interrupt has been read at the highest priority.

The Am2914 is controlled by a 4-bit instruction field $\mathrm{l}_{0}-\mathrm{I}_{3}$. The command on the instruction lines is executed if IE is LOW and is ignored if IE is HIGH, allowing the 4 I bits to be shared with other devices.

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902A | Carry Look-ahead Generator |
| Am2913 | Priority Interrupt Expander |
| Am25LS138 | 3-to-8 Decoder |
| Am27S19 | Mapping PROM |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type Priority Interrupt Controller
*Note: Flatpak available for military only.


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## BLOCK DIAGRAM DESCRIPTION

The Microinstruction Decode circuitry decodes the Interrupt Microinstructions and generates required control signals for the chip.

The Interrupt Register holds the Interrupt inputs and is an eight-bit, edge-triggered register which is set on the rising edge of the CP Clock signal.

The Interrupt latches are set/reset-type latches. When the Latch Bypass signal is LOW, the latches are enabled and act as negative pulse catchers on the inputs to the Interrupt Register. When the Latch Bypass signal is HIGH, the Interrupt latches are transparent.
The Mask Register holds the eight mask bits associated with the eight interrupt levels. The register may be loaded from or read to the $M$ Bus. Also, the entire register or individual mask bits may be set or cleared.
The Interrupt Detect circuitry detects the presence of any unmasked Interrupt Input. The eight-input Priority Encoder determines the highest priority, non-masked Interrupt Input and forms a binary coded Interrupt Vector. Following a Vector Read, the three-bit Vector Hold Register holds the binary coded interrupt vector. This stored vector is used for clearing interrupts.

The three-bit Status Register holds the status bits and may be loaded from or read to the S Bus. During a Vector Read, the Incrementer increments the Interrupt Vector by one, and the result is clocked into the Status Register. Thus the Status

Register always points to the lowest level at which an interrupt will be accepted.
The three-bit Comparator compares the Interrupt Vector with the contents of the Status Register and indicates if the Interrupt Vector is greater than or equal to the contents of the Status Register.
The Lowest Group Enabled Flip-Flop is used when a number of Am2914's are cascaded. In a cascaded system, only one Lowest Group Enabled Flip-Flop is LOW at a time. It indicates the eight interrupt group, which contains the lowest priority interrupt level which will be accepted and is used to form the higher order status bits.
The Interrupt Request and Group Enable logic contain various gating to generate the Interrupt Request, Parallel Disable, Ripple Disable, and Group Advance Send signals.

The Status Overflow signal is used to disable all interrupts. It indicates the highest priority Interrupt Vector has been read and the Status Register has overflowed.
The Clear Control logic generates the eight individual clear signals for the bits in the Interrupt Latches and Register. The Vector Clear Enable Flip-Flop indicates if the last vector read was from this group. When it is set, it enables the Clear Control Logic.

The CP clock signal is used to clock the Interrupt Register, Mask Register, Status Register, Vector Hold Register, and the Lowest Group Enabled, Vector Clear Enable and Status Overflow Flip-Flops, all on the clock LOW-to-HIGH transition.


## TABLE 1.

MICROINSTRUCTION SET FOR Am2914 PRIORITY INTERRUPT CIRCUIT

| $\mathrm{I}_{3} \mathrm{I}_{2} \mathrm{I}_{1} \mathrm{l}_{0}$ | Mnemonic | Instruction |
| :---: | :---: | :---: |
|  |  | Mask Register Functions |
| 1110 | LDM | Load mask register from M bus |
| 0111 | RDM | Read mask register to M bus |
| 1100 | CLRM | Clear mask register (enables all priorities) |
| 1000 | SETM | Set mask register (inhibits all interrupts) |
| 1010 | BCLRM | Bit clear mask register from $M$ bus |
| 1011 | BSETM | Bit set mask register from M bus |
| 1001 | LDSTA | Status Register Functions Load status register from S bus and LGE flipflop from GE input |
| 0110 | RDSTA | Read status register to S bus |
| $\begin{aligned} & 1111 \\ & 1101 \end{aligned}$ | ENIN DISIN | Interrupt Request Control Enable interrupt request Disable interrupt request |
| 0101 | RDVC | Vectored Output <br> Read vector output to $V$ outputs, load $V+1$ into status register, load $V$ into vector hold register and set vector clear enable flip-flop. |
| $\begin{aligned} & 0001 \\ & 0011 \end{aligned}$ | CLRIN CLRMR | Priority Interrupt Register Clear <br> Clear all interrupts <br> Clear interrupts from mask register data (uses the $M$ bus) |
| $\begin{aligned} & 0010 \\ & 0100 \end{aligned}$ | CLRMB CLRVC | Clear interrupts from $M$ bus data Clear the individual interrupt associated with the last vector read |
| 0000 | MCLR | Master Clear <br> Clear all interrupts, clear mask register, clear status register, clear LGE flip-flop, enable interrupt request. |



Figure 1. Interrupt Request Logic.


Figure 2.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$
DC Voltage Applied to Outputs For
High Output State $\qquad$
DC Input Voltage
0.5 V to $+\mathrm{V}_{\mathrm{Cc}}$ max

DC Output Current, Into Outputs -0.5 V to +5.5 V

DC Input Current .............................................. 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
+4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\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}$ |  | MIL, $\mathrm{l}^{\text {OH }}=-1.0 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 |  |  |  |
| ICEX | Output Leakage Current for IR Output | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  |  | 250 | $\mu \mathrm{A}$ |
| 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}$ |  |  |  |  | 0.4 | Volts |
|  |  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  | 0.45 |  |
|  |  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{I}_{1 \mathrm{~N}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=0.4 V \end{aligned}$ |  | M0-7 |  |  | -0.15 | mA |
|  |  |  |  | $\mathrm{S}_{0-2}$ |  |  | -0.1 |  |
|  |  |  |  | L. B. |  |  | -0.4 |  |
|  |  |  |  | I. D. |  |  | -2.0 |  |
|  |  |  |  | $\overline{\mathrm{E}}$ |  |  | -1.08 |  |
|  |  |  |  | All Others |  |  | -0.8 |  |
| $I_{\text {IH }}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ |  | $\mathrm{M}_{0-7}$ |  |  | 150 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{S}_{0-2}$ |  |  | 100 |  |
|  |  |  |  | $\overline{\mathrm{GE}}, \overline{\mathrm{GAR}}$ |  |  | 40 |  |
|  |  |  |  | $\overline{\text { IE }}$ |  |  | 60 |  |
|  |  |  |  | I. D. |  |  | 60 |  |
|  |  |  |  | All Others |  |  | 20 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| Iozl | Off-State Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ | $\mathrm{M}_{0-7}$ |  |  | -150 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{S}_{0-2}$ |  |  | -100 |  |
|  |  |  |  | $\mathrm{V}_{0-2}$ |  |  | -50 |  |
| IOZH |  |  | $\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}$ | $\mathrm{M}_{0-7}$ |  |  | 150 |  |
|  |  |  |  | $\mathrm{S}_{0-2}$ |  |  | 100 |  |
|  |  |  |  | $\mathrm{V}_{0-2}$ |  |  | 50 |  |
| Icc | Power Supply Current | $V_{C C}=$ MAX | COM'L | $0^{\circ} \mathrm{C}$ |  |  | 305 | mA |
|  |  |  |  | $70^{\circ} \mathrm{C}$ |  |  | 250 |  |
|  |  |  | MIL | $-55^{\circ} \mathrm{C}$ |  |  | 310 |  |
|  |  |  |  | $125^{\circ} \mathrm{C}$ |  |  | 200 |  |
| Isc | Output Short Circuit Current (Note 3) | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  | -30 |  | -85 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

## SWITCHING CHARACTERISTICS OVER OPERATING VOLTAGE AND TEMPERATURE RANGE

(Group A, subgroup 10 and 11 tests and limits) All outputs fully loaded, $C_{L}=50 \mathrm{pF}$. Measurements made at 1.5 V with input levels of 0 and 3.0V. For Interrupt Request Output, $R_{L}=390 \Omega$, $V_{\text {LOAD }}=5.0 \mathrm{~V}$.

TABLE I. CLOCK AND INTERRUPT INPUT PULSE WIDTHS (ns)

| Time | COMMERCIAL | MILITARY |
| :--- | :---: | :---: |
| Minimum Clock LOW Time | 30 | 30 |
| Minimum Clock HIGH Time | 30 | 30 |
| Minimum Interrupt Input (P0-P7) LOW Time <br> for Guaranteed Acceptance (Pulse Mode) | 40 | 40 |
| Maximum Interrupt Input (Po-P7) LOW Time <br> for Guaranteed Rejection (Pulse Mode) | 8 | 8 |
| Minimum Clock Period, $\bar{E}=H$ on current <br> cycle and previous cycle | 50 | 55 |
| Minimum Clock Period, $\bar{E}=$ L on current <br> cycle or previous cycle | 100 | 110 |

TABLE II. MAXIMUM COMBINATIONAL PROPAGATION DELAYS (ns)

| From Input | To Output |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | COMMERCIAL |  |  |  |  |  | MILITARY |  |  |  |  |  |
|  | $\begin{gathered} \mathrm{M} \\ \text { Bus } \end{gathered}$ | $\begin{gathered} \mathbf{S} \\ \text { Bus } \end{gathered}$ | $\mathrm{V}_{012}$ | Irpt <br> Req | Ripple Disable | Group Advance Send | $\begin{aligned} & \text { SM } \\ & \text { Bus } \end{aligned}$ | $\begin{gathered} S \\ \text { Bus } \end{gathered}$ | $\mathrm{V}_{012}$ | $\begin{aligned} & \text { Irpt } \\ & \text { Req } \end{aligned}$ | Ripple Disable | Group Advance Send |
| IE | 52 | 60 | 65 | - | - | 56 | 60 | 68 | 70 | - | - | 62 |
| 10123 | 52 | 60 | 65 | - | - | 56 | 60 | 68 | 70 | - | - | 62 |
| Irpt. Disable | - | - | 45 | 52 | 20 | 30 | - | - | 48 | 60 | 22 | 33 |

TABLE III. MAXIMUM DELAYS FROM CLOCK TO OUTPUTS (ns)

|  | COMMERCIAL |  |  |  |  |  |  | MILITARY |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Path | To $V_{012}$ | To Irpt Req | $\begin{aligned} & \text { To } \\ & \text { PD } \end{aligned}$ | $\begin{aligned} & \text { TO } \\ & \mathbf{R D} \end{aligned}$ | $\frac{\text { To }}{\text { GAS }}$ | To Status O'flow | $\frac{\text { To }}{\text { GS }}$ | $\begin{gathered} \text { To } \\ \mathbf{V}_{012} \end{gathered}$ | To Irpt Req | $\begin{aligned} & \text { To } \\ & \text { PD } \end{aligned}$ | $\begin{aligned} & \text { To } \\ & \frac{R D}{} \end{aligned}$ | $\frac{\text { To }}{\text { GAS }}$ | To Status O'flow | $\frac{\text { To }}{\mathbf{G S}}$ |
| Irpt Latches and Register | 76 | 97 | 67 | 67 | 80 | - | - | 82 | 105 | 75 | 75 | 85 | - | - |
| Mask Register | 76 | 97 | 67 | 67 | 80 | - | - | 82 | 105 | 75 | 75 | 85 | - | - |
| Status Register | 67 | 88 | 63 | 63 | 70 | - | - | 73 | 96 | 66 | 66 | 76 | - | - |
| Lowest Group Enabled Flip-Flop | - | - | 48 | 52 | - | - | 38 | - | - | 54 | 58 | - | - | 45 |
| Irpt Request Enable Flip-Flop | - | 62 | - | - | - | - | - | - | 66 | - | - | - | - | - |
| Status Overflow Flip-Flop | - | - | - | - | - | 35 | - | - | - | - | - | - | 40 | - |

TABLE IV. SETUP AND HOLD TIME REQUIREMENTS (ns)
(All relative to clock LOW-to-HIGH transition)

| From Input | COMMERCIAL |  | MILITARY |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Am2914 |  | Am2914 |  |
|  | Set-Up Time | Hold Time | Set-Up Time | Hold Time |
| S-Bus | 15 | 10 | 15 | 10 |
| M-Bus | 15 | 10 | 15 | 10 |
| $\overline{\mathrm{P}}_{0}-\bar{P}_{7}$ | 15 | 8 | 15 | 8 |
| Latch Bypass | 20 | 0 | 20 | 0 |
| $\begin{aligned} & \overline{\overline{I E}} \\ & \mathrm{P}_{0123} \text { (See Note) } \end{aligned}$ | $\begin{gathered} 55 \\ \mathrm{t}_{\mathrm{pwL}}+33 \end{gathered}$ | 0 | $\begin{gathered} 55 \\ \mathrm{t}_{\mathrm{pwL}}+40 \end{gathered}$ | 0 |
| $\overline{\mathrm{GE}}$ | 15 | 13 | 15 | 13 |
| GAR | 15 | 13 | 15 | 13 |
| Irpt Disable | 42 | 0 | 42 | 0 |
| $\mathrm{Po}_{0} \mathrm{P}_{7} \text { Hold Time }$ <br> Relative to LB | - | 25 | - ${ }^{1}$ | 25 |

[^7]
## SWITCHING TEST CIRCUIT

C．OPEN－COLLECTOR OUTPUTS


TC001200

D．THREE－STATE OUTPUTS


TC001210

TEST OUTPUT LOAD FOR Am2914

| Pin \＃ | Pin Label | Test Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 3 | Group <br> Signal | C | 2 K | - |
| 4 | Group <br> Advance <br> Receive | C | 2 K | - |
| 7 | Ripple <br> Disable | C | 2 K | - |
| 8 | Parallel <br> Disable | C | 2 K | - |
| 9 | Interrupt <br> Request | C | 390 | - |
| $13-11$ | $\mathrm{S}_{0-2}$ | D | 240 | 240 |
| 14 | Status <br> Overflow | C | 2 K | - |
| $18-16$ | $\mathrm{~V}_{0-2}$ | D | 240 | 240 |
| - | $\mathrm{M}_{0-7}$ | D | 240 | 240 |

## Notes on Testing

Incoming test procedures on this device should be carefully planned，taking into account the high complexity and power levels of the part．The following notes may be useful：
1．Insure the part is adequately decoupled at the test head． Large changes in $\mathrm{V}_{\mathrm{CC}}$ current as the device switches may cause erroneous function failures due to $V_{C C}$ changes．
2．Do not leave inputs floating during any tests，as they may start to oscillate at high frequency．
3．Do not attempt to perform threshold tests at high speed． Following an input transition，ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$ ．Inductance in the ground cable may allow the ground pin at the device to rise by 100s of millivolts momentarily．

4．Use extreme care in defining input levels for AC tests．Many inputs may be changed at once，so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled．AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests．

5．To simplify failure analysis，programs should be designed to perform DC，Function，and AC tests as three distinct groups of tests．

6．To assist in testing，AMD offers complete documentation on our test procedures and，in most cases，can provide Fairchild Sentry programs，under license．

Am2914 Burn-in Circuit


INPUT/OUTPUT CIRCUITS


IC000450

# Am2915A 

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus-transceiver
- Three-state bus driver output can sink 48 mA at 0.5 V max.
- Two-port input to D-type register on driver
- Receiver has output latch for pipeline operation
- Three-state receiver outputs sink 12 mA
- 3.5V minimum output high voltage for direct interface to MOS microprocessors


## GENERAL DESCRIPTION

The Am2915A is a high-performance, low-power Schottky bus transceiver intended for bipolar or MOS microprocessor system applications. The device consists of four D-type edge-triggered flip-flops with a built-in two-input multiplexer on each. The flip-flop outputs are connected to four threestate bus drivers. Each bus driver is internally connected to the input of a receiver. The four receiver outputs drive four D-type latches that feature three-state outputs.
This LSI bus transceiver is fabricated using advanced lowpower Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The three-state bus output can sink up to 48 mA at 0.5 V maximum. The bus enable input (BE) is used to force the driver outputs to the highimpedance state. When $\overline{B E}$ is HIGH, the driver is disabled. The $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ of the bus driver are selected for compatibility with standard and low-power Schottky inputs.

The input register consists of four D-type flip-flops with a buffered common clock and two-input multiplexer at the
input of each flip-flop. A common select input ( S ) controls the four multiplexers. When $S$ is LOW, the $A_{i}$ data is stored in the register and when $S$ is HIGH, the $B_{i}$ data is stored. The buffered common clock (DRCP) enters the data into this driver register on the LOW-to-HIGH transition.

Data from the $A$ or $B$ inputs is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{R L E}$ ) input. When the RLE input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted and $\overline{O E}$ LOW). When the RLE input is HIGH, the latch will close and retain the present data regardless of the bus input. The four latches have threestate outputs and are controlled by a buffered common three-state control ( $\overline{\mathrm{OE}}$ ) input. When $\overline{O E}$ is HIGH, the receiver outputs are in the high-impedance state.

## BLOCK DIAGRAM



## CONNECTION DIAGRAM Top View

## D-24-1



CD003010

Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

[^8]

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
| 8, 16, 20 | $\begin{array}{ll} A_{0}, & A_{1} \\ A_{2}, & A_{3} \\ \hline \end{array}$ | 1 | The " $A$ " word data input into the two input multiplexer of the driver register. |
| 3, 9, 15, 21 | $\begin{array}{ll} \mathrm{B}_{0}, & \mathrm{~B}_{1} \\ \mathrm{~B}_{2}, & \mathrm{~B}_{3} \\ \hline \end{array}$ | 1 | The ' $\mathrm{B}^{\prime \prime}$ word data input into the two input multiplexers of the driver register. |
| 13 | S | 1 | Select. When the select input is LOW, the A data word is applied to the driver register. When the select input is HIGH, the B word is applied to the driver register. |
| 23 | DRCP | 1 | Driver Clock Pulse. Clock pulse for the driver register. |
| 11 | $\overline{B E}$ | 1 | Bus Enable. When the Bus Enable is HIGH, the four drivers are in the high impedance state. |
| 5, 7, 17, 19 | $\overline{\text { BUS }}_{0}$, BUS $_{1}$ BUS $_{2}$, BUS $_{3}$ | 1/0 | The four driver outputs and receiver inputs (data is inverted). |
| $\begin{aligned} & 2,10,14, \\ & 22 \end{aligned}$ | $\begin{array}{ll} R_{0}, & R_{1}, \\ R_{2}, & R_{3} \end{array}$ | 0 | The four receiver outputs. Data from the bus is inverted while data from the A or $B$ inputs is non-inverted. |
| 1 | $\overline{\text { RLE }}$ | 0 | Receiver Latch Enable. When $\overline{\operatorname{RLE}}$ is LOW, data on the BUS inputs is passed through the receiver latches. When $\overline{\operatorname{RLE}}$ is HIGH, the receiver latches are closed and will retain the data independent of all other inputs. |
| 12 | $\overline{\mathrm{OE}}$ | 0 | Output Enable. When the $\overline{O E}$ input is HIGH, the four three state receiver outputs are in the high-impedance state. |

FUNCTION TABLE

| INPUTS |  |  |  |  |  |  | INTERNAL TO DEVICE |  | $\begin{array}{\|l\|} \text { BUS } \\ \hline \text { BUS }_{i} \end{array}$ | $\begin{array}{\|c\|} \hline \text { OUTPUT } \\ \hline \mathbf{R}_{\mathbf{I}} \\ \hline \end{array}$ | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S | $A_{1}$ | $\mathrm{B}_{1}$ | DRCP | $\overline{B E}$ | RLE | $\overline{\mathbf{O E}}$ | $\mathrm{D}_{\mathbf{i}}$ | $Q_{i}$ |  |  |  |
| X | X | X | X | H | X | X | X | X | Z | X | Driver output disable |
| X | X | X | X | X | X | H | X | X | X | Z | Receiver output disable |
| X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\stackrel{L}{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | Driver output disable and receive data via Bus input |
| X | X | X | X | X | H | X | X | NC | X | X | Latch received data |
| $\begin{aligned} & L \\ & L \\ & H \\ & H \end{aligned}$ | $\begin{array}{\|l\|} \hline L \\ H \\ X \\ X \\ X \end{array}$ | $\begin{aligned} & X \\ & X \\ & X \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \uparrow \\ & \uparrow \\ & \uparrow \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | Load driver register |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | No driver clock restrictions |
| X <br>  <br> $\times$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | X <br> X <br> X | $\begin{aligned} & x \\ & x \end{aligned}$ | $\underset{L}{L}$ | $\begin{aligned} & x \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | Drive Bus |

$H=H$ IGH $\quad Z=$ HIGH Impedance $\quad x=$ Don't care $\quad i=0,1,2,3$
L = LOW NC = No change $\quad \uparrow=$ LOW to HIGH transition


The Am2915A is a universal Bus Transceiver useful for many system data, address, control and timing input/output interfaces.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous .-0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to +VCC max DC Input Voltage $\qquad$ -0.5 V to +7 V
DC Output Current, Into Outputs
(Except Bus)
. .30 mA
DC Output Current, Into Bus ............................... 100 mA DC Input Current ............................. -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver <br> Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL: $\mathrm{IOH}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L: $\mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  |  | 3.5 |  |  |  |
| VOL | Output LOW Voltage (Except Bus) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | $\mathrm{IOL}=4.0 \mathrm{~mA}$ |  |  | 0.27 | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  | 0.32 | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=M I N, I^{\prime}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| IIL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{I N}=0.4 \mathrm{~V}$ |  | $\overline{\text { BE, }} \overline{\mathrm{RLE}}$ |  |  | -0.72 | mA |
|  |  |  |  | All other inputs |  |  | -0.36 |  |
| IIH | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{I N}=7.0 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Except Bus) | $V_{C C}=M A X$ |  |  | -30 |  | -130 | mA |
| ICC | Power Supply Current | $V_{C C}=M A X$ |  |  |  | 63 | 95 | mA |
| 10 | Off-State Output Current (Receiver Outputs) | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 |  |

Notes: 1. Typical limits are at $\mathrm{VCC}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Bus Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | $\mathrm{IOL}^{2}=24 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| VOH | Bus Output HIGH Voltage | $V_{C C}=\mathrm{MIN}$ | COM' ${ }^{\text {, }} \mathrm{IOH}^{\prime}=-20 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  | MIL, $\mathrm{IOH}^{\text {a }}=-15 \mathrm{~mA}$ |  |  |  |  |
| 10 | Bus Leakage Current (High Impedance) | $\begin{aligned} & V_{C C}=\mathrm{MAX} \\ & \text { Bus enable }=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 100 |  |
| loff | Bus Leakage Current (Power OFF) | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{H}}$ | Receiver Input HIGH Threshold | Bus enable $=2.4 \mathrm{~V}$ |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Receiver Input LOW Threshold | Bus enable $=2.4 \mathrm{~V}$ | COM'L |  |  | 0.8 | Volts |
|  |  |  | MIL |  |  | 0.7 |  |
| ISC | Bus Output Short Circuit Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=0 V \end{aligned}$ |  | -50 | -120 | -225 | mA |



Note: Actual current flow direction shown.
SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Am2915A |  |  | Am2915A |  |  |
|  |  |  | Min | Typ. (Note 1) | Max | Min | Typ. (Note 1) | Max |  |
| tPHL | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=130 \Omega \end{aligned}$ |  | 21 | 32 |  | 21 | 36 |  |
| tPLH |  |  |  | 21 | 32 |  | 21 | 36 | ns |
| $\mathrm{t}_{\mathrm{zH}}, \mathrm{t}_{\mathrm{ZL}}$ | Bus Enable ( $\overline{\mathrm{BE}}$ ) to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| $\mathrm{t}_{\mathrm{Hz},} \mathrm{t}_{\mathrm{L}}$ |  |  |  | 13 | 18 |  | 13 | 21 |  |
| $t_{s}$ | Data Inputs (A or B) | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{gathered}$ | 12 |  |  | 15 |  |  | ns |
| $t_{\text {h }}$ |  |  | 6.0 |  |  | 8.0 |  |  |  |
| $t_{s}$ | Select Input (S) |  | 25 |  |  | 28 |  |  | ns |
| th |  |  | 6.0 |  |  | 8.0 |  |  |  |
| tpw | Driver Clock (DRCP) Pulse Width (HIGH) |  | 17 |  | . | 20 |  |  | ns |
| tplH | Bus to Receiver Output (Latch Enable) |  |  | 18 | 30 |  | 18 | 33 | ns |
| tphL |  |  |  | 18 | 27 |  | 18 | 30 |  |
| tpl.H | Latch Enable to Receiver Output |  |  | 21 | 30 |  | 21 | 33 | ns |
| tpHL |  |  |  | 21 | 27 |  | 21 | 30 |  |
| $\mathrm{t}_{\text {s }}$ | Bus to Latch Enable ( $\overline{\mathrm{RLE}}$ ) |  | 13 |  |  | 15 |  |  | ns |
| $t_{\text {h }}$ |  |  | 4.0 |  |  | 6.0 |  |  |  |
| $\mathrm{t}_{\mathrm{ZH}}, \mathrm{t}_{\mathrm{ZL}}$ | Output Control to Receiver Output |  |  | 14 | 23 |  | 14 | 26 | ns |
| $\mathrm{t}_{\mathrm{HZ}}, \mathrm{t}_{\mathrm{LZ}}$ |  | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 14 | 23 |  | 14 | 26 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

## SWITCHING TEST CIRCUIT

 TC000880

SWITCHING WAVEFORMS


Note: Bus to Receiver output delay is measured by clocking data into the driver register and measuring the $\overline{\mathrm{BUS}}$ to R combinatorial delay.

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus-transceiver
- Two-port input to D-type register on driver
- Three-state bus driver output can sink 48 mA at 0.5 V max.
- Internal 4-bit odd parity checker/generator
- Receiver output latch can sink 12 mA
- 3.5 V minimum output high voltage for direct interface to MOS microprocessors


## GENERAL DESCRIPTION

The Am2916A is a high-performance, low-power Schottky bus transceiver intended for bipolar or MOS microprocessor system applications. The device consists of four D-type edge-triggered flip-flops with a built-in two-input multiplexer on each. The flip-flop outputs are connected to four threestate bus drivers. Each bus driver is internally connected to the input of a receiver. The four receiver outputs drive four D-type latches. The device also contains a four-bit odd parity checker/generator.

The LSI bus transceiver is fabricated using advanced lowpower Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The three-state bus output can sink up to 48 mA at 0.5 V maximum. The bus enable input $(\overline{\mathrm{BE}})$ is used to force the driver outputs to the highimpedance state. When $\overline{\mathrm{BE}}$ is HIGH, the driver is disabled.

The input register consists of four D-type flip-flops with a buffered common clock and two-input multiplexer at the input of each flip-flop. A common select input (S) controls the four multiplexers. When $S$ is LOW, the $A_{i}$ data is stored in the register and when $S$ is HIGH, the $B_{i}$ data is stored.

The buffered common clock (DRCP) enters the data into this driver register on the LOW-to-HIGH transition.

Data from the $A$ or $B$ input is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{\mathrm{RLE}})$ input. When the $\overline{\mathrm{RLE}}$ input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted). When the RLE input is HIGH, the latch will close and retain the present data regardless of the bus input.

The Am2916A features a built-in four-bit odd parity checker/generator. The bus enable input ( $\overline{\mathrm{BE}}$ ) controls whether the parity output is in the generate or check mode. When the bus enable is LOW (driver enabled), odd parity is generated based on the $A$ or $B$ field data input to the driver register. When $\overline{\mathrm{BE}}$ is HIGH , the parity output is determined by the four latch outputs of the receiver. Thus, if the driver is enabled, parity is generated and if the driver is in the high-impedance state, the BUS parity is checked.

## BLOCK DIAGRAM




## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

[^9]

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 4, 8, 16, 20 | $A_{0}, A_{1}$, $A_{2}, A_{3}$ | 1 | The " $A$ " word data input into the two input multiplexer of the driver register. |
| 3, 9, 15, 21 | $\begin{array}{ll} \hline B_{0}, & B_{1} \\ B_{2}, & B_{3} \\ \hline \end{array}$ | 1 | The "B" word data input into the two input multiplexers of the driver register. |
| 13 | S | 1 | Select. When the select input is LOW, the A data word is applied to the driver register. When the select input is HIGH, the B word is applied to the driver register. |
| 23 | DRCP | 1 | Driver Clock Pulse. Clock pulse for the driver register. |
| 11 | $\overline{B E}$ | 1 | Bus Enable. When the Bus Enable is HIGH, the four drivers are in the high-impedance state. |
| 5, 7, 17, 19 | BUS $_{0}$, BUS $_{1}$ BUS $_{2}$, BUS $_{3}$ | 1/0 | The four driver outputs and receiver inputs (data is inverted). |
| $\begin{aligned} & 2,10,14, \\ & 22 \end{aligned}$ | $\mathrm{R}_{0}, \mathrm{R}_{1},$ $\mathrm{R}_{2}, \mathrm{R}_{3}$ | 0 | The four receiver outputs. Data from the bus is inverted while data from the A or B inputs is non-inverted. |
| 1 | $\overline{\text { RLE }}$ | 0 | Receiver Latch Enable. When RLE is LOW, data on the BUs inputs is passed through the receiver latches. When RLE is HIGH, the receiver latches are closed and will retain the data independent of all other inputs. |
| 12 | ODD | 0 | Odd parity output. Generates parity with the driver enabled, checks parity with the driver in the high-impedance state. |

FUNCTION TABLE

| INPUTS |  |  |  |  |  | INTERNAL TO DEVICE |  | $\begin{array}{\|c\|} \hline \text { BUS } \\ \hline \overline{\text { BUS}}_{i} \\ \hline \end{array}$ | OUTPUTS |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S | AI | $B_{i}$ | DRCP | BE | RLE | $\mathrm{D}_{\mathbf{i}}$ | $Q_{i}$ |  | $\mathbf{R}_{1}$ | ODD |  |
| X | X | X | X | H | X | X | $x$ | Z | X | PQ | Driver output disable |
| X | X | X | X |  | X | X | X | X | X | PD | Driver output enable |
| $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | Driver output disable and receive data via Bus input |
| X | X | X | X | X | H | X | NC | X | NC | X | Latch received data |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline L \\ & H \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{x} \\ & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | Load driver register |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | No driver clock restrictions |
| $\begin{aligned} & \hline x \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | Drive Bus |

$H=H I G H \quad Z=H I G H$ Impedance $\quad X=$ Don't care $\quad i=0,1,2,3$
$\mathrm{L}=\mathrm{LOW} \quad \mathrm{NC}=$ No change $\quad \uparrow=$ LOW to HIGH transition
$P Q=$ Parity of $Q$ latches
$P D=$ Parity of $D$ flip-flops

## PARITY OUTPUT FUNCTION TABLE

| $\overline{B E}$ | ODD PARITY OUTPUT |
| :---: | :--- |
| $L$ | $O D D=I_{0} \oplus I_{1} \oplus I_{2} \oplus I_{3}$ |
| $H$ | $O D D=Q_{0} \oplus Q_{1} \oplus Q_{2} \oplus Q_{3}$ |



Generating or checking parity for 16 data bits.

## ABSOLUTE MAXIMUM RATINGS



DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver Output HIGH Voltage | $\begin{aligned} & V_{C C}=M_{I N} \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL: $\mathrm{lOH}^{=}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L: $1 \mathrm{IOH}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
|  |  | $V_{C C}=5.0 \mathrm{~V},!\mathrm{OH}=-100 \mu \mathrm{~A}$ |  |  | 3.5 |  |  |  |
| VOH | Parity <br> Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-660 \mu A \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage (Except Bus) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ |  | $\mathrm{l}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  | 0.27 | 0.4 | Volts |
|  |  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  | 0.32 | 0.45 |  |
|  |  |  |  | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
|  | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
| VIL |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage (Except Bus) | $V_{C C}=M I N, I_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{\mathbb{N}}=0.4 V$ |  | BE, RLE |  |  | -0.72 | mA |
|  |  |  |  | All other inputs |  |  | -0.36 |  |
| IH | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{\mathbb{N}}=2.7 V$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Except Bus) | $V_{C C}=\mathrm{MAX}$ | RECEIVER |  | -30 |  | -130 | mA |
|  |  |  | PAR |  | -20 |  | -100 |  |
| ICC | Power Supply Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, All inputs = GND |  |  |  | 75 | 110 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

| BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters | Description | Test Conditions (Note 1) |  | Min | Typ | Max. | Units |
| VOL | Bus Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | $\mathrm{lOL}=24 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{lOL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| VOH | Bus Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$ | COM'L, $\mathrm{I}^{\mathrm{OH}}=-20 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  | MIL, $1_{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  |  |
| 10 | Bus Leakage Current (High Impedance) | $\begin{aligned} & \mathrm{VCC}_{C C}=\mathrm{MAX} \\ & \text { Bus enable }=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 100 |  |
| loff | Bus Leakage Current (Power OFF) | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \\ & \hline \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{H}}$ | Receiver Input HIGH Threshold | Bus enable $=2.4 \mathrm{~V}$ |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Receiver Input LOW Threshold | Bus enable $=2.4 \mathrm{~V}$ | COM'L |  |  | 0.8 | Volts |
|  |  |  | MIL |  |  | 0.7 |  |
| Isc | Bus Output Short Circuit Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=O V \end{aligned}$ |  | -50 | -120 | -225 | mA |

## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000460

Note: Actual current flow direction shown.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Am2916A |  |  | Am2916A |  |  |
|  |  |  | Min | Typ (Note 1) | Max | Min | Typ (Note 1) | Max |  |
| tPHL | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=130 \Omega \end{aligned}$ |  | 21 | 32 |  | 21 | 36 |  |
| tplH |  |  |  | 21 | 32 |  | 21 | 36 | ns |
| $\mathrm{t}_{\mathrm{zH}}, \mathrm{tzL}$ | Bus Enable ( $\overline{\mathrm{BE}})$ to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| $\mathrm{t}_{\mathrm{Hz},} \mathrm{t}_{\text {L }}$ |  |  |  | 13 | 18 |  | 13 | 21 |  |
| $\mathrm{t}_{\text {s }}$ | Data Inputs (A or B) | $C_{L}=15 \mathrm{pF}$ | 12 |  |  | 15 |  |  |  |
| $t_{\text {h }}$ |  |  | 6.0 |  |  | 8.0 |  |  | ns |
| $t_{s}$ | Select Inputs (S) |  | 25 |  |  | 28 |  |  | ns |
| $t_{\text {h }}$ |  |  | 6.0 |  |  | 8.0 |  |  |  |
| tpw | Clock Pulse Width (HIGH) |  | 17 |  |  | 20 |  |  | ns |
| tplH | Bus to Receiver Output (Latch Enabled) |  |  | 18 | 30 |  | 18 | 33 | ns |
| tPHL |  |  |  | 18 | 27 |  | 18 | 30 |  |
| tplH | Latch Enable to Receiver Output |  |  | 21 | 30 |  | 21 | 33 | ns ) |
| $t_{\text {PHL }}$ |  |  |  | 21 | 27 |  | 21 | 30 |  |
| $\mathrm{t}_{\mathrm{s}}$ | Bus to Latch Enable ( $\overline{\text { RLE }}$ ) |  | 13 |  |  | 15 |  |  | ns |
| $t_{h}$ |  |  | 4.0 |  |  | 6.0 |  |  |  |
| tpliH | A or B Data to Odd Parity Output (Driver Enabled) |  |  | 32 | 42 |  | 32 | 46 | ns |
| tPHL |  |  |  | 26 | 36 |  | 26 | 40 |  |
| tPLH | Bus to Odd Parity Output (Driver Inhibited, Latch Enabled) |  |  | 21 | 32 |  | 21 | 36 | ns |
| tpHL |  |  |  | 21 | 32 |  | 21 | 36 |  |
| tpLH | Latch Enable ( $\overline{\mathrm{RLE}}$ ) to Odd Parity Output |  |  | 21 | 32 |  | 21 | 36 | ns |
| tpHL |  |  |  | 21 | 32 |  | 21 | 36 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second


Note: Bus to Receiver output delay is measured by clocking data into the driver register and measuring the $\overline{B U S}$ to $R$ combinatorial delay.

## Am2917A

Quad Three-State Bus Transceiver with Interface Logic

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed LSI bus-transceiver
- D-type driver register with tri-state bus driver output can sink 48 mA at 0.5 V max.
- Internal 4-bit odd parity checker/generator
- Receiver has output latch for pipeline operation
- Three-state receiver outputs sink 12 mA
- 3.5 V minimum output high voltage for direct interface to MOS microprocessors


## GENERAL DESCRIPTION

The Am2917A is a high-performance, low-power Schottky bus transceiver intended for bipolar or MOS microprocessor system applications. The device consists of four D-type edge-triggered flip-flops. The flip-flop outputs are connected to four three-state bus drivers. Each bus driver is internally connected to the input of a receiver. The four receiver outputs drive four D-type latches, that feature three-state outputs. The device also contains a four-bit odd parity checker/generator.
This LSI bus transceiver is fabricated using advanced lowpower Schottky processing. All inputs (except the BUS inputs) are one LS unit load. The three-state bus output can sink up to 48 mA at 0.5 V maximum. The bus enable input ( $\overline{B E}$ ) is used to force the driver outputs to the highimpedance state. When $\overline{B E}$ is HIGH, the driver is disabled.
The input register consists of four D-type flip-flops with a buffered common clock. The buffered common clock (DRCP) enters the $A_{i}$ data into this driver register on the LOW-to-HIGH transition.
Data from the A input is inverted at the BUS output. Likewise, data at the BUS input is inverted at the receiver
output. Thus, data is non-inverted from driver input to receiver output. The four receivers each feature a built-in Dtype latch that is controlled from the buffered receiver latch enable ( $\overline{\mathrm{RLE}}$ ) input. When the $\overline{\mathrm{RLE}}$ input is LOW, the latch is open and the receiver outputs will follow the bus inputs (BUS data inverted and OE LOW). When the RLE input is HIGH, the latch will close and retain the present data regardless of the bus input. The four latches have threestate outputs and are controlled by a buffered common three-state control ( $\overline{\mathrm{OE}}$ ) input. When $\overline{O E}$ is HIGH, the receiver outputs are in the high-impedance state.

The Am2917A features a built-in four-bit odd parity checker/generator. The bus enable input ( $\overline{\mathrm{BE}}$ ) controls whether the parity output is in the generate or check mode. When the bus enable is LOW (driver enabled), odd parity is generated based on the A field data input to the driver register. When $\overline{B E}$ is HIGH, the parity output is determined by the four latch outputs of the receiver. Thus, if the driver is enabled, parity is generated and if the driver is in the high-impedance state, the BUS parity is checked.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2917A | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

[^10]| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 3,7 \\ & 13,17 \end{aligned}$ | $\begin{array}{ll} A_{0}, & A_{1} \\ A_{2}, & A_{3} \end{array}$ $A_{2}, A_{3}$ | 1 | The four driver register inputs. |
| 19 | DRCP | 1 | Driver Clock Pulse. Clock pulse for the driver register. |
| 9 | $\overline{B E}$ | 1 | Bus Enable. When the Bus Enable is HIGH, the four drivers are in the high impedance state. |
| 4, 6, 14, 16 | $\begin{array}{\|l} \hline \text { BUS }_{0}, \\ \text { BUS }_{1}, \\ \text { BUS }_{2}, \\ \text { BUS }_{3} \\ \hline \end{array}$ | 1/0 | The four driver outputs and receiver inputs (data is inverted). |
| 2, 8, 12, 18 | $\mathrm{R}_{0}, \mathrm{R}_{1},$ $\mathrm{R}_{2}, \mathrm{R}_{3}$ | 0 | The four receiver outputs. Data from the bus is inverted while data from the A inputs is non-inverted. |
| 1 | $\overline{\text { RLE }}$ | 1 | Receiver Latch Enable. When $\overline{\text { RLE }}$ is LOW, data on the BUS inputs is passed through the receiver latches. When $\overline{\text { RLE }}$ is HIGH, the receiver latches are closed and will retain the data independent of all other inputs. |
| 10 | ODD | 0 | Odd parity output. Generates parity with the driver enabled, checks parity with the driver in the high-impedance state. |
| 11 | $\overline{\mathrm{OE}}$ | 1 | Output Enable. When the $\overline{O E}$ input is HIGH, the four three-state receiver outputs are in the high-impedance state. |

## FUNCTION TABLE

| INPUTS |  |  |  |  | INTERNAL TO DEVICE |  | BUS | OUTPUT |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $A_{1}$ | DRCP | $\overline{\text { BE }}$ | RLE | $\overline{\mathbf{O E}}$ | $\mathrm{D}_{\mathrm{i}}$ | $Q_{i}$ | $\overline{B U S}_{i}$ | $\mathrm{R}_{\mathrm{i}}$ | FUNCTION |
| X | X | H | X | X | X | $\times$ | Z | X | Driver output disable |
| X | X | X | X | H | X | X | X | Z | Receiver output disable |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\mathrm{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{gathered} H \\ L \end{gathered}$ | Driver output disable and receive data via Bus input |
| X | X | X | H | X | X | NC | X | X | Latch received data |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\dagger$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | Load driver register |
| $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | No driver clock restrictions |
| X <br>  | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | L | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | Drive Bus |


| $H=H I G H$ | $Z=$ HIGH Impedance | $X=$ Don't care | $i=0,1,2,3$ |
| :--- | :--- | :--- | :--- |
| $L=$ LOW | NC $=$ No change | $\uparrow=$ LOW to HIGH transition |  |

## PARITY OUTPUT FUNCTION TABLE

| $\overline{B E}$ | ODD PARITY OUTPUT |
| :---: | :---: |
| $L$ | $O D D=A_{0} \oplus A_{1} \oplus A_{2} \oplus A_{3}$ |
| $H$ | $O D D=\mathbf{Q}_{\mathbf{0}} \oplus \mathbf{Q}_{1} \oplus \mathbf{Q}_{\mathbf{2}} \oplus \mathbf{Q}_{\mathbf{3}}$ |

 Main Memory I/O Transceiver in high-speed Microprocessor Systems.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
-0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State
-0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max.
DC Input Voltage .-0.5 V to +7.0 V
DC Output Current, Into Bus $\qquad$ .100 mA
DC Output Current, Into Outputs
(Except Bus) $\qquad$ .30 mA
DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver <br> Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{\mathbb{I H}} \end{aligned}$ | MIL: $\mathrm{IOH}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM | I $\mathrm{OH}=-2.6 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  |  | 3.5 |  |  |  |
| VOH | Parity <br> Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-660 \mu A \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage (Except Bus) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ |  | $1 \mathrm{OL}=4.0 \mathrm{~mA}$ |  | 0.27 | 0.4 | Volts |
|  |  |  |  | $\mathrm{l} \mathrm{OL}=8.0 \mathrm{~mA}$ |  | 0.32 | 0.45 |  |
|  |  |  |  | $\mathrm{OLL}=12 \mathrm{~mA}$ |  | 0.37 | 0.5 |  |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | input Clamp Voltage (Except Bus) | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{I N}=0.4 V$ |  | $\overline{\text { BE, RLE }}$ |  |  | -0.72 | mA |
|  |  |  |  | All other inputs |  |  | -0.36 |  |
| $\mathrm{IIH}^{\text {H}}$ | Input HIGH Current (Except Bus) | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \times}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current (Except Bus) | $V_{C C}=M A X, V_{1 N}=7.0 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Except Bus) | $V_{C C}=M A X$ | RECEIVER |  | -30 |  | -130 | mA |
|  |  |  | PARITY |  | -20 |  | -100 |  |
| Icc | Power Supply Current | $V_{C C}=M A X$ |  |  |  | 63 | 95 | mA |
| 10 | Off-State Output Current (Receiver Outputs) | $V_{C C}=\mathrm{MAX}$ | $V_{0}=2.4 \mathrm{~V}$$V_{0}=0.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  |  | -50 |  |


| BUS INPUT/OUTPUT CHARACTERISTICS over operating temperature range |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ | Max | Units |
| VOL | Bus Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | $\mathrm{IOL}=24 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| VOH | Bus Output HIGH Voltage | $V_{C C}=\mathrm{MIN}$ | $C O M ' L,{ }^{1} \mathrm{OH}=-20 \mathrm{~mA}$ | 2.4 |  |  | Volts |
|  |  |  | MIL, $\mathrm{IOH}^{\text {}}=-15 \mathrm{~mA}$ |  |  |  |  |
| 10 | Bus Leakage Current (High Impedance) | $V_{C C}=M A X$ <br> Bus enable $=2.4 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 100 |  |
| loff | Bus Leakage Current (Power OFF) | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \\ & \hline \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IH }}$ | Receiver Input HIGH Threshold | Bus enable $=2.4 \mathrm{~V}$ |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Receiver Input LOW Threshold | Bus enable $=2.4 \mathrm{~V}$ | COM'L |  |  | 0.8 | Volts |
|  |  |  | MIL |  |  | 0.7 |  |
| ISC | Bus Output Short Circuit Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=O V \end{aligned}$ |  | -50 | -120 | -225 | mA |

## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



1c000460

Note: Actual current flow direction shown.

| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Am2917A |  |  | Am2917A |  |  |
|  |  |  | Min. | Typ (Note 1) | Max. | Min. | Typ (Note 1) | Max. |  |
| $t_{\text {PHL }}$ | Driver Clock (DRCP) to Bus | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=130 \Omega \end{aligned}$ |  | 21 | 32 |  | 21 | 36 | ns |
| tPLH |  |  |  | 21 | 32 |  | 21 | 36 | ns |
| $\mathrm{t}_{\mathrm{ZH}}, \mathrm{t}_{\mathrm{ZL}}$ | Bus Enable ( $\overline{\mathrm{BE}})$ to Bus |  |  | 13 | 23 |  | 13 | 26 | ns |
| $\mathrm{t}_{\mathrm{Hz}, \mathrm{t}} \mathrm{tz}$ |  |  |  | 13 | 18 |  | 13 | 21 |  |
| $t_{s}$ | A Data Inputs | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 12 |  |  | 15 |  |  | ns |
| $t_{\text {h }}$ |  |  | 6.0 |  |  | 8.0 |  |  |  |
| tpw | Clock Puise Width (HIGH) |  | 17 |  |  | 20 |  |  | ns |
| tPLH | Bus to Receiver Output (Latch Enabled) |  |  | 18 | 30 |  | 18 | 33 | ns |
| $t_{\text {PHL }}$ |  |  |  | 18 | 27 |  | 18 | 30 |  |
| $t_{\text {PLH }}$ | Latch Enable to Receiver Output |  |  | 21 | 30 |  | 21 | 33 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 21 | 27 |  | 21 | 30 |  |
| $\mathrm{t}_{\text {s }}$ | Bus to Latch Enable ( $\overline{\mathrm{RLE}}$ ) |  | 13 |  |  | 15 |  |  | ns |
| $t_{n}$ |  |  | 4.0 |  |  | 6.0 |  |  |  |
| tplH | A Data to Odd Parity Out (Driver Enabled) |  |  | 32 | 42 |  | 32 | 46 | ns |
| - tphL |  |  |  | 26 | 36 |  | 26 | 40 |  |
| tpLH | Bus to Odd Party Out (Driver Inhibit) |  |  | 21 | 32 | , | 21 | 36 | ns |
| tPHL |  |  |  | 21 | 32 |  | 21 | 36 |  |
| tPLH | Latch Enable ( $\overline{\mathrm{RLE}}$ ) to Odd Parity Output |  |  | 21 | 32 |  | 21 | 36 | ns |
| tpHL |  |  |  | 21 | 32 |  | 21 | 36 |  |
| $\mathrm{t}_{\mathrm{ZH}}, \mathrm{tzL}$ | Output Control to Output |  |  | 14 | 23 |  | 14 | 26 | ns |
| $\mathrm{t}_{\mathrm{HZ},} \mathrm{t}_{\mathrm{LZ}}$ |  | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 14 | 23 |  | 14 | 26 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.


Note: Bus to Receiver output delay is measured by clocking data into the driver register and measuring the BUS to R combinatorial delay.

## Am2918

## Quad D Register with Standard and Three-State Outputs

| DISTINCTIVE CHARACTERISTICS |  |
| :---: | :---: |
| - Advanced Schottky technology <br> - Four D-type flip-flops <br> - Four standard totem-pole outputs | - Four three-state outputs <br> - 75 MHz clock frequency |
| GENERAL DESCRIPTION |  |
| New Schottky circuits such as the Am2918 register provide the design engineer with additional flexibility in system configuration - especially with regard to bus structure, organization and speed. The Am2918 is a quadruple D-type register with four standard totem-pole outputs and four three-state bus-type outputs. The 16 -pin device also features a buffered common clock (CP) and a buffered common output control ( $\overline{\mathrm{OE}}$ ) for the Y outputs. Information meeting the set-up and hold requirements on the $D$ inputs is transferred to the Q outputs on the LOW-to-HIGH transition of the clock. <br> The same data as on the Q outputs is enabled at the threestate Y outputs when the "output control' ( $\overline{\mathrm{OE})}$ input is | LOW. When the $\overline{O E}$ input is HIGH, the $Y$ outputs are in the high-impedance state. <br> The Am2918 register can be used in bipolar microprocessor designs as an address register, status register, instruction register or for various data or microword register applications. Because of the unique design of the threestate output, the device features very short propagation delay from the clock to the $Q$ or $Y$ outputs. Thus, system performance and architectural design can be improved by using the Am2918 register. Other applications of Am2918 register can be found in microprogrammed display systems, communication systems and most general or special purpose digital signal processing equipment. |



## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29LS18 | Low Power Version |
| Am2919 | Quad Register |

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2918 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
| XC, XM |  |

Package
D-16-pin CERDIP
F-16-pin flatpak
$\mathrm{L}-20$-pin leadless chip carrier
$\mathrm{P}-16$-pin plastic DIP
$X$ - Dice

Device type
Quad D Register

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The four data inputs to the register. |
|  | $\mathrm{Q}_{\mathrm{i}}$ | 0 | The four data outputs of the register with standard totem-pole active pull-up outputs. Data is passed non-inverted. |
|  | $Y_{i}$ | 0 | The four three-state data outputs of the register. When the three-state outputs are enabled, data is passed noninverted. A HIGH on the "output control" input forces the $Y_{i}$ outputs to the high-impedance state. |
| 9 | CP |  | CP Clock. The buffered common clock for the register. Enters data on the LOW-to-HIGH transition. |
| 7 | $\overline{\text { OE }}$ |  | $\overline{\bar{O} E}$ Output Control. When the $\overline{\bar{O} E}$ input is HIGH, the $Y_{i}$ outputs are in the high-impedance state. When the $\overline{\mathrm{OE}}$ input is LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

TRUTH TABLE

| INPUTS |  |  | OUTPUTS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O E}$ | $\underset{\text { CP }}{\text { CLOCK }}$ | D | Q | Y |  |
| H | L | X | NC | Z | - |
| H | H | X | NC | Z | - |
| H | 1 | L | L | Z | - |
| H | $\dagger$ | H | H | Z | - |
| L | $\dagger$ | L | L | L | - |
| L | $\uparrow$ | H | H | H | - |
| L | - | - | L | L | 1 |
| L | - | - | H | H | 1 |

$\mathrm{L}=\mathrm{LOW} \quad \mathrm{NC}=$ No change
$H=$ HIGH $\quad \uparrow=$ LOW to HIGH transition
$X=$ Don't care $\quad Z=$ High impedance
Note: 1. When $\overline{O E}$ is LOW, the $Y$ output will be in the same logic state as the $Q$ output.


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $\ldots \ldots . .55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous ............... -0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ $-0.5 V$ to $+V_{C C} \max$

DC Output Current, Into Outputs ........................... 30 mA
DC Input Current $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . .30 \mathrm{~mA}$ to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage $\qquad$ $+4.5 \mathrm{~V}$ Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\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}$ | $Q \mathrm{IOH}^{\prime}=-1 \mathrm{~mA}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
|  |  |  | $Y$ | $X M,{ }^{\circ} \mathrm{OH}=-2 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
|  |  |  |  | $\mathrm{XC}, \mathrm{l}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| VOL | Output LOW Voltage (Note 6) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.2 | Volts |
| $\begin{aligned} & \hline \mathrm{ILL}_{1} \\ & \text { (Note 3) } \end{aligned}$ | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.5 \mathrm{~V}$ |  |  |  |  |  | -2.0 | mA |
| ${ }^{1 / \mathrm{H}}{ }^{(N o t e ~ 3)}$ | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=2.7 \mathrm{~V}$ |  |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| 10 | Y Output Off-State Leakage Current | $V_{C C}=M A X$ |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 |  |
| Isc | Output Short Circuit Current (Note 4) | $V_{C C}=M A X$ |  |  |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\text {CC }}=$ MAX (Note 5) |  |  |  |  | 80 | 130 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Actual input currents = Unit Load Current $x$ Input Load Factor (see Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
5. ICC is measured with all inputs at 4.5 V and all outputs open.
6. Measured on $Q$ outputs with $Y$ outputs open. Measured on $Y$ outputs with $Q$ outputs open.

## SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000410

Note: Actual current flow direction shown.
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega\right.$ )

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Clock to Q Output |  | $C_{L}=15 \mathrm{pF}$ |  | 6.0 | 9.0 | ns |
| tPHL |  |  |  | 8.5 | 13 |  |
| $t_{\text {pw }}$ | Clock Pulse Width | HIGH |  | 7.0 |  |  | ns |
|  |  | LOW |  | 9.0 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data |  |  | 5.0 |  |  | ns |
| $t_{n}$ | Data |  |  | 3.0 |  |  | ns |
| tplH | Clock to Y Output ( $\overline{O E}$ LOW) |  |  |  | 6.0 | 9.0 | ns |
| tPHL |  |  |  | 8.5 | 13 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Control to Output |  |  | $C_{L}=15 \mathrm{pF}$ |  | 12.5 | 19 | ns |
| $\mathrm{t}_{\mathrm{LL}}$ |  |  |  |  | 12 | 18 |  |  |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 4.0 | 6.0 |  |  |
| $t_{\text {L }}$ |  |  |  | 7.0 | 10.5 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency |  |  | $C_{L}=15 \mathrm{pF}$ | 75 | 100 |  | MHz |

## Am29LS18

Quad D Register with Standard and Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Low-power Schottky version of the popular Am2918
- Four three-state outputs
- Four standard totem-pole outputs
- Four D-type flip-flops


## GENERAL DESCRIPTION

The Am29LS18 consists of four D-type flip-flops with a buffered common clock. Information meeting the set-up and hold requirements on the $D$ inputs is transferred to the Q outputs on the LOW-to-HIGH transition of the clock.

The same data as on the $Q$ outputs is enabled at the threestate $Y$ outputs when the 'output control'" (何) input is LOW. When the $\overline{O E}$ input is HIGH, the $Y$ outputs are in the high-impedance state.

The Am29LS18 is a 4-bit, high-speed register intended for use in real-time signal processing systems where the
standard outputs are used in a recursive algorithm and the three-state outputs provide access to a data bus to dump the results after a number of iterations.

The device can also be used as an address register or status register in computers or computer peripherals.
Likewise, the Am29LS18 is also useful in certain display applications where the standard outputs can be decoded to drive LED's (or equivalent) and the three-state outputs are bus organized for occasional interrogation of the data as displayed.

BLOCK DIAGRAM


BD002160

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S18 | Quad D Register |
| Am25LS2518 | Quad D Register |
| Am25LS2519 | Quad Register |

## CONNECTION DIAGRAM <br> Top View

D-16-1


Note: Pin 1 is marked for orientation

## LOGIC SYMBOL



LS000900

METALLIZATION AND PAD LAYOUT


DIE SIZE 0.083" $\times \mathbf{0 . 0 9 9}{ }^{\prime \prime}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).



## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The four data inputs to the register. |
|  | $\mathrm{Q}_{\mathrm{i}}$ | 0 | The four data outputs of the register with standard totem-pole active pull-up outputs. Data is passed non-inverted. |
|  | $\mathrm{Y}_{\mathrm{i}}$ | $\bigcirc$ | The four three-state data outputs of the register. When the three-state outputs are enabled, data is passed noninverted. A HIGH on the "output control" input forces the $Y_{i}$ outputs to the high-impedance state. |
| 9 | CP |  | CP Clock. The buffered common clock for the register. Enters data on the LOW-to-HIGH transition. |
| 7 | ठE |  | $\overline{\overline{O E}}$ Output Control. When the $\overline{\mathrm{OE}}$ input is HIGH, the $Y_{i}$ outputs are in the high-impedance state. When the $\overline{\mathrm{OE}}$ input is LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

FUNCTION TABLE

| INPUTS |  |  | OUTPUTS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{~ O E ~}$ | CLOCK <br> CP | D | Q | Y |  |
| H | L | X | NC | Z | - |
| H | H | X | NC | Z | - |
| H | $\uparrow$ | L | L | Z | - |
| H | $\uparrow$ | H | H | Z | - |
| L | $\uparrow$ | L | L | L | - |
| L | $-\uparrow$ | H | H | H | - |
| L | - | - | L | L | 1 |
| L | - | - | $H$ | $H$ | 1 |

$\mathrm{L}=\mathrm{LOW} \quad \mathrm{NC}=$ No change
$H=$ HIGH $\quad i=$ LOW to HIGH transition
$X=$ Don't care $\quad Z=$ High impedance
Note: 1. When $\overline{O E}$ is LOW, the $Y$ output will be in the same logic state as the $Q$ output.



The Am29LS18 as a variable length (1, 2, 3 or 4 word) shift register.

| ABSOLUTE MAXIMUM RATINGS |
| :---: |
| Storage Temperature ....................... $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| (Ambient) Temperature Under Bias ...... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential |
| Continuous ...................................-0.5V to +7.0V |
| DC Voltage Applied to Outputs For |
| High Output State .....................-0.5V to + $\mathrm{V}_{\mathrm{CC}}$ max |
| DC Input Voltage...............................-0.5V to +7.0V |
| DC Output Current, Into Outputs ........................ 30mA |
| DC Input Current ...........................-30mA to + 5.0mA |
| Stresses above those listed under ABSOLUTE MAXIMUM |
| RATINGS may cause permanent device failure. Functionality |
| these limits is not implied. Exposure to absolute |
| ximum ratings for extended periods may affect device |
| eliability. |

## OPERATING RANGES

Commercial (C) Devices
Temperature ................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | Q, $\mathrm{IOH}^{\text {a }}=-660 \mu \mathrm{~A}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
|  |  |  | Y | MIL, $\mathrm{I}^{\text {OH }}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{IOH}=2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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}$ |  | $1 \mathrm{OL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  |  | $\mathrm{l} \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  |  | $\mathrm{lOL}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.4 \mathrm{~V}$ |  |  |  |  |  | -0.36 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | , | -20 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$. |  |  |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=\mathrm{MAX}$ |  |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  |  | 17 | 28 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is measured with all inputs at 4.5 V and all outputs open.


## DISTINCTIVE CHARACTERISTICS

- Twelve Bits Wide

Addresses up to 4096 words of microcode with one chip. All internal elements are a full 12 bits wide.

- Internal Loop Counter

Pre-settable 12-bit down-counter for repeating instructions and counting loop iterations.

- Four Address Sources

Microprogram Address may be selected from microprogram counter, branch address bus, 9 -level push/pop stack, or internal holding register.

- Sixteen Powerful Microinstructions

Executes 16 sequence control instructions, most of which are conditional on external condition input, state of internal loop counter, or both.

- Output Enable Controls for Three Branch Address Sources
Built-in decoder function to enable external devices onto branch address bus. Eliminates external decoder.
- Fast

The Am2910A supports 100ns cycle times and is 25 $30 \%$ faster than the Am2910.

## GENERAL DESCRIPTION

The Am2910A Microprogram controller is an address sequencer intended for controlling the sequence of execution of microinstructions stored in microprogram memory. Besides the capability of sequential access, it provides conditional branching to any microinstruction within its 4096-microword range. A last-in, first-out stack provides microsubroutine return linkage and looping capability; there are nine levels of nesting of microsubroutines. Microinstruction loop count control is provided with a count capacity of 4096.

During each microinstruction, the microprogram controller provides a 12-bit address from one of four sources: 1) the
microprogram address register ( $\mu \mathrm{PC}$ ), which usually contains an address one greater than the previous address; 2) an external (direct) input (D); 3) a register/counter (R) retaining data loaded during a previous microinstruction; or 4) a nine-deep last-in, first-out stack (F).

The Am2910A is a speed improved plug-in replacement of the Am2910 featuring AMD's ion-implanted micro-oxide (IMOX) processing and offering $25-30 \%$ speed improvement. The Am2910A also features a nine-word deep stack versus the five-deep stack of the Am2910.



## PIN DESCRIPTION

| Pin No．＊ | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | Direct input to register／counter and multiplexer． $\mathrm{D}_{0}$ is LSB． |
|  | i | 1 | Selects one－of－sixteen instructions for the Am2910A． |
| 14 | CC | 1 | Used as test criterion．Pass test is a LOW on $\overline{\mathrm{CC}}$ ． |
| 13 | CCEN | 1 | Whenever the signal is HIGH，$\overline{\mathrm{CC}}$ is ignored and the part operates as though $\overline{\mathrm{CC}}$ were true（LOW）． |
| 32 | Cl | 1 | Low order carry input to incrementer for microprogram counter． |
| 15 | RLD | 1 | When LOW forces loading of register／counter regardless of instruction or condition． |
| 29 | $\overline{\text { OE }}$ | 1 | Three－state control of $Y_{i}$ outputs． |
| 31 | CP | 1 | Triggers all internal state changes at LOW－to－HIGH edge． |
| ， | Yi | 0 | Address to microprogram memory．$Y_{0}$ is LSB，$Y_{11}$ is MSB． |
| 16 | FULL | 0 | Indicates that nine items are on the stack． |
| 6 | $\overline{\text { PL }}$ | 0 | Can select \＃1 source（usually Pipeline Register）as direct input source． |
| 7 | MAP | 0 | Can select \＃2 source（usually Mapping PROM or PLA）as direct input source． |
| 5 | VECT | 0 | Can select \＃3 source（for example，Interrupt Starting Address）as direct input source． |
| ＊DIP only． |  |  |  |

## PRODUCT OVERVIEW

The Am2910A is a bipolar microprogram controller intended for use in high－speed microprocessor applications．It allows addressing of up to 4 K words of microprogram．
The controller contains a four－input multiplexer that is used to select either the register／counter，direct input，microprogram counter，or stack as the source of the next microinstruction address．

The register／counter consists of 12 D－type，edge－triggered flip－flops，with a common clock enable．When its load control， $\overline{\mathrm{RLD}}$ ，is LOW，new data is loaded on a positive clock transition． A few instructions include load；in most systems，these instructions will be sufficient，simplifying the microcode．The output of the register／counter is available to the multiplexer as a source for the next microinstruction address．The direct input furnishes a source of data for loading the register／counter．
The Am2910A contains a microprogram counter（ $\mu \mathrm{PC}$ ）that is composed of a 12－bit incrementer followed by a 12－bit register． The $\mu \mathrm{PC}$ can be used in either of two ways：When the carry－in to the incrementer is HIGH，the microprogram register is loaded on the next clock cycle with the current $Y$ output word plus one $(Y+1 \rightarrow \mu \mathrm{PC})$ ．Sequential microinstructions are thus executed．When the carry－in is LOW，the incrementer passes the $Y$ output word unmodified so that $\mu \mathrm{PC}$ is reloaded with the same $Y$ word on the next clock cycle（ $Y \rightarrow \mu \mathrm{PC}$ ）．The same microinstruction is thus executed any number of times．
The third source for the multiplexer is the direct（D）input．This source is used for branching．
The fourth source available at the multiplexer input is a 9 －word by 12 －bit stack（file）．The stack is used to provide return address linkage when executing microsubroutines or loops． The stack contains a built－in stack pointer（SP）which always points to the last file word written．This allows stack reference operations（looping）to be performed without a pop．
The stack pointer operates as an up／down counter．During microinstructions 1,4 ，and 5 ，the PUSH operation may occur．

This causes the stack pointer to increment and the file to be written with the required return linkage．On the cycle following the PUSH，the return data is at the new location pointed to by the stack pointer．

During five microinstructions，a POP operation may occur．The stack pointer decrements at the next rising clock edge following a POP，effectively removing old information from the top of the stack．

The stack pointer linkage is such that any sequence of pushes，pops，or stack references can be achieved．At RESET （Instruction 0），the depth of nesting becomes zero．For each PUSH，the nesting depth increases by one；for each POP，the depth decreases by one．The depth can grow to nine．After a depth of nine is reached，FULL goes LOW．Any further PUSHes onto a full stack overwrite information at the top of the stack，but leave the stack pointer unchanged．This operation will usually destroy useful information and is normal－ ly avoided．A POP from an empty stack may place non－ meaningful data on the $Y$ outputs，but is otherwise safe．The stack pointer remains at zero whenever a POP is attempted from a stack already empty．

The register／counter is operated during three microinstruc－ tions $(8,9,15)$ as a 12 －bit down counter，with result＝zero available as a microinstruction branch test criterion．This provides efficient iteration of microinstructions．The register／ counter is arranged such that if it is preloaded with a number $N$ and then used as a loop termination counter，the sequence will be executed exactly $N+1$ times．During instruction 15，a three－way branch under combined control of the loop counter and the condition code is available．

The device provides three－state $Y$ outputs．These can be particularly useful in designs requiring automatic checkout of the processor．The microprogram controller outputs can be forced into the high－impedance state，and pre－programmed sequences of microinstructions can be executed via external access to the address lines．


## OPERATION

The Table of Instructions shows the result of each instruction in controlling the multiplexer which determines the Y outputs, and in controlling the three enable signals $\overline{\mathrm{PL}}, \overline{\mathrm{MAP}}$, and VECT. The effect on the register/counter and the stack after the next positive-going clock edge is also shown. The multiplexer determines which internal source drives the $Y$ outputs. The value loaded into $\mu \mathrm{PC}$ is either identical to the Y output, or else one greater, as determined by Cl . For each instruction one and only one of the three outputs $\overline{\mathrm{PL}}, \overline{\mathrm{MAP}}$, and $\overline{\mathrm{VECT}}$ is LOW. If these outputs control three-state enables for the primary source of microprogram jumps (usually part of a pipeline register), a PROM which maps the instruction to a microinstruction starting location, and an optional third source (often a vector from a DMA or interrupt source), respectively, the three-state sources can drive the $D$ inputs without further logic.

Several inputs (see Functional Pin Description), can modify instruction execution. The combination CC HIGH and CCEN

LOW is used as a test in 9 of the 16 instructions. RLD, when LOW, causes the $D$ input to be loaded into the register/ counter, overriding any HOLD or DEC operation specified in the instruction. $\overline{O E}$, normally LOW, may be forced HIGH to remove the Am2910A Y outputs from a three-state bus.
The stack, a nine-word last-in, first-out 12-bit memory, has a pointer which addresses the value presently on the top of the stack. Explicit control of the stack pointer occurs during instruction 0 (RESET), which makes the stack empty by resetting the SP to zero. After a RESET, and whenever else the stack is empty, the contents of the top of stack are undefined until a PUSH occurs. Any POPs performed while the stack is empty put undefined data on the F outputs and leave the stack pointer at zero.

Any time the stack is full (nine more PUSHes than POPs have occurred since the stack was last empty), the FULL warning output occurs. This signal first appears on the microcycle after a ninth PUSH. No additional PUSH should be attempted onto a full stack; if tried, information within the stack will be overwitten and lost.
table of instructions

| $1_{3}-10$ | MNEMONIC | NAME | REG/ CNTR CONTENTS | FAIL$\overline{C C E N}=L \text { and } \overline{C C}=H$ |  | $\overline{\text { PASS }} \overline{C C E N}=H \text { or } \overline{C C}=L$ |  | REG/ CNTR | ENABLE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Y | STACK | $Y$ | STACK |  |  |
| 0 | JZ | JUMP ZERO | $X$ | 0 | CLEAR | 0 | CLEAR | HOLD | PL |
| 1 | CJS | COND JSB PL | X | PC | HOLD | D | PUSH | HOLD | PL |
| 2 | JMAP | JUMP MAP | X | D | HOLD | D | HOLD | HOLD | MAP |
| 3 | CJP | COND JUMP PL | X | PC | HOLD | D | HOLD | HOLD | PL |
| 4 | PUSH | PUSH/COND LD CNTR | X | PC | PUSH | PC | PUSH | Note 1 | PL |
| 5 | JSRP | COND JSB R/PL | X | R | PUSH | D | PUSH | HOLD | PL |
| 6 | CJV | COND JUMP VECTOR | X | PC | HOLD | D | HOLD | HOLD | VECT |
| 7 | JRP | COND JUMP R/PL | X | R | HOLD | D | HOLD | HOLD | PL |
| 8 | RFCT | $\begin{aligned} & \text { REPEAT LOOP, } \\ & \text { CNTR } \neq 0 \end{aligned}$ | $\neq 0$ | F | HOLD | F | HOLD | DEC | PL |
|  |  |  | $=0$ | PC | POP | PC | POP | HOLD | PL |
| 9 | RPCT | REPEAT PL, CNTR $=0$ | $\neq 0$ | D | HOLD | D | HOLD | DEC | PL |
|  |  |  | $=0$ | PC | HOLD | PC | HOLD | HOLD | PL |
| 10 | CRTN | COND RTN | X | PC | HOLD | F | POP | HOLD | PL |
| 11 | CJPP | COND JUMP PL \& POP | X | PC | HOLD | D | POP | HOLD | PL |
| 12 | LDCT | LD CNTR \& CONTINUE | X | PC | HOLD | PC | HOLD | LOAD | PL |
| 13 | LOOP | TEST END LOOP | X | F | HOLD | PC | POP | HOLD | PL |
| 14 | CONT | CONTINUE | X | PC | HOLD | PC | HOLD | HOLD | PL |
| 15 | TWB | THREE-WAY BRANCH | $\neq 0$ | F | HOLD | PC | POP | DEC | PL |
|  |  |  | $=0$ | D | POP | PC | POP | HOLD | PL |

Note 1: If $\overline{C C E N}=L$ and $\overline{C C}=H$, hold; else load.

## THE Am2910A INSTRUCTION SET

The Am2910A provides 16 instructions which select the address of the next microinstruction to be executed. Four of the instructions are unconditional - their effect depends only on the instruction. Ten of the instructions have an effect which is partially controlled by external, data-dependent condition. Three of the instructions have an effect which is partially controlled by the contents of the internal register/counter. In this discussion it is assumed the $\mathrm{C}_{\mathrm{i}}$ is tied HIGH.

In the ten conditional instructions, the result of the datadependent test is applied to $\overline{\mathrm{CC}}$. If the $\overline{\mathrm{CC}}$ input is LOW, the test is considered to have been passed, and the action specified in the name occurs; otherwise, the test has failed and an alternate (often simply the execution of the next sequential microinstruction) occurs. Testing of $\overline{\overline{C C}}$ may be disabled for a specific microinstruction by setting CCEN HIGH, which unconditionally forces the action specified in the name; that is, it forces a pass. Other ways of using CCEN include (1) tying it HIGH, which is useful if no microinstruction is datadependent; (2) tying it LOW if data-dependent instructions are never forced unconditionally; or (3) tying to the source of Am2910A instruction bit $I_{0}$, which leaves instructions 4, 6 and 10 as data-dependent but makes others unconditional. All of these tricks save one bit of microcode width.

The effect of three instructions depends on the contents of the register/counter. Unless the counter holds a value of zero, it is decremented; if it does hold zero, it is held and a different microprogram next address is selected. These instructions are useful for executing a microinstruction loop a known number of times. Instruction 15 is affected both by the external condition code and the internal register/counter.

Perhaps the best technique for understanding the Am2910A is to simply take each instruction and review its operation. In order to provide some feel for the actual execution of these instructions, examples of all 16 instructions are included.
$\mathrm{H}=\mathrm{HIGH}$
L=LOW
$X=$ Don't Care
The examples given should be interpreted in the following manner: The intent is to show microprogram flow as various microprogram memory words are executed. For example, the CONTINUE instruction, instruction number 14, simply means that the contents of microprogram memory word 50 are executed, then the contents of word 51 are executed. This is followed by the contents of microprogram memory word 52 and the contents of microprogram memory word 53. The microprogram addresses used in the examples were arbitrarily chosen and have no meaning other than to show instruction flow. The exception to this is the first example, JUMP ZERO, which forces the microprogram location counter to address ZERO. Each dot refers to the time that the contents of the microprogram memory word is in the pipeline register. While no special symbology is used for the conditional instructions, the text to follow will explain what the conditional choices are in each example.
It might be appropriate at this time to mention that AMD has a microprogram assembler called AMDASM, which has the capability of using the Am2910A instructions in symbolic representation. AMDASM's Am2910A instruction symbolics (or mnemonics) are given in the examples, and again in the Table of instructions.

0 JUMP ZERO (JZ)


## PFR00830

Instruction 0, JZ (JUMP to ZERO, or RESET) unconditionally specifies that the address of the next microinstruction is zero. Many designs use this feature for power-up sequences and provide the power-up firmware beginning at microprogram memory word location 0.


PFR00950
Instruction 1 is a CONDITIONAL JUMP-TO-SUBROUTINE via the address provided in the pipeline register. As shown in Figure 4, the machine might have executed words at address 50,51 , and 52 . When the contents of address 52 is in the pipeline register, the next address control function is the CONDITIONAL JUMP-TO-SUBROUTINE. Here, if the test is passed, the next instruction executed will be the contents of microprogram memory location 90 . If the test has failed, the JUMP-TO-SUBROUTINE will not be executed; the contents of microprogram memory location 53 will be executed instead. Thus, the CONDITIONAL JUMP-TO-SUBROUTINE instruction at location 52 will cause the instruction either in location 90 or in location 53 to be executed next. If the TEST input is such that location 90 is selected, value 53 will be pushed onto the internal stack. This provides the return linkage for the machine when the subroutine beginning at location 90 is completed. In this example, the subroutine was completed at location 93 and a RETURN-FROM-SUBROUTINE would be found at location 93.

## 2 JUMP MAP (JMAP)

 be 90; therefore, an unconditional jump to microprogram memory address 90 is performed.

Instruction 3, CONDITIONAL JUMP PIPELINE, derives its branch address from the pipeline register branch address value $\left(B R_{0}-B R_{11}\right)$. This instruction provides a technique for branching to various microprogram sequences depending upon the test condition inputs. Quite often, state machines are designed which simply execute tests on various inputs waiting for the condition to come true. When the true condition is reached, the machine then branches and executes a set of microinstructions to perform some function. This usually has the effect of resetting the input being tested until some point in the future. The example shows the conditional jump via the pipeline register address at location 52. When the contents of microprogram memory word 52 are in the pipeline register, the next address will be either location 53 or location 30 in this example. If the test is passed, the value currently in the pipeline register (30) will be selected. If the test fails, the next address selected will be contained in the microprogram counter which, in this example, is 53.

## 4 PUSH/COND LD CNTR (PUSH)



Instruction 4 is the PUSH/CONDITIONAL LOAD COUNTER instruction and is used primarily for setting up loops in microprogram firmware. In this example, when instruction 52 is in the pipeline register, a PUSH will be made onto the stack and the counter will be loaded based on the condition. When a PUSH occurs, the value pushed is always the next sequential instruction address. In this case, the address is 53 . If the test fails, the counter is not loaded; if it is passed, the counter is loaded with the value contained in the pipeline register branch address field. Thus, a single microinstruction can be used to set up a loop to be executed a specific number of times. Instruction 8 will describe how to use the pushed value and the

Instruction 2 is the JUMP MAP instruction. This is an unconditional instruction which causes the $\overline{\text { MAP }}$ output to be enabled so that the next microinstruction location is determined by the address supplied via the mapping PROMs. Normally, the JUMP MAP instruction is used at the end of the instruction fetch sequence for the machine. In the example of Figure 4, microinstructions at locations $50,51,52$ and 53 might have been the fetch sequence and at its completion at location 53 , the jump map function would be contained in the pipeline register. This example shows the mapping PROM outputs to register/counter for looping.


## PFR00960

## 5 COND JSB R/PL (JSRP)



Instruction 5 is a CONDITIONAL JUMP-TO-SUBROUTINE via the register/counter of the contents of the PIPELINE register. A PUSH is always performed and one of two subroutines executed. In this example, either the subroutine beginning at address 80 or the subroutine beginning at address 90 will be performed. A RETURN-FROM-SUBROUTINE (instruction number 10) returns the microprogram flow to address 55 . In order for this microinstruction control sequence to operate correctly, both the next address fields of instruction 53 and the next address fields of instruction 54 would have to contain the proper value. Let's assume that the branch address fields of instruction 53 contain the value 90 so that it will be in the Am2910A register/counter when the contents of address 54 are in the pipeline register. This requires that the instruction at address 53 load the register/counter. Now, during the execution of instruction 5 (at address 54), if the test failed, the contents of the register (value $=90$ ) will select the address of the next microinstruction. If the test input passes, the pipeline register contents (value $=80$ ) will determine the address of the next microinstruction. Therefore, this instruction provides the ability to select one of two subroutines to be executed based on a test condition.

## 6 COND JUMP VECTOR (CJV)



Instruction 6 is a CONDITIONAL JUMP VECTOR instruction which provides the capability to take the branch address from a third source heretofore not discussed. In order for this instruction to be useful, the Am2910A output VECT is used to control a three-state control input of a register, buffer, or PROM containing the next microprogram address. This instruction provides one technique for performing interrupt type branching at the microprogram level. Since this instruction is conditional, a pass causes the next address to be taken from the vector source, while failure causes the next address to be taken from the microprogram counter. In the example, if the CONDITIONAL JUMP VECTOR instruction is contained at location 52, execution will continue at vector address 20 if the
$\overline{\mathrm{CC}}$ input is LOW and the microinstruction at address 53 will be executed if the $\overline{\mathrm{CC}}$ input is HIGH.

## 7 COND JUMP R/PL (JRP)



PFR00930
Instruction 7 is a CONDITIONAL JUMP via the contents of the Am2910A REGISTER/COUNTER or the contents of the PIPELINE register. This instruction is very similar to instruction 5; the CONDITIONAL JUMP-TO-SUBROUTINE via R or PL. The major difference between instruction 5 and instruction 7 is that no push onto the stack is performed with 7. The example depicts this instruction as a branch to one of two locations depending on the test condition. The example assumes the pipeline register contains the value 70 when the contents of address 52 is being executed. As the contents of address 53 is clocked into the pipeline register, the value 70 is loaded into the register/counter in the Am2910A. The value 80 is available when the contents of address 53 is in the pipeline register. Thus, control is transferred to either address 70 or address 80 depending on the test condition.

8 REPEAT LOOP, CNTR $=0$ (RFCT)


## PFR00910

Instruction 8 is the REPEAT LOOP, COUNTER $\neq$ ZERO instruction. This microinstruction makes use of the decrementing capability of the register/counter. To be useful, some previous instruction, such as 4, must have loaded a count value into the register/counter. This instruction checks to see whether the register/counter contains a non-zero value. If so, the register/counter is decremented, and the address of the next microinstruction is taken from the top of the stack. If the register/counter contains zero, the loop exit condition is occurring; control falls through to the next sequential microinstruction by selecting $\mu \mathrm{PC}$; the stack is POP' d by decrementing the stack pointer, but the contents of the top of the stack are thrown away.

In this example, location 50 most likely would contain a PUSH/ CONDITIONAL LOAD COUNTER instruction which would have caused address 51 to be PUSHed on the stack and the counter to be loaded with the proper value for looping the desired number of times.

In this example, since the loop test is made at the end of the instructions to be repeated (microaddress 54), the proper
value to be loaded by the instructions at address 50 is one less than the desired number of passes through the loop. This method allows a loop to be executed 1 to 4096 times. If it is desired to execute the loop from 0 to 4095 times, the firmware should be written to make the loop exit test immediately after loop entry.
Single-microinstruction loops provide a highly efficient capability for executing a specific microinstruction a fixed number of times. Examples include fixed rotates, byte swap, fixed point multiply, and fixed point divide.

## 9 REPEAT PL, CNTR $=0$ (RPCT)



PFR00890
Instruction 9 is the REPEAT PIPELINE REGISTER, COUNT$E R \neq$ ZERO instruction. This instruction is similar to instruction 8 except that the branch address now comes from the pipeline register rather than the file. In some cases, this instruction may be thought of as a one-word file extension; that is, by using this instruction, a loop with the counter can still be performed when subroutines are nested nine deep. This instruction's operation is very similar to that of instruction 8. The differences are that on this instruction, a failed test condition causes the source of the next microinstruction address to be the $D$ inputs; and, when the test condition is passed, this instruction does not perform a POP because the stack is not being used.

In this example, the REPEAT PIPELINE, COUNTER $\neq$ ZERO instruction is instruction 52 and is shown as a single microinstruction loop. The address in the pipeline register would be 52. Instruction 51 in this example could be the LOAD COUNTER AND CONTINUE instruction (number 12). While the example shows a single microinstruction loop, by simply changing the address in a pipeline register, multi-instruction loops can be performed in this manner for a fixed number of times as determined by the counter.

## 10 COND RETURN (CRTN)



PFR00900
Instruction 10 is the conditional RETURN-FROM-SUBROUTINE instruction. As the name implies, this instruction is used to branch from the subroutine back to the next microinstruction address following the subroutine call. Since this instruction is conditional, the return is performed only if the test is
passed. If the test is failed, the next sequential microinstruction is performed. This example depicts the use of the conditional RETURN-FROM-SUBROUTINE instruction in both the conditional and the unconditional modes. This example first shows a JUMP-TO-SUBROUTINE at instruction location 52 where control is transferred to location 90. At location 93, a conditional RETURN-FROM-SUBROUTINE instruction is performed. If the test is passed, the stack is accessed and the program will transfer to the next instruction at address 53 . If the test is failed, the next microinstruction at address 94 will be executed. The program will continue to address 97 where the subroutine is complete. To perform an unconditional RE-TURN-FROM-SUBROUTINE, the conditional RETURN-FROM-SUBROUTINE instruction is executed unconditionally; the microinstruction at address 97 is programmed to force CCEN HIGH, disabling the test and the forced PASS causes an unconditional return.

## 11 COND JUMP PL \& POP (CJPP)



Instruction 11 is the CONDITIONAL JUMP PIPELINE register address and POP stack instruction. This instruction provides another technique for loop termination and stack maintenance. The example shows a loop being performed from address 55 back to address 51. The instructions at locations 52,53 , and 54 are all conditional JUMP and POP instructions. At address 52, if the $\overline{C C}$ input is LOW, a branch will be made to address 70 and the stack will be properly maintained via a POP. Should the test fail, the instruction at location 53 (the next sequential instruction) will be executed. Likewise, at address 53, either the instruction at 90 or 54 will be subsequently executed, respective to the test being passed or failed. The instruction at 54 follows the same rules, going to either 80 or 55 . An instruction sequence as described here, using the CONDITIONAL JUMP PIPELINE and POP instruction, is very useful when several inputs are being tested and the microprogram is looping waiting for any of the inputs being tested to occur before proceeding to another sequence of instructions. This provides the powerful jump-table programming technique at the firmware level.

## 12 LD CNTR \& CONTINUE (LDCT)



## PFR00870

Instruction 12 is the LOAD COUNTER AND CONTINUE instruction, which simply enables the counter to be loaded with the value at its parallel inputs. These inputs are normally connected to the pipeline branch address field which (in the architecture being described here) serves to supply either a
branch address or a counter value depending upon the microinstruction being executed. Altogether there are three ways of loading the counter - the explicit load by this instruction 12; the conditional load included as part of instruction 4; and the use of $\overline{\operatorname{RLD}}$ input along with any instruction. The use of $\overline{\mathrm{RLD}}$ with any instruction overrides any counting or decrementation specified in the instruction, calling for a load instead. Its use provides additional microinstruction power, at the expense of one bit of microinstruction width. This instruction 12 is exactly equivalent to the combination of instruction 14 and $\overline{\operatorname{RLD}}$ LOW. Its purpose is to provide a simple capability to load the register/counter in those implementations which do not provide microprogrammed control for $\overline{\mathrm{RLD}}$.

13 TEST END LOOP (LOOP)


## PFR00860

Instruction 13 is the TEST END-OF-LOOP instruction, which provides the capability of conditionally exiting a loop at the bottom; that is, this is a conditional instruction that will cause the microprogram to loop, via the file, if the test is failed else to continue to the next sequential instruction. The example shows the TEST END-OF-LOOP microinstruction at address 56. If the test fails, the microprogram will branch to address 52. Address 52 is on the stack because a PUSH instruction had been executed at address 51. If the test is passed at instruction 56, the loop is terminated and the next sequential microinstruction at address 57 is executed, which also causes the stack to be POP'd; thus, accomplishing the required stack maintenance.

## 14 CONTINUE (CONT)



PFR00880
Instruction 14 is the CONTINUE instruction, which simply causes the microprogram counter to increment so that the next sequential microinstruction is executed. This is the simplest microinstruction of all and should be the default instruction which the firmware requests whenever there is nothing better to do.

## 15 THREE-WAY BRANCH (TWB)



PFR00810

Instruction 15, THREE-WAY BRANCH, is the most complex. It provides for testing of both a data-dependent condition and the counter during one microinstruction and provides for selecting among one of three microinstruction addresses as the next microinstruction to be performed. Like instruction 8, a previous instruction will have loaded a count into the register/ counter while pushing a microbranch address onto the stack. Instruction 15 performs a decrement-and-branch-until-zero function similar to instruction 8. The next address is taken from the top of the stack until the count reaches zero; then the next address comes from the pipeline register. The above action continues as long as the test condition fails. If at any execution of instruction 15 the test condition is passed, no branch is taken; the microprogram counter register furnishes the next address. When the loop is ended, either by the count becoming zero, or by passing the conditional test, the stack is POP'd by decrementing the stack pointer, since interest in the value contained at the top of the stack is then complete.

The application of instruction 15 can enhance performance of a variety of machine-level instructions. For instance, (1) a memory search instruction to be terminated either by finding a desired memory content or by reaching the search limit; (2) variable-field-length arithmetic terminated early upon finding that the content of the portion of the field still unprocessed is all zeroes; (3) key search, in a disc controller processing variable length records; (4) normalization of a floating point number.

As one example, consider the case of a memory search instruction. As shown, the instruction at microprogram address 63 can be instruction 4 (PUSH), which will push the value 64 onto the microprogram stack and load the number $N$, which is one less than the number of memory locations to be searched before giving up. Location 64 contains a microinstruction which fetches the next operand from the memory area to be searched and compares it with the search key. Location 65 contains a microinstruction which tests the result of the comparison and also is a THREE-WAY BRANCH for microprogram control. If no match is found, the test fails and the microprogram goes back to location 64 for the next operand address. When the count becomes zero, the microprogram branches to location 72, which does whatever is necessary if no match is found. If a match occurs on any execution of the THREE-WAY BRANCH at location 65, control falls through to location 66 which handles this case. Whether the instruction ends by finding a match or not, the stack will have been POP'd once, removing the value 64 from the top of the stack.

## ARCHITECTURES USING THE Am2910A

(Shading shows path(s) which usually limit speed)

## One Level Pipeline Based (Recommended)



PF000990
Figure 1.

One level pipeline provides better speed than most other architectures. The $\mu$ Program Memory and the Am2901 array are in parallel speed paths instead of in series. This is the recommended architecture for Am2900 designs.


This drawing shows the timing relationships in the CCU illustrated above.

## OTHER ARCHITECTURES USING THE Am2910A

(Shading shows path(s) which usually limit speed)
Figure 2.



PF001021

The Status Register provides conditional Branch control based on results of previous ALU cycle. The Microprogram Memory and Am2901C are in series in the critical paths.
d. Two Level Pipeline Based


PF001051
Two level pipeline provides highest possible speed. It is more difficult to program because the selection of a microinstruction occurs two instructions ahead of its execution.

## Am2910A HIGH SPEED APPLICATION

Optimal Am2910A configurations can support high speed bit slice designs. When used with high speed registers and PROMs, the Am2910A can execute simple instructions in 100ns.

The following figure illustrates the usual critical path in the sequencer.
Timing on the critical paths becomes

| Device | Path | Delay |
| :--- | :--- | :--- |
| Status Register | Clock $\rightarrow$ Output | 11 ns |
| Fast MUX | Select $\rightarrow$ Output | 18 ns |
| Am2910A | $\overline{\text { CC } \rightarrow Y}$ 30ns |  |
| Fast PROM | Addr $\rightarrow$ Output | 35ns |
| Pipeline Register | Setup | 4 ns |
|  |  | 99 ns |

The following gives one suggested parts configuration to meet this design criterion.

| Status Register | Am29825 |
| :--- | :--- |
| MUX (8 to 1) | 74 S 151 |
| PROM | Am27S35 |
| Pipeline Register | Am2918 |

## One Level Pipeline Based (Recommended)



PF000990
Figure 3.


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Case Temperature with Power Applied .. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ .-0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage ..-0.5 V to +5.5 V
DC Output Current, Into Outputs (Except Bus) ........ 30 mA DC Input Current ..................................-30 to +5.0mA

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$ to...............+4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage (VCC) +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| V OH | Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OH}}=-1.6 \mathrm{~mA}, \mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ |  |  | 2.4 |  |  |  |
| $\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}$ | $*$ $Y_{0-11}, \mathrm{IOL}^{\prime}=1$ <br> $\mathrm{~V}_{\mathrm{IL}} \overline{\mathrm{PECT}}, \overline{\mathrm{MA}}$  | $\mathrm{Y}_{0-11}, \mathrm{lOL}=12 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level (Note 4) | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Note 4) | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 |  |
| $\mathrm{V}_{\text {CLMP }}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 |  |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=0.5 \mathrm{~V}$ |  | $\mathrm{D}_{0.11}$ |  |  | -0.87 | mA |
|  |  |  |  | C1, CCEN |  |  | -0.54 |  |
|  |  |  |  | $\mathrm{I}_{0-3}$, $\overline{\mathrm{OE}, \text { RLD }}$ |  |  | -0.72 |  |
|  |  |  |  | $\overline{C C}$ |  |  | -1.31 |  |
|  |  |  |  | CP |  | . | -2.14 |  |
| IIH | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  | $\mathrm{D}_{0-11}$ |  |  | 80 | $\mu \mathrm{A}$ |
|  |  |  |  | C1, CCEN |  |  | 30 |  |
|  |  |  |  | $\mathrm{I}_{0-3}, \overline{\mathrm{OE}}, \overline{\mathrm{RLD}}$ |  |  | 40 |  |
|  |  |  |  | $\overline{\text { CC }}$ |  |  | 50 |  |
|  |  |  |  | CP |  |  | 100 |  |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  | -30 |  | -85 | mA |
| lozl | Output OFF Current | $V_{C C}=\mathrm{MAX}, \overline{O E}=2.4 \mathrm{~V}$ |  | $\mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
| lOZH |  |  |  | $\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}$ |  |  | 50 |  |
| Icc | Power Supply Current | $V_{C C C}=\mathrm{MAX}$ | Am2910APC, DC | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |  |  | 344 | mA |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |  |  | 280 |  |
|  |  |  | Am2910ADM, FM | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |  |  | 340 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 280 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and a maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. These input levels provide no guaranteed noise immunity and should only be static tested in a noise-free environment (not functionally tested).

## Notes on Testing

1. Insure the part is adequately decoupled at the test head. Large changes in supply current when the device switches may cause function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable may allow the ground pin at the device to rise by hundreds of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{I L}$ or $V_{I H}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide actual Sentry programs, under license from Sentry.

## SWITCHING TEST CIRCUIT

THREE-STATE OUTPUTS
NORMAL OUTPUTS


TCR01370

TCR01350
$R_{1}=\frac{5.0-V_{B E}-V_{O L}}{l_{O L}+V_{O L} / 1 K}$

$$
\begin{aligned}
& \mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{l}_{\mathrm{OH}}} \\
& \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}} / \mathrm{R}_{2}}
\end{aligned}
$$

Notes: 1. $C_{L}=50 p F$ includes scope probe, wiring and stray capacities without device in test fixture.
2. $\mathrm{S}_{1}, \mathrm{~S}_{2}, \mathrm{~S}_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpzH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2910A

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :--- | :---: | :---: | :---: |
| - | $\mathrm{Y}_{0-11}$ | A | 300 | 1 K |
| 5 | $\overline{\mathrm{VECT}}$ | B | 470 | 1.5 K |
| 6 | $\overline{\mathrm{PL}}$ | B | 470 | 1.5 K |
| 7 | $\overline{\mathrm{MAP}}$ | B | 470 | 1.5 K |
| 16 | $\overline{\mathrm{FULL}}$ | B | 470 | 1.5 K |

## Am2910A SWITCHING CHARACTERISTICS

The tables below define the Am2910A switching characteristics. Tables A are set up and hold times relative to the clock LOW-to-HIGH transition. Tables $B$ are combinational delays. Tables $C$ are clock requirements. All measurements are made at 1.5 V with input levels at OV or 3 V . All values are in ns. All outputs have maximum DC loading.

## I. GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE Am2910APC, DC <br> ( $T_{A}=0$ to $+70^{\circ} \mathrm{C}, V_{C C}=4.75$ to $5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )

A. Set-up and Hold Times

| Input | $\mathbf{t}_{\mathbf{8}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :--- | :---: | :---: |
| $\mathrm{D}_{\mathrm{i}} \rightarrow \mathrm{R}$ | 16 | 0 |
| $\mathrm{D}_{\mathrm{i}} \rightarrow \mathrm{PC}$ | 30 | 0 |
| $\mathrm{I}_{0}-\mathrm{I}_{3}$ | 35 | 0 |
| $\overline{\mathrm{CC}}$ | 24 | 0 |
| $\overline{\mathrm{CCEN}}$ | 24 | 0 |
| CI | 18 | 0 |
| $\overline{\mathrm{RLD}}$ | 19 | 0 |

B. Combinational Delays

| Input | $\mathbf{Y}$ | $\overline{\text { PL, }} \overline{\text { VECT, }} \overline{\text { MAP }}$ | $\overline{\text { Full }}$ |
| :--- | :---: | :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{11}$ | 20 | - | - |
| $\mathrm{I}_{0}-13$ | 35 | 30 | - |
| $\overline{\mathrm{CC}}$ | 30 | - | - |
| $\overline{\mathrm{CCEN}}$ | 30 | - | - |
| CP | 40 | - | 31 |
| $\overline{\mathrm{OE}}($ Note 1$)$ | $25 / 27$ | - | - |

## C. Clock Requirements

| Minimum Clock LOW Time | 20 | ns |
| :--- | :---: | :---: |
| Minimum Clock HIGH Time | 20 | ns |
| Minimum Clock Period | 50 | ns |

## II. GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE Am2910ADM, FM <br> ( $\mathrm{TC}=-55$ to $+125^{\circ} \mathrm{C}, \mathrm{V}+=4.5$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )



## C. Clock Requirements

| Minimum Clock LOW Time | 25 | ns |
| :--- | :---: | :---: |
| Minimum Clock HIGH Time | 25 | ns |
| Minimum Clock Period | 51 | ns |

Note 1. Enable/Disable. Disable times measured to 0.5 V change on output voltage level with $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$.


| Part No. | Description |
| :--- | :--- |
| Am2914 | Vectored Interrupt Controller |
| Am2918 | Pipeline Register |
| Am2922 | Condition Code MUX |
| Am25LS377 | Status Register |
| Am27S35 | Registered PROM |
| Am29818 | SSR Diagnostics/Pipeline Register |

For applications information, see Chapter II of Bit Slice Microprocessor Design, Mick \& Brick, McGraw Hill Publications.

## Am2919

Quad Register with Dual Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Four D-type flip-flops
- Two sets of three-state outputs
- Polarity control on one set of outputs
- Buffered common clock enable
- Buffered common asynchronous clear
- Separate buffered common output enable for each set of outputs


## GENERAL DESCRIPTION

The Am2919 consists of four D-type flip-flops with a buffered common clock enable. Information meeting the set-up and hold time requirements of the $D$ inputs is transferred to the flip-flop outputs on the LOW-to-HIGH transition of the clock. Data on the $Q$ outputs of the flipflops is enabled at the three-state outputs when the output control $(\overline{\mathrm{OE}})$ input is LOW. When the appropriate $\overline{\mathrm{OE}}$ input is HIGH, the outputs are in the high impedance state. Two independent sets of outputs-W and Y -are provided şuch
that the register can simultaneously and independently drive two buses. One set of outputs contains a polarity control such that the outputs can either be inverting or noninverting.

The device also features an active LOW asynchronous clear. When the clear input is LOW, the Q output of the internal flip-flops are forced LOW independent of the other inputs. The Am2919 is packaged in a space-saving (0.3inch row spacing) 20-pin package.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2519 | Quad Register |
| Am25LS2518 | Quad D Register |

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2912 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
| XC, XM |  |,

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
| $1,4,13$, <br> 16 | $\mathrm{D}_{\mathrm{i}}$ | I | Any of the four D flip-flop data lines. |
| 17 | $\overline{\mathrm{E}}$ | I | Clock Enable. When LOW, the data is entered into the register on the next clock LOW-to-HIGH transition. When <br> HIGH, the data in the register remains unchanged, regardless of the data in. |
| 9 | CP | I | Clock Pulse. Data is entered into the register on the LOW-to-HIGH transition. |
| 7,8 | $\overline{\mathrm{OE}-\mathrm{W}, \overline{\mathrm{OE}-\mathrm{Y}}}$ | I | Output Enable. When $\overline{\mathrm{OE}}$ is LOW, the register is enabled to the output. When HIGH, the output is in the high- <br> impedance state. The $\overline{\mathrm{OE}-\mathrm{W}}$ controls the W set of outputs, and $\mathrm{OE}-\mathrm{Y}$ controls the Y set. |
| $3,6,11$, <br> 14 | $\mathrm{Y}_{\mathrm{i}}$ | O | Any of the four non-inverting three-state output lines. |
| $2,5,12$, <br> 15 | $\mathrm{~W}_{\mathrm{i}}$ | O | Any of the four three-state outputs with polarity control. |
| 18 | POL | I | Polarity Control. The Wi outputs will be non-inverting when POL is LOW, and when it is HIGH, the outputs are <br> inverting. |
| 19 | $\overline{\mathrm{CLR}}$ | I | Asynchronous Clear. When $\overline{\mathrm{CLR}}$ is LOW, the internal Q flip-flops are reset to LOW. |

## GUARANTEED LOADING RULES

## OVER OPERATING RANGE (In Unit Loads)

A Low-Power Schottky TTL Unit Load is defined as $20 \mu \mathrm{~A}$ measured at 2.7 V HIGH and -0.36 mA measured at 0.4 V LOW.

| Pin <br> No.'s | Input/ <br> Output | Input <br> Load | MIL <br> HIGH | Output <br> LOW |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{D}_{0}$ | 1.0 | - | - | - | - |
| 2 | $\mathrm{~W}_{0}$ | - | 50 | 130 | 33 | 33 |
| 3 | $\mathrm{Y}_{0}$ | - | 50 | 130 | 33 | 33 |
| 4 | $\mathrm{D}_{1}$ | 1.0 | - | - | - | - |
| 5 | $\mathrm{~W}_{1}$ | - | 50 | 130 | 33 | 33 |
| 6 | $\mathrm{Y}_{1}$ | - | 50 | 130 | 33 | 33 |
| 7 | $\overline{\mathrm{OE}-\mathrm{W}}$ | 1.0 | - | - | - | - |
| 8 | $\overline{\mathrm{OE}-\mathrm{Y}}$ | 1.0 | - | - | - | - |
| 9 | CP | 1.0 | - | - | - | - |
| 10 | GND | - | - | - | - | - |
| 11 | $\mathrm{Y}_{2}$ |  | 50 | 130 | 33 | 33 |
| 12 | $\mathrm{~W}_{2}$ |  | 50 | 130 | 33 | 33 |
| 13 | $\mathrm{D}_{2}$ | 1.0 | - | - | - | - |
| 14 | $\mathrm{Y}_{3}$ | - | 50 | 130 | 33 | 33 |
| 15 | $\mathrm{~W}_{3}$ | - | 50 | 130 | 33 | 33 |
| 16 | $\mathrm{D}_{3}$ | 1.0 | - | - | - | - |
| 17 | $\overline{\mathrm{E}}$ | 1.0 | - | - | - | - |
| 18 | POL | 1.0 | - | - | - | - |
| 19 | $\overline{\mathrm{CLR}}$ | 1.0 | - | - | - | - |
| 20 | $\mathrm{~V}_{\mathrm{CC}}$ | - | - | - | - | - |

LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


IC000090
Note: Actual current flow direction shown.

| FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Function | Inputs |  |  |  |  |  |  | Internal | Outputs |  |
|  | CP | $\mathrm{D}_{\mathrm{i}}$ | $\bar{E}$ | $\overline{\text { CLR }}$ | POL | $\overline{\text { OE-W }}$ | $\overline{\mathrm{OE}-\mathrm{Y}}$ | $Q$ | Wi | $Y_{i}$ |
| Output Three-State Control | $\begin{aligned} & \hline \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \\ & \mathrm{NC} \\ & \mathrm{NC} \\ & \hline \end{aligned}$ | $\begin{gathered} z \\ \text { Enabled } \\ Z \\ \text { Enabled } \\ \hline \end{gathered}$ | $\begin{gathered} \text { Enabled } \\ Z \\ Z \\ \text { Enabled } \\ \hline \end{gathered}$ |
| Wi Polarity | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $L$ | $\begin{aligned} & \text { NC } \\ & \text { NC } \end{aligned}$ | Non-Inverting Inverting | Non-Inverting Non-Inverting |
| Asynchronous Clear | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | $\underset{L}{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| Clock Enabled | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $X$ $X$ $L$ $L$ $H$ $H$ | H $L$ $L$ $L$ $L$ $L$ | H H H H H | $\begin{aligned} & \hline X \\ & L \\ & H \\ & L \\ & H \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline X \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \hline X \\ & L \\ & L \\ & L \\ & L \end{aligned}$ |  | $\begin{gathered} \hline N C \\ L \\ H \\ H \\ L \\ \hline \end{gathered}$ | $\begin{gathered} \hline N C \\ L \\ L \\ H \\ H \\ \hline \end{gathered}$ |
| $\begin{aligned} & \mathrm{L}=\text { LOW } \\ & H=\text { HIGH } \\ & Z=\text { High Impedance } \\ & \text { NC }=\text { No Change } \\ & X=\text { Don't Care } \\ & \dagger=\text { LOW-to-HIGH Transition } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |



The Am2919 provides for easy control of the selection of source and destination register addresses for the Am2901. These controls can emanate from both the instruction register and the pipeline register. The control is accomplished by three-state action at the Am2919 outputs. Four different register outputs can be selected by the $B$ address which is the destination register in the Am2901. Two registers can be selected for the Am2901 A input which is a second RAM source.

The other pair of three-state outputs can be used for function control select as shown with the Am2921. Here, bit set, bit clear, bit toggle and bit test on any of the 16 bits can be performed.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous ..................................... 0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage. $\qquad$ $\ldots . .-0.5 \mathrm{~V}$ to +7.0 V
DC Output Current, Into Outputs .......................... 30 mA DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{MIL}, \mathrm{l}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{IOH}^{\prime}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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}^{\text {O }}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}^{\prime}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| IIH | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=\operatorname{MAX}$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  | MIL |  | 24 | 36 | mA |
|  |  |  |  | COM'L |  | 24 | 39 |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Inputs grounded: outputs open.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tphL | Clock to $\mathrm{Y}_{\mathrm{i}}$ |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 22 | 33 | ns |
| tpHL |  |  |  | 20 | 30 |  |
| tpli | Clock to $\mathrm{W}_{\mathrm{i}}$ (Either Polarity) |  |  |  | 24 | 36 |  |
| tPHL |  |  |  | 24 | 36 | ns |  |
| tphL | Clear to $\mathrm{Y}_{\mathrm{i}}$ |  |  |  | 29 | 43 | ns |
| tplH | Clear to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 25 | 37 | ns |
| tphL |  |  |  | 30 | 45 |  |
| tple | Polarity to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 23 | 34 | ns |
| tPHL |  |  |  | 25 | 37 |  |
| $t_{\text {pw }}$ | Clear |  |  | 18 |  |  | ns |
| ${ }_{\text {tpw }}$ | Clock Pulse Width | LOW |  | 15 |  |  | ns |
|  |  | HIGH |  | 18 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data |  |  | 15 |  |  | ns |
| $t_{\text {h }}$ | Data |  |  | 5 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Data Enable |  |  | 20 |  |  | ns |
| $t_{n}$ | Data Enable |  |  | 0 |  |  | ns |
| $\mathrm{t}_{\mathbf{s}}$ | Set-up Time, Clear Recovery (Inactive) to Clock |  |  | 20 | 15 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable to W or Y |  |  |  | 11 | 17 | ns |
| t ZL |  |  |  | 13 | 20 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Enable to W or Y |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =5.0 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 13 | 20 | ns |
| tLz |  |  |  |  | 11 | 17 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ | 35 | 45 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

|  | Description |  | Test Conditions | $\begin{gathered} \hline \text { Commercial } \\ \hline \text { Am2919 } \end{gathered}$ |  | $\frac{\text { Military }}{\text { Am2919 }}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
| Parameters |  |  | Min | Max | Min | Max |  |
| tplH | Clock to $Y_{i}$ |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 39 |  | 42 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  |  | 39 |  | 45 |  |  |
| tpli | Clock to $\mathrm{W}_{\mathrm{i}}$ (Either Polarity) |  |  |  | 41 |  | 43 | ns |  |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  |  | 44 |  | 48 |  |  |
| tphL | Clear to $Y_{i}$ |  |  |  | 52 |  | 58 | ns |  |
| tplh | Clear to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 42 |  | 43 | ns |  |
| tphL |  |  |  |  | 51 |  | 53 |  |  |
| tpli | Polarity to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 41 |  | 45 | ns |  |
| tPHL |  |  |  |  | 42 |  | 44 |  |  |
| $\mathrm{t}_{\mathrm{pw}}$ | Clear |  | 20 |  |  | 20 |  | ns |  |
| $t_{\text {pw }}$ | Clock | LOW | 20 |  |  | 20 |  | ns |  |
|  |  | HIGH | 20 |  |  | 20 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data |  | 15 |  |  | 15 |  | ns |  |
| $t_{\text {h }}$ | Data |  | 10 |  |  | 10 |  | ns |  |
| $t_{s}$ | Data Enable |  | 25 |  |  | 25 |  | ns |  |
| $t_{\text {h }}$ | Data Enable |  | 0 |  |  | 0 |  | ns |  |
| $t_{s}$ | Set-up Time, Clear Recovery (Inactive) to Clock |  | 23 |  |  | 24 |  | ns |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable to $\mathrm{W}_{\mathrm{i}}$ or $\mathrm{Y}_{\mathrm{i}}$ |  |  |  | 24 |  | 27 | ns |  |
| $\mathrm{t}_{\mathrm{LL}}$ |  |  |  |  | 29 |  | 35 |  |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Enable to $\mathrm{W}_{\mathrm{i}}$ or $\mathrm{Y}_{\mathrm{i}}$ |  | $\begin{aligned} C_{L} & =5.0 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 33 |  | 45 | ns |  |
| tLZ |  |  |  | 22 |  | 26 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 30 |  | 25 |  | MHz |

*Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am2920

Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control

## DISTINCTIVE CHARACTERISTICS

- Buffered common clock enable input
- Buffered common asynchronous clear input
- Three-state outputs
- 8-bit, high-speed parallel register with positive edgetriggered, D-type flip-flops


## GENERAL DESCRIPTION

The Am2920 is an 8-bit register built using advanced LowPower Schottky technology. The register consists of eight D-type flip-flops with a buffered common clock, a buffered common clock enable, a buffered asynchronous clear input, and three-state outputs.

When the clear input is LOW, the internal flip-flops of the register are reset to logic 0 (LOW), independent of all other inputs. When the clear input is HIGH, the register operates in the normal fashion.

When the three-state output enable ( $\overline{\mathrm{OE}}$ ) input is LOW, the Y outputs are enabled and appear as normal TTL outputs. When the output enable ( $\overline{\mathrm{OE}})$ input is HIGH, the $Y$ outputs are in the high impedance (three-state) condition. This does not affect the internal state of the flip-flop $Q$ output.

The clock enable input $(\overline{\mathrm{E}})$ is used to selectively load data into the register. When the $\bar{E}$ input is HIGH, the register will retain its current data. When the $\bar{E}$ is LOW, new data is entered into the register on the LOW-to-HIGH transition of the clock input.





The Am2920 is a useful device in interfacing with the Am9080A system buses.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . . . . . . . . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $\ldots \ldots-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous .....................................5V to +7.0 V
DC Voltage Applied to Outputs For
High Output State ........................-0.5V to $+\mathrm{V}_{\mathrm{CC}}$ max
DC Input Voltage..................................-0.5V to +7.0 V
DC Output Current, Into Outputs ........................... 30mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{MIL}, 1 \mathrm{l} \mathrm{IOH}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, ${ }^{\mathrm{OHH}}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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{l}^{\mathrm{OL}}=4.0$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{lOL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| IH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathbb{I}}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 24 | 37 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All outputs open, $E=G N D, D_{i}$ inputs $=C L R \overline{O E}=4.5 \mathrm{~V}$. Apply momentary ground, then 4.5 V to clock input.

SWITCHING CHARACTERISTICS ${ }^{\prime}\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}\right)$


Note 1. Per industry convention, $f_{\text {max }}$ is the worst case value of the maximum device operating frequency with no contraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMMERCIAL <br> Am2920 |  | $\begin{aligned} & \text { MILITARY } \\ & \text { Am2920 } \end{aligned}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Clock to $Y_{i}(\overline{O E}$ LOW) | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 33 |  | 39 | ns |
| tPHL |  |  |  | 45 |  | 54 |  |
| tPHL | Clear to $Y$ |  |  | 43 |  | 51 | ns |
| $t_{\text {s }}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  | 15 |  | ns |
| $t_{h}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  | 15 |  | ns |
| $t_{s}$ | Enable (E) |  | 17 |  | 20 |  | ns |
|  |  |  | 20 |  | 23 |  |  |
| th | Enable (E) |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {s }}$ | Clear Recovery ( In-Active) to Clock |  | 13 |  | 15 |  | ns |
| $t_{\text {pw }}$ | Clock |  | 25 |  | 30 |  | ns |
|  |  |  | 30 |  | 35 |  |  |
| $t_{\text {pw }}$ | Clear |  | 22 |  | 25 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ |  |  | 19 |  | 25 | ns |
| t ZL |  |  |  | 30 |  | 39 |  |
| $\mathrm{t}_{\mathrm{H}} \mathrm{z}$ | $\overline{O E}$ to $Y_{i}$ | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 35 |  | 40 | ns |
| tLZ |  | $R_{L}=2.0 \mathrm{~K} \Omega$ |  | 39 |  | 42 |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  | 25 |  | 20 |  | MHz |

*Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am2921

One-of-Eight Decoder with Three-State Outputs and Polarity Control

## DISTINCTIVE CHARACTERISTICS

- Three-state decoder outputs
- Buffered common output polarity control
- Inverting and non-inverting enable inputs
- AC parameters specified over operating temperature and power supply ranges.


## GENERAL DESCRIPTION

The Am2921 is a three-line to eight-line decoder/demultiplexer fabricated using advanced Low-Power Schottky technology. The decoder has three buffered select inputs $A, B$, and $C$, which are decoded to one-of-eight $Y$ outputs. Two active-HIGH and two active-LOW enables can be used for gating the decoder or can be used with incoming data for demultiplexing applications.

A separate polarity ( POL ) input can be used to force the function active-HIGH or active-LOW at the output. Two
separate active-LOW output enables ( $\overline{\mathrm{OE}}$ ) inputs are provided. If either $\overline{O E}$ input is HIGH, the output is in the high impedance (off) state. When the POL input is LOW, the $Y$ outputs are active-HIGH and when the POL input is HIGH , the Y outputs are active-LOW.

The device is packaged in a space saving (0.3-inch row spacing) 20-pin package.


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2536 | 8-Bit Decoder |
| Am25LS2537 | 1 of 10 Decoder |
| Am25LS2538 | 1 of 8 Decoder |
| Am25LS2539 | Dual 1 of 4 Decoder |
| Am2924 | 3 to 8 Line Decoder/ <br> Demultiplexer |

## CONNECTION DIAGRAM

 Top ViewP-20
D-20
F-20*

L-20-1


CD004700
*F-20 pin configuration identical to D-20, P-20.
Note: Pin 1 is marked for orientation


ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2921
```


$L_{\text {Screening Option }}$ Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-20-pin CERDIP
F-20-pin flatpak L-20-pin leadless chip carrier P -20-pin plastic DIP X - Dice

Device type
1-of-8 Decoder

| Valid Combinations |  |
| :--- | :--- |
| Am2921 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


| FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FUNCTION | INPUTS |  |  |  |  |  |  |  |  |  | OUTPUTS |  |  |  |  |  |  |  |
|  | $\overline{\mathrm{OE}} \mathrm{I}_{1}$ | $\overline{\mathrm{OE}}_{2}$ | $\bar{E}_{1}$ | $\bar{E}_{2}$ | $E_{3}$ | $\mathrm{E}_{4}$ | POL | C | B | A | $\mathrm{Y}_{0}$ | $\mathrm{Y}_{1}$ | $\mathrm{Y}_{2}$ | $\mathrm{Y}_{3}$ | $Y_{4}$ | $\mathrm{Y}_{5}$ | $\mathrm{Y}_{6}$ | $\mathrm{Y}_{7}$ |
| High-Impedance | $\begin{aligned} & \mathrm{H} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \hline X \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $z$ | $\bar{z}$ | $\mathrm{Z}$ | $\frac{z}{z}$ | $\bar{z}$ | $\bar{z}$ | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{Z} \end{aligned}$ | Y Z Z |
| Disable | $L$ $L$ $L$ $L$ $L$ $L$ $L$ | $L$ $L$ $L$ $L$ $L$ $L$ | $\begin{aligned} & \mathrm{H} \\ & H \\ & X \\ & X \\ & X \\ & X \\ & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & \hline X \\ & X \\ & X \\ & H \\ & H \\ & X \\ & X \\ & X \\ & X \end{aligned}$ |  | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{~L} \\ & \mathbf{L} \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & H \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline X \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ |  | $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ | $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ |  | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & H \end{aligned}$ |  | $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & H \\ & H \end{aligned}$ |
| Active-HIGH Output |  |  | $L$ $L$ $L$ $L$ $L$ $L$ $L$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & H \end{aligned}$ |  | $\begin{aligned} & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $L$ $L$ $H$ $L$ $L$ $L$ $L$ |  | $L$ $L$ $L$ $L$ $H$ $L$ $L$ |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & H \end{aligned}$ | $L$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ |
| Active-LOW Output |  |  | $L$ $L$ $L$ $L$ $L$ $L$ $L$ | $L$ $L$ $L$ $L$ $L$ $L$ $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | H H H H H H H H | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \end{aligned}$ | $H$ $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & L \end{aligned}$ | L L H H H H H H H | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | H H H H H H H H | H H H H L H H H H | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $L$ |

$$
\begin{array}{r}
\mathrm{H}=\mathrm{HIGH} \quad \mathrm{~L}=\text { LOW } \quad \mathrm{X}=\text { Don't Care } \quad \mathrm{Z}=\text { High Impedance } \\
\text { APPLICATIONS }
\end{array}
$$



AF001860
Two Am2921's can be used to perform a bit set, bit clear, bit toggle or bit test on any of sixteen bits in a microprocessor system. Examples of the operations performed are as follows:

| Microprogram Control |  |  |  |  | 0 | 1 | 2 | 3 | 4 | $\begin{array}{cc} \text { 16-Bit } \\ 5 & 6 \end{array}$ |  | Field | From 8 |  | Am2921 |  | 12 | 13 | 14 | 15 | $\begin{aligned} & \text { Am2901 } \\ & \text { ALU } \\ & \text { Function } \end{aligned}$ | Bit Function Performed On Selected Register |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D | C | B | A | POL |  |  |  |  |  |  |  | 10 |  |  | 11 |  |  |  |  |  |  |  |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | OR |  | SET |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | AND |  | TEST |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | AND |  | CLEAR |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |  | 1 | 1 | 1 | 1 | EX NOR |  | TOGGLE |
| 1. | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | EX OR |  | TOGGLE |

Note: Bit test is performed using $\mathbf{F}=\mathbf{0}$ output of Am2901.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ 0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage. $\qquad$
DC Output Current, Into Outputs .......................... 30 mA
DC input Current $\qquad$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}}=1.0 \mathrm{~mA}$ (MIL) |  | 2.4 | 3.4 |  | Volts |
|  |  |  | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ (COM'L) |  | 2.4 | 3.4 |  |  |
| 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{l}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{I}^{\mathrm{OL}}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{1 \mathrm{~N}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| IIH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 21 | 34 | mA |

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | A, B, C to $Y_{i}$ | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 20 | 30 | ns |
| tpHL |  |  |  | 15 | 22 |  |
| tplH | $\overline{E_{1}}, \bar{E}_{2}$ to $Y_{i}$ |  |  | 19 | 28 | ns |
| tpHL |  |  |  | 20 | 30 |  |
| tPLH | $E_{3}, E_{4}$ to $Y_{i}$ |  |  | 21 | 31 | ns |
| tPHL |  |  |  | 23 | 34 |  |
| tPLH | POL to $\mathrm{Y}_{\mathrm{i}}$ |  |  | 16 | 24 | ns |
| tPHL |  |  |  | 20 | 30 |  |
| ${ }_{\text {Z }}$ | $\overline{O E_{1}}, \overline{O E_{2}}$ to $Y_{i}$ |  |  | 17 | 25 | ns |
| t ZL |  |  |  | 14 | 21 |  |
| $\mathrm{thz}^{\text {L }}$ | $\overline{O E_{1}}, \overline{O E_{2}}$ to $Y_{i}$ | $C_{L}=5.0 \mathrm{pF}$ |  | 17 | 25 | ns |
| t ${ }_{L}$ |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 20 | 30 |  |


| Parameters | Description | Test Conditions | COMMERCIAL <br> Am2921 |  | $\begin{aligned} & \text { MILITARY } \\ & \text { Am2921 } \end{aligned}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tpLH | A, B, C to $\mathrm{Y}_{\mathrm{i}}$ | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 36 |  | 42 | ns |
| tpHL |  |  |  | 29 |  | 37 |  |
| tPLH. | $\overline{E_{1}}, \bar{E}_{2}$ to $Y_{i}$ |  |  | 34 |  | 39 |  |
| tpHL |  |  |  | 38 |  | 45 | ns |
| tPLH | $E_{3}, E_{4}$ to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| tpHL |  |  |  | 43 |  | 52 |  |
| tPLH | POL to $Y_{i}$ |  |  | 29 |  | 34 | ns |
| tPHL |  |  |  | 39 |  | 49 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{\mathrm{OE}} \mathrm{V}_{1}, \mathrm{OE}_{2}$ to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| tzL |  |  |  | 23 |  | 25 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{\mathrm{OE}}{ }_{1}, \overline{\mathrm{OE}_{2}}$ to $Y_{i}$ | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 29 |  | 33 | ns |
| tzz |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 33 |  | 36 |  |

*Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

# Am2922 

Eight Input Multiplexer with Control Register

## DISTINCTIVE CHARACTERISTICS

- High speed eight-input multiplexer
- On-chip Multiplexer Select and Polarity Control Register
- Output polarity control for inverting or non-inverting output
- Three-state output for expansion
- Common register enable, asynchronous register clear
- AC parameters specified over operating temperature and power supply ranges


## GENERAL DESCRIPTION

The Am2922 is an eight-input Multiplexer with Control Register. The device features high speed from clock to output and is intended for use in high speed computer control units or structured state machine designs.
The Am2922 contains an internal register which holds the A, B and C multiplexer select lines as well as the POL (Polarity) control bit. When the Register Enable input ( $\overline{\mathrm{RE}}$ ) is LOW, new data is entered into the register on the LOW-to-HIGH transition of the clock. When $\overline{R E}$ is HIGH, the register retains its current data. An asynchronous clear input ( $\overline{\mathrm{CLR}}$ ) is used to reset the register to a logic LOW level.
The $A, B$ and $C$ register outputs select one of eight multiplexer data inputs. A HIGH on the Polarity Control flip-
flop output causes a true (non-inverting) multiplexer output, and a LOW causes the output to be inverted. In a computer control unit, this allows testing of either true or complemented flag data at the microprogram sequencer test input.

An active LOW Multiplexer Enable input ( $\overline{\mathrm{ME}}$ ) allows the selected multiplexer input to be passed to the output. When $\overline{\mathrm{ME}}$ is HIGH , the output is determined only by the Polarity Control bit.

The Am2922 also features a three-state Output Enable control ( $\overline{\mathrm{OE}}$ ) for expansion. When $\overline{\mathrm{OE}}$ is LOW, the output is enabled. When $\overline{\mathrm{OE}}$ is HIGH , the output is in the high impedance state.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2922
            D L
                        Blank - Standard processing
                        B - Burn-in
                Temperature (See Operating Range)
                C-Commercial ( }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to +70
                M - Military (-55 % to +125 % )
    Package
    D-20-pin CERDIP
    F-20-pin flatpak
    L-20-pin leadless chip carrier
    P-20-pin plastic DIP
    X-Dice
    Device type
    8-Input Multiplexer
```



## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
| $4,6,5$ | A, B, C | 1 | Multiplexer Select Lines. One of eight multiplexer data inputs is selected by the A, B and C register outputs. |
| 9 | POL | 1 | Polarity Control Bit. A HIGH register output causes a true (non-inverted) output and a LOW causes the output to be <br> inverted. |
| 2 | $\overline{M E}$ | 1 | Multiplexer Enable. When LOW, it enabled the 8-input multiplexer. When HIGH, the Y output is determined by only <br> the Polarity Control bit. |
| 3 | $\overline{R E}$ | 1 | Register Enable. When LOW, the Multiplexer Select and Polarity Control Register is enabled for loading. When <br> HIGH, the register holds its current data. |
| 8 | $\overline{C L R}$ | 1 | Clear. A LOW asynchronously resets the Multiplexer Select and Polarity Control Register. |
| 7 | $\mathrm{D}_{1}-\mathrm{D}_{8}$ | 1 | Data Inputs to the 8-input multiplexer. |
| 16 | $\overline{\mathrm{CP}}$ | 1 | Clock Pulse. When $\overline{\text { RE }}$ is LOW, the Multiplexer Select and Polarity Control Register changes state on the LOW-to- <br> HIGH transition of CP. |
| 15 | Y | 1 | Output Enable. When LOW, the output is enabled. When HIGH, the output is in the high impedance state. |

FUNCTION TABLE

| MODE | INPUTS |  |  |  |  |  |  | INTERNAL |  |  |  | INPUTS |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | C | B | A | POL | $\overline{\mathrm{RE}}$ | $\overline{\text { CLR }}$ | CP | $\mathbf{Q}_{\mathbf{C}}$ | $\mathbf{Q}_{\mathbf{B}}$ | $Q_{\text {A }}$ | QPOL | ME | $\overline{O E}$ | Y |
| Clear | $\frac{1}{1}$ | ${ }_{\downarrow}^{x}$ | ${ }^{x}$ | 1 1 | $x$ $\downarrow$ | $\stackrel{L}{1}$ | $\stackrel{1}{x}$ | $\stackrel{1}{1}$ | $\stackrel{L}{1}$ | $\stackrel{L}{L}$ | $\downarrow$ | H L X | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} H \\ \overline{\mathrm{D}}_{0} \\ \mathrm{Z} \end{gathered}$ |
| Reg. Disable | X | X | X | X | H | H | X | NC | NC | NC | NC | L | L | $\begin{aligned} & \overline{\bar{D}} / / D_{i} \\ & (\text { Note } 1) \end{aligned}$ |
| Select (Multiplex) | $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ | $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ | $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ |  |  |  | $\dagger$ | $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ | $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ | $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ |  |  | 1 | $\overline{\mathrm{D}}_{0} / \mathrm{D}_{0}$ $\mathrm{D}_{1} / \mathrm{D}_{1}$ $\mathrm{D}_{2} / \mathrm{D}_{2}$ $\mathrm{D}_{3} / \mathrm{D}_{3}$ $\overline{\mathrm{D}}_{4} / \mathrm{D}_{4}$ $\overline{\mathrm{D}}_{5} / \mathrm{D}_{5}$ $\mathrm{D}_{6} / \mathrm{D}_{6}$ $\mathrm{D}_{7} / \mathrm{D}_{7}$ |
| Multiplexer Disable | ${ }^{1}$ |  |  | $x$ | $x$ | ${ }_{H}$ | X | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{gathered} H \\ L \end{gathered}$ |
| Tri-state Output Disable | $\downarrow$ | $\downarrow$ |  | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | X | X | X | X | X | H | $z$ |

## APPLICATIONS



AF001840
A versatile one-of-sixteen Test Select with Polarity Control and Test Select Hold.

| ABSOLUTE MAXIMUM RATINGS |  |
| :---: | :---: |
| Storage Temperature ........................ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
|  |  |
| Supply Voltage to Ground Potential Continuous |  |
| DC Voltage Applied to Outputs For |  |
| High Output State .....................-0.5V to + $\mathrm{V}_{\text {CC }}$ max |  |
| DC Input Voltage..............................-0.5V to +5.5 V |  |
| DC Output Current, Into Outputs ...................... 30 mA |  |
| DC Input Current ..........................-30mA to + 5.0 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 device reliability. |  |
|  |  |
|  |  |

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{MIL}, \mathrm{I}^{\mathrm{OH}}=-2.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, ${ }^{1} \mathrm{OH}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| 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{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=8.0 \mathrm{~mA}$ |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=20 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.7 | Volts |
|  |  |  |  | 0.8 |  |  |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IIN}^{\text {a }}$ = 18 mA |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=0.4 V \end{aligned}$ | $\overline{M E}, \overline{O E}, \overline{\mathrm{RE}}$ |  |  | -0.72 | mA |
|  |  |  | $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \mathrm{CP}, \overline{\mathrm{CLR}}$ |  |  | -2.0 |  |
| IH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | $\overline{\mathrm{ME}}, \overline{\mathrm{OE}}, \overline{\mathrm{RE}}$ |  |  | 40 | $\mu$ |
|  |  |  | $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \mathrm{CP}, \overline{\mathrm{CLR}}$ |  |  | 50 |  |
| 1 | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=5.5 \mathrm{~V} \end{aligned}$ | $\overline{\mathrm{ME}}, \overline{\mathrm{OE}}, \overline{\mathrm{RE}}$ |  |  | 0.1 | mA |
|  |  |  | $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \mathrm{CP}, \overline{\mathrm{CLR}}$ |  |  | 1.0 |  |
|  | Off-State (High-Impedance) Output Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
| loz |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=\mathrm{MAX}$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  | 97 | 148 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \overline{\mathrm{ME}}$ at Gnd. All other inputs and outputs open. Measured after a momentary ground then 4.5 V applied to clock input.

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Clock to Y POL - LOW | $\begin{gathered} C_{L}=15 \mathrm{pF} \\ R_{L}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 21 | 32 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 19 | 29 |  |
| ${ }_{\text {tPLH }}$ | Clock to Y POL - HIGH |  |  | 16 | 24 | ns |
| tpHL |  |  |  | 19 | 29 |  |
| tPLH | $D_{n}$ to $Y$ |  |  | 10 | 16 | ns |
| tPHL |  |  |  | 13 | 19 |  |
| tPLH | CLR to $Y$ |  |  | 22 | 33 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 22 | 33 |  |
| tPLH | $\overline{M E}$ to $Y$ |  |  | 12 | 18 | ns |
| tPHL |  |  |  | 12 | 18 |  |
| t ZL | $\overline{O E}$ to Y |  |  | 8 | 14 | ns |
| ${ }_{\text {Z }} \mathrm{H}$ |  |  |  | 8 | 14 |  |
| tLZ |  | $C_{L}=5.0 \mathrm{pF}$$R_{L}=2.0 \mathrm{k} \Omega$ |  | 10 | 17 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 10 | 17 |  |
| $t_{s}$ | A, B, C, POL | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 10 |  |  | ns |
|  | CE |  | 15 |  |  |  |
| $\mathrm{t}_{5}$ | CLR Recovery |  | 5 |  |  | ns |
| $t_{\text {pw }}$ | Clock |  | 10 |  |  | ns |
|  | Clear (LOW) |  | 10 |  |  |  |
| $t_{n}$ | A, B, C, POL, CE |  | 0 |  |  | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMMERCIAL <br> Am2922 |  | MILITARY Am2922 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Clock to Y POL - LOW |  |  | 40 |  | 47 | ns |
| tPHL |  |  |  | 34 |  | 38 |  |
| tple | Clock to Y POL - HIGH |  |  | 29 |  | 33 | ns |
| tpHL |  |  |  | 35 |  | 41 |  |
| tPLH | $D_{n}$ to $Y$ |  |  | 19 |  | 21 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 22 |  | 24 | ns |
| tpli | CLR to $Y$ | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 39 |  | 45 | ns |
| tPHL |  |  |  | 39 |  | 45 |  |
| tpli | $\overline{M E}$ to $Y$ |  |  | 22 |  | 26 | ns |
| tPHL |  |  |  | 19 |  | 20 |  |
| $\mathrm{t}_{\mathrm{ZL}}$ | $\overline{O E}$ to $Y$ |  |  | 19 |  | 24 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 22 |  | 29 |  |
| $\mathrm{t}_{\mathrm{L} Z}$ |  | $\begin{aligned} C_{L} & =5.0 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 24 |  | 30 | ns |
| thz |  |  |  | 24 |  | 30 |  |
| $t_{s}$ | A, B, C, POL | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 11 |  | 12 |  | ns |
|  | CE |  | 18 |  | 20 |  |  |
| $\mathrm{t}_{5}$ | CLR Recovery |  | 6 |  | 7 |  | ns |
| $t_{\text {pw }}$ | Clock |  | 11 |  | 12 |  | ns |
|  | Clear (LOW) |  | 11 |  | 12 |  |  |
| $t_{\text {h }}$ | A, B, C, POL, CE |  | 3 |  | 3 |  | ns |

*Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2535 | 8-Input Multiplexer |
| Am2923 | 8-Input Multiplexer |

## Am2923

Eight-Input Multiplexer

## DISTINCTIVE CHARACTERISTICS

- Advanced Schottky technology
- 3-state output for bus organized systems
- Switches one of eight inputs to two complementary outputs


## GENERAL DESCRIPTION

The Am2923 is an 8-input multiplexer that switches one of eight inputs onto the inverting and non-inverting outputs under the control of a 3 -bit select code. The inverting output is one gate delay faster than the non-inverting output.

The Am2923 features a 3-state output for data bus organization. The active-LOW strobe, or '"output control', applies to both the inverting and non-inverting output. When the output control is HIGH, the outputs are in the highimpedance state. When the output control is LOW, the active pull-up output is enabled.

BLOCK DIAGRAM


BD002360
RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2922. | 8 Input MUX with Register Control |
| Am25LS2535 | 8 Input MUX with Register Control |

## P-16 D-16* <br> F-16*


Note: Pin 1 is marked for orientation
*F-16 pin configuration identical to D-16, P-16.

## METALLIZATION AND PAD LAYOUT


ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2923 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
|  | XC, XM |

Package
D-16-pin CERDIP
F-16-pin flatpak
$\mathrm{L}-20$-pin leadless chip carrier
P -16-pin plastic DIP
$X$ - Dice

Device type
8-Input Multiplexer
$L_{\text {Screening Option }}$
Blank - Standard processing B - Burn-in

Temperature (See Operating Range)
$\mathrm{C}-\mathrm{Commercial}\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
| $9,10,11$ | $A, B, C$ | 1 | The three select inputs of the multiplexer. |
|  | $D_{0}, D_{1}$ <br> $D_{2}, D_{3}$, <br> $D_{4}, D_{5}$ <br> $D_{6}, D_{7}$ | 1 | The eight data inputs of the multiplexer. |
| 5 | Y |  |  |
| 6 | $\bar{W}$ | 0 | The true multiplexer output. |
| 7 | $\bar{S}$ | 0 | The complement multiplexer output. |


| INPUTS |  |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| C | B | A | Output Control | Y | $\overline{\mathbf{W}}$ |
| X | X | X | H | Z | z |
| L | L | L | L | $\mathrm{D}_{0}$ | $\mathrm{D}_{0}$ |
| L | L | H | L | $\mathrm{D}_{1}$ | $\mathrm{D}_{1}$ |
| L | H | L | L | $\mathrm{D}_{2}$ | $\mathrm{D}_{2}$ |
| L | H | H | L | $\mathrm{D}_{3}$ | $\mathrm{D}_{3}$ |
| H | L | L | L | $\mathrm{D}_{4}$ | $\mathrm{D}_{4}$ |
| H | L | H | L | $\mathrm{D}_{5}$ | $\mathrm{D}_{5}$ |
| H | H | L | , | $\mathrm{D}_{6}$ | $\mathrm{D}_{6}$ |
| H | H | H | L | $\mathrm{D}_{7}$ | $\mathrm{D}_{7}$ |
| $\begin{array}{ll}H=H \text { HGH } & X=\text { Don't Care } \\ L=\text { LOW } & Z=\text { High Impedance }\end{array}$ |  |  |  |  |  |
|  |  |  |  |  |  |
| $\mathrm{D}_{0}-\mathrm{D}_{7}=$ The output will follow the HIGH-level or LOWlevel of the selected input. |  |  |  |  |  |
| $\bar{D}_{0}-\bar{D}_{7}=$ The output will follow the complement of the HIGH-level or LOW-level of the selected input. |  |  |  |  |  |

## SCHOTTKY INPUT/OUTPUT

 CURRENT INTERFACE CONDITIONS

IC000370
Note: Actual current flow direction shown.

LOADING RULES (In Unit Loads)

| Input/ |
| :---: | :---: | :---: | :---: | :---: |
| Output |$\quad$ Pin No.'s $\left.$| Input |
| :---: |
| Unit Load | | Fun-out |
| :---: |
| Output |
| HIGH | | Output |
| :---: |
| LOW | \right\rvert\,

A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ measured at 2.7 V HIGH and -2.0 mA measured at 0.5 V LOW.


32-INPUT MULTIPLEXER


AF001690

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ......................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias $\ldots . . . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous. $\qquad$
DC Voltage Applied to Outputs For
High Output State $\qquad$ .-0.5 V to +7.0 V

DC Input Voltage $\qquad$ 0.5 V to $+\mathrm{V}_{\text {CC }} \max$

DC Output Current, Into Outputs .-0.5 V to +5.5 V
DC Input Current $\qquad$
$\qquad$
$\qquad$
................. -30 mA to +5.0 mA

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
+4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

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 device reliability.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  | Min | Typ <br> (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IOL}_{2}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{I H} \text { or } \mathrm{V}_{I L} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{l}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| $\begin{aligned} & \text { ILL } \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input LOW Current | $V_{C C}=M A X, V_{I N}=0.5$ |  |  |  | -2 | mA |
| $\begin{aligned} & \hline \mathrm{I}_{\mathrm{H}} \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA |
| lo(off) | Off-State (High-Impedence) Output Current | $\begin{aligned} & V_{C C}=M A X, V_{O}=2.4 \mathrm{~V} \\ & V_{I N}=V_{I H} \text { or } V_{I L} V_{O}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | $\begin{gathered} 50 \\ -50 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| ISC | Output Short Circuit Current (Note 4) | $V_{C C}=$ MAX $V_{\text {OUT }}=0.0 \mathrm{~V}$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ MAX (Note 5) |  |  | 55 | 85 | mA |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V} C \mathrm{C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Actual input currents = Unit Load Current $x$ Input Load Factor (see Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
5. Icc is measured with all outputs open and all inputs at 4.5 V .

SWITCHING CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | A, B, or C to Y; 4 Levels of Delay | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$ |  | 12 | 18 | ns |
| tPHL |  |  |  | 13 | 19.5 |  |
| tplH | A, B, or C to $\bar{W} ; 3$ Levels of Delay |  |  | 10 | 15 | ns |
| tPHL |  |  |  | 9 | 13.5 |  |
| tPLH | Any $D$ to $Y$ |  |  | 8 | 12 | ns |
| tPHL |  |  |  | 8 | 12 |  |
| tPLH | Any D to $\bar{W}$ |  |  | 4.5 | 7 | ns |
| tPHL |  |  |  | 4.5 | 7 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable to Y | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$ |  | 13 | 19.5 | ns |
| t ZL |  |  |  | 14 | 21 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable to $\bar{W}$ |  |  | 13 | 19.5 | ns |
| t tL |  |  |  | 14 | 21 |  |
| $\mathrm{thz}^{\text {l }}$ | Output Enable to Y | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 5.5 | 8.5 | ns |
| tLZ |  |  |  | 9 | 14 |  |
| $\mathrm{t}_{\mathrm{t} Z}$ | Output Enable to $\bar{W}$ |  |  | 5.5 | 8.5 | ns |
| tLz |  |  |  | 9 | 14 |  |

## Am2924

Three-Line to Eight-Line Decoder/Demultiplexer

## DISTINCTIVE CHARACTERISTICS

- Advanced Schottky technology
- Inverting and non-inverting enable inputs


## GENERAL DESCRIPTION

The Am2924 is a 3-line to 8 -line decoder/demultiplexer fabricated using advanced Schottky technology. The decoder has three buffered select inputs $A, B$ and $C$ that are decoded to one of eight $\bar{Y}$ outputs.

One active-HIGH and two active-LOW enables can be used for gating the decoder or can be used with incoming data for demultiplexing applications. When the enable input function is in the disable state, all eight $\bar{Y}$ outputs are HIGH regardless of the $A, B$ and $C$ select inputs.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

D-16-pin CERDIP
F-16-pin flatpak
L-20-pin leadless chip carrier
$P-16-$ pin plastic DIP
$X$-Dice
Device type
Decoder/Demultiplexer


| Valid Combinations |  |
| :--- | :--- |
| Am2924 | PC |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
| XC, XM |  |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin No. | Name |  |  | Description |  |  |  |  |  |
| 1, 2, 3 | A, B, C |  | 1 | A, B, C Select. The three select inputs to the decoder. |  |  |  |  |  |
| 6 | G1 |  | 1 | The active-HIGH enable input. A LOW on the G1 input forces all $\bar{Y}$ outputs HIGH regardless of any other inputs. |  |  |  |  |  |
| 4,5 | द2A, $\overline{\text { G2B }}$ |  | 1 | The active-LOW enable input. A HIGH on either the G2A or $\overline{\text { G2B }}$ input forces all $\bar{Y}$ outputs HIGH regardless of any other inputs. |  |  |  |  |  |
| $\begin{aligned} & 15,14,13 \\ & 12,11,10 \\ & 9,7 \end{aligned}$ | $\begin{aligned} & \overline{Y_{0}}, \overline{Y_{1}}, \overline{\bar{Y}_{2}} \\ & \frac{Y_{3}}{Y_{6}}, \frac{Y_{4}}{Y_{7}}, \end{aligned}$ |  | 0 | The eight decoder outputs. |  |  |  |  |  |
| FUNCTION TABLE |  |  |  |  | LOADING RULES (In Unit Loads) |  |  |  |  |
| Inputs |  |  | Outputs |  | Input/ Output | Pin No.'s | Unit Load | Fan-out |  |
| Enable |  | Select |  |  | Output |  |  | Output |
| G1 G2A | G2B | C B A | $\begin{array}{lllllllllll}\overline{\mathrm{Y}_{0}} & \overline{\mathbf{Y}_{1}} & \overline{\mathbf{Y}_{2}} & \overline{\mathrm{Y}_{3}} & \overline{\mathrm{Y}_{4}} & \overline{\mathbf{Y}_{5}} & \overline{\mathbf{Y}_{6}} & \overline{\mathbf{Y}_{7}}\end{array}$ |  |  |  |  |  |  |
| L $X$ <br> $X$ $H$ <br> $X$ $X$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ <br> $H$ $L$ | X | $\mathrm{x} \times \mathrm{x}$ | $\left\{\begin{array}{lllllll} H & H & H & H & H & H & H \\ H & H & H & H & H & H & H \\ H & 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 & H \\ H & H & H & L & H & H & H \\ H & H & H & H & L & H & H \\ H & H \\ H & H & H & H & H & L & H \\ H & H & H & H & H & H & L \\ H & H & H & H & H & H & L \end{array}\right.$ |  |  | A | , |  |  |  |
|  | X | $x$ $x$ $x$ <br> $x$   <br>    |  |  | B | 2 | 1 | - | - |
|  | H | $\begin{array}{llll}X & X & \\ L & \\ L & L & L\end{array}$ |  |  | C | 3 | 1 | - | - |
|  | $\underset{L}{L}$ | $\begin{array}{lll}L & L & L \\ L & L & H\end{array}$ |  |  | $\overline{\mathrm{G} 2 \mathrm{~A}}$ | 4 | 1 | - | - |
|  | L | L H L |  |  | $\overline{\text { G2B }}$ | 5 | 1 | - | - |
|  | L | $\begin{array}{llll}\text { L } & H & H \\ H & L & \\ H\end{array}$ |  |  | G1 | 6 | 1 | - | - |
|  | L | H L L H |  |  | $\overline{Y_{7}}$ | 7 | - | 20 | 10 |
|  | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{array}{llll}\mathrm{H} & \mathrm{H} & \mathrm{L} \\ \mathrm{H} & \mathrm{H} & \mathrm{H}\end{array}$ |  |  | GND | 8 | - | - | - |
| $\begin{aligned} & \mathrm{H}=\mathrm{HIGH} \\ & \mathrm{~L}=\text { LOW } \\ & \mathrm{X}=\text { Don't care } \end{aligned}$ |  |  |  |  | $\overline{Y_{6}}$ | 9 | - | 20 | 10 |
|  |  |  |  |  | $\overline{Y_{5}}$ | 10 | - | 20 | 10 |
|  |  |  |  |  | $\overline{Y_{4}}$ | 11 | - | 20 | 10 |
| SCHOTTKY INPUT/OUTPUT <br> CURRENT INTERFACE CONDITIONS <br> DRIVING OUTPUT DRIVEN INPUT |  |  |  |  | $\overline{Y_{3}}$ | 12 | - | 20 | 10 |
|  |  |  |  |  | $\overline{Y_{2}}$ | 13 | - | 20 | 10 |
|  |  |  |  |  | $\overline{Y_{1}}$ | 14 | - | 20 | 10 |
| IC000370 <br> Note: Actual current flow direction shown. |  |  |  |  | $\bar{Y}_{0}$ | 15 | - | 20 | 10 |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{CC}}$ | 16 | - | - | - |
|  |  |  |  |  | A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ measured at 2.7 V HIGH and -2.0 mA measured at 0.5V LOW. |  |  |  |  |

APPLICATIONS

$\mathrm{H}=\mathrm{HIGH}$
AF002010
One-of-Sixteen Demultiplexer

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
（Ambient）Temperature Under Bias
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
（Pin 16 to Pin 8）Continuous
s．．．．．．
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$
DC Input Voltage $\qquad$ ．．．-0.5 V to +5.5 V
DC Output Current，Into Outputs $\qquad$
DC Input Current ．．．．．．．．．．．．．．．．．．．．．．．．．．．．．－30mA to +5.0 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 device reliability．

## OPERATING RANGES

Commercial（C）Devices
Temperature . $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage

$$
+4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V}
$$

Military（M）Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the function－ ality of the device is guaranteed．

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions（Note 1） |  | Min | Typ （Note 2） | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-1 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  | COM＇L | 2.7 | 3.4 |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{1 \mathrm{~N}}=-18 \mathrm{~mA}$ |  |  |  | －1．2 | Volts |
| $\begin{aligned} & \mathrm{I}_{1 \mathrm{~L}} \\ & \text { (Note 3) } \end{aligned}$ | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.5 \mathrm{~V}$ |  |  |  | －2 | mA |
| $\begin{aligned} & \mathrm{I} / \mathrm{H} \\ & \text { (Note 3) } \end{aligned}$ | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| ISC | Output Short Circuit Current （Note 4） | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |  | －40 |  | －100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{C C}=$ MAX（Note 5） |  |  | 49 | 74 | mA |

Notes：1．For conditions shown as MIN or MAX，use the the appropriate value specified under Operating Ranges for the applicable device type．
2．Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading．
3．Actual input currents $=$ Unit Load Current $\times$ Input Load Factor（See Loading Rules）
4．Not more than one output should be shorted at a time．Duration of the short circuit test should not exceed one second．
5．Output enabled and open．

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

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | Two Level Delay Select to Output | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega$ |  | 4.5 | 7 | ns |
| tPHL |  |  |  | 7 | 10.5 |  |
| tpLH | Three Level Delay Select to Output |  |  | 7.5 | 12 | ns |
| tphL |  |  |  | 8 | 12 |  |
| ${ }^{\text {tpLH }}$ | $\overline{\text { G2A }}$ or $\overline{\text { G2B }}$ to Output |  |  | 5 | 8 | ns |
| tPHL |  |  |  | 7 | 11 |  |
| tple | G1 to Output |  |  | 7 | 11 | ns |
| tPHL |  |  |  | 7 | 11 |  |

## DISTINCTIVE CHARACTERISTICS

Crystal controlled oscillator
Stable operation from 1 MHz to over 31 MHz

- Four microcode controlled clock outputs

Allows clock cycle length control for $15-30 \%$ increase in system throughput. Microcode selects one of eight clock patterns from 3 to 10 oscillator cycles in length

- System controls for $\overline{\mathrm{Run}} / \overline{\mathrm{Halt}}$ and Single Step Switch debounced inputs provide flexible halt controls
- Slim 0.3" 24-pin package

LSI complexity in minimum board area

## GENERAL DESCRIPTION

The Am2925 is a single-chip general purpose clock generator/driver. It is crystal controlled, and has microprogrammable clock cycle length to provide significant speed-up over fixed clock cycle approaches and meet a variety of system speed requirements. The Am2925 generates four different simultaneous clock output waveforms tailored to meet the needs of Am2900 and other bipolar and MOS microprocessor based systems. One-of-eight cycle lengths may be generated under microprogram control using the Cycle Length inputs $L_{1}, L_{2}$, and $L_{3}$.

The Am2925 oscillator runs at frequencies to over 31 MHz . A buffered oscillator output, $F_{0}$, is provided for external system timing in addition to the four microcode controlled clock outputs $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}$ and $\mathrm{C}_{4}$.

System control functions include Run, Halt, Single-Step, Initialize and Ready/Wait controls. In addition, the FIRST/ LAST input determines where a halt occurs and the CX input determines the end point timing of wait cycles. WAITACK indicates that the Am2925 is in a wait state.

BLOCK DIAGRAM


BD002590

DIE SIZE: 0.097" $\times$. $122^{\prime \prime}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am2925 | DC, DCB, DMB <br>  <br>  <br>  <br> LC, LCB, LMB <br> XC, XM |

Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
Package
D - 24-pin SLIMDIP
L - 28 -pin leadless chip carrier
X - Dice
Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


BD002541

# PIN DESCRIPTION 

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 6, 7, 8, 9 | $\begin{array}{ll} \mathrm{C}_{1}, & \mathrm{C}_{2} \\ \mathrm{C}_{3}, & \mathrm{C}_{4} \\ \hline \end{array}$ | 0 | System clock outputs. These outputs are all active during every system clock cycle. Their timing is determined by clock cycle length controls, $L_{1}, L_{2}$, and $L_{3}$. |
| 3, 4, 5 | $L_{1}, L_{2}, L_{3}$ | 1 | Clock cycle length control inputs. These inputs receive the microcode bits that select the microcycle lengths. They form a control word which selects one of the eight microcycle waveform patterns $\mathrm{F}_{3}$ through $\mathrm{F}_{10}$. |
| 14 | $\mathrm{F}_{0}$ | 0 | The buffered oscillator output. $\mathrm{F}_{0}$ internally generates all of the timing edges for outputs $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ and WAITACK. $\mathrm{F}_{0}$ rises just prior to all of the $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ transitions. |
| 18, 19 | $\frac{\overline{\text { HALT }}}{\text { RUN }}$ and | 1 | Debounced inputs to provide $\overline{\text { HALT }}$ control. These inputs determine whether the output clocks run or not. A LOW input on HALT ( $\overline{\mathrm{RUN}}=$ HIGH) will stop all clock outputs. |
| 17 | FIRST/[AST | 1 | $\overline{\text { HALT }}$ time control input. A HIGH input in conjunction with a HALT command will cause a halt to occur when $\mathrm{C}_{4}=$ LOW and $\mathrm{C}_{1}=\mathrm{C}_{2}=\mathrm{C}_{3}=$ HIGH (see clock waveforms). A LOW input causes a HALT to occur when $\mathrm{C}_{1}=\mathrm{C}_{2}=\mathrm{C}_{3}=$ LOW and $\mathrm{C}_{4}=\mathrm{HIGH}$. |
| 11, 10 | $\begin{aligned} & \text { SSNO and } \\ & \text { SSNC } \end{aligned}$ | 1 | Single Step control inputs. These debounced inputs allow system clock cycle single stepping while HALT is activated LOW. |
| 21 | WAITREQ | 1 | The Wait Request active LOW input. When LOW this input will cause the outputs to halt during the next oscillator cycle after the $\mathrm{C}_{\mathrm{X}}$ input goes LOW. |
| 23 | $C_{x}$ | 1 | Wait cycle control input. The clock outputs respond to a wait request one oscillator clock cycle after $\mathrm{C}_{\mathrm{X}}$ goes LOW. $\mathrm{C}_{\mathrm{X}}$ is normally tied to any one of $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}$ or $\mathrm{C}_{4}$. |
| 20 | WAITACK | 0 | The Wait Acknowledge active LOW output. When LOW, this output indicates that all clock outputs are in the "WAIT" state. |
| 2 | $\overline{\text { READY }}$ | 1 | The $\overline{\text { READY }}$ active LOW input is used to continue normal clock output patterns after a wait stage. |
| 22 | INIT | 1 | The Initialize active LOW input. This input is intended for use during power up initialization of the system. When LOW all clock outputs free run regardless of the state of the Halt, Single Step, Wait Request and Ready inputs. |
| 16, 15 | $x_{1}, x_{2}$ | I, 0 | External crystal connections. $\mathrm{X}_{1}$ can also be driven by a TTL frequency source. |

The Am2925 is a dynamically programmable general-purpose clock generator/driver. It can be logically separated into three parts. There is an oscillator, a state machine decoder and a state machine control section.

The oscillator is a linear inverting amplifier which may be configured with a minimum of external parts as a 1st harmonic* crystal oscillator, 3rd harmonic* crystal oscillator, L-C oscillator or used to buffer an external clock. The buffered, inverted output of this oscillator is available as $\mathrm{F}_{0}$.

The state machine takes microcode information from the Microcycle Length " $L$ ' inputs $L_{1}, L_{2}$ and $L_{3}$ and counts the fundamental frequency of the internal oscillator, $\mathrm{F}_{0}$, to create the clock outputs, $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}$ and $\mathrm{C}_{4}$.

The clock outputs have a characteristic wave shape relationship for each microcycle length. For example, $\mathrm{C}_{1}$ is always LOW only on the last $F_{0}$ clock period of a microcycle and $C_{4}$ is always LOW on the first. $\mathrm{C}_{3}$ has an approximately $50 \%$ duty cycle, and $\mathrm{C}_{2}$ is HIGH for all but the last two periods.
The current state of the machine is contained in a register, part of which is the Clock Generator Register. $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}$ and $\mathrm{C}_{4}$ are the outputs of this register. These outputs and the outputs of the Microcycle Control Latch are fed into a set of combinatorial logic to generate the next state. On each falling edge of the internal clock the next state is entered into the
current state register. The Microcycle Control Latch is latched when $\mathrm{C}_{1}$ is HIGH. This means that it will be loaded during the last state of each microcycle $\left(C_{1}=C_{2}=C_{3}=\right.$ LOW, $\mathrm{C}_{4}=\mathrm{HIGH}$ ). This internal latch selects one of eight possible microcycle lengths, $F_{3}$ to $F_{10}$.

The state machine control logic, which determines the mode of operation of the state machine, is intended to be connected to a front panel. There are four basic modes of operation of the Am2925 comprised of Run, Halt, Wait and Single Step.

## SYSTEM TIMING

In the typical computer, the time required to execute different instructions varies. However, the time allotted to each instruction is the time that it takes to execute the longest instruction. The Am2925 allows the user to dynamically vary the time allotted for each instruction, thereby allowing the user to realize a higher throughput.

This application section will cover several aspects of the Am2925. The first topic to be covered is the oscillator section which is responsible for providing the basis of all system timing. Second will be how to operate the Am2925; last will be an example of an Am2925 in a 16-bit microprogrammed machine.
*It is understood that the terms 'fundamental mode' and '3rd overtone" are generally regarded as more technically correct, but "1st harmonic" and "3rd harmonic' are used here because of their more generally accepted usage.

## OSCILLATOR

The Am2925 contains an inverting, linear amplifier which is intended to form the basis of a crystal oscillator. In designing this oscillator it is necessary to consider several factors related to the application.

The first consideration is the desired frequency accuracy. This may be subdivided into several areas. An oscillator is considered stable if it is insensitive to variations in temperature and supply voltage, and if it is unaffected by individual component changes and aging. The design of the Am2925 is such that the degree to which these goals are met is determined primarily by the choice of external components. Various types of crystals are available and the manufacturers' literature should be consulted to determine the appropriate type. For good temperature stability, zero temperature coefficient capacitors should be used (Type NPO). For extreme temperature stability, an oven must be used or some other form of temperature compensation applied.

Absolute frequency accuracy must also be considered. The resonant frequency varies with load capacitance. It is therefore important to match the load specified by the crystal manufacturer for a standard crystal (usually 32 pF ), or to specify the load when ordering a special crystal. It should then be possible to determine from the crystal characteristics the load tolerance to maintain a given accuracy. If the 'set-on'" error due to load tolerance is unacceptable, a trimmer capacitor should be incorporated for fine adjustment.

The mechanism by which a crystal resonates is electromechanical. This resonance occurs at a fundamental frequency (1st harmonic) and at all odd harmonics of this frequency (even harmonic resonance is not mechanically possible). Unless otherwise constrained crystal oscillators operate at their fundamental frequency. However, crystals are not generally available with fundamental frequencies above $20-25 \mathrm{MHz}$. At higher frequencies, an overtone oscillator must be used. In this case, the crystal is designed to oscillate efficiently at one of its odd harmonic frequencies and additional components are included in the oscillator circuit to prevent it oscillating at lower harmonics.

Where a high degree of accuracy or stability is not required, the amplifier may be configured as an L-C oscillator. It may also be driven from an external clock source if operation is required in synchronism with that source.

## 1st Harmonic (Fundamental) Oscillator

The circuit of a typical 1st harmonic oscillator is shown in Figure 1. The crystal load is comprised of the two 68pF capacitors in series. This 34 pF approximates the standard 32 pF crystal load. If a closer match is required then one of the capacitors should be replaced with a parallel combination of a fixed capacitor and a trimmer. The nominal value of the combination should be 60 pF to provide proper crystal loading.

## A typical crystal specification for use in this circuit is:

Frequency Range: $5-20 \mathrm{MHz}$
Resonance: Parallel Mode
Load: 32pF
Stability: $.01 \%$ or to match systems requirements
Case: H-17-for smaller size
Temp Range: -30 to $+70^{\circ} \mathrm{C}$
Note: Frequency will change over temp


DF000810
Figure 1. Connections for $5 \mathbf{- 2 0} \mathbf{~ M H z}$.

It is good practice to ground the case of the crystal to eliminate stray pick-up and keep all connections as short as possible.

Note: At fundamental frequencies below 5 MHz it is possible for the oscillator to operate at the 3rd harmonic. To prevent this a resistor should be added in series with the $X_{2}$ pin as shown in the circuit diagram.

The resistor value should match the impedance of $\mathrm{C}_{2}$ :
$R=X_{C_{2}}=\frac{1}{2 \pi f C_{2}}$

## 3rd Harmonic Oscillator

At frequencies greater than 20 MHz the crystal can be operated at its 3rd harmonic. A typical circuit is shown in Figure 2. Two additional components are included; an inductor, $L_{1}$, and a capacitor, $\mathrm{C}_{3}$. The purpose of the capacitor is to block the d.c. path through the inductor and thereby maintain the correct amplifier bias. $\mathrm{C}_{3}$ should be large $(\geqslant 1000 \mathrm{pF})$.

The inductor forms a parallel tuned circuit with $\mathrm{C}_{1}$. This circuit has its resonance set between the 1st and 3rd harmonics of the crystal and is used to prevent the oscillator operating at the 1st harmonic. In the 1st harmonic oscillator (Figure 1), the crystal appears as an inductor and forms a $\pi$-network with the two capacitors, thus providing the necessary phase shift for oscillation. In the 3rd harmonic oscillator, $L_{1}$ and $C_{1}$ are chosen such that at the 3rd harmonic the impedance of circuit is equivalent to that of the capacitor $\mathrm{C}_{2}$ in the 1st harmonic oscillator (Figure 3b). Thus, the same $\pi$-network is formed (Figure 3c) and oscillation is possible. At the 1st harmonic the tuned circuit appears as an inductor (Figure 3a), the $\pi$-network is not formed and oscillation is not possible.

The following specification is typical for a crystal to be used in a 3rd harmonic oscillator.

Frequency Range: Above 20 MHz
Resonance: Parallel Mode
Load: 32pF
Stability: . $01 \%$ or to match systems requirements
Case: H-17 - for smaller size
Temp Range: -30 to $+70^{\circ} \mathrm{C}$
Note: Frequency will change temp
Again it is good practice to ground the crystal case and keep connections short.


Figure 2. Connections for Frequencies above 20 MHz .

a) Fundamental Equivalent

b) Trap Impedance

c) 3rd Harmonic Equivalent

Figure 3. Forcing Third Harmonic Oscillation.

## Design Procedure

(1) Assume $\mathrm{C}_{1}=82 \mathrm{pF}$ and $\mathrm{C}_{2}=68 \mathrm{pF}$ (this gives a sensible inductor value). $L_{1}$ is calculated according to the formula:

$$
L_{1}=\frac{1151}{f_{0}{ }^{2}} \quad f_{0}=\underset{\substack{\text { Operating frefquency } \\ L_{1} \text { in } \mu H}}{M H z}
$$

This sets the resonant frequency of the L-C combination at $0.52 \mathrm{f}_{\mathrm{o}}$.
(2) Select the closest standard value inductor for $L_{1}$. Using this value calculate $\mathrm{C}_{1}$ such that the resulting crystal load at the 3rd harmonic is 32 pF .

$$
C_{1}=60+\frac{25330}{L_{1} \cdot f_{0}{ }^{2}} \quad C_{1} \text { in } p F
$$

Choose the closest standard capacitor value to this.

Using standard values both the resonant frequency of the L-C circuit ( $f_{r}$ ) and the crystal load are non-optimal. This will cause a slight error in the oscillating frequency. If this is not permissible $\mathrm{C}_{1}$ may be a fixed capacitor in parallel with a trimmer such that the range of adjustment includes the calculated value for $\mathrm{C}_{1}$. This is then set to give the desired frequency. In either case the approximate inductor value will cause the resonant frequency to the L-C circuit to change. This frequency, $f_{r}$, may be computed and should remain approximately midway between the 1st and 3rd harmonic.

$$
f_{r}=\frac{159}{\sqrt{L_{1} C_{1}}} \quad \begin{aligned}
& f_{r} \text { in } M H Z \\
& L_{1} \text { in } \mu H \\
& C_{1} \text { in } p F
\end{aligned}
$$

## L-C Oscillator

The Am2925 can be operated as an L-C tuned oscillator (Figure 4) and will perform as a stable oscillator within the restrictions of the chosen frequency determining components (i.e., inductor and capacitors). The circuit chosen is a classical $\pi$-network with DC loop isolation. The Am2925 oscillator is a DC biased linear amplifier. This DC bias is necessary and therefore $\mathrm{C}_{3}$ is included to block the DC path through the inductor. If a variable slug tuned inductor is used a moderate range of frequency adjustment tuneability (approximately $2: 1$ ) can be achieved. The range can be enhanced by switching the two resonant capacitors $\left(C_{1}, C_{2}\right)$ to larger or smaller values. The specific frequency of operation can be determined by the formula:


DF000870

Figure 4. L-C Tuned Oscillator.

## External Clock Drive

The Am2925 can be driven from an external clock source at a signal level of 1.0 V P-P or greater. This is accomplished by reducing the gain of the amplifier and AC coupling the input signal (Figure 5). The gain is reduced by feeding the amplifier output back to the input through a $4.7 \mathrm{k} \Omega$ resistor. AC coupling is provided by a $0.01 \mu \mathrm{~F}$ capacitor. The controlled gain minimizes ringing caused by the fast rising edges of the driver. The AC coupling maintains oscillator output symmetry by preserving oscillator $D C$ bias levels.
$X_{1}$ can be driven directly by TTL levels meeting the DC input requirements.'


DF000880
Figure 5. External Clock Drive.

## Am2925 Control Inputs

The control inputs fall into two categories, microcycle length control and clock control. Microcycle length control is provided via the ' $L$ '" inputs which are intended to be connected to the microprogram memory. The " $L$ " inputs are used to select one of eight cycle lengths ranging from three oscillator cycles for pattern $F_{3}$ to ten oscillator cycles for pattern $F_{10}$. This information is always loaded at the end of the microcycle into the Microcycle Control Latch. The Microcycle Latch performs the function of a pipeline register for the microcycle length microcode bits. Therefore, the cycle length goes in the same microword as the instruction that it is associated with.

The clock control inputs are used to synchronize the microprogram machine with the external world and I/O devices. Inputs like $\overline{R U N}, \overline{H A L T}$, SSNO and SSNC, which start and stop execution, are meant to be connected to switches on the front panel of the microprogrammed machine (see Figure 6). These inputs have internal pull-up resistors and are connected to an R-S flip-flop in order to provide switch debouncing. The FIRST/LAST input is used to determine at what point of the microcycle the Am2925 will halt when HALT or a SINGLE STEP is initiated. In most applications the user wires this input HIGH or LOW depending on his design.


Figure 6. Switch Connection for RUN/HALT and Single Step.


Figure 7. Am 2925 WAIT/READY Timing.

When HALT is held low ( $\overline{\text { RUN }}=\mathrm{HIGH}$ ) the state machine will start the halt mode on the last ( $\mathrm{C}_{1}=\mathrm{LOW}$ ) or the first ( $\mathrm{C}_{4}=\mathrm{LOW}$ ) state of the microcycle as determined by the FIRST/ $\overline{\text { LAST }}$ input. When $\overline{\text { RUN }}$ goes low $(\overline{H A L T}=\mathrm{HIGH})$ the state machine will resume the run mode.
The WAITREQ, $C_{x}, \overline{\text { READY }}$ and $\overline{\text { WAITACK }}$ signals are used io synchronize other parts of a computer system (memory, I/O devices) to the CPU by dynamically stretching the microcycle. For example, the CPU may access a slow peripheral that requires the data remain on the data bus for several microseconds in which case the peripheral pulls the WAITREQ line LOW. The $\mathrm{C}_{X}$ input lets the designer specify when the WAITREQ line is sampled in the microcycle. This has a direct impact on how much time the peripheral has to respond in order to request a wait cycle (see Figure 7). The READY line is used by the peripheral to signal when it is ready to resume execution of the rest of the microcycle. The WAITACK line goes LOW on the next oscillator cycle after the CX input goes LOW and remains LOW until the second oscillator cycle after READY goes LOW.

The SSNO and SSNC inputs are used to initiate the SINGLE STEP mode. These debounced inputs allow a single microcycle to occur while in the halt mode. SSNO (normally open) and SSNC (normally closed) are intended to be connected to a momentary SPDT switch. After SSNO has been low for one clock edge, the state machine will change to the run mode. The microcycle will end on the first or last state of the microcycle depending on the state of the FIRST//[AST.

## AC Timing Signal References

Set-up and hold times in registers and latches are measured relative to the clock signals that drive them. In the Am2925, the crystal oscillator provides a free running clock signal that drives all the registers on the devices. This clock is provided for the user through the buffered output of $\mathrm{F}_{0}$. Therefore, $\mathrm{F}_{0}$ is used as the reference for set-up, hold and clock to output times. However for the Microcontrol Latch, the set-up and hold times are referenced to the $\mathrm{C}_{1}$ output which is the buffered version of the latch enable. This reference is appropriate for the Microcontrol Latch because in a typical application this latch is considered part of the pipeline register which is also driven by one of the " C " outputs.

## Clock Outputs

There are four clock outputs provided for the user which have different duty cycles. The user must make a decision as to which one best fits his purposes. For example, in a three address architecture, with the Am2903 (Figure 8), the $\mathrm{C}_{3}$ clock (approximately $50 \%$ duty cycle) could be used to drive the clock input while $\mathrm{C}_{2}$ (always low last two oscillator cycles) drives Instruction Enable. This guarantees, for microcycle lengths greater than four, that the internal RAM data latches of the Am2903 are closed and the destination address is multiplexed onto the $B$ address bus before the RAM begins the Write cycle (Figure 9).

## 16-BIT MACHINE WITH Am2925

The block diagram in Figure 10 shows a 16 -bit microprogrammed machine which uses an Am2925 to generate system timing. The design decisions include oscillator frequency and clock pattern selections.

## Selecting the Crystal

In order to pick the oscillator frequency, a detailed timing analysis of the machine must be done in order to determine the execution length of every operation to be performed. For each operation there will be several delay paths, which usually include the ALU and the microprogram control.


DF000930
Figure 8. Am2903 Three Address Architecture.


Figure 9. Am2903 Three Address Operation.


Figure 10. 16-Bit Microprogrammed Machine.

Table 1 is an example of two of these paths. PATH 1 is a path through the Am2910 (Figure 10) for a microprogram Conditional Jump Subroutine. PATH 2 is a data flow path through the Am2903 for an Add instruction. Therefore, if the operation were an Add with a Conditional Jump Subroutine the maximum delay would be 170 ns . If there were a Program Control Unit also, then delays through it would have to be considered.

After the execution times all of the instruction types have been calculated, the oscillator frequency can be selected. It is desirable to minimize the difference between the most commonly used instructions and multiples of the oscillator period. In this way the most efficient use can be made of the variable microcycle scheme.

For example, in the hypothetical machine in Figure 10 there are five instruction types (most machines will have more). Table 2 is a table which lists each instruction type, corresponding execution time, and anticipated percentage of the typical instruction stream for each instruction. Several possible frequencies are shown which contain the next highest multiple of the corresponding oscillator period for each instruction. 20 MHz is the best choice because it comes closest to matching instructions A and C which compose $90 \%$ of the typical instruction stream.

In this example, 20 MHz was chosen. AT 20 MHz there is a choice between fundamental or overtone crystals. Fundamental frequency crystals are commonly available up to 25 MHz and 3rd harmonic crystals are available above 17 MHz . A fundamental crystal was selected for the example machine because the component count for the oscillator design is lower than for the overtone design. However, if it had turned out that 30 MHz was a better choice then overtone operation would be chosen since fundamental crystals above 25 MHz are not generally available.

## Fixed Bandwidth Buses

For those designs that require a data bus with fixed bandwidth and fixed time slots for each memory access, the designer should consider using cycle lengths which are a multiple of the shortest cycle length, i.e., cycle lengths 3, 6 and 9 or cycle lengths 4 and 8.

The design could further require that the bus be accessed only during the shortest cycle length. Therefore, by using multiple cycle lengths it can be predicted when the CPU will access the bus and for how long, thereby maintaining the fixed bandwidth.

## Performance Comparison

Estimated performance can be calculated directly from Table 2. For a fixed microcycle machine the longest instruction execution time would have to be used for all instructions, yielding an average instruction time of 228 ns . With a variable microcycle machine the average instruction time is the sum of the products for each instruction, of the percentage of the instruction stream and the next highest multiple. The average instruction for the example machine with a 20 MHz crystal is:
$(0.6 \times 150+.08 \times 200+.3+200+$
$.01 \times 200+.01+250)=170.5 \mathrm{~ns}$
This represents a $25 \%$ increase in system performance without requiring any other system speed-ups and without requiring faster devices.

| Device No. | Device Path | Path 1 | Path 2 |
| :--- | :--- | :---: | :---: |
| Am27S27 | CP - Q | 27 | 27 |
| Am2904 | INST - CT | 58 | - |
| Am2903A | I/AB - GP | - | 50 |
| Am2910A | CC - Y | 30 | - |
| Am2902A | GP - CN + Z | - | 7 |
| Am27S27 | TS | 55 | - |
| Am2903A | CN - Z | - | 35 |
| Am2904 | TSZ | - | 17 |
| Total | ns | 170 | 136 |

Table 1: Delay Path Totals for an Add and a Condition Jump Subroutine.

| Instruction Type | A | B | C | D | E | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Execution Time | 143 | 180 | 184 | 200 | 228 | ns |
| Percentage of Instruction Stream | 60\% | 8\% | 30\% | 1\% | 1\% | \% |
| Closest Multiple Oscillator Period $20 \mathrm{MHz} \mathrm{P}=50$ <br> $25 \mathrm{MHz} \mathrm{P}=40$ <br> $30 \mathrm{MHz} \mathrm{P}=33$ <br> $33 \mathrm{MHz} \mathrm{P}=30$ | $\begin{aligned} & 150(3 P) \\ & 160(4 \mathrm{P}) \\ & 167(5 \mathrm{P}) \\ & 150(5 \mathrm{P}) \end{aligned}$ | $\begin{aligned} & 200(4 \mathrm{P}) \\ & 200(5 \mathrm{P}) \\ & 200(6 \mathrm{P}) \\ & 180 \text { (6P) } \end{aligned}$ | $\begin{aligned} & 200(4 \mathrm{P}) \\ & 200(5 \mathrm{P}) \\ & 200(6 \mathrm{P}) \\ & 210(7 \mathrm{P}) \end{aligned}$ | $\begin{aligned} & 200(4 \mathrm{P}) \\ & 200(5 \mathrm{P}) \\ & 200(6 \mathrm{P}) \\ & 210 \text { (7P) } \end{aligned}$ | $\begin{aligned} & 250 \text { (5P) } \\ & 240 \text { (6P) } \\ & 233 \text { (7P) } \\ & 240 \text { (8P) } \end{aligned}$ |  |

Table 2. Instruction Time Analysis.

## EXTERNAL COMPONENT CALCULATIONS SUMMARY



$$
\mathrm{R}=\mathrm{X}_{\mathrm{C}_{2}}=\frac{1}{\mathrm{Tf}_{\mathrm{C}_{2}}} \text { for } 1-6 \mathrm{MHz}
$$

$$
\mathrm{R}=0 \text { for } 6-20 \mathrm{MHz}
$$

FUNDAMENTAL OSCILLATOR

## EXTERNAL CLOCK DRIVE



3rd HARMONIC OSCILLATOR
TYPICAL EXTERNAL CONNECTIONS


PF001070

## DESIGN CONSIDERATIONS

1. Oscillator external connections should be less than $1^{\prime \prime}$ long - wirewrap is not recommended.
2. $\mathrm{V}_{\mathrm{CC}}$ and GND connections should be less than $1 / 2^{\prime \prime}$ long to power plane.
3. Supply decoupling includes both high frequency and bulk storage elements.
4. The same considerations apply for 3rd overtone configurations.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage .................................... 0.5 V to +5.5 V
DC Output Current, Into Outputs ........................... 30mA
DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage

$$
+4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V}
$$

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots+4.5 \mathrm{~F} . \ldots$ to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. Typical values are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX use the appropriate value specified under Operating Ranges for the applicable device type.
3. Does not apply to $X_{1}$ and $X_{2}$.
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
5. ICC varies with temperature and oscillation frequency as shown in Figure 12. The parameters specified (worst case) applies to $\mathrm{f}_{0}=0,+25^{\circ} \mathrm{C}, \mathrm{C}_{1}=\mathrm{C}_{2}=\mathrm{C}_{3}=\mathrm{LOW}, \mathrm{C}_{4}=\mathrm{HIGH}, \mathrm{X}_{1}=2.4 \mathrm{~V}, \mathrm{X}_{2}=$ open and $\mathrm{F}_{0}=$ LOW. The variations shown in Figure 12 apply to typical values.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

|  | Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{f}_{\text {MAX }}$ | $\mathrm{F}_{0}$ Frequency ( $\mathrm{C}_{\mathrm{X}}$ Connected) ( ( 0 ete 6) | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \\ & \hline \end{aligned}$ | 31 |  |  | MHz |
| 2 | $f_{\text {MAX2 }}$ | $F_{0}$ Frequency ( $\mathrm{C}_{x}=\mathrm{HIGH}$ ) |  |  | 42 |  |  |
| 3 | toffset | $\mathrm{F}_{0}(5)$ to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or WAITACK ( 5 ) | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 0 | 5.0 | 7.5 | ns |
| 4 | toffset | $\mathrm{F}_{0}(\boldsymbol{J})$ to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or WAITACK ( 5 ) |  | 3 | 11.5 | 16 | ns |
| 5 | tSKEW | $\mathrm{C}_{1}(\sim)$ to $\mathrm{C}_{2}(5)$ |  | 0 | 0.5 | 2 | ns |
| 6 | tSKEW | $\mathrm{C}_{1}(\underline{5})$ to $\mathrm{C}_{3}(\sqrt{5})$ |  | 0 | 0.5 | 2 | ns |
| 7 | tSKEW | $\mathrm{C}_{1}(\sqrt{5})$ to $\mathrm{C}_{4}(\sqrt{5})$ Opposite Transition |  | 4 | 7 | 10 | ns |
| 8 | ts | $L_{1}, L_{2}, L_{3}$ to $C_{1}(J)$ |  | 5 |  |  | ns |
| 9 | $\mathrm{t}_{\mathrm{H}}$ | $L_{1}, L_{2}, L_{3}$ to $C_{1}$ ( I ) |  | 9 |  |  | ns |
| 10 | ts | $\mathrm{C}_{\mathrm{x}}$ to $\mathrm{F}_{0}(\underline{5})($ Note 7) |  | 20 | 17 |  | ns |
| 11 | $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{C}_{\mathrm{x}}$ to $\mathrm{F}_{0}(\underline{5}$ ) (Note 7) |  | 0 | -10 |  | ns |
| 12 | ts | $\overline{\text { WAITREQ to } F_{0}(5) \text { ( }}$ ( 0 ete 8) |  | 20 | 17 |  | ns |
| 13 | ${ }_{\text {t }}$ | $\overline{\text { WAITREQ }}$ to $\mathrm{F}_{0}(\sqrt{5}$ ) (Note 8) |  | 0 | -10 |  | ns |
| 14 | ts | $\overline{\text { READY }}$ to Fo (5) (Note 8) |  | 20 | 17 |  | ns |
| 15 | $\mathrm{t}_{\mathrm{H}}$ | $\overline{\text { READY }}$ to Fo ( 5) (Note 8) |  | 0 | -10 |  | ns |
| 16 | ts |  |  | 20 | 14 |  | ns |
| 17 | ts | SSNC, SSNO to Fo ( 5) (Notes 8, 9) |  | 20 | 14 |  | ns |
| 18 | ts | FIRST/LAST to $\mathrm{F}_{0}(\boldsymbol{r})$ ( ( l (ete 10) |  | 25 | 17 |  | ns |
| 19 | ts | $\overline{\mathrm{NIT}}$ ( - ) to $\mathrm{F}_{0}$ ( I) (Note 8) |  | 30 |  |  | ns |
| 20 | tPWL | $\overline{\text { INTT }}$ LOW Pulse Width |  | 15 | 10 |  | ns |
| 21 | tple | INIT to WAITACK |  |  | 16 | 23 | ns |
| 22 | tplH | $\begin{aligned} & \text { Propagation Delay (Note 11) } \\ & \mathrm{X}_{1} \text { to } \mathrm{F}_{0} \end{aligned}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \\ & \hline \end{aligned}$ |  | 13 | 16 | ns |
| 23 | tphL |  |  |  | 14 | 17 | ns |

Notes: 6. The frequency guarantees apply with $\mathrm{C}_{X}$ connected to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or HIGH. The $\mathrm{C}_{\mathrm{X}}$ input load must be considered part of the $50 \mathrm{pF} / 2.0 \mathrm{k} \Omega$ clock output loading
7. These set-up and hold times apply to the FO LOW-to-HIGH transition of the period in which CX goes LOW
8. These inputs are synchronized internally. Failure to meet ts may cause a $1 / F_{0}$ delay but will not cause incorrect operation.
9. These inputs are "debounced" by an internal R-S flip-fiop and are intended to be connected to manual break-before-make switches.
10. FIRST/LAST normally wired HIGH or LOW.
11. Reference point of $T$ offset has been moved forward which has increased $T$ offsets.


PF001080
$X_{1}$ is not a TTL input. It is a crystal connection to an inverting linear oscillator amplifier, and is specified primarily for test convenience.

Figure 11. Am2925 $X_{1}$ Input Characteristics (Typical, $\mathrm{V}_{\mathrm{C}}=5.0 \mathrm{~V}$ ).

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

|  | Parameters | Description | Test Conditions | COMMERCIAL <br> Am2925 |  | $\begin{gathered} \hline \text { MILITARY } \\ \hline \text { Am2925 } \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  | Min | Max | Min | Max |  |
| 1 | ${ }_{\text {max }}$ | $F_{0}$ Frequency ( $\mathrm{C}_{X}$ Connected) (Note 6) | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \\ & \hline \end{aligned}$ | 31 |  | 31 |  | MHz |
| 2 | $\mathrm{f}_{\text {MAX2 }}$ | $F_{0}$ Frequency ( $\mathrm{C}_{\mathrm{X}}=\mathrm{HIGH}$ ) |  |  |  |  |  |  |
| 3 | toffset | $\mathrm{F}_{0}(5)$ to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or WAITACK ( 5 ) | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 8.5 |  | 8.5 | ns |
| 4 | toffsET | $\mathrm{F}_{0}(\underline{5})$ to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or $\overline{\text { WAITACK }}$ ( -5$)$ |  |  | 17.0 |  | 18.0 | ns |
| 5 | tSKEW | $\mathrm{C}_{1}(\sqrt{5})$ to $\mathrm{C}_{2}(\sqrt{5})$ |  |  | 2 |  | 2 | ns |
| 6 | tSkEW | $\mathrm{C}_{1}(\sqrt{5})$ to $\mathrm{C}_{3}(\sqrt{5})$ |  |  | 2 |  | 2 | ns |
| 7 | ${ }^{\text {tSKEW }}$ | $\mathrm{C}_{1}\left(\sqrt{5}\right.$ ) to $\mathrm{C}_{4}$ ( 5 ) Opposite Transition |  |  | 11 |  | 11 | ns |
| 8 | ts | $\mathrm{L}_{1}, \mathrm{~L}_{2}, \mathrm{~L}_{3}$ to $\mathrm{C}_{1}$ ( $J$ ) |  | 6 |  | 7 |  | ns |
| 9 | ${ }_{\text {t }}$ | $L_{1}, L_{2}, L_{3}$ to $C_{1}$ ( 5) |  | 11 |  | 11 |  | ns |
| 10 | ts | $\mathrm{C}_{\mathrm{x}}$ to $\mathrm{F}_{0}(5)$ (Note 7) |  | 25 |  | 25 |  | ns |
| 11 | $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{C}_{\mathrm{X}}$ to $\mathrm{F}_{0}(5)$ (Note 7) |  | 0 |  | 0 |  | ns |
| 12 | ts | WAITREQ to $\mathrm{F}_{0}(\underline{5}$ ) (Note 8) |  | 25 |  | 25 |  | ns |
| 13 | $\mathrm{t}_{\mathrm{H}}$ | $\overline{\text { WAITREQ }}$ to $\mathrm{F}_{0}(\boldsymbol{r})$ (Note 8) |  | 0 |  | 0 |  | ns |
| 14 | ts | READY to $\mathrm{F}_{0}$ ( I) (Note 8) |  | 25 |  | 25 |  | ns |
| 15 | $\mathrm{t}_{\mathrm{H}}$ | READY to $\mathrm{F}_{0}$ ( 5 ) (Note 8) |  | 0 |  | 0 |  | ns |
| 16 | ts | $\overline{\mathrm{RUN}}, \overline{\mathrm{HALT}}$ (5) to $\mathrm{F}_{0}(\sqrt[5]{ }$ ) (Notes 8, 9) |  | 25 |  | 25 |  | ns |
| 17 | ts | SSNC, SSNO to Fo ( 5 ) (Notes 8, 9) |  | 25 |  | 25 |  | ns |
| 18 | ts | FIRST/ $\overline{\text { LAST }}$ to $\mathrm{F}_{0}$ ( I ) ( ( |  | 30 |  | 35 |  | ns |
| 19 | ts | INIT ( I) to $\mathrm{F}_{0}(\sqrt{5})$ (Note 8) |  | 33 |  | 35 |  | ns |
| 20 | tpWL | INIT LOW Pulse Width |  | 20 |  | 25 |  | ns |
| 21 | $\mathrm{t}_{\text {PLH }}$ | INIT to WAITACK |  |  | 25 |  | 27 | ns |
| 22 | tPLH | $\begin{aligned} & \text { Propagation Delay (Note 11) } \\ & \mathrm{X}_{1} \text { to } \mathrm{F}_{0} \end{aligned}$ | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =280 \Omega \end{aligned}$ |  | 23 |  | 26 | ns |
| 23 | tPHL |  |  |  | 21 |  | 23 | ns |

Notes: 6. The frequency guarantees apply with $\mathrm{C}_{X}$ connected to $\mathrm{C}_{1}, \mathrm{C}_{2}, \mathrm{C}_{3}, \mathrm{C}_{4}$ or HIGH. The $\mathrm{C}_{X}$ input load must be considered part of the $50 \mathrm{pF} / 2.0 \mathrm{k} \Omega$ clock output łoading
7. These set-up and hold times apply to the $\mathrm{F}_{0}$ LOW-to-HIGH transition of the period in which CX goes LOW
8. These inputs are synchronized internally. Failure to meet ts may cause a $1 / F_{0}$ delay but will not cause incorrect operation
9. These inputs are "debounced" by an internal R-S flip-flop and are intended to be connected to manual break-before-make switches.
10. FIRST/LAST normally wired HIGH or LOW.
11. Reference point of $T$ offset has been moved forward which has increased $T$ offsets.


Figure 12. Am2925 Icc Normalized vs Frequency (VCC $=5.5 \mathrm{~V}$ ).



WF003080


## Am2927/Am2928

Quad Three-State Bus Transceivers With Clock Enable

## DISTINCTIVE CHARACTERISTICS

- Three-state bus driver outputs can sink 48 mA , and Three-state receiver outputs sink 24 mA - both at 0.5 V max.
- D-type register on drivers
- Latch output on Am2927; Registered output on Am2928
- Output data to input wrap around gating; Input register to output transfer gating with or without driving data bus
- Clock enabled registers
- 3.0V minimum $\mathrm{V}_{\mathrm{OH}}$ for direct interface to MOS microprocessors


## GENERAL DESCRIPTION

The Am2927 and Am2928 are high-performance, lowpower Schottky, quad bus transceivers intended for use in bipolar or MOS microprocessor system applications.
Both devices feature register enable lines which function as clock enables without introducing gate delay in the clock inputs. The four transceivers share common enables, clock, select and three-state control lines.
The Am2927 consists of four D-type edge-triggered flipflops. Each flip-flop output is connected to a three-state data bus driver and separately to the input of a corresponding receiver latch input. The receiver latch can select input from the driver or the data bus. The select line determines the source of input data for the bus driver choosing between input data or data recirculated from the receiver output. The receiver output also has a three-state output buffer.

The combination of the select input, S , the driver input enable, $\overline{E N D R}$, and the receiver latch enable, $\overline{\operatorname{RLE}}$, provide seven different data path operating modes not available in
other transceivers. For example, transmitted data can be stored in the receiver for subsequent retransmission. Also, received data can be output to the system and simultaneously fed back to the driver input.

The Am2928 is similar to the Am2927, but with a D-type edge-triggered register in the receiver and a receiver enable, ENREC, which functions as a common clock enable.

Data from each $D$ input is inverted at the bus output. Likewise, data at the bus input is inverted at the receiver output.

All three-state controls and enable lines are active low (the Am2927 receiver latch is transparent when $\overline{R L E}$ is LOW). The select input, S, determines whether the enabled driver input accepts data from the data input, $D$, or from the corresponding receiver output, Y. Similarly, the select line determines whether the receiver accepts input data from the data bus, or the driver output.

BLOCK DIAGRAM



Note: Pin 1 is marked for orientation
*ENREC for Am2928

*ENREC for Am2928

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

## Am2927/2928 <br>  <br> Blank - Standard processing B - Burn-in <br> Temperature (See Operating Range) <br> C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ <br> Package <br> D-20-pin CERDIP <br> L-28-pin leadless chip carrier <br> X - Dice

| Valid Combinations |  |
| :--- | :--- |
|  | DC, DM |
| Am2927 | LC, LCB, LM, |
| Am2928 | LMB |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## Device type

Quad 3-state Bus Transceivers

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
| 9 | CP | 1 | Clock Pulse to internal registers enters data on the LOW-to-HIGH transition. |
| 11 | $\overline{B E}$ | 1 | Bus Enable. When Bus Enable is LOW the four drivers drive the BUS outputs. |
| $\begin{aligned} & 5,8, \\ & 12,15 \end{aligned}$ | $\begin{aligned} & \overline{B U S}_{0}, \\ & \overline{\text { BUS }}_{1}, \\ & {\overline{B U S_{2}^{2}}}_{3}, \\ & \overline{B U S}_{3} \end{aligned}$ | 1/0 | The four driver outputs and receiver inputs. |
| $\begin{aligned} & 4,7 \\ & 13,16 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{0}, \mathrm{D}_{1}, \\ & \mathrm{D}_{2}, \mathrm{D}_{3} \\ & \hline \end{aligned}$ | 1 | The four driver data inputs inverting from D to BUS. |
| $\begin{aligned} & 3,6 \\ & 14,17 \end{aligned}$ | $\begin{aligned} & Y_{0}, Y_{1}, \\ & Y_{2}, Y_{3}, \end{aligned}$ | 0 | The four receiver data outputs inverting from $\overline{\mathrm{BUS}}$ to Y . |
| 1 | S | 1 | Select input controls data path modes in conjunction with ENDR and $\overline{\text { RLE }}$ (or ENREC). |
| 18 | $\overline{O E}$ | 1 | Output Enable. When Output Enable is LOW the four receiver outputs $Y$ are active. |
| 19 | ENDR | 1 | Driver Enable. Common clock enable for the input register. Allows the data on the D inputs to be loaded into the driver register on the clock LOW-to-High transition. |
| 2 | $\overline{\text { RLE }}$ | 1 | Receiver Latch Enable (Am2927 only). When Receiver Latch Enable is LOW, the four receiver latches are transparent.The latches hold received data when RLE is HIGH. |
| 2 | ENREC | 1 | Receiver Enable (Am2928 only). Common clock enable for the receiver register. Allows the BUS driver or previous receiver data to enter the receiver register on the rising edge of the clock. |

## Am2927 FUNCTION TABLES

Driver Register Control
Receiver Latch Control

| ENDR | S | $\overline{\text { RLE }}$ | Receiver Output |
| :---: | :---: | :---: | :--- |
| X | X | H | Data Latched |
| H | H | L | Driver Register Output at Y output <br> (Latch Transparent) |
| X | L | L | Bus Data at $Y$ Output <br> (Latch Transparent) |
| L | X | L |  |

## Am2928 FUNCTION TABLES

| Driver Register Control |  |  |
| :---: | :---: | :---: |
| ENDR | S | Driver Register |
| H | X | Hold Previous Data |
| L | L | Load from D input |
| L | H | Load from Receiver Register |


| Receiver Register Control |  |  |  |
| :---: | :---: | :---: | :---: |
| $\overline{\text { ENDR }}$ S $\overline{\text { ENREC }}$ | Receiver Output |  |  |
| X | X | H | Hold Previous Data |
| H | H | L | Load from Driver Register |
| X | L | L | Load from $\overline{\text { BUS }}$ |
| L | X | L |  |


| Driver Input From | Am2927 AND Am2928 FUNCTION TABLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Receiver Input From | Control Input Condition |  |  | Signal Flow | $\overline{B E}$ |
|  |  | S | ENDR | * |  |  |
| $\begin{gathered} \text { D } \\ \text { Input } \end{gathered}$ | BUS | L | L | L | $\rightarrow \overline{\text { BUS }}$ | H |
|  | (No Load) | L | L | H | - 만 | L |
| Receiver | BUS | H | L | L | [D $\square^{\text {L }}$ | H |
|  | (No Load) | H | L | H | -回困 | L |
| (No Load) | BUS | L | H | L. | (1) $\square_{\text {R }}$ | H |
|  | Driver | H | H | L | ( $)^{1}$ - $\mathrm{R}^{-}$ | X |
|  | (No Load) | X | H | H | [ㅁ) ${ }^{1}$ | L |

* $\overline{\text { RLE }}$ for Am2917 (asynchronous) or ENREC for Am2928 ( $\Gamma$ ).


## APPLICATION



AF001800
The Am2927 and Am2928 can be used to provide Data Bus, Address Bus and Control Bus Interface in a high-speed bipolar microprocessor system.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Output Current, Into Bus $\qquad$
DC Output Current, Into Outputs
(Except Bus) $\qquad$
$\qquad$ 30 mA
DC Input Current ..............................-30mA to +5.0mA
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Receiver Output HIGH Voltage | $\begin{aligned} & V_{C C}=\mathrm{MIN} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ | MIL, $1 \mathrm{OH}=-2.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, ${ }^{\text {IOH }}=-6.5 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  |  | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ | 3.0 |  |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | $\mathrm{lOL}=24 \mathrm{~mA}$ |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 20 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical MIL  <br> LOW voltage for all inputs  COM'L $^{\prime}$ |  |  |  | 0.8 | Volts |
|  |  |  |  |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \operatorname{liN}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=0.4 V \end{aligned}$ | S, ENDR |  |  | -2.8 | mA |
|  |  |  | All other inputs |  |  | -1.4 |  |
| In | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | S, ENDR |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  | All other inputs |  |  | 50 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| lozh | Off-State Output Current (Receiver Output) | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| Iozl |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |
| Isc | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Receiver | -40 |  | -100 | mA |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Am2927 |  | 150 | 185 | mA |
|  |  |  | Am2928 |  | 153 | 190 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. This parameter is typical of device characterization data and is not tested in production.


Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. This parameter is typical of device characterization data and is not tested in production.

## SWITCHING TEST CIRCUIT



Note: For standard totem-pole outputs, remove $R_{1} ; S_{1}$ and $S_{2}$ closed.
SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2927

| Parameters | Description | Test Conditions (Note 2) | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2927 |  |  | Am2927 |  |  |  |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| tpLH | Driver Clock, CP, to BUS | $\begin{aligned} & C_{L}(B U S)=50 \mathrm{pF} \\ & R_{L}(B U S)=130 \Omega \end{aligned}$ |  | 18 | 26 |  | 18 | 23 |  |
| tPHL |  |  |  | 18 | 26 |  | 18 | 23 |  |
| $\mathrm{t}_{\mathrm{ZH}} \cdot \mathrm{tzL}$ | Bus Enable, $\overline{\mathrm{BE}}$, to $\overline{\mathrm{BUS}}$ |  |  | 14 | 26 | 4 | 14 | 23 | ns |
| $t_{H Z}$ • tLZ |  | $R_{L}=130 \Omega, C_{L}=5 p F$ |  | 12 | 18/30 |  | 12 | 16/23 |  |
| tpw | Min Clock Pulse Width (HIGH or LOW) |  | 18 |  |  | 15 | , |  | ns |
| tPLH | $\overline{\text { BUS }}$ to Receiver Output (Latch Enabled) | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & R_{L}=270 \Omega \end{aligned}$ |  |  | 23 |  | 16 | 20 | ns |
| tPHL |  |  |  |  | 23 |  | 16 | 20 |  |
| tpLH | Latch Enable, $\overline{\mathrm{RLE}}$, to Receiver Output |  | - | \% | 26 |  | 18 | 23 | ns |
| tpHL |  |  | - |  | 26 |  | 18 | 23 |  |
| $\mathrm{t}_{\mathrm{ZH}} \cdot \mathrm{tzL}$ | Output Enable, $\overline{\mathrm{OE}}$, to Receiver Output |  |  |  | 23 |  |  | 21 | ns |
| $\mathrm{thz}^{\text {e }} \mathrm{t}_{\text {LZ }}$ |  | $C_{L}=5 p F, R_{L}=270 \Omega$ |  |  | 21 |  | 14 | 18 |  |
| $t_{s}$ | Driver Enable, ENDR, to Clock | - | 10 |  |  | 9 |  |  | ns |
| $t_{\text {h }}$ |  |  | 3 |  |  | 3 |  |  |  |
| $t_{s}$ | Select S , to Clock $(\overline{\mathrm{RLE}}=\mathrm{HIGH})$ |  | 18 |  |  | 15 |  |  | ns |
| $t_{\text {h }}$ |  |  | 3 |  |  | 2 |  |  |  |
| tPLH | Select S, to Receiver Output | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =270 \Omega \end{aligned}$ |  |  | 26 |  |  | 23 | ns |
| tPHL |  |  |  |  | 35 |  |  | 30 |  |
| $\mathrm{t}_{\text {s }}$ | Data Inputs D, to Clock |  | 9 |  |  | 7 |  |  | ns |
| th |  |  | 5 |  |  | 4 |  |  |  |
| $t_{s}$ | $\overline{\text { BUS }}$ to Latch Enable, $\overline{\text { RLE }}$ |  | 11 |  |  | 10 |  |  | ns |
| $t_{n}$ |  |  | 4 |  |  | 3 |  |  |  |
| Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading. <br> 2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. <br> 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. |  |  |  |  |  |  |  |  |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2928

| Parameters | Description | Test Conditions (Note 2) | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am2928 |  |  | Am2928 |  |  |  |
|  |  |  | Min | $\begin{array}{\|c\|} \hline \text { Typ } \\ \text { (Note 1) } \\ \hline \end{array}$ | Max | Min | $\begin{array}{\|c\|} \hline \text { Typ } \\ \text { (Note } 1) \\ \hline \end{array}$ | Max |  |
| tpLH | Driver Clock, CP, to ${ }^{\text {BUS }}$ | $\begin{aligned} & C_{L}(B U S)=50 p F \\ & R_{L}(B U S)=130 \Omega \end{aligned}$ |  | 18 | 23 |  |  | 26 |  |
| tPHL |  |  |  | 18 | 23 |  |  | 26 |  |
| $\mathrm{t}_{\mathrm{ZH}} \cdot \mathrm{t}_{\mathrm{ZL}}$ | Bus Enable, $\overline{B E}$, to $\overline{B U S}$ |  |  | 14 | 23 |  |  | 26 | ns |
| $\mathrm{t}_{\mathrm{Hz}} \cdot \mathrm{t}_{\mathrm{L}}$ |  | $R_{L}=130 \Omega, C_{L}=5 p F$ |  | 12 | 16/23 |  |  | 18/30 | ns |
| tpLH | Clock, CP, to Receiver Output | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & R_{L}=270 \Omega \end{aligned}$ |  | 18 | 23 |  |  | 26 |  |
| tPHL |  |  |  | 18 | 23 |  |  | 26 |  |
| tpW | Min Clock Pulse Width (HIGH or LOW) |  | 15 | , |  | 18 |  |  | ns |
| $\mathrm{t}_{\mathrm{ZH}} \cdot \mathrm{t}_{\mathrm{ZL}}$ | Output Enable, $\overline{\mathrm{O}}$, to Receiver Output |  |  | 14 | 21 |  |  | 23 | ns |
| $\mathrm{t}_{\mathrm{HZ}} \cdot \mathrm{t}_{\mathrm{L}} \mathrm{z}$ |  |  |  | 21 | 18 |  |  | 26 |  |
| $\mathrm{t}_{\text {s }}$ | Driver Enable, ENDR, to Clock |  | 9 |  |  | 10 |  |  |  |
| $t_{n}$ |  |  | 3 |  |  | 3 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | BUS to Clock (Receiver Register) |  | 7 |  |  | 8 |  |  | ns |
| $\mathrm{th}^{\text {n }}$ |  |  | 4 |  |  | 5 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Receiver Enable, ENMREC, to Clock |  | 8 |  |  | 10 |  |  | ns |
| $t_{n}$ |  |  | 4 |  |  | 5 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | S to Clock |  | 10 |  |  | 12 |  |  | ns |
| $t_{n}$ |  |  | 4 |  |  | 5 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data Inputs, D, to Clock (Driver Register) |  | 7 |  |  | 9 |  |  | ns |
| $t_{\text {h }}$ |  |  | 4 |  |  | 5 |  |  |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

## DISTINCTIVE CHARACTERISTICS

- Powerful, 4-bit slice address controller for memories Useful with both main memory and microprogram memory
Expandable to generate any address length
- Executes 32 instructions

Capable of executing branch and subroutine call and return

- Twelve different relative address instructions Including JUMP-TO-SUBROUTINE relative and RE-TURN-FROM-SUBROUTINE relative
- Built-in condition code input

Sixteen instructions are dependent on external condition control

- Seventeen-level push/pop stack

On-chip storage of subroutine return addresses
nested up to 17 levels deep

- Separate incrementer for program counter A relative address may be computed and PC may be incremented by one on a single cycle


## GENERAL DESCRIPTION

The Am2930 is a four-bit wide Program Control Unit intended to perform machine level addressing functions, although the device can also be used as a microprogram sequencer. Four Am2930's may be interconnected to generate a 16 -bit address ( 64 K words). The Am2930 contains a program counter, a subroutine stack, an auxiliary register, and a full adder for computing relative addresses.

The Am2930 performs five types of instructions. These are: 1) Unconditional Fetch; 2) Conditional Jump; 3) Conditional Jump-to-Subroutine; 4) Conditional Return-from-Subroutine; and 5) Miscellaneous Instructions.

There are four sources of data for the adder which generates the Address outputs $\left(\mathrm{Y}_{0}-\mathrm{Y}_{3}\right)$. These are: 1) the Program Counter (PC); 2) the Stack (S); 3) the auxiliary Register (R); and 4) the Direct inputs (D). Under control of the Instruction inputs $\left(\mathrm{l}_{0}-\mathrm{I}_{4}\right)$, the multiplexers at the adder inputs allow various combinations of these terms to be generated at the three-state $Y$ address outputs. The instruction lines also control the updating of the program counter and the auxiliary register. A condition code input is provided for conditional instructions.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2930
```



```
Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-28-pin CERDIP
F-28-pin flatpak
L-28-pin leadless chip carrier \(X\) - Dice
Device type
Program Control Unit
```

| Valid Combinations |  |
| :--- | :--- |
| Am2930 | DC, DCB, DMB |
|  | FMB |
|  | LC, LMB |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
|  | 10-4 |  | The five Instruction control lines to the Am2930, used to establish data paths and enable internal registers. |
| 22 | IEN | 1 | The instruction Enable input, used to enable and disable internal registers. When IEN is LOW, all internal registers are under control of the Instruction inputs. When IEN is HIGH, all internal registers except R are inhibited from changing state. $R$ is controlled by the $\overline{R E}$ input. The $\overline{\operatorname{EN}}$ input does not affect the combinatorial data paths and the outputs established by the Instruction inputs. |
| 23 | $\bar{C}$ | 1 | The Condition Code input determines whether or not a conditional instruction (Instructions 16-31) is performed. If $\overline{\mathrm{CC}}$ is LOW, the conditional instruction is executed. If $\overline{\mathrm{CC}}$ is HIGH, Fetch PC (Instruction 1) is executed. The CC input may be either HIGH or LOW for unconditional instructions (Instructions 0-15). |
| 21 | $\overline{\text { RE }}$ | 1 | The Register Enable input for the Auxiliary Register ( $R$ ). A LOW on $\overline{R E}$ causes the Auxiliary Register ( $R$ ) to be loaded from the D inputs unless Instruction 8 or 9 is being executed and IEN is LOW. |
| 7 | $\mathrm{C}_{n}$ | 1 | The carry-in to the Full Adder. |
| 13 | $\mathrm{C} n+4$ | 0 | The carry-out of the Full Adder. |
| 16,12 | $\overline{\mathrm{P}}, \overline{\mathrm{G}}$ | 0 | The carry generate and propagate outputs of the Full Adder. |
| 4 | $\mathrm{C}_{\mathrm{i}}$ | 1 | The carry-in to the program counter incrementer. |
| 6 | $\mathrm{C}_{\mathrm{i}+4}$ | 0 | The carry-out of the program counter incrementer. |
|  | $\mathrm{Y}_{0-3}$ | 0 | The four address outputs of the Am2930. These are three-state output lines. When enabled, they display the outputs of the Full Adder. |
| 5 | $\overline{O E}$ | I | Output Enable. When $\overline{O E}$ is HIGH, the $Y$ outputs are OFF (high-impedance); when $\overline{O E}$ is LOW, the $Y$ outputs are active (HIGH or LOW). |
|  | $D_{0-3}$ | 1 | The four Direct inputs which are used as inputs to the Auxiliary Register, the RAM, and the Full Adder, under instruction control. |
| 3 | Empty | 0 | The Empty output is LOW when the Stack is empty. |
| 2 | Full | 0 | The Full output is LOW when the LIFO stack is full - during and after the 17th push operation. |
| 15 | CP | 1 | The clock input to the Am2930. All internal registers (R, SP, PC) and the RAM are updated on the LOW-toHIGH transition of the clock input. |

## BLOCK DIAGRAM



## *INTERNAL

## ARCHITECTURE OF THE Am2930

The Am2930 is a bipolar Program Control Unit intended for use in high-speed microprocessor applications. The device is a cascadable, four-bit slice such that three devices allow addressing of up to 4 K words of memory and four devices allow addressing of up to 64 K words of memory.

As shown in the Block Diagram, the device consists of the following:

1. A full adder with input multiplexers
2. A Program Counter Register with an incrementer and an input multiplexer
3. A $17 \times 4$ Last-In, First-Out (LIFO) stack consisting of an input multiplexer, a $17 \times 4$ RAM, and a Stack Pointer
4. An auxiliary register with an input multiplexer
5. An instruction decoder
6. Four 3-state output buffers on the address outputs

The following paragraphs describe each of these blocks in detail.

## Full Adder

The Full Adder is a binary device with full lookahead carry logic for high-speed addition and provision is made for further lookahead by including both carry propagate $(\bar{P})$ and carry generate $(\bar{G})$ outputs. In slower systems, the carry output $\left(C_{n}+4\right)$ can be connected to the next higher $C_{n}$ to provide ripple block arithmetic. The carry input to the adder $\left(C_{n}\right)$ is internally inhibited during those instructions which do not require an addition to be performed. For these instructions, the data is passed directly through the adder, independent of the state of $\mathrm{C}_{\mathrm{n}}$.
The multiplexers at the $A$ and $B$ inputs of the adder are controlled by the Instruction decoder which selects the appropriate adder inputs for the selected instruction.

## Program Counter

The program counter consists of a register preceded by an incrementer. The Program Counter Register (PC) is a four-bit, edge-triggered, D-type register which is loaded from the incrementer output on the LOW-to-HIGH transition of the clock input (CP) at the end of every instruction.
The incrementer utilizes full lookahead logic for high speed. For cascading devices, the carry output of the incrementer $\left(C_{i}+4\right)$ is connected to the incrementer carry input $\left(C_{i}\right)$ of the next higher device. The output of the incrementer, which is loaded into the PC, is equal to the incrementer input plus $\mathrm{C}_{\mathrm{i}}$. Therefore, it is possible to control the entire cascaded incrementer from the $\mathrm{C}_{\mathrm{i}}$ input of the least significant device; a LOW on the $C_{i}$ input of the least significant device will simply pass the data from the multiplexer output to the inputs of PC; a HIGH will cause the outputs of the multiplexer to be incremented before they are loaded into PC. During three instructions (unconditional Hold and conditional Hold and Suspend when the $\overline{\mathrm{CC}}$ input is LOW), the $\mathrm{C}_{\mathrm{i}}$ input is internally inhibited; therefore, data is passed from the multiplexer output to the PC without incrementing. The multiplexer selects the input to the incrementer from either PC or the output of the Full Adder, depending upon the instruction being executed. During the Jump, Jump-to-Subroutine, and Return instructions, the multiplexer chooses the Full Adder outputs as the input to the incrementer if the $\overline{\mathrm{CC}}$ input is LOW. The Full Adder output is
also selected for the Reset instruction. For all other instructions, the PC is selected as the input to the incrementer.

## $17 \times 4$ LIFO Stack

The $17 \times 4$ LIFO stack consists of a multiplexer, a $17 \times 4$ RAM, and a Stack Pointer (SP) which address the words in the RAM.

The SP always points to the last word written into the RAM (Top of the Stack). The Top of the Stack (S) is available at the output of the RAM.
Data is pushed onto the Top of the Stack from either D or PC. It is written into memory location SP+1. The SP is incremented on the LOW-to-HIGH clock transition at the end of the cycle so that it still points to the last data written into the RAM.
For a Pop operation, the contents of the RAM are not changed, but the SP is decremented at the end of the cycle so that it then points to the new Top of the Stack.
The SP is an up/down counter which changes state on the LOW-to-HIGH transition of the Clock input. It is internally prevented from incrementing when the stack is full and from decrementing when the Stack is empty. When the Stack is full, the RAM write circuitry is also inhibited.
The active LOW Empty output (EMPTY) is LOW when the stack is empty (after the Reset instruction and after the last word has been Popped from the stack); the active LOW Full output (FULL) is LOW either when the stack is full or when the current instruction being executed will fill the stack (during and after the 17th Push).

## Auxiliary Register ( R )

The Auxiliary Register ( $R$ ) can be loaded from either the Direct inputs (D) or the output of the Full Adder. It is loaded on the LOW-to-HIGH transition of the clock input (CP) if the Register Enable input ( $\overline{\mathrm{RE}})$ is LOW or if the Instruction inputs call for it to be loaded. When $\overline{R E}$ is LOW, $R$ is loaded from the $D$ inputs unless the Instruction dictates that $R$ be loaded from the output of the Full Adder.

## Instruction Decoder

The Instruction Decoder generates the signals necessary to establish the data paths and to enable the loading of the PC, $R, S P$, and RAM.
For unconditional instructions, the $\overline{\mathrm{CC}}$ input is not utilized; it may be either HIGH or LOW. For conditional instructions, if $\overline{\mathrm{CC}}$ is LOW, the condition is met and the conditional operation is performed; if $\overline{C C}$ is HIGH, a Fetch PC is performed.

## Output Buffers

The Address outputs $\left(\mathrm{Y}_{0}-\mathrm{Y}_{3}\right)$ are three-state drivers which may be disabled either under Instruction control or by a HIGH on the Output Enable input ( $\overline{\mathrm{OE}})$. Disabling the Y outputs does not affect the execution of instructions inside the Am2930.

## Instruction Enable

When HIGH, the Instruction Enable input (IEN) forces PC and SP into the hold mode and disables the write circuitry to the RAM. The auxiliary register ( $R$ ) is under control of the $\overline{\operatorname{RE}}$ input when IEN is HIGH, independent of the state of the Instruction inputs. The IEN input does not affect the combinatorial data paths or $Y$ outputs in the Am2930. The data paths are selected by the Instruction and $\overline{\mathrm{CC}}$ inputs and are not affected by IEN.

## Am2930 INSTRUCTION SET

The Am2930 Instruction set can be divided into five types of instructions. These are:

- Unconditional Fetches
- Conditional Jumps
- Conditional Jumps-to-Subroutine
- Conditional Returns-from-Subroutine
- Miscellaneous Instructions

The following paragraphs describe each of these types in detail.

## Unconditional Fetches

As can be seen from Table 1, there are nine unconditional Fetch instructions (Instructions 1-9). Under control of the Instruction inputs, the desired value is placed at the $Y$ outputs. For all Fetch instructions, PC is incremented if $\mathrm{C}_{\mathrm{i}}$ of the least significant device is HIGH. For Instructions 1 through 7, the auxiliary register is under control of the RE input. For Instructions 8 and $9, R$ is loaded with $P C$ and $R+D$, respectively. The RAM and Stack Pointer are not changed during a Fetch instruction.

## Conditional Jumps

There are six conditional Jump instructions (Instructions 16 through 21). Under control of the Instruction inputs, the desired value is placed at the Y outputs. Additionally, the value is incremented if $\mathrm{C}_{\mathrm{i}}$ of the least significant device is HIGH and loaded into PC. During these instructions, $R$ is controlled by $\overline{R E}$. The RAM and Stack Pointer are not changed during these instructions. The above operations are performed if the $\overline{\mathrm{CC}}$ input is LOW; if $\overline{\mathrm{CC}}$ is HIGH, a Fetch PC operation is performed.

## Conditional Jumps-to-Subroutine

There are six conditional Jump-to-Subroutine instructions (Instructions 22 through 27). Under control of the Instruction inputs, the desired value is placed on the $Y$ outputs. On the rising edge of the clock the value is incremented* and loaded into PC; PC is loaded into the RAM at location SP +1, and SP is incremented.
As with Conditional Jump Instructions, R is controlled by $\overline{\mathrm{RE}}$ and whether the Jump-to-Subroutine or Fetch PC is performed depends upon the state of the $\overline{\mathrm{CC}}$ input.

## Conditional Returns-from-Subroutine

There are two conditional Return-from-Subroutine instructions (Instructions 28 and 29). Under control of the instruction inputs, either $S$ or $S+D$ is placed at the $Y$ outputs. Additionally , the selected value is incremented* and loaded into PC and SP is decremented at the end of the cycle (on the rising edge of the clock).

As with the Condition Jump and Jump-to-Subroutine Instructions, $R$ is controlled by $\overline{R E}$ and whether the Return-fromSubroutine or Fetch PC is performed depends upon the state of the $\overline{\mathrm{CC}}$ input.

## Miscellaneous Instructions

Each of the nine miscellaneous instructions is described individually.

## Reset (Instruction 0)

The Reset instruction forces the $Y$ outputs to zero, loads either zero or one into PC, depending upon the $\mathrm{C}_{\mathrm{j}}$ input of the least significant device, and resets SP. The RAM is unchanged and $R$ is controlled by $\overline{R E}$.

## Load R (Instruction 10)

This instruction loads the data on the D inputs into R. PC is either incremented or held depending upon $\mathrm{C}_{\mathrm{i}}$ of the least significant device. The SP and RAM are not changed.

## Push PC (Instruction 11)

This instruction is the same as Fetch PC except that PC is loaded into RAM and SP is incremented at the end of the cycle; i.e., the current PC is Pushed onto the stack.

## Push D (Instruction 12)

This instruction is the same as Fetch PC except that $D$ is loaded into the RAM and SP is incremented at the end of the cycle; i.e., external data is Pushed onto the stack.

## Pop S (Instruction 13)

This instruction places the Top of the Stack (S) at the $Y$ outputs and decrements SP at the end of the cycle. The PC is incremented if the $C_{i}$ input of the least significant device is HIGH. R is controlled by $\overline{\mathrm{RE}}$.

## Pop PC (Instruction 14)

This instruction is the same as Fetch PC except SP is decremented at the end of the cycle, causing the data at the top of the stack to be lost.

## Hold (Instruction 15)

This instruction places $P C$ at the $Y$ outputs and inhibits any change in PC, SP, and RAM. R is controlled by $\overline{R E}$.

## Conditional Hold (Instruction 30)

This instruction is the same as Hold except $\overline{\mathrm{CC}}$ must be LOW. If $\overline{\mathrm{CC}}$ is HIGH , the Fetch PC instruction is performed.

## Suspend (Instruction 31)

The Suspend instruction is the same as the Conditional Hold instruction except the Y outputs are forced into the highimpedance state if $\overline{\mathrm{CC}}$ is LOW.
*If $\mathrm{C}_{\mathrm{i}}$ of the least significant device is HIGH.


Notes: 1. When IEN is HIGH, the $\mathrm{Y}_{0}-\mathrm{Y}_{3}$ outputs contain the same data as when $\overline{\mathrm{IEN}}$ is LOW, as determined by $\mathrm{I}_{0}-\mathrm{I}_{4}$ and $\overline{\mathrm{CC}}$. 2. $\mathbf{Z}=$ High impedance state (outputs "OFF').
3. $-=$ No change.

## APPLICATIONS

The Am2930 is shown in a typical 16-bit, 2900 Microcomputer design in Figure 1.

The Direct inputs (D) of the Am2930 are derived from one of three sources: the Instruction Register, the Data Bus via a 16bit register (two Am2920 8-bit Registers), and the output of the Am2901's via a 16 -bit register.

The Address outputs ( Y ) of the Am2930 are loaded into a 16bit Memory Address Register (MAR). Although the MAR is shown as part of the CPU, in some applications it may be part of the memory.

An Am2902 High-Speed Lookahead Carry Generator is utilized to provide high-speed relative and indexed addressing. In
slower systems, the $C_{n}+4$ output can be wired to the next higher $\mathrm{C}_{\mathrm{n}}$ input to provide ripple block arithmetic.
The Condition Code input ( $\overline{\mathrm{CC}}$ ) is derived from the same condition code multiplexer which generates the condition code input for the microprogram sequencer.
The control inputs of the Am2930 ( $\mathrm{I}_{0-4}, \overline{\mathrm{EN}}, \overline{\mathrm{RE}}, \overline{\mathrm{OE}}$, and $\mathrm{C}_{\mathrm{i}}$ and $C_{n}$ of the least significant device) are shown originating at the Pipeline Register. Although it is not shown in Figure 1, it is possible to share the Pipeline Register outputs which go to these pins with another device. This can be accomplished if both the Am2930 and the other device do not operate on the same microcycle. Forcing the IEN input HIGH inhibits any changes in the Am2930 internal registers, independent of the state of these seven inputs. This allows the Am2930 to be placed in a hold mode while the other device is using the same Pipeline Register outputs as control signals.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ .-0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ ..-0.5V to $+V_{C C}$ max
DC Input Voltage $\qquad$ .-0.5 V to +5.5 V
DC Output Current, Into Outputs $\qquad$ .............. 30 mA
DC Input Current .............................. -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage 4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. These input levels provide no guaranteed noise immunity and should only be tested in a static-, noise-free environment.
5. Minimum ICC is at maximum temperature.

## SWITCHING TEST CIRCUIT

A. THREE STATE OUTPUTS
B. NORMAL OUTPUTS


Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $\mathrm{S}_{1}, \mathrm{~S}_{2}, \mathrm{~S}_{3}$ are closed during function tests and all $A C$ tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpzH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $C_{L}-5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2930

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :--- | :---: | :---: | :---: |
| 2 | FULL | B | 300 | 2 K |
| 3 | $\overline{\text { EMPTY }}$ | B | 300 | 2 K |
| 6 | $\mathrm{C}_{\mathrm{i}}+4$ | B | 240 | 1.5 K |
| $8-11$ | $\mathrm{Y}_{0-3}$ | A | 240 | 1 K |
| 12 | $\overline{\mathrm{G}}$ | B | 240 | 1.5 K |
| 13 | $\mathrm{C}_{\mathrm{n}}+4$ | B | 240 | 1.5 K |
| 16 | P | B | 300 | 2 K |

For additional information on testing, see section
'Guidelines on Testing Am2900 Family Devices.'

## Am2930 SWITCHING CHARACTERISTICS

Tables $\mathrm{A}, \mathrm{B}, \mathrm{C}$ and D define the timing characteristics of the Am 2930 . Measurements are made at 1.5 V with $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ and $\mathrm{V}_{1 H}=3.0 \mathrm{~V}$. For three-state disable tests, $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ and measurement is to 0.5 V change on output voltage level.
I. GUARANTEED PERFORMANCE OVER COMMERCIAL OPERATING RANGE

$$
V_{C C}=4.75 \text { to } 5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C}
$$

TABLE IA Clock Characteristics.

| Minimum Clock LOW Time | 31 ns |
| :--- | :--- |
| Minimum Clock HIGH Time | 33 ns |

TABLE IC
Combinational Propagation Delays.
All in ns.
Outputs fully loaded. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.

|  | To Output |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From <br> Input | $\mathbf{Y}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $\mathbf{C}_{\mathbf{n}+\mathbf{4}}$ | $\mathbf{C}_{\mathbf{i}}+\mathbf{4}$ <br> $\mathbf{I}_{\mathbf{4}}=\mathbf{L}$ | $\mathbf{C}_{\mathbf{i}+\mathbf{4}}$ <br> $\mathbf{I}_{\mathbf{4}}=\mathbf{H}$ | $\overline{\text { Full }}$ | $\overline{\text { Empty }}$ |
| $\mathrm{I}_{\mathbf{4}-0}$ | 81 | 67 | 77 | 80 | 91 | 69 | - |
| $\overline{\mathrm{CC}}$ | 63 | 45 | 55 | - | 72 | 42 | - |
| $\mathrm{C}_{\mathrm{n}}$ | 32 | - | 25 | - | 45 | - | - |
| $\mathrm{C}_{\mathrm{i}}$ | - | - | - | 22 | 22 | - | - |
| CP | 69 | 53 | 61 | 43 | 78 | 55 | 55 |
| D | 49 | 33 | 40 | - | 59 | - | - |
| $\overline{\mathrm{IEN}}$ | - | - | - | - | - | 40 | - |

TABLE IB
Output Enable/Disable Times. All in ns.
$C_{L}=5.0 \mathrm{pF}$ for output disable tests.

| From | To | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 27 | 26 |
| CC <br> (Note 1) | Y | 55 | 37 |
| $I_{4-0}$ <br> (Note 1) | Y | 80 | 55 |

Note 1: "Suspend" instruction.
TABLE ID
Set-up and Hold Times. All in ns.
All relative to clock
LOW-to-HIGH transition.

| Input | CP: |  |
| :---: | :---: | :---: |
|  | Set-up Time | Hold Time |
| $1_{4-0}$ | 114 | 0 |
| $\overline{C C}$ | 75 | 0 |
| IEN | 55 | 0 |
| $\mathrm{C}_{\mathrm{n}}$ | 43 | 0 |
| $\mathrm{C}_{\mathrm{i}}$ | 32 | 5 |
| $\begin{aligned} & \hline \text { D }(\overline{\mathrm{RE}}=\mathrm{L} \\ & \left.\mathrm{I}_{4-0}=0-8 \text { or } 10-15\right) \\ & \hline \end{aligned}$ | 25 | 2 |
| $\overline{R E}$ | 24 | 4 |

## II. GUARANTEED PERFORMANCE OVER MILITARY OPERATING RANGE <br> $\mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$

TABLE IIA Clock Characteristics.

| Minimum Clock LOW Time | 35 ns |
| :--- | :--- |
| Minimum Clock HIGH Time | 35 ns |

TABLE IIC
Combinational Propagation Delays.
All in ns.
Outputs fully loaded. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.

|  | To Output |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From <br> Input | $\mathbf{Y}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | $\mathbf{C}_{\mathbf{n}+\mathbf{4}}$ | $\mathbf{C}_{\mathbf{I}+\mathbf{4}}$ <br> $\mathbf{I}_{\mathbf{4}}=\mathbf{L}$ | $\mathbf{C}_{\mathbf{I}+\mathbf{4}}$ <br> $\mathbf{I}_{\mathbf{4}}=\mathbf{H}$ | $\overline{\text { Full }}$ | $\overline{\text { Empty }}$ |  |
| $\mathrm{I}_{4-0}$ | 88 | 74 | 82 | 87 | 97 | 78 | - |  |
| $\overline{\mathrm{CC}}$ | 68 | 52 | 60 | - | 78 | 47 | - |  |
| $\mathrm{C}_{\mathrm{n}}$ | 37 | - | 30 | - | 46 | - | - |  |
| $\mathrm{C}_{\mathrm{i}}$ | - | - | - | 23 | 23 | - | - |  |
| CP | 74 | 58 | 66 | 48 | 84 | 60 | 60 |  |
| D | 55 | 38 | 45 | - | 65 | - | - |  |
| $\overline{\mathrm{IEN}}$ | - | - | - | - | - | 45 | - |  |


| Input | CP: |  |
| :---: | :---: | :---: |
|  | Set-up Time | Hold Time |
| $\mathrm{I}_{4-0}$ | 124 | 0 |
| $\overline{\mathrm{CC}}$ | 80 | 0 |
| IEN | 69 | 0 |
| $\mathrm{C}_{\mathrm{n}}$ | 52 | 0 |
| $\mathrm{C}_{\mathrm{i}}$ | 37 | 5 |
| $\begin{aligned} & D(\overline{R E}=L \\ & \left.I_{4-0}=0-8 \text { or } 10-15\right) \end{aligned}$ | 30 | 2 |
| D (All other conditions) | 72 | 2 |
| $\overline{\text { RE }}$ | 29 | 4 |

TABLE IIB
Output Enable/Disable Times.
All in ns.
$\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

| From | To | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | Y | 32 | 31 |
| CC <br> (Note 1) | Y | 60 | 42 |
| $\mathrm{I}_{4-0}$ <br> (Note 1) | Y | 85 | 60 |

Note 1: "Suspend" instruction.
TABLE IID
Setup and Hold Times. All in ns.
All relative to clock
LOW-to-HIGH transition.

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current when the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-3 \mathrm{~ns}$. Inductance in the ground
cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\mathrm{IL}}$ or $\mathrm{V}_{\mathbb{I}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

INPUT/OUTPUT CURRENT INTERFACE CONDITIONS
Driven Inputs


IC000570


Note: $\mathrm{C}_{\mathrm{i}}$ input is connected to both configurations in parallel.

Driving Outputs


Note: Actual current flow direction shown.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902A | Carry Look-Ahead Generator |
| Am2904 | Status and Shift Control Unit |
| Am2920 | 8-Bit Register |
| Am2922 | Condition Code MUX |

For applications information, see Chapter V of Bit Slice Microprocessor Design, Mick \& Brick, McGraw Hill Publications.

## Am2932

Program Control Unit/Push-Pop Stack

## DISTINCTIVE CHARACTERISTICS

- Powerful, 4-bit slice address controller for memories Useful with both main memory and microprogram memory
Expandable to generate any address length
- Executes 16 instructions

Automatic generation of address and update of program counter for fetch cycles, branch cycles, and subroutine call and return

- Eight relative address instructions Including Jump relative and Jump-to-Subroutine relative
- Seventeen-level push/pop stack On-chip storage of subroutine return addresses nested up to 17 levels deep
- Separate incrementer for program counter A relative address may be computed and PC may be incremented by one on a single cycle


## GENERAL DESCRIPTION

The Am2932 is a four-bit wide Program Control Unit intended to perform machine level addressing functions, although the device can also be used as a microprogram sequencer. Four Am2932s may be interconnected to generate a 16-bit address ( 64 K words). The Am2932 contains a program counter, a subroutine stack, an auxiliary register, and a full adder for computing relative addresses.

The Am2932 performs five types of instructions. These are: 1. Fetch; 2. Jump; 3. Jump-to-Subroutine; 4. Return-fromSubroutine; and 5. Miscellaneous Instructions.

There are four sources of data for the adder which generates the Address outputs ( $\mathrm{Y}_{0}-\mathrm{Y}_{3}$ ). These are: 1. the Program Counter (PC); 2. the Stack (S); 3. the auxiliary Register (R); and 4. the Direct inputs (D). Under control of the Instruction inputs ( $\mathrm{I}_{0}^{-} \mathrm{I}_{3}$ ), the multiplexers at the adder inputs allow various combinations of these terms to be generated at the three-state $Y$ address outputs. The instruction lines also control the updating of the program counter and the auxiliary register.

## *INTERNAL



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am2932


Package
D-20-pin CERDIP
$\mathrm{L}-28$-pin leadless chip carrier
$\mathrm{X}-$ Dice
Device type
Program Control Unit

| Valid Combinations |  |
| :--- | :--- |
| Am2932 | DC, DCB, DMB <br>  <br>  |
|  |  |,

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## ARCHITECTURE OF THE Am2932

The Am2932 is a bipolar Program Control Unit intended for use in high-speed microprocessor applicátions. The device is a cascadable, four-bit slice such that three devices allow addressing of up to 4 K words of memory and four devices allow addressing of up to 64 K words of memory.
As shown in the Block Diagram, the device consists of the following:

1. A full adder with input multiplexers
2. A Program Counter Register with an incrementer and an input multiplexer
3. A $17 \times 4$ Last-In, First-Out (LIFO) stack consisting of an input multiplexer, a $17 \times 4$ RAM, and a Stack Pointer
4. An auxiliary register with an input multiplexer
5. An instruction decoder
6. Four 3-state output buffers on the address outputs

The following paragraphs describe each of these blocks in detail.

## Full Adder

The Full Adder is a binary device with full lookahead carry logic for high-speed addition. The carry output $\left(C_{n}+4\right)$ can be connected to the next higher $\mathrm{C}_{\mathrm{n}}$ to provide ripple block arithmetic. The carry input to the adder $\left(\mathrm{C}_{n}\right)$ is internally inhibited during those instructions which do not require an addition to be performed. For these instructions, the data is passed directly through the adder, independent of the state of Cn.
The multiplexers at the $A$ and $B$ inputs of the adder are controlled by the Instruction decoder which selects the appropriate adder inputs for the selected instruction.

## Program Counter

The program counter consists of a register preceded by an incrementer. The Program Counter Register (PC) is a four-bit, edge-triggered, D-type register which is loaded from the incrementer output on the LOW-to-HIGH transition of the clock input (CP) at the end of every instruction.
The incrementer utilizes full lookahead logic for high speed. For cascading devices, the carry output of the incrementer $\left(C_{i}+4\right)$ is connected to the incrementer carry input $\left(C_{i}\right)$ of the next higher device. The output of the incrementer, which is loaded into the PC, is equal to the incrementer input plus $\mathrm{C}_{\mathrm{i}}$. Therefore, it is possible to control the entire cascaded incrementer from the $\mathrm{C}_{\mathrm{i}}$ input of the least significant device; a LOW on the $C_{i}$ input of the least significant device will simply pass the data from the multiplexer output to the inputs of PC ; a HIGH will cause the outputs of the multiplexer to be increment-
ed before they are loaded into 'PC. During the suspend instruction, the $C_{i}$ input is internally inhibited; therefore, data is passed from the multiplexer output to the PC without incrementing. The multiplexer selects the input to the incrementer from either PC or the output of the Full Adder, depending upon the instruction being executed. During the Jump, Jump-toSubroutine, and Return instructions, the multiplexer chooses the Full Adder outputs as the input to the incrementer. The Full Adder output is also selected for the Reset instruction. For all other instructions, the PC is selected as the input to the incrementer.

## $17 \times 4$ LIFO Stack

The $17 \times 4$ LIFO stack consists of a multiplexer, a $17 \times 4$ RAM, and a Stack Pointer (SP) which address the words in the RAM.
The SP always points to the last word written into the RAM (Top of the Stack). The Top of the Stack ( S ) is available at the output of the RAM.

Data is pushed onto the Top of the Stack from either D or PC. It is written into memory location $S P+1$. The SP is incremented on the LOW-to-HIGH clock transition at the end of the cycle so that it still points to the last data written into the RAM.

For a Pop operation, the contents of the RAM are not changed, but the SP is decremented at the end of the cycle so that it then points to the new Top of the Stack.

The SP is an up/down counter which changes state on the LOW-to-HIGH transition of the Clock input. It is internally prevented from incrementing when the stack is full and from decrementing when the Stack is empty. When the Stack is full, the RAM write circuitry is also inhibited.
The active LOW Full output ( $\overline{\mathrm{FULL}}$ ) is LOW either when the stack is full or when the current instruction being executed will fill the stack (during and after the 17th Push).

## Auxiliary Register (R)

The Auxiliary Register (R) can be loaded from either the Direct inputs (D) or the output of the Full Adder. It is loaded on the LOW-to-HIGH transition of the clock input (CP) if the Instruction inputs call for it to be loaded.

## Instruction Decoder

The Instruction Decoder generates the signals necessary to establish the data paths and to enable the loading of the PC, R, SP, and RAM.

## Output Buffers

The Address outputs $\left(Y_{0}-Y_{3}\right)$ are three-state drivers which may be disabled under Instruction control.

## Am2932 INSTRUCTION SET

The Am2932 Instruction set can be divided into five types of instructions. These are:

- Fetches
- Jumps
- Jumps-to-Subroutine
- Return-from-Subroutine
- Miscellaneous Instructions

The following paragraphs describe each of these types in detail.

## Fetches

As can be seen from Table $I$, there are four Fetch instructions (Instructions 4, 8, 9, 10). Under control of the Instructions
inputs, the desired value is placed at the Y outputs. For all Fetch instructions, $P C$ is incremented if $\mathrm{C}_{\mathrm{i}}$ of the least significant device is HIGH. For Instruction 10, R is loaded with PC. The RAM and Stack Pointer are not changed during a Fetch instruction.

## Jumps

There are three Jump instructions (Instructions 5, 11, 12). Under control of the Instruction inputs, the desired value is placed at the $Y$ outputs. Additionally, the value is incremented if $\mathrm{C}_{\mathrm{i}}$ of the least significant device is HIGH and loaded into PC. The RAM, Stack Pointer and R are not changed during these instructions.

## Jumps-to-Subroutine

There are two Jump-to-Subroutine instructions (Instructions 13 and 14). Under control of the Instruction inputs, the desired value is placed on the $Y$ outputs. On the rising edge of the clock the value is incremented* and loaded into PC; PC is loaded into the RAM at location SP +1 ; and $S P$ is incremented.

During these instructions, $R$ is not changed.

## Return-from-Subroutine (Instruction 7)

Under control of the instruction inputs, $S$ is placed at the $Y$ outputs. Additionally, the value of $S$ is incremented* and loaded into PC and SP is decremented at the end of the cycle (on the rising edge of the clock). During this instruction, R is not changed.

## Miscellaneous Instructions

Each of the nine miscellaneous instructions is described individually.

## Reset (Instruction 0)

The Reset instruction forces the $Y$ outputs to zero, loads either zero or one into PC, depending upon the $C_{i}$ input of the least significant device, and resets SP. The RAM and R are unchanged.

## Load R (Instruction 15)

This instruction loads the data on the $D$ inputs into R. PC is either incremented or held depending upon $C_{j}$ of the least significant device. The SP and RAM are not changed.

## Push PC (Instruction 6)

This instruction is the same as Fetch PC except that PC is loaded into RAM and SP is incremented at the end of the cycle; i.e., the current PC is Pushed onto the stack.

## Push D (Instruction 2)

This instruction is the same as Fetch PC except that $D$ is loaded into the RAM and SP is incremented at the end of the cycle; i.e., external data is Pushed onto the stack.

## Pop S (Instruction 3)

This instruction places the Top of the Stack (S) at the $Y$ outputs and decrements SP at the end of the cycle. The PC is incremented if the $C_{i}$ input of the least significant device is HIGH. R is not changed.

## Suspend (Instruction 1)

The Suspend instruction inhibits any change in PC, SP, R and RAM and forces the $Y$ outputs into the high impedance state.

## TABLE I-Am2932 INSTRUCTION SET

| Instruction Number | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | 11 | $\mathrm{I}_{0}$ | Mnemonic | Instruction | $\mathrm{Y}_{0}-\mathrm{Y}_{3}$ | Next State (after CP F) - Note 2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | PC | R | RAM | SP |
| 0 | L | L | L | L | PRST | RESET | '0' | ' 0 ' + C | - | - | Reset |
| 1 | L | L | L | H | PSUS | SUSPEND | Z (Note 1) |  | - | - | - |
| 2 | L . | L | H | L | PSHD | PUSH D | PC | $\mathrm{PC}+\mathrm{Ci}_{\mathrm{i}}$ | - | $\mathrm{D} \rightarrow$ Loc $\mathrm{SP}+1$ | SP + 1 |
| 3 | L | L | H | H | POPS | POP S |  | $\mathrm{PC}+\mathrm{C}_{\mathrm{i}}$ | - | - | SP-1 |
| 4 | L | H | L | L | FPC | FETCH PC | PC | $\mathrm{PC}+\mathrm{Ci}_{\mathrm{i}}$ | - | - | - |
| 5 | L | H | L | H | JMPD | JUMP D | D | $\mathrm{D}+\mathrm{C}_{\mathrm{i}}$ | - | PC ${ }^{-} \mathrm{SP}+1$ | - |
| 6 | L | H | H | L | PSHP | PUSH PC | PC | $\mathrm{PC}+\mathrm{C}_{\mathrm{i}}$ | - | PC $\rightarrow$ Loc SP + 1 | SP + 1 |
| 7 | L | H | H | H | RTS | RETURN S | S | $\mathrm{S}+\mathrm{Ci}_{\mathrm{i}}$ | - | P-Loc SP+1 | SP-1 |
| 8 | H | L | L | L | FR | FETCH R | R | $\mathrm{PC}+\mathrm{C}_{\mathrm{i}}$ | - | - | - |
| 9 | H | $L$ | L | H | FPR | FETCH PC + R | $\mathrm{PC}+\mathrm{R}+\mathrm{C}_{\mathrm{n}}$ | $\mathrm{PC}+\mathrm{C}_{\mathrm{i}}$ | - | - | - |
| 10 | H | $L$ | H | L | FPLR | FETCH PC $\rightarrow$ R | PC | $\mathrm{PC}+\mathrm{Ci}_{\mathrm{i}}$ | PC | - | - |
| 11 | H | L | H | H | JMPR | JUMP R |  | $\mathrm{R}+\mathrm{Ci}_{\mathrm{i}}$ | - | - | - |
| 12 | H | H | L | L | JPPR | JUMP PC + R | $P C+R+C n$ | $\mathrm{PC}+\mathrm{R}+\mathrm{C}_{\mathrm{n}}+\mathrm{Ci}_{i}$ | - | PC - | - ${ }^{-}$ |
| 13 | H | H | L | H | JSBR | JSB R |  | $\mathrm{R}+\mathrm{Ci}_{\mathrm{i}}$ | - | $\mathrm{PC} \rightarrow$ Loc $\mathrm{SP}+1$ | SP + 1 |
| 14 | H | H | H | L | JSPR | JSB PC + R | $P C+R+C_{n}$ | $\mathrm{PC}+\mathrm{R}+\mathrm{C}_{\mathrm{n}}+\mathrm{C}_{\mathrm{i}}$ | - | $P C \rightarrow$ Loc $S P+1$ | SP + 1 |
| 15 | H | H | H | H | PLDR | LOAD R | PC | $\mathrm{PC}+\mathrm{C}_{\mathrm{i}}$ | D | + | - |

Notes: 1. $\mathrm{Z}=$ = High impedance state (outputs "OFF'). 2. $-=$ No change

PC - Program Counter
SP - Stack Pointer
S - Stack Top D - Direct Inputs
*If $C_{i}$ of the least significant device is HIGH.

## APPLICATIONS

The Am2932 is shown in a typical 16-bit, 2900 Microcomputer design in Figure 1.

The Direct inputs (D) of the Am2932 are derived from one of three sources: the Instruction Register, the Data Bus via a 16bit register (two Am2920 8-bit Registers), and the output of the Am2901Cs via a 16-bit register.

The Address outputs $(\mathrm{Y})$ of the Am2932 are passed to the address bus.

The $C_{n+4}$ output can be wired to the next higher $C_{n}$ input to provide ripple block arithmetic.

The control inputs of the Am2932 ( $\mathrm{I}_{0-3}, \mathrm{C}_{\mathrm{i}}$ and $\mathrm{C}_{n}$ of the least significant device) are shown originating at the Pipeline Register.

For applications information, see Chapter V of Bit Slice
Microprocessor Design, Mick \& Brick, McGraw Hill Publications.


Figure 1. Typical 16-Bit Microcomputer Design.


| $\mathbf{l}_{\mathbf{1}}$ | $\mathbf{l}_{\mathbf{0}}$ | INSTRUCTION | Y OUTPUTS |
| :--- | :--- | :--- | :--- |
| L | L | RESET | '0' |
| L | $H$ | SUSPEND | Z (HIGH IMPEDANCE) |
| $H$ | L | PUSH D | SEE NOTE 1 |
| $H$ | $H$ | POP S | TOP OF STACK |



This figure shows the use of four Am2932s as a 17 -word by 16 -bit LIFO stack by grounding $\mathrm{I}_{2}$ and $\mathrm{I}_{3}$. The effect of grounding $l_{3}$ is shown in Figure 3.

Note 1. During this instruction, PC is placed on the $Y$ outputs. If $C_{i}$ is held LOW, the $Y$ outputs will be LOW for this instruction after the device is initialized with a Reset instruction.

Figure 2. Application of Four Am2932s as a 17-Word by 16-Bit LIFO Stack.

AF002030

| $\mathbf{I}_{\mathbf{2}}$ | $\mathbf{I}_{\mathbf{1}}$ | $\mathbf{I}_{\mathbf{0}}$ | INSTRUCTION |
| :--- | :--- | :--- | :--- |
| $L$ | L | L | RESET |
| L | L | $H$ | SUSPEND |
| L | $H$ | L | PUSH D |
| L | $H$ | $H$ | POP S |
| $H$ | $L$ | $L$ | FETCH PC |
| $H$ | $L$ | $H$ | JUMP D |
| $H$ | $H$ | L | PUSH PC |
| $H$ | $H$ | $H$ | RETURN S |




AF002000

Figure 3. Equivalent Circuit of Am2932 with $\mathbf{I}_{3}$ Grounded.

## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature ........................ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$(Ambient) Temperature Under Bias ...... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Supply Voltage to Ground Potential Continuous |  |
| DC Voltage Applied to Outputs For |  |
| Input Voltage | -0.5 V to +5.5 |
| Output Current, | 30 |
|  |  |

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................. $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ....................... +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second
4. These input levels provide no guaranteed noise immunity and should only be tested in a static-, noise-free environment.
5. Minimum $I_{\mathrm{CC}}$ is at maximum temperature.

## SWITCHING TEST CIRCUIT

A. THREE STATE OUTPUTS
B. NORMAL OUTPUTS


TCR01370

TCR01350

$$
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{~K}}}
$$

$$
\begin{gathered}
\mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{1 \mathrm{OH}} \\
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}^{+}+\mathrm{V}_{\mathrm{OL}}}{\mathrm{R}_{2}}}
\end{gathered}
$$

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $\mathrm{S}_{1}, \mathrm{~S}_{2}, \mathrm{~S}_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpzH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disabled tests.

TEST OUTPUT LOADS FOR Am2932

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\cdot \mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 2 | FULL | B | 300 | 2 K |
| 4 | $\mathrm{C}_{\mathrm{i}}+4$ | B | 240 | 1.5 K |
| $6-9$ | $\mathrm{Y}_{0-3}$ | A | 240 | 1 K |
| 12 | $\mathrm{C}_{\mathrm{n}}+4$ | B | 240 | 1.5 K |

For additional information on testing, see section
"Guidelines on Testing Am2900 Family Devices.'"

## Am2932 SWITCHING CHARACTERISTICS

Tables A, B, C and D define the timing characteristics of the Am2932. Measurements are made at 1.5 V with $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}$. For three-state disable tests, $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ and measurement is to 0.5 V change on output voltage level.

## I. GUARANTEED PERFORMANCE OVER COMMERCIAL OPERATING RANGE.

$$
\mathrm{V}_{\mathrm{CC}}=4.75 \text { to } 5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0 \text { to }+70^{\circ} \mathrm{C}
$$

TABLE IA Clock Characteristics.

| Minimum Clock LOW Time | 31 ns |
| :---: | :---: |
| Minimum Clock HIGH Time | 33 ns |

TABLE IB
Output Enable/Disable Times.
All in ns.
$C_{L}=5.0 \mathrm{pF}$ for output disable tests.

| From | To | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $I_{3-0}$ | $Y$ | 80 | 55 |

TABLE IC
Combinational Propagation Delays.
All in ns.
Outputs fully loaded. $C_{L}=50 \mathrm{pF}$.

|  | To Output |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| From Input | Y | $\mathrm{C}_{\mathbf{i}+4}$ | $\begin{gathered} C_{i+4} \\ \text { (Note 1) } \end{gathered}$ | $\begin{gathered} C_{i+4} \\ (\text { Note 2) } \end{gathered}$ | Full |
| $\mathrm{I}_{3-0}$ | 81 | 77 | 91 | 80 | 69 |
| $\mathrm{C}_{n}$ | 32 | 25 | 45 | - | - |
| $\mathrm{C}_{i}$ | - | - | 22 | 22 | - |
| CP | 69 | 61 | 78 | 43 | 55 |
| D | 39 | - | 50 | - | - |

TABLE ID
Set-up and Hold Times.
All in ns.
All relative to clock
LOW-to-HIGH transition.

| Input | CP: |  |
| :--- | :---: | :---: |
|  | Set-up <br> Time | Hold <br> Time |
| $C_{n}$ | 43 | 0 |
| $C_{i}$ | 32 | 5 |
| $D$ | 52 | 2 |
| $I_{3}-0$ | 114 | 0 |

Note: 1. Instructions 5, 7, 11, 12, 13, 14.
2. All instructions except $5,7,11,12,13,14$.

## II. GUARANTEED PERFORMANCE OVER MILITARY OPERATING RANGE.

$$
V_{C C}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{C}}=-55 \text { to }+125^{\circ} \mathrm{C}
$$

TABLE IIA
Clock Characteristics.

| Minimum Clock LOW Time | 35 ns |
| :--- | :--- |
| Minimum Clock HIGH Time | 35 ns |

TABLE IIB
Output Enable/Disable Times.
All in ns.
$\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

| From | To | Enable | Disable |
| :---: | :---: | :---: | :---: |
| $I_{3-0}$ | Y | 85 | 60 |

TABLE IIC
Combinational Propagation Delays.
All in ns.
Outputs fully loaded. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$.

|  | To Output |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From <br> Input | $\mathbf{Y}$ | $\mathbf{C}_{\boldsymbol{i}+\mathbf{4}}$ | $\mathbf{C}_{\boldsymbol{i}}+\mathbf{4}$ <br> $($ Note 1) | $\mathbf{C}_{\mathbf{i}}$ 4 <br> (Note 2) | Full |  |
| $\mathrm{I}_{3}-0$ | 88 | 82 | 97 | 87 | 78 |  |
| $\mathrm{C}_{n}$ | 37 | 30 | 46 | - | - |  |
| $\mathrm{C}_{\boldsymbol{i}}$ | - | - | 23 | 23 | - |  |
| CP | 74 | 66 | 84 | 45 | 60 |  |
| $D$ | 44 | - | 55 | - | - |  |

TABLE IID

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in VCC current when the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground
cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $\mathrm{V}_{\mathbb{H}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

Note: 1. Instructions 5, 7, 11, 12, 13, 14.
2. All instructions except $5,7,11,12,13,14$.

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902A | Carry Look-Ahead Generator |
| Am2904 | Status and Shift Control Unit |
| Am2920 | 8-Bit Register |
| Am2922 | Condition Code MUX |

DMA Address Generator

## DISTINCTIVE CHARACTERISTICS

- DMA Address Generation

Generates memory address, word count and DONE signal for DMA transfer operation.

- Expandable Eight-bit Slice

Any number of Am2940's can be cascaded to form larger memory addresses - three devices address 16 megawords.

- Repeat Data Transfer Capability

Initial memory address and word count are saved so that the data transfer can be repeated.

- Programmable Control Modes

Provides four types of DMA transfer control plus memory address increment/decrement.

- High Speed, Bipolar LSI

Advanced Low-Power Schottky TTL technology provides typical CLOCK to DONE propagation delay of 50 ns and 24 mA output current sink capability.

- Microprogrammable

Executes 8 different instructions.

## GENERAL DESCRIPTION

The Am2940, a 28-pin member of Advanced Micro Devices' Am2900 family of Low-Power Schottky bipolar LSI chips, is a high-speed, cascadable, eight-bit wide Direct Memory Access Address Generator slice. Any number of Am2940's can be cascaded to form larger addresses.
The primary function of the device is to generate sequential memory addresses for use in the sequential transfer of data to or from a memory. It also maintains a data word count and generates a DONE signal when a programmable terminal count has been reached. The device is designed
for use in peripheral controllers with DMA capability or in any other system which transfers data to or from sequential locations of a memory.

The Am2940 can be programmed to increment or decrement the memory address in any of four control modes, and executes eight different instructions. The initial address and word count are saved internally by the Am2940 so that they can be restored later in order to repeat the data transfer operation.


For applications information see the last part of this data sheet and Chapter VII of Bit Slice Microprocessor Design, by Mick and Brick, McGraw-Hill Publishers.


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2940
```



```
\(\stackrel{\text { B }}{1}\) Screening Option
Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
- Package
D-28-pin CERDIP
F-28-pin flatpak
L-28-pin leadless chip carrier X - Dice
Device type DMA Address Generator
```

| Valid Combinations |  |
| :--- | :--- |
| Am2940 | DC, DCB, DMB |
|  | FMB |
|  | LC, LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
| $23,24,25$ | $I_{0-2}$ | 1 | Selects one of eight instructions. |
| 11 | $\overline{A C I}$ | 1 | Carry-in to the address counter. |
| 6 | $\overline{A C O}$ | O | Carry-out from the address counter. |
| 9 | $\overline{\mathrm{WCl}}$ | I | Carry-in to the word counter. |
| 10 | $\overline{\mathrm{WCO}}$ | O | Carry-out from the word counter. |
|  | $\mathrm{D}_{0-7}$ | $\mathrm{I} / \mathrm{O}$ | External data. |
|  | $\mathrm{A}_{0-7}$ | O | Address outputs under control of Output Enable input, $\overline{\mathrm{OE}}_{\mathrm{A}}$. |
| 20 | $\overline{\mathrm{OE}}_{\mathrm{A}}$ | I | Address output enable. |
| 7 | DONE | O | Transfer complete signal. |
| 21 | CP | I | Clock input. Registers and counters change on the LOW-to-HIGH transition. |

## Am2940 ARCHITECTURE

As shown in the Block Diagram, the Am2940 consists of the following:

- A three-bit Control Register
- An eight-bit Address Counter with input multiplexer
- An eight-bit Address Register
- An eight-bit Word Counter with input multiplexer
- An eight-bit Word Count Register
- Transfer complete circuitry
- An eight-bit wide data multiplexer with three-state output buffers
- Three-state address output buffers with external output enable control
- An instruction decoder


## Control Register

Under instruction control, the Control Register can be loaded or read from the bidirectional DATA lines $D_{0}-D_{7}$. Control Register bits 0 and 1 determine the Am2940 Control Mode, and bit 2 determines whether the Address Counter increments or decrements. Figure 1 defines the Control Register format.

## Address Counter

The Address Counter, which provides the current memory address, is an eight-bit, binary, up/down counter with full lookahead carry generation. The Address Carry Input ( $\overline{\mathrm{ACl}}$ ) and Address Carry Output ( $\overline{\mathrm{ACO}}$ ) allow cascading to accommodate larger addresses. Under instruction control, the Address Counter can be enabled, disabled, and loaded from the DATA inputs, $D_{0}-D_{7}$, or the Address Register. When enabled and the $\overline{\mathrm{ACl}}$ input is LOW, the Address Counter increments/decrements on the LOW-to-HIGH transition of the CLOCK input, CP. The Address Counter output can be enabled onto the threestate ADDRESS outputs $A_{0}-A_{7}$ under control of the Output Enable input, $\overline{\mathrm{OE}} \mathrm{A}$.

## Address Register

The eight-bit Address Register saves the initial address so that it can be restored later in order to repeat a transfer operation. When the LOAD ADDRESS instruction is executed, the Address Register and Address Counter are simultaneously loaded from the DATA inputs, $D_{0}-D_{7}$.

## Word Counter and Word Count Register

The Word Counter and Word Count Register, which maintain and save a word count, are similar in structure and operation to the Address Counter and Address Register, with the exception that the Word Counter increments in Control Modes 1 and 3, decrements in Control Mode 0, and is disabled in Control Mode 2. The LOAD WORD COUNT instruction simultaneously loads the Word Counter and Word Count Register.

## Transfer Complete Circuitry

The Transfer Complete Circuitry is a combinational logic network which detects the completion of the data transfer operation in three Control Modes and generates the DONE output signal. The DONE signal is an open-collector output, which can be dot-anded between chips.

## Data Multiplexer

The Data Multiplexer is an eight-bit wide, 3-input multiplexer which allows the Address Counter, Word Counter, and Control Register to be read at the DATA lines, $D_{0}-D_{7}$. The Data Multiplexer and three-state Data Output Buffers are instruction controlled.

## Address Output Buffers

The three-state Address Output Buffers allow the Address Counter output to be enabled onto the ADDRESS lines, $A_{0}-A_{7}$, under external control. When the Output Enable input, $\overline{O E_{A}}$, is LOW, the Address output buffers are enabled; when $\overline{O E_{A}}$ is HIGH, the ADDRESS lines are in the high-impedance state. The Address and Data Output Buffers can sink 24 mA output current over the commercial operating range.

## Instruction Decoder

The Instruction Decoder generates required internal control signals as a function of the INSTRUCTION inputs, $\mathrm{I}_{0}-\mathrm{I}_{2}$ and Control Register bits, $\mathrm{CR}_{0}-\mathrm{CR}_{1}$.

## Clock

The CLOCK input, CP is used to clock the Address Register, Address Counter, Word Count Register, Word Counter, and Control Register, all on the LOW-to-HIGH transition of the CP signal.


Figure 1. Control Register Format Definition.

## Am2940 CONTROL MODES

## Control Mode 0 - Word Count Equals Zero Mode

In this mode, the LOAD WORD COUNT instruction loads the word count into the Word Count Register and Word Counter. When the Word Counter is enabled and the Word Counter Carry-in, $\overline{\mathrm{WCl}}$, is LOW, the Word Counter decrements on the LOW-to-HIGH transition of the clock input, CP. Figure 1 specifies when the DONE signal is generated.

## Control Mode 1 - Word Count Compare Mode

In this mode the LOAD WORD COUNT instruction loads the word count into the Word Count Register and clears the Word Counter. When the Word Counter is enabled and the Word Counter Carry-in, $\overline{\mathrm{WCI}}$, is LOW, the Word Counter increments on the LOW-to-HIGH transition of the clock input, CP. Figure 1 specifies when the DONE signal is generated.

## Control Mode 2 - Address Compare Mode

In this mode, only an initial and final memory address need be specified. The initial Memory Address is loaded into the Address Register and Address Counter and the final memory
address is loaded into the Word Count Register and Word Counter. The Word Counter is always disabled in this mode and serves as a holding register for the final memory address. When the Address Counter is enabled and the $\overline{\mathrm{ACl}}$ input is LOW, the Address Counter increments or decrements (depending on Control Register bit 2) on the LOW-to-HIGH transition of the CLOCK input, CP. The Transfer Complete Circuitry compares the Address Counter with the Word Counter and generates the DONE signal during the last word transfer; i.e., when the Address Counter equals the Word Counter.

## Control Mode 3 - Word Counter Carry Out Mode

For this mode of operation, the user can load the Word Count Register and Word Counter with the two's complement of the number of data words to be transferred. When the Word Counter is enabled and the $\overline{\mathrm{WCI}}$ input is LOW, the Word Counter increments on the LOW-to-HIGH transition of the CLOCK input, CP. A Word Counter Carry Out signal, $\overline{\text { WCO, }}$ indicates the last data word is being transferred. The DONE signal is not required in this mode and, therefore, is always LOW.


Figure 2. Am2940 Interconnections.

## Am2940 INSTRUCTIONS

The Am2940 instruction set consists of eight instructions. Six instructions load and read the Address Counter, Word Counter and Control Register; one instruction enables the Address and Word counters; and one instruction reinitializes the Address and Word Counters. The function of the REINITIALIZE COUNTERS, LOAD WORD COUNT, and ENABLE COUNTERS instructions varies with the Control Mode being utilized. Table 1 defines the Am2940 Instructions as a function of Instruction inputs $\mathrm{I}_{0}-\mathrm{I}_{2}$ and the four Am2940 Control Modes.

The WRITE CONTROL REGISTER instruction writes DATA input $D_{0}-D_{2}$ into the Control Register; DATA inputs $D_{3}-D_{7}$ are "don't care" inputs for this instruction. The READ CONTROL REGISTER instruction gates the Control Register outputs to DATA lines, $D_{0}-D_{2}$. DATA lines $D_{3}-D_{7}$ are in the HIGH state during this instruction.

The Word Counter can be read using the READ WORD COUNTER instruction, which gates the Word Counter outputs to DATA lines $D_{0}-D_{7}$. The LOAD WORD COUNT instruction is Control Mode dependent. In Control Modes 0, 2, and 3, DATA inputs $D_{0}-D_{7}$ are written into both the Word Count Register and Word Counter. In Control Mode 1, DATA inputs $D_{0}-D_{7}$ are
written into the Word Count Register and the Word Counter is cleared.

The READ ADDRESS COUNTER instruction gates the Address Counter outputs to DATA lines $D_{0}-D_{7}$, and the LOAD ADDRESS instruction writes DATA inputs $D_{0}-D_{7}$ into both the Address Register and Address Counter.

In Control Modes 0, 1, and 3, the ENABLE COUNTERS instruction enables both the Address and Word Counters; in Control Mode 2, the Address Counter is enabled and the Word Counter holds its contents. When enabled and the carry input is active, the counters increment on the LOW-to-HIGH transition of the CLOCK input, CP. Thus, with this instruction applied, counting can be controlled by the carry inputs.

The REINITIALIZE COUNTERS instruction also is Control Mode dependent. In Control Modes 0, 2, and 3, the contents of the Address Register and Word Count Register are transferred to the respective Address Counter and Word Counter; in Control Mode 1, the content of the Address Register is transferred to the Address Counter and the Word Counter is cleared. The REINITIALIZE COUNTERS instruction allows a data transfer operation to be repeated without reloading the address and word count from the DATA lines.

| ᄂ |  |  | TABLE I. Am2940 INSTRUCTIONS |  |  |  |  | Address Counter | Control Register | Data$D_{0}-D_{7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{lll}l_{2} & l_{1} & l_{0}\end{array}$ | Octal Code | Function | Mnemonic | Control Mode | Word Reg. | Word Counter | Address Reg. |  |  |  |
| L L L | 0 | WRITE CONTROL REGISTER | WRCR | 0,1,2,3 | HOLD | HOLD | HOLD | HOLD | $\mathrm{D}_{0}-\mathrm{D}_{2} \rightarrow \mathrm{CR}$ | INPUT |
| $L \quad \mathrm{~L}$ | 1 | $\begin{aligned} & \text { READ } \\ & \text { CONTROL } \end{aligned}$ REGISTER | RDCR | 0,1,2,3 | HOLD | HOLD | HOLD | HOLD | HOLD | $\underset{(\text { Note 1) }}{C \mathrm{CR}_{\rightarrow} \mathrm{D}_{0}-\mathrm{D}_{2}}$ |
| $\mathrm{L} \quad \mathrm{H}$ L | 2 | READ WORD COUNTER | RDWC | 0,1,2,3 | HOLD | HOLD | HOLD | HOLD | HOLD | $W C \rightarrow D$ |
| L H H | 3 | READ ADDRESS COUNTER | RDAC | 0,1,2,3 | HOLD | HOLD | HOLD | HOLD | HOLD | $A C \rightarrow D$ |
|  | 4 | REINITIALIZE COUNTERS | REIN | 0,2,3 | HOLD | WCR $\rightarrow$ WC | HOLD | $A R \rightarrow A C$ | HOLD | Z |
| H L L |  |  |  | 1 | HOLD | ZERO $\rightarrow$ WC | HOLD | $\mathrm{AR}_{\rightarrow} \mathrm{AC}$ | HOLD | Z |
| H L H | 5 | LOAD ADDRESS | LDAD | 0,1,2,3 | HOLD | HOLD | $D \rightarrow A R$ | $D \rightarrow A C$ | HOLD | INPUT |
| H H L | 6 | LDAD | LDWC | 0,2,3 | D $\rightarrow$ WR | D $\rightarrow$ WC | HOLD | HOLD | HOLD | INPUT |
|  |  | $\begin{aligned} & \text { WORD } \\ & \text { COUNT } \end{aligned}$ |  | 1 | D $\rightarrow$ WR | ZERO $\rightarrow$ WC | HOLD | HOLD | HOLD | INPUT |
| H H H | 7 |  | ENCT | 0,1,3 | HOLD | ENABLE COUNT | HOLD | ENABLE COUNT | HOLD | Z |
|  |  | COUNTERS |  | 2 | HOLD | HOLD | HOLD | ENABLE COUNT | HOLD | Z |
| $C R=$ Control Reg. <br> WCR = Word Count Reg. <br> AR = Address Reg. <br> WC = Word Counter <br> AC = Address Counter <br> D = Data <br> Note 1: Data Bits $D_{3}-D_{7}$ are high during this instruction. <br> APPLICATIONS <br> The Am2940 is designed for use in peripheral controllers with DMA capability or in any other system which transfers data to or from sequential locations of a memory. One or more Am2940's can be used in each peripheral controller of a distributed DMA system to provide the memory address and word count required for DMA operation. <br> Figure 3 shows a block diagram of an example microprogrammed DMA peripheral controller. The Am2910A Microprogram Sequencer, Microprogram Memory, and the Microinstruction Register form the microprogram control portion of this peripheral controller. The Am2940 generates the memory address and maintains the word count required for DMA operation. An internal three-state bus provides the communication path between the Microinstruction Register, the Am2917 Data Transceivers, the Am2940, the Am2901C Microprocessor, and the Device Interface Circuitry. |  |  |  |  | The Am2940 interconnections are shown in detail in Figure 2. Two Am2940's are cascaded to generate a sixteen-bit address. The Am2940 ADDRESS and DATA output current sink capability is 24 mA over the commercial operating range. This allows the Am2940's to drive the System Address Bus and Internal Three-State Bus directly, thereby eliminating the need for separate bus drivers. Three-bits in the Microinstruction Register provide the Am2940 Instruction Inputs, $\mathrm{I}_{0}-\mathrm{I}_{2}$. The microprogram clock is used to clock the Am2940's and, when the ENABLE COUNTERS instruction is applied, address and word counting is controlled by the CNT bit of the Microinstruction Register. <br> Asynchronous interface control circuitry generates System Bus control signals and enables the Am2940 Address onto the System Address Bus at the appropriate time. The opencollector DONE outputs are dot-anded and used as a test input to the Am2910A Microprogram Sequencer. |  |  |  |  |  |



BD002221
Figure 3. DMA Peripheral Controller Block Diagram.


## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS
C. OPEN-COLLECTOR OUTPUTS



$$
\begin{gathered}
\mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{IOH}_{\mathrm{OH}}} \\
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{IOL}^{+}+\mathrm{V}_{\mathrm{OL}}}{R_{2}}}
\end{gathered}
$$

$$
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{OL}}}{\mathrm{lOL}}
$$

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, stray wiring and capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for $t_{P Z H}$ test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2940 (DIP)

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | $\mathrm{A}_{0-7}$ | A | 220 | 1 K |
| - | $\mathrm{D}_{0-7}$ | A | 220 | 1 K |
| 6 | $\overline{\text { ACO }}$ | B | 470 | 2.4 K |
| 7 | DONE | C | 270 | - |
| 10 | $\overline{\text { WCO }}$ | B | 470 | 2.4 K |

For additonal information on testing, see section
'"Guidelines on Testing Am2900 Family Devices.'"

## SWITCHING CHARACTERISTICS

The tables below define the Am2940 switching characteristics. Tables A are set-up and hold times relative to the clock LOW-toHIGH transition. Tables B are combinational delays. Tables C are clock requirements. All measurements are made at 1.5 V with input levels at $O V$ or 3 V . All values are in $n s$ with $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ except output disable times ( $\overline{\mathrm{OE}}$ to A and I to D ) which are specified or a 5 pF load.

## I. GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

Am2940DC ( $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )

## A. Set-up and Hold Times

(Relative to clock LOW-to-HIGH transition)

| Input | $\mathbf{t}_{\mathbf{s}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :--- | :---: | :---: |
| $\mathrm{D}_{0-7}$ | 24 | 4 |
| $\mathrm{I}_{012}$ | 46 | 5 |
| $\overline{\mathrm{ACl}}$ | 30 | 4 |
| WCl <br> (Note 1) | 30 | 3 |

B. Combinational Delays

| Input | $\overline{\text { ACO }}$ | $\overline{\text { WCO }}$ | A $_{0-7}$ | DONE | $\mathbf{D}_{0-7}$ |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{ACI}}$ | 20 | - | - | - | - |
| WCI <br> (Note 2) | - | 20 | - | 46 | - |
| $\mathrm{I}_{0-2}$ | - | - | - | - | 37 |
| CP <br> (Note 3) | 58 | 58 | 54 | 85 | - |

D. Enable/Disbable Times

| From | To | Disable | Enable |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{012}$ | $\mathrm{D}_{0-7}$ | 35 | 35 | ns |
| $\overline{\mathrm{OE}}$ | $\mathrm{A}_{0-7}$ | 25 | 25 | ns |

## II. GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE

Am2940DM, $\mathrm{FM}\left(\mathrm{T}_{\mathrm{C}}=-55\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )
A. Set-up and Hold Times
(Relative to clock LOW-to-HIGH transition)

| Input | $\boldsymbol{t}_{\mathbf{s}}$ | $\boldsymbol{t}_{\mathbf{h}}$ |
| :--- | :---: | :---: |
| $\mathrm{D}_{0-7}$ | 27 | 6 |
| $\mathrm{I}_{012}$ | 49 | 5 |
| $\overline{\mathrm{ACl}}$ | 34 | 5 |
| WCl <br> (Note 1) | 34 | 5 |

## C. Clock Requirements

| Minimum Clock LOW Time | 23 | ns |
| :---: | :---: | :---: |
| Minimum Clock HIGH Time | 35 | ns |
| Maximum Clock Frequency | 16 | MHz |

B. Combinational Delays
B. Combinational Delays

| Input | $\overline{\text { ACO }}$ | $\overline{\mathrm{WCO}}$ | A $0-7$ | DONE | $\mathbf{D}_{0-7}$ |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{ACl}}$ | 21 | - | - | - | - |
| $\overline{\mathrm{WCl}}$ <br> (Note 2) | - | 21 | - | 54 | - |
| $\mathrm{I}_{0-12}$ | - | - | - | - | 41 |
| CP <br> (Note 3) | 64 | 64 | 62 | 88 | - |

D. Enable/Disable Times

| From | To | Disable | Enable |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{012}$ | $\mathrm{D}_{0-7}$ | 42 | 42 | ns |
| $\overline{\mathrm{OE}}$ | $\mathrm{A}_{0-7}$ | 30 | 30 | ns |

Notes: 1. Control modes 0,1 , and 3 only.
2. $\overline{\mathrm{WCl}}$ to DONE occurs only in control modes 0 and 1.
3. CP to DONE occurs only in control modes 0,1 , and 2.

| Minimum Clock LOW Time | 23 | ns |
| :---: | :---: | :---: |
| Minimum Clock HIGH Time | 34 | ns |
| Maximum Clock Frequency | 17 | MHz |



Figure 4. Switching Waveforms.

See Tables $A$ for $t_{s}$ and $t_{h}$ for various inputs. See Tables. B for combinational delays from clock and other inputs to outputs.

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current when the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 's of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{1 L}$ or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

# Am2942 

Programmable Timer/Counter DMA Address Generator

## DISTINCTIVE CHARACTERISTICS

- Expandable eight-bit slice
- Any number of Am2942s can be cascaded. Three devices provide a 48-bit counter.
- Reinitialize capability
- Counters can be reinitialized from on-chip registers.
- Executes 16 instructions
- Eight DMA instructions plus eight Timer/Counter instructions.
- Programmable control modes
- Provide four types of control.
- Two independent programmable 8-bit up/down counters
- Counters can be cascaded to form single-chip 16-bit up/down counter.
- High speed bipolar LSI
- Typical count frequency of 25 MHz and 24 mA output current sink capability.


## GENERAL DESCRIPTION

The Am2942, a 22-pin version of the Am2940, can be used as a high-speed DMA Address Generator or Programmable Timer/Counter. It provides multiplexed Address and Data lines, for use with a common bus, and additional Instruction Input and Instruction Enable pins. The Am2942 executes 16 instructions; eight are the same as the Am2940 instructions, and eight instructions facilitate the use of the Am2942 as a Programmable Timer/Counter. The Instruction Enable input allows the sharing of the Am2942 instruction field with other devices.

When used as a Timer/Counter, the Am2942 provides two independent, programmable, eight-bit, up-down counters in a 22-pin package. The two on-chip counters can be cascaded to form a single chip, 16-bit counter. Also, any number of chips can be cascaded - for example three cascaded Am2942s form a 48-bit timer/counter.

Reinitialization instructions provide the capability to reinitialize the counters from on-chip registers. Am2942 Programmable Control Modes, identical to those of the Am2940, offer four different types of programmable control.

BLOCK DIAGRAM


For applications information see the last part of this data sheet and Chapter VII of Bit Slice Microprocessor Design, by Mick and Brick, McGraw-Hill Publishers.

## CONNECTION DIAGRAM Top View


*F-22 Pin Configuration identical to D-22
Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am2942


Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
Package
D-22-pin CERDIP
F-22-pin flatpak
L-28-pin leadless chip carrier
X - Dice

Device type
DMA Address Generator


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| ．PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No． | Name | 1／0 | Description＊ |
| 12，13，14， 15 | $\mathrm{l}_{0-3}$ | 1 | Selects one of sixteen instructions． |
| 3 | $\overline{\mathrm{ACl}}$ | 1 | Carry－in to the address counter． |
| 20 | $\overline{\mathrm{ACO}}$ | 0 | Carry－out from the address counter． |
| 1 | $\overline{\mathrm{WCl}}$ | 1 | Carry－in to the word counter． |
| 2 | $\overline{\text { WCO }}$ | 0 | Carry－out from the word counter． |
|  | $\mathrm{D}_{0-7}$ | 1／0 | Bidirectional data bus． |
| 9 | $\overline{O E}_{D}$ | 1 | Data bus output enable． |
| 8 | $\overline{\mathrm{I}}$ | 1 | Instruction enable for $\mathrm{l}_{0-2}$ ． |
| 21 | DONE | 0 | Transfer complete signal． |
| 10 | CP | 1 | Clock input．Registers and counters change on the LOW－to－HIGH transition． |

## Am2942 ARCHITECTURE

As shown in the Block Diagram，the Am2942 consists of the following：
－A three－bit Control Register．
－An eight－bit Address Counter with input multiplexer．
－An eight－bit Address Register．
－An eight－bit Word Counter with input multiplexer．
－An eight－bit Word Count Register．
－Transfer complete circuitry．
－An eight－bit wide data multiplexer with three－state output buffers．
－An instruction decoder．

## CONTROL REGISTER

Under instruction control，the Control Register can be loaded or read from the bidirectional DATA lines $D_{0}-D_{7}$ ．Control Register bits 0 and 1 determine the Am2942 Control Mode， and bit 2 determines whether the Address Counter increments or decrements．Figure 1 defines the Control Register format．

## Address Counter

The Address Counter，which provides the current memory address，is an eight－bit，binary，up／down counter with full lookahead carry generation．The Address Carry input（ $\overline{\mathrm{ACl}}$ ） and Address Carry Output（ $\overline{\mathrm{ACO}}$ ）allow cascading to accom－ modate larger addresses．Under instruction control，the Ad－ dress Counter can be enabled，disabled，and loaded from the DATA inputs，$D_{0}-D_{7}$ ，or the Address Register．When enabled and the $\overline{\mathrm{ACl}}$ input is LOW，the Address Counter increments／ decrements on the LOW－to－HIGH transition of the CLOCK input，CP．

## Address Register

The eight－bit Address Register saves the initial address so that it can be restored later in order to repeat a transfer operation． When the LOAD ADDRESS instruction is executed，the Address Register and Address Counter are simultaneously loaded from the DATA inputs，$D_{0}-D_{7}$ ．

## Word Counter and Word Count Register

The Word Counter and Word Count Register，which maintain and save a word count，are similar in structure and operation to the Address Counter and Address Register，with the exception that the Word Counter increments in Control Modes 1 and 3，decrements in Control Mode 0 and is disabled in Control Mode 2．The LOAD WORD COUNT instruction simul－ taneously loads the Word Counter and Word Count Register．

## Transfer Complete Circuitry

The Transfer Complete Circuitry is a combinational logic network which detects the completion of the data transfer operation in three Control Modes and generates the DONE output signal．The DONE signal is a open－collector output， which can be dot－anded between chips．

## Data Multiplexer

The Data Multiplexer is an eight－bit wide，three－input multiplex－ er which allows the Address Counter，Word Counter and Control Register to be read at DATA lines $D_{0}-D_{7}$ ．The Data Multiplexer output， $\mathrm{Y}_{0}-\mathrm{Y}_{7}$ ，is enabled onto DATA lines $\mathrm{D}_{0}-\mathrm{D}_{7}$ if and only if the Output Enable input，$\overline{O E_{D}}$ ，is LOW．（Refer to Figure 2．）

## Instruction Decoder

The Instruction Decoder generates required internal control signals as a function of the INSTRUCTION inputs， $\mathrm{l}_{0}-\mathrm{l}_{3}$ ， Control Register bits， $\mathrm{CR}_{0}-\mathrm{CR}_{1}$ ，and the INSTRUCTION EN－ ABLE input，$\overline{\Gamma_{E}}$ ．

## Clock

The CLOCK input，CP is used to clock the Address Register， Address Counter，Word Count Register，Word Counter，and Control Register，all on the LOW－to－HIGH transition of the CP signal．


| $\mathbf{C R}_{\mathbf{2}}$ | Address Counter |
| :---: | :---: |
| L | Increment |
| H | Decrement |

$$
\begin{aligned}
H & =\mathrm{HIGH} \\
\mathrm{~L} & =\mathrm{LOW}
\end{aligned}
$$

Figure 1. Control Register Format Definition.

| $\overline{O E}_{\mathbf{D}}$ | $\mathbf{D}_{\mathbf{0}}-\mathrm{D}_{\mathbf{7}}$ |
| :---: | :--- |
| L | DATA MULTIPLEXER OUTPUT, $Y_{0}-Y_{7}$ <br> $H$ |

Figure 2. Data Bus Output Enable Function.

## Am2942 CONTROL MODES

## Control Mode 0 - Word Count Equals Zero Mode

In this mode, the LOAD WORD COUNT instruction loads the word count into the Word Count Register and Word Counter. When the Word Counter is enabled and the Word Counter Carry-in, $\overline{\mathrm{WCI}}$, is LOW, the Word Counter decrements on the LOW-to-HIGH transition of the CLOCK input, CP. Figure 1 specifies when the DONE signal is generated in this mode.

## Control Mode 1 - Word Count Compare Mode

In this mode the LOAD WORD COUNT instruction loads the word count into the Word Count Register and clears the Word Counter. When the Word Counter is enabled and the Word Counter Carry-in, $\overline{\mathrm{WCI}}$, is LOW, the Word Counter increments on the LOW-to-HIGH transition of the clock input, CP. Figure 1 specifies when the DONE signal is generated.

## Control Mode 2 - Address Compare Mode

In this mode, only an initial and final memory address need to be specified. The initial Memory Address is loaded into the Address Register and Address Counter and the final memory address is loaded into the Word Count Register and Word Counter. The Word Counter is always disabled in this mode and serves as a holding register for the final memory address.

When the Address Counter is enabled and the $\overline{\mathrm{ACl}}$ input is LOW, the Address Counter increments or decrements (depending on Control Register bit 2) on the LOW-to-HIGH transition of the CLOCK input, CP. The Transfer Complete Circuitry compares the Address Counter with the Word Counter and generates the DONE signal during the last word transfer; i.e., when the Address Counter equals the Word Counter.

## Control Mode 3 - Word Counter Carry Out Mode

For this mode of operation, the user can load the Word Count Register and Word Counter with the two's complement of the number of data words to be transferred. When the Word Counter is enabled and the WCl input is LOW, the Word Counter increments on the LOW-to-HIGH transition of the CLOCK input, CP. A Word Counter Carry Out signal, WCO, indicates the last data word is being transferred. The DONE signal is not required in this mode and, therefore, is always LOW.

## Am2942 INSTRUCTIONS

The Am2942 instruction set consists of sixteen instructions. Eight are DMA Instructions and are similar to the Am2940 instructions. The remaining eight instructions are designed to facilitate the use of the Am2942 as a Programmable Timer/ Counter. Figures 3 and 4 define the Am2942 Instructions.

Instructions 0－7 are DMA instructions．The WRITE CONTROL REGISTER instruction writes DATA input $D_{0}-D_{2}$ into the Control Register；DATA inputs $\mathrm{D}_{3}-\mathrm{D}_{7}$ are＂don＇t care＂inputs for this instruction．The READ CONTROL REGISTER instruc－ tion gates the Control Register to Data Multiplexer outputs $\mathrm{Y}_{0}$－ $\mathrm{Y}_{2}$ ．Outputs $\mathrm{Y}_{3}-\mathrm{Y}_{7}$ are HIGH during this instruction．

The Word Counter can be read using the READ WORD COUNTER instruction，which gates the Word Counter to Data Multiplexer outputs，$Y_{0}-Y_{7}$ ．The LOAD WORD COUNT instruc－ tion is Control Mode dependent．In Control Modes 0,2 ，and 3 ， DATA inputs $D_{0}-D_{7}$ are written into both the Word Count Register and Word Counter．In Control Mode 1，DATA inputs $D_{0}-D_{7}$ are written into the Word Count Register and the Word Counter is cleared．

The READ ADDRESS COUNTER instruction gates the Ad－ dress Counter to Data Multiplexer outputs，$Y_{0}-Y_{7}$ ，and the LOAD ADDRESS instruction writes DATA inputs $D_{0}-D_{7}$ into both the Address Register and Address Counter．

In Control Modes 0，1，and 3，the ENABLE COUNTERS instruction enables both the Address and Word Counters；in Control Mode 2，the Address Counter is enabled and the Word Counter holds its contents．When enabled and the carry input is active，the counters increment on the LOW－to－HIGH transi－ tion of the CLOCK input，CP．Thus，with this instruction applied，counting can be controlled by the carry inputs．

The REINITIALIZE COUNTERS instruction also is Control Mode dependent．In Control Modes 0，2，and 3，the contents of the Address Register and Word Count Register are trans－ ferred to the respective Address Counter and Word Counter； in Control Mode 1，the content of the Address Register is transferred to the Address Counter and the Word Counter is cleared．The REINITIALIZE COUNTERS instruction allows a data transfer operation to be repeated without reloading the address and word count from the DATA lines．

When $I_{E}$ is HIGH，Instruction inputs， $\mathrm{I}_{0}-\mathrm{I}_{2}$ ，are disabled．When $l_{3}$ is LOW，the function performed is identical to that of the ENABLE COUNTERS instruction．Thus，counting can be controlled by the carry inputs with the ENABLE COUNTERS instruction applied or with Instruction Inputs $1_{0}-\mathrm{I}_{2}$ disabled．

Instructions 8－F facilitate the use of the Am2942 as a Programmable Timer／Counter．They differ from instructions 0－ 7 in that they provide independent control of the Address Counter，Word Counter and Control Register．
The WRITE CONTROL REGISTER，T／C instruction writes DATA input $D_{0}-D_{2}$ into the Control Register．DATA inputs $D_{3}-$ $\mathrm{D}_{7}$ are＂don＇t care＂inputs for this instruction．The Address and Word Counters are enabled，and the Control Register contents appear at the Data Multiplexer output．
The REINITIALIZE ADDRESS COUNTER instruction allows the independent reinitialization of the Address Counter．The Word Counter is enabled and the contents of the Address Counter appear at the Data Multiplexer output．
The Word Counter can be read，using the READ WORD COUNTER，T／C instruction．Both counters are enabled when this instruction is executed．
When the READ ADDRESS COUNTER，T／C instruction is executed，both counters are enabled and the address counter contents appear at the Data Multiplexer output．
The REINITIALIZE ADDRESS and WORD COUNTERS in－ struction is identical to the REINITIALIZE COUNTERS instruc－ tion and provides the capability to reinitialize both counters at the same time．The Address Counter contents appear at the Data Multiplexer output．
DATA inputs $D_{0}-D_{7}$ are loaded into both the Address Register and Counter when the LOAD ADDRESS，T／C instruction is executed．The Word Counter is enabled and its contents appear at the Data Multiplexer output．

The LOAD WORD COUNT，T／C instruction is identical to the LOAD WORD COUNT instruction with the exception that the Address Counter is enabled．
The Word Counter can be independently reinitialized using the REINITIALIZE WORD COUNTER instruction．The Address Counter is enabled and the Word Counter contents appear at the Data Multiplexer output．
When the $\bar{T}_{E}$ input is HIGH，Instruction inputs， $\mathrm{I}_{0-1} \mathrm{I}_{2}$ ，are disabled．The function performed when $I_{3}$ is HIGH is identical to that performed when $I_{3}$ is LOW，with the exception that the Word Counter contents appear at the Data Multiplexer output．

| TE | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | 10 | $\begin{aligned} & \text { HEX } \\ & \text { CODE } \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | WRITE CONTROL REGISTER |  |
| 0 | 0 | 0 | 0 | 1 | 1 | READ CONTROL REGISTER |  |
| 0 | 0 | 0 | 1 | 0 | 2 | READ WORD COUNTER |  |
| 0 | 0 | 0 | 1 | 1 | 3 | READ ADDRESS COUNTER | DMA |
| 0 | 0 | 1 | 0 | 0 | 4 | REINITIALIZE COUNTERS | INSTRUCTIONS |
| 0 | 0 | 1 | 0 | 1 | 5 | LOAD ADDRESS |  |
| 0 | 0 | 1 | 1 | 0 | 6 | LOAD WORD COUNT |  |
| 0 | 0 | 1 | 1 | 1 | 7 | ENABLE COUNTERS |  |
| 1 | 0 | X | X | X | 0－7 | INSTRUCTION DISABLE |  |
| 0 | 1 | 0 | 0 | 0 | 8 | WRITE CONTROL REGISTER，T／C |  |
| 0 | 1 | 0 | 0 | 1 | 9 | REINITIALIZE ADDRESS COUNTER |  |
| 0 | 1 | 0 | 1 | 0 | A | READ WORD COUNTER，T／C |  |
| 0 | 1 | 0 | 1 | 1 | B | READ ADDRESS COUNTER，T／C | TIMER／COUNTER |
| 0 | 1 | 1 | 0 | 0 | C | REINITIALIZE ADDRESS \＆WORD COUNTERS | INSTRUCTIONS |
| 0 | 1 | 1 | 0 | 1 | D | LOAD ADDRESS，T／C |  |
| 0 | 1 | 1 | 1 | 0 | E | LOAD WORD COUNT，T／C |  |
| 0 | 1 | 1 | 1 | 1 | F | REINITIALIZE WORD COUNTER |  |
| 1 | 1 | X | X | X | 8－F | INSTRUCTION DISABLE，T／C |  |
| $0=$ LOW |  | 1 ＝HIGH |  | $\mathrm{X}=$ DON＇T CARE |  |  |  |

Figure 3．Am2942 Instructions．

| $\bar{T}$ | $I_{3} I_{2} I_{1} I_{0}$ (Hex) | Function | Mnemonic | Control Mode | Word Reg. | Word Counter | Adr. Reg. | Adr. Counter | Control Reg. | Data Multiplexer Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | 0 | WRITE CONTROL REGISTER | WRCR | 0, 1, 2, 3 | HOLD | HOLD | HOLD | HOLD | $\mathrm{D}_{0-2} \rightarrow \mathrm{CR}$ | $\begin{aligned} & \text { FORCED } \\ & \text { HIGH } \end{aligned}$ |
| L | 1 | $\begin{aligned} & \text { READ CONTROL } \\ & \text { REGISTER } \end{aligned}$ | RDCR | 0, 1, 2, 3 | HOLD | HOLD | HOLD | HOLD | HOLD | CONTROL REG. |
| L | 2 | READ WORD COUNTER | RDWC | 0, 1, 2, 3 | HOLD | HOLD | HOLD | HOLD | HOLD | WORD COUNTER |
| L | 3 | READ ADDRESS COUNTER | RDAC | 0, 1, 2, 3 | HOLD | HOLD | HOLD | HOLD | HOLD | ADR. COUNTER |
| L | 4 | REINITIALIZE | REIN | 0, 2, 3 | HOLD | $\mathrm{WR} \rightarrow \mathrm{WC}$ | HOLD | $A R \rightarrow A C$ | HOLD | ADR. CNTR. |
|  |  | COUNTERS |  | 1 | HOLD | ZERO $\rightarrow$ WC | HOLD | $A R \rightarrow A C$ | HOLD | ADR. CNTR. |
| L | 5 | LOAD COUNT | LDAD | 0, 1, 2, 3 | HOLD | HOLD | $D \rightarrow A R$ | $D \rightarrow A C$ | HOLD | WORD COUNTER |
| 1 | 6 | LOAD WORD | LDWC | 0, 2, 3 | $\mathrm{D} \rightarrow$ WR | D $\rightarrow$ WC | HOLD | HOLD | HOLD | FORCED HIGH |
|  |  | COUNT |  | 1 | $D \rightarrow$ WR | ZERO $\rightarrow$ WC | HOLD | HOLD | HOLD | FORCED HIGH |
| L | 7 | ENABLE | ENCT | 0, 1, 3 | HOLD | ENABLE | HOLD | ENABLE | HOLD | ADR. CNTR |
|  |  | COUNTERS |  | 2 | HOLD | HOLD | HOLD | ENABLE | HOLD | ADR. CNTR. |
|  |  | INSTRUCTION |  | 0, 1, 3 | HOLD | ENABLE | HOLD | ENABLE | HOLD | ADR. CNTR. |
| H | 0-7 | DISABLE | - | 2 | HOLD | HOLD | HOLD | ENABLE | HOLD | ADR. CNTR. |
| L | 8 | WRITE CONTROL REGISTER, T/C | WCRT | 0, 1, 2, 3 | HOLD | ENABLE | HOLD | ENABLE | $\mathrm{D}_{0-2} \rightarrow \mathrm{CR}$ | $\begin{gathered} \text { CONTROL } \\ \text { REG. } \end{gathered}$ |
| L | 9 | REINITIALIZE ADR. COUNTER | REAC | 0, 1, 2, 3 | HOLD | ENABLE | HOLD | $A R \rightarrow A C$ | HOLD | ADR. COUNTER |
| L | A | READ WORD COUNTER, T/C | RWCT | 0, 1, 2, 3 | HOLD | ENABLE | HOLD | ENABLE | HOLD | WORD COUNTER |
| L | B | READ ADDRESS COUNTER, T/C | RACT | 0, 1, 2, 3 | HOLD | ENABLE | HOLD | ENABLE | HOLD | ADR. COUNTER |
| 1 | c | REINITIALIZE ADDRESS AND | RAWC | 0, 2, 3 | HOLD | WR $\rightarrow$ WC | HOLD | $A R \rightarrow A C$ | HOLD | ADR. CNTR. |
| L | C | WORD COUNTERS | Rawc | 1 | HOLD | ZERO $\rightarrow$ WC | HOLD | $A R \rightarrow A C$ | HOLD | ADR. CNTR. |
| L | D | $\begin{gathered} \text { LOAD } \\ \text { ADDRESS, T/C } \\ \hline \end{gathered}$ | LDAT | 0, 1, 2, 3 | HOLD | ENABLE | $D \rightarrow A R$ | $D \rightarrow A C$ | HOLD | WORD COUNTER |
| L | E | LOAD WORD | IWCT | 0, 2, 3 | $\mathrm{D} \rightarrow \mathrm{WR}$ | D $\rightarrow$ WC | HOLD | ENABLE | HOLD | FORCED HIGH |
| L | E | COUNT, T/C | LWCT | 1 | $D \rightarrow$ WR | ZERO $\rightarrow$ WC | HOLD | ENABLE | HOLD | FORCED HIGH |
| L | F | REINITIALIZE | REWC | 0, 2, 3 | HOLD | WR $\rightarrow$ WC | HOLD | ENABLE | HOLD | WD. CNTR. |
|  |  | WORD COUNTER |  | 1 | HOLD | ZERO $\rightarrow$ WC | HOLD | ENABLE | HOLD | WD. CNTR. |
|  |  | INSTRUCTION |  | 0, 1, 3 | HOLD | ENABLE | HOLD | ENABLE | HOLD | WD. CNTR. |
| H | 8-F | DISABLE, T/C | - | 2 | HOLD | HOLD | HOLD | ENABLE | HOLD | WD. CNTR. |

WR = WORD REGISTER
WC = WORD COUNTER
AR = ADDRESS REGISTER

AC = ADDRESS COUNTER
CR = CONTROL REGISTER
$D=$ DATA

Figure 4. Am2942 Function Table.

## APPLICATIONS

Figure 5 shows an Am2942 used as two independent, programmable eight-bit timer/counters. In this example, an Am2910A Microprogram Sequencer provides an address to Am27S27 512 $\times 8$ Registered PROMs. The on-chip PROM output register is used as the Microinstruction Register.

The Am2942 Instruction input, $\mathrm{I}_{3}$, is tied HIGH to select the eight Timer/Counter instructions. The $\overline{I_{E}}, I_{0}-I_{2}$, and $\overline{O E_{D}}$ inputs are provided by the microinstruction, and the $D_{0}-D_{7}$ data lines are connected to a common Data Bus. GATE WC and GATE AC are separate enable controls for the respective Word Counter and Address Counter. The DONE, $\overline{\mathrm{ACO}}$ and $\overline{\mathrm{WCO}}$
output signals indicate that a pre-programmed time or count has been reached.

Figure 6 shows an Am2942 used as a single 16-bit programmable timer/counter. In this example, the Word Counter carryout, $\overline{\mathrm{WCO}}$, is connected to the Address Counter carry-in, $\overline{\mathrm{ACl}}$, to form a single 16 -bit counter which is enabled by the GATE signal.
Figure 7 shows two Am2942s cascaded to form a 32-bit programmable timer/counter. The two Word Counters form the low order 16 bits, and the two Address Counters form the high order bits. This allows the timer/counter to be loaded and read 16 bits at a time.


Figure 5．Two 8－Bit Programmable Counters／Timers in a 22－Pin Package．


AF001901

Figure 6．16－Bit Programmable Counter／Timer Using a Single Am2942．


AF001921

Figure 7. 32-Bit Programmable Counter/Timer Using Two Am2942s.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ........................ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$
DC Voltage Applied to Outputs For High Output State $\qquad$ .-0.5V to $+V_{C C} \max$
DC Input Voltage $\qquad$
$\qquad$ ....-0.5 V to +5.5 V
DC Output Current, Into Outputs .......................... 30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{\mathbb{I H}} \text { or } V_{\mathbb{I L}} \end{aligned}$ | MIL $\mathrm{IOH}=-1.0 \mathrm{~mA}$ |  |  | 2.4 |  |  |  |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L} \mathrm{IOH}^{\prime}=-2.6 \mathrm{~mA}$ |  |  |  |  |  | Volts |
| $\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}$ | $\overline{\text { WCO, }}$ ACO |  | $\mathrm{L}=8.0 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  |  |  |
|  |  |  | D0-7, DONE |  | $L=16 \mathrm{~mA}$ |  |  |  |  |
|  |  |  |  |  | $1 \mathrm{OL}=24 \mathrm{~mA}$ |  |  |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level (Note 4) | Guaranteed Input Logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Note 4) | Guaranteed input Logical LOW voltage for all inputs |  |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $V_{C C}=M A X, V_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  |  |  | -0.15 |  |
|  |  |  |  |  | hers |  |  | -0.8 | mA |
| $I_{\text {IH }}$ | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  |  | 150 | $\mu \mathrm{A}$ |
|  |  |  |  |  | hers |  |  | 40 |  |
| ICEX | Output Leakage on DONE | $V_{C C}=M A X, V_{O}=5.5 \mathrm{~V}$ |  |  |  |  |  | 250 | $\mu \mathrm{A}$ |
| 1 | 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 (Note 3) | $\mathrm{V}_{C C}=\mathrm{MAX}+0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  |  | -30 |  | -85 | mA |
| lozl | Output OFF Current | $\begin{aligned} & V_{C C}=M A X \\ & O E=2.4 V \end{aligned}$ | $\mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ |  | $\mathrm{D}_{0-7}$ |  |  | -150 | $\mu \mathrm{A}$ |
| IOZH |  |  | $V_{\text {OUT }}=2.4$ |  | $\mathrm{D}_{0.7}$ |  |  | 150 |  |
| Icc | Power Supply Current | $V_{C C}=$ MAX | Am2942PC, DC | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  | 265 | mA |
|  |  |  |  |  |  |  |  | 220 |  |
|  |  |  | Am2942DM, FM | $\mathrm{T}_{\mathrm{C}}$ | to $+125^{\circ} \mathrm{C}$ |  |  | 285 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}$ |  |  |  | 205 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. These input levels provide no guaranteed noise immunity and should only be static tested in a noise-free environment (not functionally tested).

## SWITCHING TEST CIRCUIT

A. THREE STATE OUTPUTS
B. NORMAL OUTPUTS
C. OPEN-COLLECTOR OUTPUTS





$$
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{OL}}}{\mathrm{lOL}}
$$

Notes: 1. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tPZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2942 (DIP)

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :--- | :---: | :---: | :---: |
| - | $\mathrm{D}_{0-7}$ | A | 220 | 1 K |
| 20 | $\overline{\mathrm{ACO}}$ | B | 470 | 2.4 K |
| 21 | DONE | C | 270 | - |
| 2 | $\overline{\mathrm{WCO}}$ | B | 470 | 2.4 K |

For additional information on testing, see section
"'Guidelines on Testing Am2900 Family Devices.'

$$
\begin{aligned}
& \mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{1 \mathrm{OH}} \\
& R_{1}=\frac{5.0-V_{B E}-V_{O L}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{~K}}} \\
& \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{IOL}^{2}+V_{\mathrm{OL}}}{\mathrm{R}_{2}}}
\end{aligned}
$$

## SWITCHING CHARACTERISTICS

The tables below define the Am2942 switching characteristics．Tables A are set－up and hold times relative to the clock LOW－to－ HIGH transition．Tables B are combinational delays．Tables $C$ are clock requirements．All measurements are made at 1.5 V with input levels at 0 V or 3 V ．All values are in $n s$ with $C_{L}=50 \mathrm{pF}$ except output disable times（ $I$ to $D$ ）which are specified for a 5 pF load．

## I．GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

Am2942，$D C\left(T_{A}=0\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{Cc}}=4.75$ to $\left.5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)$

A．Set－up and Hold Times
（Relative to clock LOW－to－HIGH transition）

| Input | $\mathbf{t}_{\mathbf{3}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :--- | :---: | :---: |
| $\mathrm{D}_{0-7}$ | 24 | 6 |
| $\mathrm{I}_{0-3}$ | 46 | 5 |
| $\overline{\mathrm{ACl}}$ | 30 | 4 |
| $\overline{\mathrm{WCl}}$ | 30 | 3 |
| $\mathrm{I}_{\mathrm{E}}$ | 46 | 5 |

C．Clock Requirements

| Minimum Clock LOW Time | 23 | ns |
| :--- | :---: | :---: |
| Minimum Clock HIGH Time | 34 | ns |
| Maximum Clock Frequency | 17 | MHz |

B．Combinational Delays

| Input | $\overline{\text { ACO }}$ | $\overline{\mathbf{W C O}}$ | DONE | $\mathbf{D}_{\mathbf{0} \mathbf{- 7}}$ |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{ACl}}$ | 20 | - | - | - |
| $\overline{\mathrm{WCl}}$ <br> （Note 1） | - | 20 | 46 | - |
| $\mathrm{I}_{0-3}$ | - | - | - | 37 |
| CP <br> （Note 2） | 58 | 58 | 85 | 59 |
| $\mathrm{I}_{\mathrm{E}}$ | - | - | - | 37 |

II．GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE
Am2942DM， FM （ $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ ）

A．Set－up and Hold Times （Relative to clock LOW－to－HIGH transition）

| Input | $\mathbf{t}_{\mathbf{s}}$ | $\mathbf{t}_{\boldsymbol{h}}$ |
| :--- | :--- | :--- |
| $\mathrm{D}_{0-7}$ | 27 | 7 |
| $\mathrm{I}_{0-3}$ | 49 | 5 |
| $\overline{\mathrm{ACl}}$ | 34 | 5 |
| $\overline{\mathrm{WCl}}$ | 34 | 5 |
| $\mathrm{I}_{\mathrm{E}}$ | 49 | 5 |

C．Clock Requirements

| Minimum Clock LOW Time | 23 | ns |
| :--- | :---: | :---: |
| Minimum Clock HIGH Time | 35 | ns |
| Maximum Clock Frequency | 17 | MHz |

B．Combinational Delays

| Input | $\overline{\mathrm{ACO}}$ | $\overline{\mathrm{WCO}}$ | DONE | $\mathrm{D}_{\mathbf{0 - 7}}$ |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{ACI}}$ | 21 | - | - | - |
| $\overline{\mathrm{WCl}}$ <br> $($ Note 1） | - | 21 | 54 | - |
| $\mathrm{I}_{0-3}$ | - | - | - | 41 |
| CP <br> （Note 2） | 64 | 64 | 88 | 68 |
| $\mathrm{I}_{\mathrm{E}}$ | - | - | - | 41 |

D．Enable／Disable Times

| From | To | Disable | Enable |  |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | $\mathrm{D}_{0-7}$ | 30 | 30 | ns |

Notes：1．$\overline{\mathrm{WCl}}$ to DONE occurs only in control modes 0 and 1.

2．CP to DONE occurs only in control modes 0,1 ， and 2.


Figure 8. Switching Waveforms.
See Tables A for $t_{s}$ and $t_{h}$ for various inputs. See Tables B for combinational delays from clock and other inputs to outputs.

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current when the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

# Am2946/Am2947 

Octal Three-State Bidirectional Bus Transceivers

## DISTINCTIVE CHARACTERISTICS

- 8 -bit bidirectional data flow reduces system package count
- 3-state inputs/outputs for interfacing with bus-oriented systems; PNP inputs reduce input loading
- $\mathrm{V}_{\mathrm{CC}}-1.15 \mathrm{~V}$ OH interfaces with TTL, MOS and CMOS
- $48 \mathrm{~mA}, 300 \mathrm{pF}$ bus drive capability; Low power -8 mA per bidirectional bit
- Am2946 inverting transceivers; Am2947 noninverting transceivers; Transmit/度eceive and Chip Disable simplify control logic
- Bus port stays in hi-impedance state during power up/ down


## GENERAL DESCRIPTION

The Am2946 and Am2947 are 8-bit state Schottky transceivers. They provide bidirectional drive for bus-oriented microprocessor and digital communications systems. Straight through bidirectional transceivers are featured, with 24 mA drive capability on the A ports and 48 mA bus drive capability on the $B$ ports. PNP inputs are incorporated to reduce input loading.

One input, Transmit/促eceive, determines the direction of logic signals through the bidirectional transceiver. The Chip Disable input disables both A and B ports by placing them in a 3-state condition. Chip Disable is functionally the same as an active LOW chip select.

The output high voltage $\left(\mathrm{V}_{\mathrm{OH}}\right)$ is specified at $\mathrm{V}_{\mathrm{CC}}-1.15 \mathrm{~V}$ minimum to allow interfacing with MOS, CMOS, TTL, ROM, RAM, or microprocessors.


Am2946 has inverting transceivers.


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

[^11]| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am2946 | DC, DCB, DM, |
| Am2947 | DMB |
|  | XC |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{0}-\mathrm{A}_{7}$ | 1/0 | A port inputs/outputs are receiver output drivers when $T / \overline{\mathrm{R}}$ is LOW and are transmit inputs when $T / \overline{\mathrm{R}}$ is HIGH. |
|  | $B_{0}-B_{7}$ | 1/0 | B port inputs/outputs are transmit output drivers when $T / \overline{\bar{R}}$ is HIGH and receiver inputs when $T / \bar{R}$ is LOW. |
| 9 | CD | 1 | Chip Disable forces all output drivers into 3-state when HIGH (same function as active LOW chip select, $\overline{\mathrm{CS}}$ ). |
| 11 | T/ $\bar{R}$ | 1 | Transmit//̄eceive direction control determines whether A port or B port drivers are in 3-state. With T/ $\bar{R}$ HIGH A port is the input and B port is the output. With $T / \overline{\mathrm{R}}$ LOW A port is the output and B port is the input. |

## FUNCTION TABLE

| Inputs | Conditions |  |  |
| :--- | :---: | :---: | :---: |
| Chip Disable | L | L | H |
| Transmit/Receive | L | H | X |
| A Port | Out | In | $\mathrm{HI}-\mathrm{Z}$ |
| B Port | In | Out | $\mathrm{HI}-\mathrm{Z}$ |

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage ..................................................... 7.0 V
Input Voltage 5.5V

Output Voltage .....................................................5.5V
Lead Temperature (Solder, 10 seconds) ................. $300^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified



Figure 1. Propagation Delay from A Port to B Port or from B Port to A Port.


TC001390
Note: $\mathrm{C}_{2}$ and $\mathrm{C}_{3}$ include test fixture capacitance.


WF003110
$t_{r}=t_{f}<10 n s 10 \%$ to $90 \%$

Figure 2. Propagation Delay from $T / \bar{R}$ to $A$ Port or $B$ Port.


Note: $\mathrm{C}_{4}$ includes test fixture capacitance. Port input is in a fixed logical condition.

$\mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}<10 \mathrm{~ns} 10 \%$ to $90 \%$

Figure 3. Propagation Delay from CD to A Port or B Port.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$ Am2946

| Parameter | Description | Test Conditions | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A PORT DATA/MODE SPECIFICATIONS |  |  |  |  |  |
| tPDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure } 1) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 8 | 12 | ns |
| tPDLHA | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 11 | 16 | ns |
| tPLZA | Propagation Delay from a Logical " 0 " to 3-State from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 3) } \\ & \mathrm{S}_{3}=1, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF} \end{aligned}$ | 10 | 15 | ns |
| tPHZA | Propagation Delay from a Logical " 1 " to 3-State from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLA | Propagation Delay from 3-State to a Logical " 0 " from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3 ) $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF}$ | 19 | 25 | ns |
| tpZHA | Propagation Delay from 3-State to a Logical " 1 " from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF}$ | 19 | 25 | ns |

B PORT DATA/MODE SPECIFICATIONS

| tPDHLB | Propagation Delay to a Logical " 0 " from A Port to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 12 | 18 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 7 | 12 | ns |
| tPDLHB | Propagation Delay to a Logical "1" from A Port to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 15 | 20 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 9 | 14 | ns |
| tPLZB | Propagation Delay from a Logical ' 0 ' to 3-State from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3 ) $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 13 | 18 | ns |
| tPHZB | Propagation Delay from a Logical " 1 " to 3-State from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3 ) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLB | Propagation Delay from 3-State to a Logical " 0 " from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=1, \mathrm{R}_{5}=100 \Omega, \mathrm{C}_{4}=300 \mathrm{pF}$ | 25 | 35 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{1}=45 \mathrm{pF}$ | 16 | 22 | ns |
| tPZHB | Propagation Delay from 3-State to a Logical "1" from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=300 \mathrm{pF}$ | 22 | 35 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 14 | 22 | ns |
| TRANSMIT RECEIVE MODE SPECIFICATIONS |  |  |  |  |  |
| tTRL | Propagation Delay from Transmit Mode to Receive a Logical ' 0 ', $T / \bar{R}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & S_{1}=1, R_{4}=100 \Omega, C_{3}=5 \mathrm{pF} \\ & S_{2}=1, R_{3}=1 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 23 | 33 | ns |
| tTR | Propagation Delay from Transmit Mode to Receive a Logical "1", $\mathrm{T} / \overline{\mathrm{R}}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=0, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=5 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, R_{3}=5 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 22 | 33 | ns |
| tric | Propagation Delay from Transmit Mode to Receive a Logical " 0 ", $\mathrm{T} / \overline{\mathrm{R}}$ to B Port | $\begin{aligned} & \mathrm{CD}=0.4 \mathrm{~V} \text { (Figure } 2) \\ & \mathrm{S}_{1}=1, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=1, \mathrm{R}_{3}=300 \Omega, \mathrm{C}_{2}=5 \mathrm{pF} \end{aligned}$ | 26 | 35 | ns |
| trith | Propagation Delay from Transmit Mode to Receive a Logical "1", $T / \bar{R}$ to $B$ Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & S_{1}=0, R_{4}=1 \mathrm{k}, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, R_{3}=300 \Omega, C_{2}=5 \mathrm{pF} \end{aligned}$ | 27 | 35 | ns |

Note: 1. All typical values given are for $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$.
2. Only one output at a time should be shorted.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2946

| Parameter |  |  | COMMERCIAL <br> Am2946 | MILITARY <br> Am2946 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Description | Test Conditions | Max | Max |


| tpDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure } 1) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 16 | 19 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tpdLHA | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 20 | 23 | ns |
| tplZA | Propagation Delay from a Logical " 0 " to 3 -State from CD to A Port | $\begin{aligned} & B_{0} \text { to } B_{7}=2.4 \mathrm{~V}, T / \bar{R}=0.4 \mathrm{~V} \text { (Figure 3) } \\ & S_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF} \end{aligned}$ | 18 | 21 | ns |
| tPHZA | Propagation Delay from a Logical "1" to 3-State from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \quad \text { (Figure 3) } \\ & \mathrm{S}_{3}=0, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF} \end{aligned}$ | 18 | 21 | ns |
| tpZLA | Propagation Delay from 3-State to a Logical " 0 " from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 3) } \\ & \mathrm{S}_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 28 | 33 | ns |
| tpZHA | Propagation Delay from 3-State to a Logical " 1 " from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \bar{R}=0.4 \mathrm{~V} \quad \text { (Figure 3) } \\ & \mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{p} \end{aligned}$ | 28 | 33 | ns |

B PORT DATA/MODE SPECIFICATIONS

| tPDHLB | Propagation Delay to a Logical " 0 " from A Port to B Port | $\begin{aligned} & C D=0.4 V, T / \bar{R}=2.4 \mathrm{~V}(\text { Figure 1) } \\ & R_{1}=100 \Omega, R_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 24 | 29 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 16 | 19 | ns |
| tpdLhB | Propagation Delay to a Logical " 1 " from A Port to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 25 | 30 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 19 | 22 | ns |
| tplzb | Propagation Delay from a Logical " 0 " to 3-State from CD to B Port | $\begin{aligned} & A_{0} \text { to } A_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 3) } \\ & \mathrm{S}_{3}=1, \mathrm{R}_{5}=1 \mathrm{k}, C_{4}=15 \mathrm{pF} \end{aligned}$ | 23 | 26 | ns |
| tPHZB | Propagation Delay from a Logical " 1 " to 3-State from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 18 | 21 | ns |
| tpZLB | Propagation Delay from 3-State to a Logical " 0 " from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=1, \mathrm{R}_{5}=100 \Omega, \mathrm{C}_{4}=300 \mathrm{pF}$ | 38 | 43 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{4}=45 \mathrm{pF}$ | 26 | 30 | ns |
| tPZHB | Propagation Delay from 3-State to a Logical "1" from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $S_{3}=0, R_{5}=1 k, C_{4}=300 \mathrm{pF}$ | 38 | 43 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=45 \mathrm{pF}$ | 26. | 30 | ns |

TRANSMIT RECEIVE MODE SPECIFICATIONS

| tTRL | Propagation Delay from Transmit Mode to Receive a Logical " 0 ", T/ $\bar{R}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=1, \mathrm{R}_{4}=100 \Omega, C_{3}=5 \mathrm{pF} \\ & \mathrm{~S}_{2}=1, \mathrm{R}_{3}=1 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 38 | 43 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tTRH | Propagation Delay from Transmit Mode to Receive a Logical " 1 ", T/R to A Port | $\begin{aligned} & \mathrm{CD}=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=0, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=5 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, \mathrm{R}_{3}=5 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 38 | 43 | ns |
| triL | Propagation Delay from Receive Mode to Transmit a Logical " 0 ", T/ $\bar{R}$ to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure } 2 \text { ) } \\ & S_{1}=1, R_{4}=100 \Omega, C_{3}=300 \mathrm{pF} \\ & S_{2}=1, R_{3}=300 \Omega, C_{2}=5 \mathrm{pF} \end{aligned}$ | 41 | 47 | ns |
| trin | Propagation Delay from Receive Mode to Transmit a Logical " 1 ", $T / \bar{R}$ to $B$ Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=0, \mathrm{R}_{4}=1 \mathrm{k}, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, \mathrm{R}_{3}=300 \Omega, \mathrm{C}_{2}=5 \mathrm{pF} \end{aligned}$ | 41 | 47 | ns |

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$
Am2947

| Parameter | Description | Test Conditions | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A PORT DATA/MODE SPĖCIFICATIONS |  |  |  |  |  |
| tPDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, T / \bar{R}=0.4 \mathrm{~V} \text { (Figure } 1) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 14 | 18 | ns |
| tpdLha | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}(\text { Figure } 1) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 13 | 18 | ns |
| tPLZA | Propagation Delay from a Logical " 0 " to 3-State from CD to A Port | $\mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 3) }$ $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 11 | 15 | ns |
| tPHZA | Propagation Delay from a Logical "1" to 3-State from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLA | Propagation Delay from 3-State to a Logical " 0 " from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3) $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF}$ | 19 | 25 | ns |
| tPZHA | Propagation Delay from 3-State to a Logical " 1 " from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF}$ | 19 | 25 | ns |
| B PORT DATA/MODE SPECIFICATIONS |  |  |  |  |  |
| tpDHLB | Propagation Delay to a Logical " 0 " from A Port to B Port | $\begin{aligned} C D & =0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 1) } \\ \mathrm{R}_{1} & =100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 18 | 23 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 11 | 18 | ns |
| tPDLHB | Propagation Delay to a Logical " 1 " from A Port to B Port | $\begin{aligned} C D & =0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure 1) } \\ R_{1} & =100 \Omega, R_{2}=1 \mathrm{k}, C_{1}=300 \mathrm{pF} \end{aligned}$ | 16 | 23 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 11 | 18 | ns |
| tplzB | Propagation Delay from a Logical ' 0 " to 3-State from CD to B Port | $A_{0}$ to $A_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3},=1, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 13 | 18 | ns |
| tPHZB | Propagation Delay from a Logical "1" to 3-State from CD to B Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $S_{3},=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLB | Propagation Delay from 3-State to a Logical ' 0 ' from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=1, \mathrm{R}_{5}=100 \Omega, \mathrm{C}_{4}=300 \mathrm{pF}$ | 25 | 35 | ns |
|  |  | $\mathrm{R}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{1}=45 \mathrm{pF}$ | 16 | 22 | ns |
| tPZHB | Propagation Delay from 3-State to a Logical "1" from CD to B Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3 ) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=300 \mathrm{pF}$ | 26 | 35 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 14 | 22 | ns |

TRANSMIT RECEIVE MODE SPECIFICATIONS

| tTRL | Propagation Delay from Transmit Mode to Receive a Logical " 0 ", $\mathrm{T} / \overline{\mathrm{R}}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & S_{1}=1, R_{4}=100 \Omega, C_{3}=5 \mathrm{pF} \\ & S_{2}=1, R_{3}=1 \mathrm{k}, C_{2}=30 \mathrm{pF} \end{aligned}$ | 28 | 38 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tTRH }}$ | Propagation Delay from Transmit Mode to Receive a Logical " 1 ", $T / \bar{R}$ to A Port | $\begin{aligned} & \mathrm{CD}=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=1, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=5 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, \mathrm{R}_{3}=5 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 28 | 38 | ns |
| $t_{\text {RTL }}$ | Propagation Delay from Transmit Mode to Receive a Logical " 0 ', $T / \bar{R}$ to $B$ Port | $\begin{aligned} & C D=0.4 V \text { (Figure 2) } \\ & S_{1}=1, R_{4}=100 \Omega, C_{3}=300 \mathrm{pF} \\ & S_{2}=0, R_{3}=300 \Omega, C_{2}=5 \mathrm{pF} \end{aligned}$ | 31 | 40 | ns |
| $t_{\text {RTH }}$ | Propagation Delay from Transmit Mode to Receive a Logical " 1 ", $T / \bar{R}$ to $B$ Port | $\begin{aligned} & \mathrm{CD}=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=0, \mathrm{R}_{4}=1 \mathrm{k}, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=1, \mathrm{R}_{3}=300 \Omega, \mathrm{C}_{2}=5 \mathrm{pF} \end{aligned}$ | 31 | 40 | ns |

Note: 1. All typical values given are for $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. Only one output at a time should be shorted.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2947

| Parameter | Description | Test Conditions | COMMERCIAL <br> Am2947 | MILITARY Am2947 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Max | Max |  |
| A PORT DATA/MODE SPECIFICATIONS |  |  |  |  |  |
| tPDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 1) } \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 21 | 24 | ns |
| tPDLHA | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure } 1 \text { ) } \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 21 | 24 | ns |
| tplza | Propagation Delay from a Logical " 0 " to 3-State from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \mathrm{R}=0.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 18 | 21 | ns |
| tPHZA | Propagation Delay from a Logical "1" to 3-State from CD to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{A}}=0.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=0, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 18 | 21 | ns |
| tPZLA | Propagation Delay from 3-State to a Logical " 0 " from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 3) } \\ & \mathrm{S}_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 28 | 33 | ns |
| tPZHA | Propagation Delay from 3-State to a Logical "1" from CD to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { (Figure 3) } \\ & \mathrm{S}_{3}=0, \mathrm{~K}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 28 | 33 | ns |
| B PORT DATA/MODE SPECIFICATIONS |  |  |  |  |  |
| $t_{\text {PDHLB }}$ | Propagation Delay to a Logical "0" from A Port to B Port | $C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 1) <br> $\mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF}$ <br> $\mathrm{A}_{1}=67 \Omega, \mathrm{R}_{2}=5 \mathrm{c}, \mathrm{C}_{1}=45 \mathrm{l}$ | 28 | 34 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 22 | 25 | ns |
| tPDLHB | Propagation Delay to a Logical "1" from A Port to B Port | $C D=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 1) <br> $\mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF}$ <br> $\mathrm{R}_{1}=67 \Omega, \mathrm{R}_{2}=5 \mathrm{C}$ | 28 | 34 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 22 | 25 | ns |
| tPLZB | Propagation Delay from a Logical "0" to 3-State from CD to B Port | $A_{0}$ to $A_{7}=0.4 \mathrm{~V}, T / \bar{R}=2.4 \mathrm{~V}$ (Figure 3) $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 23 | 26 | ns |
| tPHZB | Propagation Delay from a Logical "1" to 3-State from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3 ) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 18 | 21 | ns |
| tPZLB | Propagation Delay from 3-State to a Logical " 0 " from CD to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $S_{3}=1, R_{5}=100 \Omega, C_{4}=300 \mathrm{pF}$ | 38 | 43 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{4}=45 \mathrm{pF}$ | 26 | 30 | ns |
| tPZHB | Propagation Delay from 3-State to a Logical "1" from CD to B Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \mathrm{~T} / \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure 3) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=300 \mathrm{pF}$ | 38 | 43 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=45 \mathrm{pF}$ | 26 | 30 | ns |


| tTRL | Propagation Delay from Transmit Mode to Receive a Logical " 0 ", T/ $\bar{R}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure } 2 \text { ) } \\ & S_{1}=0, R_{4}=100 \Omega, C_{3}=5 \mathrm{pF} \\ & S_{2}=1, R_{3}=1 \mathrm{k}, C_{2}=30 \mathrm{pF} \end{aligned}$ | 42 | 48 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tTRH | Propagation Delay from Transmit Mode to Receive a Logical " 1 ", T/ $\bar{R}$ to A Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=1, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=5 \mathrm{pF} \\ & \mathrm{~S}_{2}=0, \mathrm{R}_{3}=5 \mathrm{k}, \mathrm{C}_{2}=30 \mathrm{pF} \end{aligned}$ | 42 | 48 | ns |
| $t_{\text {RTL }}$ | Propagation Delay from Receive Mode to Transmit a Logical ' 0 ", T/R to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure } 2 \text { ) } \\ & \mathrm{S}_{1}=1, \mathrm{R}_{4}=100 \Omega, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=1, \mathrm{R}_{3}=300 \Omega, \mathrm{C}_{2}=5 \mathrm{pF} \end{aligned}$ | 45 | 51 | ns |
| $t_{\text {RTH }}$ | Propagation Delay from Receive Mode to Transmit a Logical "1", $T / \bar{R}$ to B Port | $\begin{aligned} & C D=0.4 \mathrm{~V} \text { (Figure 2) } \\ & \mathrm{S}_{1}=0, \mathrm{R}_{4}=1 \mathrm{k}, \mathrm{C}_{3}=300 \mathrm{pF} \\ & \mathrm{~S}_{2}=1, \mathrm{R}_{3}=300 \Omega, \mathrm{C}_{2}=5 \mathrm{pF} \end{aligned}$ | 45 | 51 | ns |

## DISTINCTIVE CHARACTERISTICS

- 8-bit bidirectional data flow reduces system package count
- 3-state inputs/outputs for interfacing with bus-oriented systems; PNP inputs reduce input loading
- $V_{\mathrm{CC}}-1.15 \mathrm{~V} \mathrm{~V}_{\mathrm{OH}}$ interfaces with TTL, MOS, and CMOS
- 48mA, 300pF bus drive capability; Low power - 8 mA per bidirectional bit
- Am2948 has inverting transceivers; Am2949 has non inverting transceivers - both have separate TRANSMIT and RECEIVE Enables
- Bus port stays in hi-impedance state during power up/ down


## GENERAL DESCRIPTION

The Am2948 and Am2949 are 8-bit, 3-state Schottky transceivers. They provide bidirectional drive for busoriented microprocessor and digital communications systems. Straight through bidirectional transceivers are featured, with 24 mA drive capability on the A ports and 48 mA bus drive capability on the $B$ ports. PNP inputs are incorporated to reduce input loading.

Separate TRANSMIT and RECEIVE Enables are provided for microprocessor system with separated read and write control bus lines.

The output high voltage $\left(\mathrm{V}_{\mathrm{OH}}\right)$ is specified at $\mathrm{V}_{\mathrm{CC}}-1.15 \mathrm{~V}$ minimum to allow interfacing with MOS, CMOS, TTL, ROM, RAM, or microprocessors.

BLOCK DIAGRAM


Am2948 has inverting transceivers.


| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{0}-\mathrm{A}_{7}$ | 1/0 | A port inputs/.outputs are receiver output drivers when $\overline{\text { Receive }}$ is LOW and Transmit is HIGH, and are transmit inputs when Receive is HIGH and Transmit is LOW. |
|  | $B_{0}-B_{7}$ | 1/O | B port inputs/outputs are transmit output drivers when Transmit is LOW and $\overline{\text { Receive }}$ is HIGH, and are receiver inputs when Transmit is HIGH and Receive is LOW. |
| 9,11 | $\begin{array}{\|c} \hline \frac{\text { Transmit }}{\text { Receive }} \end{array}$ | 1 | These controls determine whether A port and B port drivers are in 3-state. With both Transmit and $\overline{\text { Receive }}$ HIGH both ports are in 3-state. Transmit and Receive both LOW activate both drivers and may cause oscillations. This is not an intended logic condition. With Transmit HIGH and Receive LOW A port is the output and B port is the input. With Transmit LOW and $\overline{\text { Receive HIGH. B port is the output and A port is the input. }}$ |

FUNCTION TABLE

| Control Inputs |  | Resulting Conditions |  |
| :---: | :---: | :---: | :---: |
| Transmit | Receive | A Port | B Port |
| H | L | Out | In |
| L | H | In | Out |
| H | H | 3-State | 3-State |
| L | L | Both Active $^{*}$ |  |

*This is not an intended logic condition and may cause oscillations.

## ABSOLUTE MAXIMUM RATINGS

| Storage Temp | $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Supply Voltage | 7.0V |
| Input Voltage | 5.5 V |
| Output Voltage | 5.5V |
|  | $300^{\circ} \mathrm{C}$ |

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . \ldots 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
 Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A PORT ( $A_{0}-A_{7}$ ) |  |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical "1" Input Voltage | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{~A}}=2.0 \mathrm{~V}$ |  |  | $2.0$ |  |  | Volts |
| $V_{\text {IL }}$ | Logical "O' Input Voltage | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{~A}}=2.0 \mathrm{~V}$ |  | COM'L |  |  | 0.8 | Volts |
|  |  |  |  | MIL |  |  | 0.7 |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical "1" Output Voltage | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}$ | $\begin{aligned} & \mathrm{OH}=-0.4 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-3.0 \mathrm{~mA} \\ & \hline \end{aligned}$ |  | $V_{C C}-1.15$ | $\mathrm{V}_{\text {CC }}-0.7$ |  | Volts |
|  |  |  |  |  | 2.7 | 3.95 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical' ${ }^{\prime \prime}$ ' Output Voltage | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}$ | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  | 0.3 | 0.4 | Volts |
|  |  |  | COM'L $\mathrm{IOL}=24 \mathrm{~mA}$ |  |  | 0.35 | 0.50 |  |
| los | Output Short Circuit Current | $\begin{aligned} & \overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}, \mathrm{~V}_{0}=0 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{MAX} ; \text { Note } 2 \end{aligned}$ |  |  | -10 | -38 | -75 | mA |
| 1 IH | Logical "1" Input Current | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 0.1 | 80 | $\mu \mathrm{A}$ |
| 1 | Input Current at Maximum Input Voltage | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{~V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1}=\mathrm{V}_{C C} \mathrm{MAX}$ |  |  |  |  | 1 | mA |
| IIL | Logical "0" Input Current | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -70 | -200 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{l}_{\mathrm{N}}=-12 \mathrm{~mA}$ |  |  |  | -0.7 | -1.5 | Volts |
| IOD | Output/Input 3-State Current | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}$ | $V_{O}=0.4 \mathrm{~V}$ |  |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.0 \mathrm{~V}$ |  |  |  | 80 |  |
| B PORT ( $\mathrm{B}_{0}-\mathrm{B}_{7}$ ) |  |  |  |  |  |  |  |  |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}$ |  |  | 2.0 |  |  | Volts |
| VIL | Logical " 0 " Input Voltage | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}$ |  | COM'L |  |  | 0.8 | Volts |
|  |  |  |  | MIL |  |  | 0.7 |  |
| $\mathrm{VOH}^{\text {O }}$ | Logical "1" Output Voltage | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{R}}=2.0 \mathrm{~V}$ | $\mathrm{OH}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\text {CC }}-1.15$ | $\mathrm{V}_{\text {CC }}-0.8$ |  | Volts |
|  |  |  | $\begin{aligned} & \mathrm{IOH}=-5.0 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mathrm{~mA} \\ & \hline \end{aligned}$ |  | 2.7 | 3.9 |  |  |
|  |  |  |  |  | 2.4 | 3.6 |  |  |
| $\mathrm{VOL}_{\text {O }}$ | Logical " 0 " Output Voltage | $\overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{R}}=2.0 \mathrm{~V}$ | $\mathrm{OL}=20 \mathrm{~mA}$ |  |  | 0.3 | 0.4 | Volts |
|  |  |  | $\mathrm{OL}=48 \mathrm{~mA}$ |  |  | 0.4 | 0.5 |  |
| Ios | Output Short Circuit Current | $\begin{aligned} & \overline{\mathrm{T}}=0.8 \mathrm{~V}, \overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{MAX}, \text { Note } 2 \end{aligned}$ |  |  | -25 | -50 | -150 | mA |
| 1 IH | Logical "1" Input Current | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}, \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 0.1 | 80 | $\mu \mathrm{A}$ |
| 1 | Input Current at Maximum Input Voltage | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{~V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1}=\mathrm{V}_{C C} \mathrm{MAX}$ |  |  |  |  | 1 | mA |
| IIL | Logical ' 0 " Input Current | $\overline{\mathrm{T}}=2.0 \mathrm{~V}, \overline{\mathrm{R}}=0.8 \mathrm{~V}, \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -70 | -200 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{N}}=-12 \mathrm{~mA}$ |  |  |  | -0.7 | -1.5 | Volts |
| IOD | Output/Input 3-State Current | $\overline{\mathrm{T}}=\overline{\mathrm{R}}=2.0 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -200 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=4.0 \mathrm{~V}$ |  |  |  | 200 |  |



Figure A. Propagation Delay from A Port to B Port or from B Port to A Port.

$t_{r}=t_{f}<10 \mathrm{~ns}$
$10 \%$ to $90 \%$

Figure B. Propagation Delay to/from Three-State from $\overline{\mathbf{R}}$ to A Port and $\overline{\mathrm{T}}$ to B Port.

| SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$ Am2948 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Description | Test Conditions | Typ | Max | Units |
| A PORT DATA／MODE SPECIFICATIONS |  |  |  |  |  |
| tpDHLA | Propagation Delay to a Logical＂0＂from B Port to A Port | $\begin{aligned} & \bar{T}=2.4 \mathrm{~V}, \overline{\mathrm{~A}}=0.4 \mathrm{~V}(\text { Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 8 | 12 | ns |
| tpdLHA | Propagation Delay to a Logical＂1＂from B Port to A Port | $\begin{aligned} & \bar{T}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=0.4 \mathrm{~V} \text { ( Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 11 | 16 | ns |
| tplza | Propagation Delay from a Logical＇ 0 ＇to 3－State from $\overline{\mathrm{A}}$ to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$（Figure B ） $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 10 | 15 | ns |
| tPHZA | Propagation Delay from a Logical＂ 1 ＂to 3－State from $\vec{R}$ to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$（Figure B ） $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLA | Propagation Delay from 3－State to a Logical＇ 0 ＇ from $\overline{\mathrm{R}}$ to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$（Figure B ） $S_{3}=1, R_{5}=1 k, C_{4}=30 \mathrm{pF}$ | 20 | 27 | ns |
| tpZHA | Propagation Delay from 3－State to a Logical＂1＂ from $\overline{\mathrm{A}}$ to A Port | $\begin{aligned} & \left.\mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{B}\right) \\ & \mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 20 | 27 | ns |
| B PORT DATA／MODE SPECIFICATIONS |  |  |  |  |  |
| tpDHLB | Propagation Delay to a Logical＂ 0 ＂from A Port to B Port | $\begin{aligned} & \bar{T}=0.4 \mathrm{~V}, \overline{\mathrm{~B}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 12 | 18 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 8 | 12 | ns |
| tPDLHB | Propagation Delay to a Logical＂1＂from A Port to B Port | $\begin{aligned} & \bar{T}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=100 \Omega, R_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 15 | 20 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 9 | 14 | ns |
| tplzB | Propagation Delay from a Logical＇ 0 ＇to 3－State from $T$ to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$（Figure B ） $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 13 | 18 | ns |
| tPHZB | Propagation Delay from a Logical＂ 1 ＂to 3－State from $T$ to $B$ Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$（Figure B ） $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 8 | 15 | ns |
| tPZLB | Propagation Delay from 3－State to a Logical＂ 0 ＂ from T to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$（Figure B） $S_{3}=1, R_{5}=100 \Omega, C_{4}=300 \mathrm{pF}$ | 25 | 35 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{1}=45 \mathrm{pF}$ | 18 | 25 | ns |
| tPZHB | Propagation Delay from 3－State to a Logical＂ 1 ＂ from T to B Port | $A_{0}$ to $A_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~B}}=2.4 \mathrm{~V}$（Figure B） $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=300 \mathrm{pF}$ | 25 | 35 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=45 \mathrm{pF}$ | 16 | 25 | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2948

| Parameter |  |  | $\begin{array}{c}\text { COMMERCIAL } \\ \text { Am2948 }\end{array}$ | MILITARY |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |$]$

A PORT DATA/MODE SPECIFICATIONS

| tPDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & \bar{T}=2.4 \mathrm{~V}, \overrightarrow{\mathrm{R}}=0.4 \mathrm{~V}(\text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 19 | 16 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tpdLHA | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & \bar{T}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=0.4 \mathrm{~V}(\text { Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 23 | 20 | ns |
| tplZA | Propagation Delay from a Logical " 0 " to 3-State from $\bar{A}$ to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=2.4 \mathrm{~V}, \mathrm{~T}=2.4 \mathrm{~V} \text { (Figure B) } \\ & \mathrm{S}_{3}=1, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF} \end{aligned}$ | 21 | 18 | ns |
| tPHZA | Propagation Delay from a Logical " 1 " to 3-State from B to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V} \text { (Figure B) } \\ & \mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF} \end{aligned}$ | 21 | 18 | ns |
| tPZLA | Propagation Delay from 3-State to a Logical " 0 " from R to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}=2.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V} \text { (Figure B) } \\ & \mathrm{S}_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 35 | 30 | ns |
| tpZHA | Propagation Delay from 3-State to a Logical " 1 " from A to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V} \text { (Figure B) } \\ & \mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 35 | 30 | ns |

B PORT DATA/MODE SPECIFICATIONS

| tPDHLB | Propagation Delay to a Logical " 0 " from A Port to B Port | $\begin{aligned} & \overline{\mathrm{T}}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure A) } \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 29 | 24 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 19 | 16 | ns |
| tPDLHB | Propagation Delay to a Logical "1" from A Port to B Port | $\begin{aligned} & \overline{\mathrm{T}}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 30 | 25 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 22 | 19 | ns |
| tPLZB | Propagation Delay from a Logical " 0 " to 3-State from T to B Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \bar{R}=2.4 \mathrm{~V}$ (Figure B ) $\mathrm{S}_{3}=1, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 26 | 23 | ns |
| tPHZB | Propagation Delay from a Logical "1" to 3-State from $\bar{T}$ to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure B ) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 21 | 18 | ns |
| tPZLB | Propagation Delay from 3-State to a Logical " 0 " from T to B Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure B ) $\mathrm{S}_{3}=1, \mathrm{R}_{5}=100 \Omega, \mathrm{C}_{4}=300 \mathrm{pF}$ | 43 | 38 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{4}=45 \mathrm{pF}$ | 33 | 28 | ns |
| tPZHB | Propagation Delay from 3-State to a Logical " 1 " from $\bar{T}$ to $B$ Port | $A_{0}$ to $A_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~A}}=2.4 \mathrm{~V}$ (Figure B ) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=300 \mathrm{pF}$ | 43 | 38 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=45 \mathrm{pF}$ | 33 | 28 | ns |



SWITCHING CHARACTERISTICS over operating range unless otherwise specified Am2949

| Parameter | Description | Test Conditions | COMMERCIAL Am2949 | MILITARY Am2949 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Max | Max |  |
| A PORT DATA/MODE SPECIFICATIONS |  |  |  |  |  |
| tPDHLA | Propagation Delay to a Logical " 0 " from B Port to A Port | $\begin{aligned} & T_{1}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=0.4 \mathrm{~V}(\text { Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 24 | 21 | ns |
| tPDLHA | Propagation Delay to a Logical "1" from B Port to A Port | $\begin{aligned} & \bar{T}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=0.4 \mathrm{~V}(\text { Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=1 \mathrm{k}, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=30 \mathrm{pF} \end{aligned}$ | 24 | 21 | ns |
| tPLZA | Propagation Delay from a Logical "0" to 3-State from R to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$ (Figure B ) $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 21 | 18 | ns |
| tPHZA | Propagation Delay from a Logical " 1 " to 3-State from R to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$ (Figure B ) $\mathrm{S}_{3}=0, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 21 | 18 | ns |
| tpZLA | Propagation Delay from 3-State to a Logical " 0 " from R to A Port | $\begin{aligned} & \mathrm{B}_{0} \text { to } \mathrm{B}_{2}=0.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V} \text { (Figure B) } \\ & \mathrm{S}_{3}=1, \mathrm{~K}_{5}=1 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF} \end{aligned}$ | 35 | 30 | ns |
| $t^{\text {tPZHA }}$ | Propagation Delay from 3-State to a Logical "1" from A to A Port | $\mathrm{B}_{0}$ to $\mathrm{B}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{~T}}=2.4 \mathrm{~V}$ (Figure B ) $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=30 \mathrm{pF}$ | 35 | 30 | ns |

B PORT DATA/MODE SPECIFICATIONS

| tPDHLB | Propagation Delay to a Logical " 0 " from A Port to B Port | $\begin{aligned} & \bar{T}=0.4 \mathrm{~V}, \overline{\mathrm{~A}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 34 | 28 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 25 | 22 | ns |
| tpDLHB | Propagation Delay to a Logical "1" from A Port to B Port | $\begin{aligned} & \overline{\mathrm{T}}=0.4 \mathrm{~V}, \overline{\mathrm{~B}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{A}) \\ & \mathrm{R}_{1}=100 \Omega, \mathrm{R}_{2}=1 \mathrm{k}, \mathrm{C}_{1}=300 \mathrm{pF} \end{aligned}$ | 34 | 28 | ns |
|  |  | $\mathrm{R}_{1}=667 \Omega, \mathrm{R}_{2}=5 \mathrm{k}, \mathrm{C}_{1}=45 \mathrm{pF}$ | 25 | 22 | ns |
| tplZB | Propagation Delay from a Logical " 0 " to 3-State from $\bar{T}$ to B Port | $\left.\mathrm{A}_{0} \text { to } \mathrm{A}_{7}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V} \text { (Figure } \mathrm{B}\right)$ $S_{3}=1, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 26 | 23 | ns |
| tphzs | Propagation Delay from a Logical "1" to 3-State from $\bar{T}$ to B Port | $\mathrm{A}_{0}$ to $\mathrm{A}_{7}=2.4 \mathrm{~V}, \overline{\mathrm{R}}=2.4 \mathrm{~V}$ (Figure B ) $S_{3}=0, R_{5}=1 \mathrm{k}, \mathrm{C}_{4}=15 \mathrm{pF}$ | 21 | 18 | ns |
| tPZLB | Propagation Delay from 3-State to a Logical " 0 " from $\bar{T}$ to $B$ Port | $A_{0}$ to $A_{7}=0.4 \mathrm{~V}, \overline{\mathrm{R}}=0.4 \mathrm{~V}$ (Figure B ) $S_{3}=1, R_{5}=100 \Omega, C_{4}=300 \mathrm{pF}$ | 43 | 38 | ns |
|  |  | $\mathrm{S}_{3}=1, \mathrm{R}_{5}=667 \Omega, \mathrm{C}_{4}=45 \mathrm{pF}$ | 33 | 28 | ns |
| tpZHB | Propagation Delay from 3-State to a Logical "1" from $\bar{T}$ to $B$ Port | $A_{0}$ to $A_{7}=2.4 \mathrm{~V}, \bar{R}=2.4 \mathrm{~V}$ (Figure B) $S_{3}=0, R_{5}=1 k, C_{4}=300 \mathrm{pF}$ | 43 | 38 | ns |
|  |  | $\mathrm{S}_{3}=0, \mathrm{R}_{5}=5 \mathrm{k}, \mathrm{C}_{4}=45 \mathrm{pF}$ | 33 | 28 | ns |

# Am2950-50A/Am2951-51A 

Eight-Bit Bidirectional I/O Ports with Handshake

## DISTINCTIVE CHARACTERISTICS

- Eight-Bit, Bidirectional I/O Port with HandshakeTwo eight-bit, back-to-back registers store data moving in both directions between two bidirectional busses.
- Register Full/Empty Flags-

On-chip flag flip-flops provide data transfer handshaking signals.

- 24mA Output Current Sink Capability.
- Separate Clock, Clock Enable and Three-State Output Enable for Each Register.
- Separate, Edge-Sensitive Clear Control for Each Flag Flip-Flop.
- Fast -

The Am2950A and Am2951A will be 25-30\% faster than the Am2950 and Am2951.

## GENERAL DESCRIPTION

The Am2950 and Am2951, members of Advanced Micro Devices' Am 2900 Family, are designed for use as parallel data I/O ports. Two eight-bit, back-to-back registers store data moving in both directions between two bidirectional, 3state busses. On chip flag flip-flops, set automatically when a register is loaded, provide the handshaking signals required for demand-response data transfer.

Considerable flexibility is designed into the Am2950/ Am2951. Separate clock, Clock Enable and Three-State Output Enable signals are provided for each register, and
edge-sensitive clear inputs are provided for each flag flipflop. A number of these circuits can be used for wider I/O ports. Both inverting and non-inverting versions are available.

24 mA output current sink capability, sufficient for most three-state busses, is provided by the Am2950/Am2951.
The Am2950A and Am2951A feature AMD's ion-implanted micro-oxide ( $\mathrm{IMOX}^{\top}{ }^{\mathrm{M}}$ ) processing. They are plug-in replacements for the Am2950 and Am2951 respectively but will be approximately $30 \%$ faster.



BD002421

Note: The Am2951 provides inverting data outputs ( $\mathrm{B}_{0-7}$ ).


CD004650

CONNECTION DIAGRAM Top View

F-28
$\underset{\text { L-28 }}{\text { Chip-Pak }}{ }^{\text {TM }}$


CD004640
Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type
8-Bit Bidirectional I/O Ports


Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## APPLICATIONS

The Am2950/Am2951 provides data transfer handshaking signals as well as eight-bit, bidirectional data storage. Its flexibility allows it to be used in any type of computer system, including Am2900, 8080, 8085, 8086, Z80, and Z8000 systems.

Figure 1 shows an Am2950 used to store data moving in both directions between a bidirectional system data bus and a
bidirectional peripheral data bus. The on-chip Flag flip-flops provide the data in, data out handshaking signals required for data transfer and interrupt request generation.

Figure 2 shows a multiple I/O port system using Am2950's. Two Am2950's are used at each port to interface the 16-bit system data bus. The Am2950 flags are used to generate I/O interrupt requests.


Figure 1. A Bidirectional I/O Port with Handshaking Using the Am2950.


Figure 2. Multiple I/O Port System.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ...................................... 0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage. $\qquad$ ... -0.5 V to +5.5 V
DC Output Current, Into Outputs .......................... 30 mA
DC Input Current.............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature ............................... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage ............................... +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified
Am2950/Am2951

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ <br> (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | FR, FS | $\mathrm{OH}=-1 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ | MIL, $\mathrm{I}^{\text {OH }}=-2 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
| $\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}$ | FR,FS | $\mathrm{OL}=12 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ | $\mathrm{MIL} \mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
|  |  |  |  | COM'L, $\mathrm{IOL}=2.4 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input voltage for all inp | $\begin{aligned} & \text { logical HIGH } \\ & \text { puts } \\ & \hline \end{aligned}$ |  | 2.0 |  |  | Volts |
| VIL. | Input LOW Level | Guaranteed input voltage for all inp | $\begin{aligned} & \text { logical LOW } \\ & \text { outs } \end{aligned}$ |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}=$ | - 18 mA |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=0.5 \mathrm{~V}$ |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ |  |  | -250 | $\mu \mathrm{A}$ |
|  |  |  |  | CLRR,CLRS |  |  | -2.0 | mA |
|  |  |  |  | Others |  |  | -360 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | CLRR, CLRS |  |  | 100 |  |
|  |  |  |  | Others |  |  | 20 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| 10 | Output Off-state Leakage Current | $V_{C C}=M A X$ | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -250 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -30 |  | -85 | mA |
| Icc | Power Supply Current (Notes 4,5) | $V_{C C}=M A X$ | COM'L | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  | 275 | mA |
|  |  |  |  | $\mathrm{T}^{\prime}=+70^{\circ} \mathrm{C}$ |  |  | 228 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  | 309 |  |
|  |  |  | MIL | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 202 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is measured with all inputs at 4.5 V and all outputs open.
5. Worst case ICC is at minimum temperature.

## A. THREE-STATE OUTPUTS <br> B. NORMAL OUTPUTS



$$
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{~K}}}
$$

$$
\begin{aligned}
& \mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{lOH}} \\
& \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{\mathrm{R}_{2}}}
\end{aligned}
$$

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in VCC current when the device switches may cause erroneous function failures due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground
cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $V_{\mathbb{I H}}$ until the noise has settled. AMD recommends using $V_{\mathrm{IL}} \leqslant O \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

## Am2950A/Am2951A SWITCHING CHARACTERISTICS

The tables below define the Am2950A/Am2951A switching characteristics. Tables A are setup and hold times relative to a clock LOW-to-HIGH transition. Tables B are propagational delays. Tables $C$ are recovery times. Tables $D$ are pulse-width requirements. Tables E are enable/disable times. All measurements are made at 1.5 V with input levels at 0 V or 3 V . All values are in ns with RL on Ai and $\mathrm{Bi}=220 \Omega$ and RL on FS and $\mathrm{FR}=300 \Omega$. $\mathrm{CL}=50 \mathrm{pF}$ except output disable times which are specified at $\mathrm{CL}=5 \mathrm{pF}$.

## gUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

$$
\left(\mathrm{T}_{\mathrm{A}}=0 \text { to }+70^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.75 \text { to } 5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

A. Set-up and Hold Times.

| Input | With <br> Respect To |  | ts | th |
| :---: | :--- | ---: | :---: | :---: |
| A0-7 | CPR | $\Gamma$ |  |  |
| B0-7 | CPS | $\Gamma$ |  |  |
| CES | CPS | $\Gamma$ |  |  |
| CER | CPR | $\Gamma$ |  |  |

## C. Recovery Times

| From | To | tREC |
| :---: | :---: | :---: |
| CLRS $\Gamma$ | CPS $\Gamma$ |  |
| CLRR $\Gamma$ | CPR $\Gamma$ |  |

B. Propagation Delays

| Input | A0-7 | B0-7 | FS | FR |
| :---: | :---: | :---: | :---: | :---: |
| CPS $\Gamma$ |  |  |  |  |
| CPR $\Gamma$ |  |  |  |  |
| CLRS $\Gamma$ |  |  |  |  |
| CLRR $\Gamma$ |  |  |  |  |

D. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS |  |  |
| CPR |  |  |
| CLRS |  |  |
| CLRR |  |  |

E. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\text { OEAS }}$ | $\mathrm{AO}-7$ |  |  |
| OEBR | BO-7 |  |  |

## GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE

$$
\left(T_{C}=-55 \text { to }+125^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

A. Set-up and Hold Times.

| Input | With <br> Respect To |  | ts | th |
| :---: | :--- | :---: | :---: | :---: |
| A0-7 | CPR | $\Gamma$ |  |  |
| B0-7 | CPS | $\Gamma$ |  |  |
| CES | CPS | $\Gamma$ |  |  |
| $\overline{\text { CER }}$ | CPR | $\Gamma$ |  |  |

B. Propagation Delays

| Input | A0-7 | B0-7 | FS | FR |
| :---: | :---: | :---: | :---: | :---: |
| CPS $\Gamma$ |  |  |  |  |
| CPR $\Gamma$ |  |  |  |  |
| CLRS $\Gamma$ |  |  |  |  |
| CLRR $\Gamma$ |  |  |  |  |



## Am2950/Am2951 SWITCHING CHARACTERISTICS

The tables below define the Am2950/Am2951 switching characteristics. Tables A are set-up and hold times relative to a clock LOW-to-HIGH transition. Tables B are propagational delays. Tables C are recovery times. Tables D are pulse-width requirements. Tables E are enable/disable times. All measurements are made at 1.5 V with input levels at 0 V or 3 V . All values are in ns with RL on Ai and $\mathrm{Bi}=220 \Omega$ and RL on FS and $\mathrm{FR}=300 \Omega$. $\mathrm{CL}=50 \mathrm{pF}$ except output disable times which are specified at $\mathrm{CL}=5 \mathrm{pF}$.

GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

$$
\left(\mathrm{T}_{\mathrm{A}}=0 \text { to }+70^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.75 \text { to } 5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

## A. Set-up and Hold Times.

| Input | With <br> Respect To |  | ts | th |
| :---: | :--- | :---: | :---: | :---: |
| A0-7 | CPR | $\Gamma$ | 7 | 5 |
| B0-7 | CPS | $\Gamma$ | 7 | 5 |
| CES | CPS | $\Gamma$ | ${ }^{*} 19 / 15$ | 4 |
| CER | CPR | $\Gamma$ | ${ }^{*} 19 / 15$ | 4 |


| From | To |  | tREC |
| :---: | :---: | :---: | :---: |
| CLRS $\boldsymbol{\Gamma}$ | CPS | $\Gamma$ | 31 |
| CLRR $\digamma$ | CPR | $\Gamma$ | 31 |

D. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS | 20 | 20 |
| CPR | 20 | 20 |
| CLRS | 20 | 20 |
| CLRR | 20 | 20 |

E. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\text { OEAS }}$ | A0-7 | 22 | 27 |
| $\overline{\text { OEBR }}$ | B0-7 | 22 | 27 |

*Where two numbers appear, the first is the Am2950 spec, the second is the Am2951 spec.

## guaranteed characteristics OVER military operating range

$$
\left(\mathrm{T}_{\mathrm{C}}=-55 \text { to }+125^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

A. Set-up and Hold Times.

| Input | With <br> Respect To |  | ts | th |
| :---: | :--- | :---: | :---: | :---: |
| A0-7 | CPR | $\Gamma$ | 11 | $\mathbf{8}$ |
| B0-7 | CPS | $\Gamma$ | 11 | $\mathbf{8}$ |
| $\overline{C E S}$ | CPS | $\Gamma$ | $* 20 / 15$ | 4 |
| $\overline{C E R}$ | CPR | $\Gamma$ | ${ }^{*} 20 / 15$ | 4 |


| From | To | tREC |
| :---: | :---: | :---: |
| CLRS 5 | CPS 5 | 34 |
| CLRR 5 | CPR 5 | 34 |

B. Propagation Delays

| Input | A0-7 | B0-7 | FS | FR |
| :---: | :---: | :---: | :---: | :---: |
| CPS $\Gamma$ | $* 35 / 28$ | - | 20 | - |
| CPR $\Gamma$ | - | $* 35 / 28$ | - | 20 |
| CLRS $\Gamma$ | - | - | 22 | - |
| CLRR $\Gamma$ | - | - | - | 22 |


| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS | 20 | 20 |
| CPR | 20 | 20 |
| CLRS | 20 | 20 |
| CLRR | 20 | 20 |

## E. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\text { OEAS }}$ | A0-7 | 24 | 28 |
| $\overline{\text { OEBR }}$ | BO-7 | 24 | 28 |

*Where two numbers appear, the first is the Am2950 spec, the second is the Am2951 spec.

# Am2952-52A/Am2953-53A 

Eight-Bit Bidirectional I/O Ports with Handshake

## DISTINCTIVE CHARACTERISTICS

- Eight-Bit, Bidirectional I/O Port Two eight-bit, back-to-back registers store data moving in both directions between two bidirectional busses.
- Separate Clock, Clock Enable and Three-State Output Enable for Each Register.
- 24mA Output Current Sink Capability.
- Inverting and Non-Inverting Versions -

The Am2952 provides non-inverting data outputs. The Am2953 provides inverting data outputs.

- 24-pin Slim Package
- Fast -

The Am2952A and Am2953A will be 25-30\% faster than the Am2952 and Am2953.

## GENERAL DESCRIPTION

The Am2952 and Am2953, members of Advanced Micro Devices' Am2900 Family, are designed for use as parallel data I/O ports. Two eight-bit, back-to-back registers store data moving in both directions between two bidirectional, 3state busses. On chip flag flip-flops, set automatically when a register is loaded, provide the handshaking signals required for demand-response data transfer.

Considerable flexibility is designed into the Am2952/ Am2953. Separate Clock, Clock Enable and Three-State Output Enable signals are provided for each register, and
edge-sensitive clear inputs are provided for each flag flipflop. A number of these circuits can be used for wider I/O ports. Both inverting and non-inverting versions are available.

24mA output current sink capability, sufficient for most three-state busses, is provided by the Am2952/Am2953.

The Am2952A and Am2953A feature AMD's ion-implanted micro-oxide (IMOX ${ }^{\text {TM }}$ ) processing. They are plug-in replacements for the Am2952 and Am2953 respectively but will be approximately $30 \%$ faster.

## CONNECTION DIAGRAM Top View

Am2952
D-24-SLIM


CD004820
Note: Pin 1 is marked for orientation
$B_{i}$ is inverted on Am2953


ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am2952/52A
Am2953/53A
```



Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )

- Package

$$
\begin{aligned}
& \text { D- } 24 \text {-pin SLIMDIP } \\
& \text { X-Dice }
\end{aligned}
$$

Device type
8-Bit Bidirectional I/O Ports

| Valid Combinations |  |  |
| :--- | :--- | :---: |
| Am2952/52A | DC, DCB, DMB |  |
| Am2953/53A | XC, XM |  |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | AO-7 | I/O | Eight bidirectional lines carrying the R Register inputs or S Register outputs. |
| 10 | BO-7 | I/O | Eight bidirectional lines carrying the S Register inputs or R Register outputs. |
| 11 | CPR | I | The clock for the R Register. When CER is LOW, data is entered into the R Register on the LOW-to-HIGH <br> transition of the CPR signal. |
| 9 | OEBR | I | The Clock Enable for the R Register. When CER is LOW, data is entered into the R Register on the LOW-to-HIGH <br> transition of the CPR signal. When CER is HIGH, the R Register holds its contents, regardless of CPR signal <br> transitions. |
| 14 | CPS | I | The Output Enable for the R Register. When OEBR is LOW, the R Register three-state outputs are enabled onto <br> the BO-7 lines. When OEBR is HIGH, the R Register outputs are in the high-impedance state. |
| 13 | CES | The clock for the S Register. When CES is LOW, data is entered into the S Register on the LOW-to-HIGH transition <br> of the CPS signal. |  |
| 15 | I | The clock enable for the S Register. When CES is LOW, data is entered into the S Register on the LOW-to-HIGH <br> transition of the CPS signal. When CES is HIGH, the S Register holds its contents, regardless of CPS signal <br> transitions. |  |

REGISTER FUNCTION TABLE
(Applies to R or S Register)

| Inputs |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{D}$ | $\mathbf{C P}$ | $\mathbf{C E}$ | Internal <br> Q | Function |
| X | X | H | NC | Hold Data |
| L | $\uparrow$ | L | L | Load Data |
| H | $i$ | L | H |  |

OUTPUT CONTROL

| $\overline{O E}$ | Internal Q | Y-Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Am2950 | Am2951 |  |
| H | X | Z | 2 | Disable Outputs |
| L | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | L | H L | Enable Outputs |

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
..............................
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to +7.0 V
$\qquad$
-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage

DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{A}_{0-7}, \mathrm{~B}_{0-7}$ | $\mathrm{MIL}, \mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  |  | COM'L, $\mathrm{IOL}=-6.5 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
| $\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{A}_{0.7} \mathrm{~B}_{0-7}$ | $\mathrm{MIL}, \mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  |  | COM'L, $\mathrm{l}^{\text {OL }}=24 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{iH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=0.5 \mathrm{~V}$ |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ |  |  | -250 | $\mu \mathrm{A}$ |
|  |  |  |  | Others |  |  | -360 | $\mu \mathrm{A}$ |
| IIH | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | Others |  |  | 20 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1.0 | mA |
| 10 | Output Off-state Leakage Current | $V_{C C}=M A X$ | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -250 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  | -30 |  | -85 | mA |
| ICC | Power Supply Current (Notes 4, 5) | $V_{C C}=\mathrm{MAX}$ | COM'L | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |  |  | 275 | mA |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |  |  | 228 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |  |  | 309 |  |
|  |  |  | MIL | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 202 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is measured with all inputs at 4.5 V and all outputs open.
5. Worst case ICC is at minimum temperature.

## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS


$$
\begin{aligned}
& \mathrm{TCO01100} \mathrm{R}_{2} \\
&=\frac{2.4 \mathrm{~V}}{\mathrm{lOH}} \\
& \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{IOL}+\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{~K}}} \mathrm{R}_{1}
\end{aligned}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{\mathrm{R}_{2}}}
$$



Notes: 1. $C_{L}=50 p F$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test.
4. $C_{L}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am2952/2953

| Pin\# <br> (DIP) | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| $16-23$ | $\mathrm{~A}_{0-7}$ | A | 220 | 1 K |
| $1-8$ | $\mathrm{~B}_{0-7}$ | A | 220 | 1 K |

For additional information on testing, see section
"Guidelines on Testing Am2900 Family Devices."

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in V $V_{C C}$ current when the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground
cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{\text {IL }}$ or $\mathrm{V}_{\mathrm{IH}}$ until the noise has settled. AMD recommends using $V_{I L} \leqslant O V$ and $V_{I H} \geqslant 3.0 \mathrm{~V}$ for $A C$ tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

## Am2952A/Am2953A SWITCHING CHARACTERISTICS

The tables below define the Am2952/Am2953A switching characteristics. Tables A are set-up and hold times relative to a clock LOW-to-HIGH transition. Tables $B$ are propagational delays. Tables $C$ are pulse-width requirements. Tables $D$ are enable/disable times. All measurements are made at 1.5 V with input levels at 0 V or 3 V . All values are in ns with $R_{L}$ on $A_{i}$ and $B_{i}=220 \Omega$ and $R_{L}$ on FS and $\mathrm{FR}=300 \Omega$. $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ except output disable times which are specified at $C_{L}=5 \mathrm{pF}$.

## GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

( $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )
A. Set-up and Hold Times
B. Propagation Delays

| Input | $\begin{gathered} \text { With } \\ \text { Respect To } \end{gathered}$ | $\mathrm{t}_{\text {s }}$ | $t_{n}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0.7} \mathrm{~J}$ | CPR |  |  |
| $\mathrm{B}_{0.7} \mathrm{~F}$ - | CPS |  |  |
| $\overline{\text { CES }}$ - | CPS |  |  |
| $\overline{\mathrm{CE} R}$ 「 | CPR |  |  |


| Input | $\mathbf{A}_{\mathbf{0}-\mathbf{7}}$ | $\mathbf{B}_{\mathbf{0}-\mathbf{7}}$ |
| :---: | :---: | :---: |
| CPS - |  |  |
| CPR - |  |  |

C. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS |  |  |
| CPR |  |  |


| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE} A S}$ | $\mathrm{~A}_{0-7}$ |  |  |
| $\overline{\mathrm{OE}} \mathrm{BR}$ | $\mathrm{B}_{0-7}$ |  |  |

guaranteed characteristics over commercial operating range

$$
\left(T_{C}=-55 \text { to }+125^{\circ} \mathrm{C}, V_{C C}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

A. Set-up and Hold Times.

| Input | With Respect To | $t_{s}$ | $t_{n}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0-7}$ - 5 | CPR |  |  |
| $\mathrm{B}_{0-7}$ J | CPS |  |  |
| $\overline{\text { CES }-5}$ | CPS |  |  |
| $\overline{\text { CER }-5}$ | CPR |  |  |


| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS |  |  |
| CPR |  |  |

B. Propagation Delays

| Input | $\mathbf{A}_{\mathbf{0}-\mathbf{7}}$ | $\mathbf{B}_{\mathbf{0 . 7}}$ |
| :---: | :---: | :---: |
| CPS $\Gamma$ |  |  |
| CPR $\Gamma$ |  |  |

D. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\text { OEAS }}$ | $A_{0-7}$ |  |  |
| $\overline{\mathrm{OE}} \mathrm{BR}$ | $\mathrm{B}_{0-7}$ |  |  |

## Am2952/Am2953 SWITCHING CHARACTERISTICS

The tables below define the Am2952/Am2953 switching characteristics. Tables A are set-up and hold times relative to a clock LOW-to-HIGH transition. Tables B are propagational delays. Tables C are pulse-width requirements. Tables D are enable/disable times. All measurements are made at 1.5 V with input levels at 0 V or 3 V . All values are in ns with $R_{L}$ on $A_{i}$ and $B_{i}=220 \Omega$ and $R_{L}$ on $F S$ and $F R=300 \Omega$. $C_{L}=50 \mathrm{pF}$ except output disable times which are specified at $C_{L}=5 p F$.

GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

$$
\left(T_{A}=0 \text { to }+70^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.75 \text { to } 5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

## A. Set-up and Hold Times

| Input | With <br> Respect To | $\mathbf{t}_{\mathbf{s}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0-7} \boldsymbol{\Gamma}$ | CPR | 7 | 5 |
| $\mathrm{~B}_{0-7} \boldsymbol{\Gamma}$ | CPS | 7 | 5 |
| $\overline{\mathrm{CE}} \boldsymbol{\Gamma}$ | CPS | ${ }^{*} 19 / 15$ | 4 |
| $\mathrm{CE} \quad \boldsymbol{\Gamma}$ | CPR | ${ }^{*} 19 / 15$ | 4 |

B. Propagation Delays

| Input | $\mathbf{A}_{\mathbf{0}-\mathbf{7}}$ | $\mathbf{B}_{\mathbf{0 - 7}}$ |
| :---: | :---: | :---: |
| CPS F | ${ }^{* 30 / 26}$ | - |
| CPR $\boldsymbol{\Gamma}$ | - | ${ }^{*} 30 / 26$ |

C. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS | 20 | 20 |
| CPR | 20 | 20 |

D. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}} A \mathrm{~S}$ | $\mathrm{~A}_{0-7}$ | 22 | 27 |
| $\overline{\mathrm{OE}} \mathrm{BR}$ | $\mathrm{B}_{0-7}$ | 22 | 27 |

*Where two numbers appear, the first is the Am2952 spec, the second is the Am2953 spec.

## GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE

$$
\left(T_{C}=-55 \text { to }+125^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=4.5 \text { to } 5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\right)
$$

## A. Set-up and Hold Times

| Input | With <br> Respect To | $\mathbf{t}_{\mathbf{s}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0-7} \boldsymbol{\Gamma}$ | CPR | 11 | 8 |
| $\mathrm{~B}_{0-7} \boldsymbol{\Gamma}$ | CPS | 11 | 8 |
| $\overline{\mathrm{CE}} \boldsymbol{\Gamma}$ | CPS | ${ }^{*} 20 / 15$ | 4 |
| $\overline{\mathrm{CE}}-\boldsymbol{\Gamma}$ | CPR | ${ }^{*} 20 / 15$ | 4 |

B. Propagation Delays

| Input | $\mathbf{A}_{\mathbf{0}-\mathbf{7}}$ | $\mathbf{B}_{\mathbf{0}-\mathbf{7}}$ |
| :---: | :---: | :---: |
| CPS $\Gamma$ | ${ }^{*} 35 / 28$ | - |
| CPR $-\quad$ | - | ${ }^{*} 35 / 28$ |

C. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS | 20 | 20 |
| CPR | 20 | 20 |

D. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}} A \mathrm{~S}$ | $\mathrm{~A}_{0-7}$ | 24 | 28 |
| $\overline{\mathrm{OE}} \mathrm{BR}$ | $\mathrm{B}_{0-7}$ | 24 | 28 |

*Where two numbers appear, the first is the Am2952 spec, the second is the Am2953 spec.

## Am2954/Am2955

Octal Registers with Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Eight-bit, high-speed parallel registers
- Am2954 has non-inverting inputs; Am2955 has inverting inputs
- Positive, edge-triggered, D-type flip-flops
- Buffered common clock and buffered common threestate control
- $\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}(\max )$ at $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$
- High-speed - Clock to output 11 ns typical


## GENERAL DESCRIPTION

The Am2954 and Am2955 are 8-bit registers built using high-speed Schottky technology. The registers consist of eight D-type flip-flops with a buffered common clock and a buffered 3 -state output control. When the output enable $(\overline{O E})$ input is LOW, the eight outputs are enabled. When the $\overline{\mathrm{OE}}$ input is HIGH, the outputs are in the 3 -state condition.

Input data meeting the set-up and hold time requirements of the $D$ inputs is transferred to the $Y$ outputs on the LOW-to-HIGH transition of the clock input.

The devices are packaged in a space-saving (0.3-inch row spacing) 20-pin package.

## BLOCK DIAGRAM



BD002440
Inputs $D_{0}$ through $D_{7}$ are inverted on the Am2955

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29821-26 | 8, 9, 10-Bit Registers |
| Am2918 | Quad D-Register |
| Am2920 | Quad D-Type Flip-Flop |

Note: Pin 1 is marked for orientation
*F-20 pin configuration identical to D-20, P-20.

Note: Inputs $D_{0}$ through $D_{7}$ are inverted on the Am2955

## METALLIZATION AND PAD LAYOUT <br> Am2954


DIE SIZE $0.085^{\prime \prime} \times \mathbf{0 . 1 1 0 "}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
|  | PC |
|  | DC, DCB, DM, |
| Am2954 | DMB |
| Am2955 | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\mathrm{D}_{\mathrm{i}} / \overline{\bar{D}_{\mathrm{i}}}$ | 1 | The D flip-flop data inputs (Am2954, non-inverting/Am2955, inverting). |
| 11 | CP | I | Clock Pulse for the register. Enters data on the LOW-to-HIGH transition. |
|  | Yi | O | The register three-state outputs. |
| 1 | $\overline{\mathrm{OE}}$ | I | Output Control. An active-LOW three-state control used to enable the outputs. A HIGH level input forces the <br> outputs to the high impedance (off) state. |

FUNCTION TABLE

| Function | Inputs |  |  |  | Internal | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{O E}}$ | Clock | $\begin{gathered} \text { Am2954 } \\ \mathrm{D}_{\mathrm{i}} \end{gathered}$ | $\begin{gathered} \text { Am2955 } \\ D_{i} \end{gathered}$ | $Q_{i}$ | $\mathbf{Y}_{\mathbf{i}}$ |
| $\mathrm{H}_{\mathrm{i}}-\mathrm{Z}$ | H | L | X | X | NC | Z |
|  | H | H | X | X | NC | Z |
| $\begin{aligned} & \text { LOAD } \\ & \text { REGISTER } \end{aligned}$ | L | $\dagger$ | L | H | L | L |
|  | L | $\uparrow$ | H | L | H | H |
|  | H | 1 | L | H | L | Z |
|  | H | $\uparrow$ | H | L | H | Z |

$$
\begin{aligned}
& \mathrm{H}=\mathrm{HIGH} \\
& \mathrm{~L}=\mathrm{LOW}
\end{aligned}
$$

NC = No Change

$$
Z=\text { High Impedance }
$$

$$
\bar{X}=\text { Don't Care } \quad \bar{t}=\text { LOW-to-HIGH transition }
$$



AF001870
Dual 16 -word by 16 -bit non-inverting high-speed data buffer.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential (Pin 16 to Pin 8) Continuous... For High Output State $\qquad$ .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ $\ldots . . .-0.5 \mathrm{~V}$ to +5.5 V
DC Output Current, Into Outputs ......................... 30 mA
DC Input Current .................................-30 to +5.0mA
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage $\qquad$ +4.5 V to +5.5 V
Operating ranges define those limits over which the function- ality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  | Min | Typ <br> (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL., $\mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.1 |  |  |
| $\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{OL}=20 \mathrm{~mA}$ |  |  | . 45 | Volts |
|  |  |  | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  |  | . 5 |  |
| Vin | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| I/L | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| IN | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| loz | Off-State (High-Impedance) Output Current | $V_{C C}=\operatorname{MAX}$ | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  | -40 |  | -100 | mA |
| ICC | ```Power Supply Current (Note 4)``` | $V_{C C}=M A X$ |  |  | 90 | 140 | mA |

Notes: 1. For conditions shown as MIN or MAX use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Am2954 measured at CLK $=$ LOW-to-HIGH, $\overline{\mathrm{OE}}=\mathrm{HIGH}$ and all data inputs are LOW.

Am2955 measured at CLK $=$ LOW-to-HIGH, $\overline{O E}=H I G H$, and all data inputs are $\overline{O E}=H I G H$, and all data inputs are LOW.

|  | Description |  |  | Am2954 / Am2955 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters |  |  | Test Conditions | Min | Typ | Max |  |
| ${ }_{\text {tPLH }}$ | Clock to Output, $\mathrm{Y}_{\mathrm{i}}$ |  | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =280 \Omega \end{aligned}$ |  | 8 | 15 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 11 | 17 | ns |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  |  | 8 | 15 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 11 | 18 | ns |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | $\begin{gathered} C_{L}=5 \mathrm{pF} \\ R_{\mathrm{L}}=280 \Omega \end{gathered}$ |  | 5 | 9 | ns |
| tLZ |  |  |  |  | 7 | 12 | ns |
|  | Clock Pulse Width | HIGH |  | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =280 \Omega \end{aligned}$ | 6 |  |  | ns |
| tpW |  | LOW | 7.3 |  |  |  | ns |
| ts | Data to Clock |  | 5 |  |  |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ |  |  | 2 |  |  |  | ns |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  | 75 |  | 100 |  | MHz |

INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am2956/Am2957

Octal Latches with Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- 8-bit, high-speed parallel latches
- Am2956 has non-inverting inputs
- Am2957 has inverting inputs
- $\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ (max) at $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$
- Hysteresis on latch enable input for improved noise margin
- 3-state outputs interface directly with bus organized systems


## GENERAL DESCRIPTION

The Am2956 and Am2957 are octal latches with 3-state outputs for bus organized system applications. The latches appear to be transparent to the data (data changes asynchronously) when latch enable, G , is HIGH. When G is LOW, the data that meets the set-up times is latched. Data appears on the bus when the output enable, $\overline{O E}$, is LOW.

When $\overline{O E}$ is HIGH the bus output is in the high-impedance state.

The Am2956 presents non-inverted data at the outputs while the Am2957 is inverting.

The devices are packaged in a space-saving ( 0.3 -inch row spacing) 20-pin package.


Inputs $D_{0}$ through $D_{7}$ are inverted on the Am2957.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29841-46 | $8,9,10$-Bit Latches |



ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am2956/2957


Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )

- Package

D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless chip carrier
P -20-pin plastic DIP X -Dice

Device type
Octal Latches with 3-State Outputs

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
|  | DC, DCB, DM, |
| Am2956 | DMB |
| Am2957 | FM, FMB |
|  | LC, LCB, LM, |
|  | LMB XM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\mathrm{D}_{\mathrm{i}} / \overline{\mathrm{D}_{\mathrm{i}}}$ | I | The latch data inputs (Am2956, non-inverting/Am2957, inverting). |
| 11 | G | I | The latch enable input. The latches are transparent when G is HIGH. Input data is latched on the HIGH-to-LOW <br> transition. |
|  | Yi | O | The 3-state latch outputs. |
| 1 | $\overline{\mathrm{OE}}$ | I | The output enable control. When $\overline{\mathrm{OE}}$ is LOW, the outputs $\mathrm{Y}_{\mathrm{i}}$ are enabled. When $\overline{\mathrm{OE}}$ (he is HIGH, the outputs $\mathrm{Y}_{i}$ are in <br> the |

Am2957

| Inputs |  |  | Internal | Outputs | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | G | $\overline{D_{1}}$ | $Q_{i}$ | $\mathbf{Y}_{\mathbf{i}}$ |  |
| H | X | X | X | Z | $\mathrm{Hi}-\mathrm{Z}$ |
| L | H | L | H | H | Transparent |
| L | H | H | L | L |  |
| L | L | X | NC | NC | Latched |

$$
\begin{aligned}
& \mathrm{H}=\mathrm{HIGH} \\
& \mathrm{~L}=\mathrm{LOW} \\
& \mathrm{X}=\text { Don't Care }
\end{aligned}
$$

NC = No Change
$Z=$ High Impedance

FUNCTION TABLES

Am2956

| Inputs |  |  | Internal | Outputs | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{O E}}$ | G | $D_{i}$ | $Q_{1}$ | Y ${ }_{\mathbf{i}}$ |  |
| H | X | X | X | Z | $\mathrm{Hi}-\mathrm{Z}$ |
| L | H | L | L | L | Transparent |
| L | H | H | H | H |  |
| L | L | X | NC | NC | Latched |

## APPLICATION



AF001880
Transparent Latches are used in high performance CPU designs. The Z Latch configuration shown provides overlapped fetch of machine instructions and operand data.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous...............-0.5V to +7.0 V DC Voltage Applied to Outputs For
High Output State ...................... -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage .................................-0.5V to +5.5 V
DC Output Current, Into Outputs ........................... 30mA DC Input Current ..................................-30 to +5.0mA

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description |  | Test Conditons (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\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}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.1 |  |  |
| 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}$ | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  |  | 46 | Volts |
|  |  |  | $\mathrm{IOL}=32 \mathrm{~mA}$ |  |  |  | . 5 |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level |  | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level |  | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{l}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |  |
| ILL | Input LOW Current |  | $V_{C C}=M A X, V_{1 N}=0.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |  |
| IN | Input HIGH Current |  | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |  |
| 1 | Input HIGH Current |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1} \mathrm{~N}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |  |
| Ioz | Off-State (High-Impedance) Output Current |  | $V_{C C}=M A X$ | $\mathrm{V}_{0}=0.5 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |  |
|  |  |  | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  | 50 |  |  |
| Isc | Output Short Circuit Current (Note 3) |  |  | $V_{C C}=M A X$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current <br> (Note 4) | 2956 | $V_{C C}=M A X$ |  |  | 105 | 160 | mA |  |
|  |  | 2957 |  |  |  | 110 | 168 |  |  |

Notes:1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX use the appropiate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Inputs grounded; outputs open.

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

 Am2956| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH |  | $\begin{aligned} & C_{L}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \end{aligned}$ |  | 7 | 14 | ns |
| tPHL | Enable to Output |  |  | 12 | 18 | ns |
| tpLH | Data Input to Output |  |  | 5 | 9 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 9 | 13 | ns |
| $\mathrm{t}_{\mathrm{s}}(\mathrm{H})$ | HIGH Data to Enable |  | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}}(\mathrm{L})$ | LOW Data to Enable |  | 0 |  |  | ns |
| th(H) | HIGH Data to Enable |  | 10 |  |  | ns |
| $\mathrm{th}^{(\mathrm{L}}$ ) | LOW Data to Enable |  | 10 |  |  | ns |
| $\mathrm{t}_{\mathrm{pwH}}$ | Enable Pulse Width |  | 6 |  |  | ns |
| $\mathrm{t}_{\mathrm{pwL}}$ |  |  | 7.3 |  |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | 8 | 15 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 11 | 18 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E} \text { to } Y_{i}$ | $\begin{gathered} C_{L}=5 p F \\ R_{L}=280 \Omega \end{gathered}$ |  | 6 | 9 | ns |
| tLZ |  |  |  | 8 | 12 | ns |

*Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$ Am2957

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tply | Enable to Output | $\begin{aligned} & C_{L}=15 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \end{aligned}$ |  | 17 | 24 | ns |
| tPHL |  |  |  | 19 | 26 | ns |
| tPLH | Data Input to Output |  |  | 10 | 14 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 14 | 20 | ns |
| $\mathrm{t}_{\mathrm{s}}(\mathrm{H})$ | HIGH Data to Enable |  | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}}(\mathrm{L})$ | LOW Data to Enable |  | 0 |  |  | ns |
| th(H) | HIGH Data to Enable |  | 10 |  |  | ns |
| th(L) | LOW Data to Enable |  | 10 |  |  | ns |
| $\mathrm{t}_{\mathrm{pwH}}$ | Enable Pulse Width |  | 6 |  |  | ns |
| $\mathrm{t}_{\mathrm{pwL}}$ |  |  | 7.3 |  |  | ns |
| $\mathrm{t}_{\mathrm{Z} \mathrm{H}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | 8 | 15 | ns |
| tZL |  |  |  | 11 | 18 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $Y_{i}{ }^{\prime}$ | $\begin{gathered} C_{L}=5 p F \\ R_{L}=280 \Omega \end{gathered}$ |  | 6 | 9 | ns |
| tLZ |  |  |  | 8 | 10 | ns |

## DISTINCTIVE CHARACTERISTICS

## - Expandable Register File -

The Am29203 includes the necessary "hooks" to expand the register file externally to any number of registers.

- Built-in Multiplication Logic -

Performing multiplication with the Am2901A requires a few external gates - these gates are contained on-chip in the Am29203. Three special instructions are used for unsigned multiplication, two's complement multiplication and the last cycle of a two's complement multiplication.

- Built-in Division Logic -

The Am29203 contains all logic and interconnects for execution of a non-restoring, multiple-length division with correction of the quotient.

- Built-in Normalization Logic -

The mantissa and exponent of a floating-point number can be developed using a single microcycle per shift.

- Built-in Parity Generation and Sign Extension Circuitry -
Can supply parity across the entire ALU outputs and provide sign-extension at any slice boundary.
- BCD Arithmetic -

The Am29203 features automatic BCD add and subtract and conversion between binary and BCD.

- Two Bidirectional Data Lines
- Improved I/O Capability -

Both the DA and DB data buses are bidirectional on the Am29203. In addition, the Y port is also bidirectional.

## GENERAL DESCRIPTION

The Am29203 is a four-bit expandable bipolar microprocessor slice. The Am29203 performs all functions performed by the industry standard Am2901 and Am2903A, in addition, provides a number of significant enhancements that are especially useful in arithmetic-oriented processors. Infinitely expandable memory and three-port, three-address architecture are provided by the Am29203. In addition to its
complete arithmetic and logic instruction set, the Am29203 provides a special set of instructions which facilitate the implementation of multiplication, division, normalization, BCD arithmetic and conversion, and other previously timeconsuming operations. The Am29203 has three bidirectional ports and features AMD's ion-implanted micro-oxide (IMOX ${ }^{\text {TM }}$ ) technology.

BLOCK DIAGRAM


AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).
Am29203


${ }^{\text {B }}$ Screening Option
Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
Package
D-48-pin CERDIP
F-48-pin flatpak
L-52-pin leadless chip carrier X-Dice
Device type
Bipolar Microprocessor Slice

| DC, DCB, DMB |
| :--- |
| FMB |
| LC, LMB |
| XC, XM |

XC, XM

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2902A | Carry Look-Ahead Generator |
| Am2904 | Status and Shift Control Unit |
| Am2910A | Microprogram Controller |
| Am2914 | Vectored Priority Interrupt <br> Controller |
| Am2917A | Bus Transceiver |
| Am2918 | Pipeline Register |
| Am2920 | Octal Register |
| Am2922 | Condition Code MUX |
| Am2925 | System Clock Generator |
| Am2940 | DMA Address Generator |
| Am2952 | Bidirectional I/O Port |
| Am29707 | Two-Port RAM |
| Am27S35 | Registered PROM |

## PIN DESCRIPTION

| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A}_{0-3}$ | 1 | Four RAM address inputs which contain the address of the RAM word appearing at the RAM A output port. |
|  | $\mathrm{B}_{0-3}$ | 1 | Four RAM address inputs which contain the address of the RAM word appearing at the RAM B output port and into which new data is written when the $\overline{\mathrm{WE}}$ input and the CP input are LOW. |
| 37 | $\overline{W E}$ | 1 | The RAM write enable input. If $\overline{\text { WE }}$ is LOW, data at the Y I/O port is written into the RAM when the CP input is LOW. When WE is HIGH, writing data into the RAM is inhibited. |
|  | DA0-3 | 1/0 | A four-bit external data input which can be selected as one of the ALU operand sources; DA 0 is the least significant bit. On the AM29203, the DA path is bidirectional, operating as either an ALU source operand or as an external output for the RAM A-port. |
| 2 | $\bar{E} \bar{A}$ | 1 | A control input which, when HIGH selects DA $0_{0-3}$ as the ALU R operand, and, when LOW, selects RAM output A as the ALU R operand and the $\mathrm{DA}_{0-3}$ output data. |
|  | $\mathrm{DB}_{0-3}$ | 1/0 | A four-bit external data input/output. Under control of the $\overline{O E B}$ input, RAM output port B can be directly read on these lines, or input data on these lines can be selected as the ALU S operand. |
| 31 | OEB | 1 | A control input which, when LOW, enables RAM output $B$ onto the $\mathrm{DB}_{0-3}$ lines and, when HIGH, disables the RAM output B tri-state buffers. |
| 10 | $\mathrm{C}_{\mathrm{n}}$ | 1 | The carry-in input to the AM29203 ALU. |
|  | ${ }^{10-8}$ | 1 | The nine instruction inputs used to select the Am29203 operation to be performed. |
| 38 | IEN | 1 | The instruction enable input which, when LOW, allows the Q Register and the Sign Compare flip-flop to be written. When IEN is HIGH, the Q Register and Sign Compare flip-flop are in the hold mode. On the Am29203, WRITE is not affected by IEN, but internally disables the RAM write enable. |
| 11 | $\mathrm{Cn}+4$ | 0 | This output generally indicates the carry-out of the Am29203 ALU. Refer to Table 5 for an exact definition of this pin. |
| 14 | $\overline{\mathrm{G}} / \mathrm{N}$ | 0 | A multi-purpose pin which indicates the carry generate, $\overline{\mathrm{G}}$, function at the least significant and intermediate slices, and generally indicates the sign, N , of the ALU result at the most significant slice. Refer to Table 5 for an exact definition of this pin. |
| 12 | $\overline{\text { P/OVR }}$ | 0 | A multi-purpose pin which indicates the carry propagate, $\overline{\mathrm{P}}$, function at the least significant and intermediate slices, and indicates the conventional two's complement overflow, OVR, signal at the most significant slice. Refer to Table 5 for an exact definition of this pin. |
| 22 | Z | 1/0 | An open-collector input/output pin which, when HIGH, generally indicates the outputs are all LOW. For some Special Functions, Z is used as an input pin. Refer to Table 5 for an exact definition of this pin. |
| 20, 21 | $\begin{aligned} & \mathrm{SIO}_{0} \\ & \mathrm{SIO}_{3} \end{aligned}$ | 1/0 | Bidirectional serial shift inputs/outputs for the ALU shifter. During a shift-up operation, $\mathrm{SIO}_{0}$ is an input and $\mathrm{SIO}_{3}$ an output. During a shift-down operation, $\mathrm{SiO}_{3}$ is an input and $\mathrm{SIO}_{0}$ is an output. Refer to Tables 3 and 4 for an exact definition of these pins. |
| 1,48 | $\begin{aligned} & \mathrm{QIO}_{0} \\ & \mathrm{QiO}_{3} \\ & \hline \end{aligned}$ | 1/0 | Bidirectional serial shift inputs/outputs for the Q shifter which operate like $\mathrm{SIO}_{0}$ and $\mathrm{SIO}_{3}$. Refer to Tables 3 and 4 for an exact definition of these pins. |
| 39 | LSS | 1 | An input pin which, when tied LOW, programs the chip to act as the least significant slice (LSS) of an Am29203 array and enables the WRITE output onto the WRITE/MSS pin. When LSS is tied HIGH, the chip is programmed to operate as either an intermediate or most significant slice and the WRITE output buffer is disabled. |
| 40 | $\begin{array}{\|l\|} \hline \frac{\text { WRITE/ }}{\text { MSS }} \end{array}$ | 1/0 | When $\overline{\text { LSS }}$ is tied LOW, the WRITE output signal appears at this pin; the WRITE signal is LOW when an instruction which writes data into the RAM is being executed. When $\overline{\text { LSS }}$ is tied HIGH, WRITE/MSS is an input pin; tying it HIGH programs the chip to operate as an intermediate slice (IS) and tying it LOW programs the chip to operate as the most significant slice (MSS). |
|  | $Y_{0-3}$ | 1/0 | Four data inputs/outputs of the Am29203. Under control of the $\overline{\mathrm{OEY}}$ input, the ALU shifter output data can be enabled onto these lines, or these lines can be used as data inputs when external data is written directly into the RAM. |
| 15 | OEY | 1 | A control input which, when LOW, enables the ALU shifter output data onto the $\mathrm{Y}_{0-3}$ lines and, when HIGH, disables the $Y_{0-3}$ three-state output buffers. |
| 43 | CP | 1 | The clock input to the Am29203. The Q register and Sign Compare flip-flop are clocked on the LOW-to-HIGH transition of the CP signal. When enabled by WE, data is written in the RAM when CP is LOW. |

## ARCHITECTURE OF THE Am29203

The Am29203 is a high-performance, cascadable, four-bit bipolar microprocessor slice designed for use in CPUs, peripheral controllers, microprogrammable machines, and numerous other applications. The microinstruction flexibility of the Am29203 allows the efficient emulation of almost any digital computing machine. The nine-bit microinstruction selects the ALU sources, function and destination. The Am29203 is cascadable with full lookahead or ripple carry, has three-state outputs, and provides various ALU status flag outputs. Advanced Low-Power Schottky processing is used to fabricate this 48-pin LSI circuit.

All data paths within the device are four bits wide. As shown in the block diagram, the device consists of a 16 -word by 4 -bit, two-port RAM with latches on both output ports, a highperformance ALU and shifter, a multi-purpose Q Register with shifter input, and a nine-bit instruction decoder.

## Two-Port RAM

Any two RAM words addressed at the $A$ and $B$ address ports can be read simultaneously at the respective RAM A and B output ports. Identical data appear at the two output ports when the same address is applied to both address ports. The latches at the RAM output ports are transparent when the clock input, CP, is HIGH and they hold the RAM output data when CP is LOW. Under control of the $\overline{\mathrm{OEB}}$ three-state output enable, RAM data can be read directly at the Am2903 DB I/O port. On the Am29203, $\overline{E A}$ provides the same feature at the DA port.

External data at the Am29203 Y I/O port can be written directly into the RAM, or ALU shifter output data can be enabled onto to Y I/O port and entered into the RAM. Data is written into the RAM at the $B$ address when the write enable input, $\overline{W E}$, is LOW and the clock input, CP, is LOW.

## Arithmetic Logic Unit

The Am29203 high-performance ALU can perform seven arithmetic and nine logic operations on two 4-bit operands. Multiplexers at the ALU inputs provide the capability to select various pairs of ALU source operands. The EA input selects either the DA external data input or RAM output port A for use as one ALU operand and the $\overline{O E B}$ and $\mathrm{I}_{0}$ inputs select RAM output port B, DB external data input, or the Q register content for use as the second ALU operand. Also, during some ALU operations, zeroes are forced at the ALU operand inputs. Thus, the Am29203 ALU can operate on data from two external sources, from an internal and external source, or from two internal sources. Table 1 shows all possible pairs of ALU source operands as a function of the $\overline{E A}, \overline{O E B}$, and $\mathrm{I}_{0}$ inputs.

TABLE 1. ALU OPERAND SOURCES

| $\overline{E A}$ | $\mathbf{I}_{0}$ | $\overline{\text { OEB }}$ | ALU Operand R | ALU Operand $\mathbf{S}$ |
| :--- | :--- | :---: | :--- | :--- |
| L | L | L | RAM Output A | Ram Output B |
| L | L | H | RAM Output A | DB ${ }_{0}-3$ |
| L | H | X | RAM Output A | Q Register |
| H | L | L | DA $0_{0-3}$ | Ram Output B |
| $H$ | L | H | DA $A_{0-3}$ | DB $_{0-3}$ |
| $H$ | $H$ | X | DA $A_{0-3}$ | Q Register |

L = LOW
$H=H I G H$
$\mathrm{X}=$ Don't Care

TABLE 2. Am29203 ALU FUNCTIONS

| $\mathrm{I}_{4}$ | ${ }^{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | 10 | ALU Functions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | L | L | Special Functions |
| L | L | L | L | H | $\mathrm{F}_{\mathrm{i}}=\mathrm{HIGH}$ |
| L | L | L | H | x | $F=S$ Minus R Minus 1 Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | L | H | L | X | $F=R$ Minus $S$ Minus 1 Plus $C_{n}$ |
| L | L | H | H | X | $F=R$ Plus $S$ Plus $C_{n}$ |
| L | H | L | L | X | $F=S$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | L | H | X | $\mathrm{F}=\overline{\mathrm{S}}$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | H | L | L | Reserved Special Functions |
| L | H | H | L | H | $\mathrm{F}=\mathrm{R}$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| L | H | H | H | L | Reserved Special Functions |
| L | H | H | H | H | $\mathrm{F}=\overline{\mathrm{R}}$ Plus $\mathrm{C}_{\mathrm{n}}$ |
| H | L | L | L | L | Special Functions |
| H | L | L | L | H | $\mathrm{F}_{\mathrm{i}}=$ LOW |
| H | L | L | H | X | $\mathrm{F}_{\mathrm{i}}=\overline{\mathrm{R}}_{\mathrm{i}}$ AND $\mathrm{S}_{\mathrm{i}}$ |
| H | L | H | L | X | $F_{i}=R_{i}$ EXCLUSIVE NOR $S_{i}$ |
| H | L | H | H | X | $\mathrm{F}_{\mathrm{i}}=\mathrm{R}_{\mathrm{i}}$ EXCLUSIVE OR $\mathrm{S}_{\mathrm{i}}$ |
| H | H | L | L | X | $\mathrm{F}_{\mathrm{i}}=\mathrm{R}_{\mathrm{i}}$ AND $\mathrm{S}_{\mathrm{i}}$ |
| H | H | L | H | X | $F_{i}=R_{i}$ NOR $\mathrm{S}_{\mathrm{i}}$ |
| H | H | H | L | X | $F_{i}=R_{i}$ NAND $S_{i}$ |
| H | H | H | H | X | $F_{i}=R_{i}$ OR $S_{i}$ |

$\mathrm{L}=$ LOW
$\mathrm{H}=\mathrm{HIGH}$
$i=0$ to 3
X = LOW or HIGH

When instruction bits $l_{4}, l_{3}, l_{2}, l_{1}$, and $l_{0}$ are LOW, the Am29203 executes special functions. Table 4 defines these special functions and the operation which the ALU performs for each. When the Am29203 executes instructions other than the 16 special functions, the ALU operation is determined by
instruction bits $I_{4}, I_{3}, I_{2}$, and $I_{1}$. Table 2 defines the ALU operation as a function of these four instruction bits.

Am29203s may be cascaded in either a ripple carry or lookahead carry fashion. When a number of Am29203s are cascaded, each slice must be programmed to be a most significant slice (MSS), intermediate slice (IS), or least significant slice (LSS) of the array. The carry generate, G, and carry propagate, P , signals required for a lookahead carry scheme are generated by the Am29203 and are available as outputs of the least significant and intermediate slices.
The Am29203 also generates a carry-out signal, $\mathrm{C}_{\mathrm{n}}+4$, which is generally available as an output of each slice. Both the carry-in, $C_{n}$, and carry-out, $C_{n+4}$, signals are active HIGH. The ALU generates two other status outputs. These are negative, $N$, and overflow, OVR. The $N$ output is generally the most significant (sign) bit of the ALU output and can be used to determine positive or negative results. The OVR output indicates that the arithmetic operation being performed exceeds the available two's complement number range. The N and OVR signals are available as outputs of the most significant slice. Thus, the multipurpose $\bar{G} / N$ and $\bar{P} / O V R$ outputs indicate $\bar{G}$ and $\bar{P}$ at the least significant and intermediate slices, and sign and overflow at the most significant slice. To some extent, the meaning of the $\mathrm{C}_{\mathrm{n}}+4, \overline{\mathrm{P}} /$ OVR, and $\overline{\mathrm{G}} / \mathrm{N}$ signals vary with the ALU function being performed. Refer to Table 5 for an exact definition of these four signals as a function of the Am29203 instruction.

## ALU Shifter

Under instruction control, the ALU shifter passes the ALU output (F) non-shifted, shifts it up one bit position (2F), or shifts it down one bit position ( $F / 2$ ). Both arithmetic and logical shift operations are possible. An arithmetic shift operation shifts data around the most significant (sign) bit position of the most significant slice, and a logical shift operation shifts data through this bit position (see Figure A). $\mathrm{SIO}_{0}$ and $\mathrm{SIO}_{3}$ are bidirectional serial shift inputs/outputs. During a shift-up operation, $\mathrm{SIO}_{0}$ is generally a serial shift input and $\mathrm{SIO}_{3}$ a serial shift output. During a shift-down operation, $\mathrm{SIO}_{3}$ is generally a serial shift input and $\mathrm{SIO}_{0}$ a serial shift output.

To some extent, the meaning of the $\mathrm{SIO}_{0}$ and $\mathrm{SIO}_{3}$ signals is instruction dependent. Refer to Tables 3 and 4 for an exact definition of these pins.
The ALU shifter also provides the capability to sign extend at slice boundaries. Under instruction control, the $\mathrm{SIO}_{0}$ (sign) input can be extended through $Y_{0}, Y_{1}, Y_{2}, Y_{3}$ and propagated to the $\mathrm{SIO}_{3}$ output.

A cascadable, five-bit parity generator/checker is designed into the Am29203 ALU shifter and provides ALU error detection capability. Parity for the $F_{0}, F_{1}, F_{2}, F_{3}$ ALU outputs and $\mathrm{SIO}_{3}$ input is generated and, under instruction control, is made available at the $\mathrm{SIO}_{0}$ output. Refer to the Am29203 applications section for a more detailed description of the Am29203 sign extension and parity generation/checking capability.
The instruction inputs determine the ALU shifter operation. Table 4 defines the special functions and the operation the ALU shifter performs for each. When the Am29203 executes instructions other than the special functions, the ALU shifter operation is determined by instruction bits $I_{8}, 1_{7}, I_{6}, I_{5}$. Table 3 defines the ALU shifter operation as a function of these four bits.

## Q Register

The Q Register is an auxiliary four-bit register which is clocked on the LOW-to-HIGH transition of the CP input. It is intended primarily for use in multiplication and division operations;
however, it can also be used as an accumulator or holding register for some applications. The ALU output, F, can be loaded into the Q Register and/or the Q Register can be selected as the source for the ALU S operand. The shifter at the input to the $Q$ Register provides the capability to shift the Q Register contents up one bit position (2Q) or down one bit position (Q/2). Only logical shifts are performed. $\mathrm{QIO}_{0}$ and $\mathrm{QIO}_{3}$ are bidirectional shift serial inputs/outputs. During a $Q$ Register shift-up operation, $\mathrm{QIO}_{0}$ is a serial shift input and $\mathrm{QIO}_{3}$ is a serial shift output. During a shift-down operation, $\mathrm{QIO}_{3}$ is a serial shift input and $\mathrm{QIO}_{0}$ is a serial shift output.

Double-length arithmetic and logical shifting capability is provided by the Am29203. The double-length shift is performed by connecting $\mathrm{QIO}_{3}$ of the most significant slice to $\mathrm{SIO}_{0}$ of the least significant slice, and executing an instruction which shifts both the ALU output and the Q register.

The $Q$ register and shifter are controlled by the instruction inputs. Table 4 defines the Am29203 special functions and the operations which the $Q$ register and shifter perform for each. When the Am29203 executes instructions other than the special functions, the $Q$ register and shifter operation is controlled by instruction bits $I_{8}, I_{7}, I_{6}, I_{5}$. Table 3 defines the $Q$ register and shifter operation as a function of these four bits.

TABLE 3. ALU DESTINATION CONTROL FOR $\mathrm{I}_{0} O R \mathrm{I}_{1} O R \mathrm{I}_{2} \mathrm{OR} \mathrm{I}_{3}=\mathrm{HIGH}$, $\mathrm{IEN}=\mathrm{LOW}$

| $\begin{array}{lllll}18 & 17 & l_{6} & l_{5}\end{array}$ |  |  |  | Hex Code | ALU Shifter Function | $\mathrm{SiO}_{3}$ |  | $\mathrm{Y}_{3}$ |  | $\mathrm{Y}_{2}$ |  | $\mathrm{Y}_{1}$ | $\mathrm{Y}_{0}$ | $\mathbf{S 1 O} 0$ | WRITE | Q Reg \& Shifter Function | $\mathrm{ClO}_{3}$ | $\mathrm{QIO}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Most Sig. Slice |  | Other Slices | Most Sig. Slice | Other Slices | Most Sig. Slice | Other Slices |  |  |  |  |  |  |  |
|  | L | L | L |  | 0 | Arith. $F / 2 \rightarrow Y$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{0}$ | L | Hold | $\mathrm{Hi}-\mathrm{Z}$ | $\mathrm{Hi}-\mathrm{Z}$ |
|  | L | L | H | 1 | Log. $\mathrm{F} / 2 \rightarrow Y$ | Input | Input | $\mathrm{SiO}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | L | Hold | Hi-Z | Hi-Z |
|  | L | H | L | 2 | Arith. $F / 2 \rightarrow Y$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | L | Log. Q/2 $\rightarrow$ Q | Input | $Q_{0}$ |
|  | L | H | H | 3 | Log. $F / 2 \rightarrow Y$ | Input | Input | $\mathrm{SiO}_{3}$ | $\mathrm{SIO}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $F_{0}$ | L | Log. Q/2 $\rightarrow$ Q | Input | $Q_{0}$ |
|  | H | L | L | 4 | $\mathrm{F} \rightarrow \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{0}$ | Parity | L | Hold | Hi-Z | Hi-Z |
|  | H | L | H | 5 | $F_{\rightarrow} \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | Parity | H | Log. Q/2 $\rightarrow$ Q | Input | $Q_{0}$ |
|  | H | H | L | 6 | $\mathrm{F}_{\rightarrow} \mathrm{Y}$ | Input | Input | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Parity | H | $F \rightarrow Q$ | Hi-Z | Hi-Z |
|  | H | H | H | 7 | $F \rightarrow Y$ | Input | Input | $\mathrm{F}_{3}$ | F3 | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | Parity | L | $F \rightarrow Q$ | Hi-Z | Hi-Z |
|  | H L | L | L | 8 | Arith. $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | Hi-Z | Hi-Z |
| H | H L | L | H | 9 | Log. $2 F_{\rightarrow} \mathrm{Y}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | Hi-Z | $\mathrm{Hi}-\mathrm{Z}$ |
| H | H L | H | L | A | Arith. $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $F_{1}$ | $\mathrm{F}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Log. $2 \mathrm{Q} \rightarrow \mathrm{Q}$ | $\mathrm{Q}_{3}$ | Input |
| H | H L | H | H | B | Log. $2 F_{\rightarrow} \mathrm{Y}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{1}$ | $\mathrm{F}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Log. 2Q $\rightarrow$ Q | $\mathrm{Q}_{3}$ | Input |
|  | H | L | L | C | $F \rightarrow Y$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Hi-Z | H | Hold | Hi-Z | Hi-Z |
|  | H | L | H | D | $F \rightarrow Y$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $F_{1}$ | $\mathrm{F}_{0}$ | Hi-Z | H | Log. 2Q $\rightarrow$ Q | $\mathrm{Q}_{3}$ | Input |
|  | H H | H | L | E | $\begin{aligned} & \mathrm{SIO}_{0 \rightarrow} \mathrm{Y}_{0}, \mathrm{Y}_{1}, \\ & \mathrm{Y}_{2}, \mathrm{Y}_{3} \end{aligned}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SiO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{0}$ | Input | L | Hold | Hi-Z | Hi-Z |
|  | H H | H | H | F | $F \rightarrow Y$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | $\mathrm{F}_{3}$ | F3 | $\mathrm{F}_{2}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ | Hi-Z | L | Hold | Hi-Z | Hi-Z |

[^12]TABLE 4. SPECIAL FUNCTONS (Note 7)

| $\begin{aligned} & \text { (Hex) } \\ & \mathbf{I S I}_{8} \mathrm{I}_{6} \mathrm{I}_{5} \end{aligned}$ | 14 | $\begin{aligned} & \text { (Hex) } \\ & \mathbf{I}_{3} \mathbf{I}_{2} I_{1} I_{0} \end{aligned}$ | Special Function | ALU Function | ALU Shifter Function | $\mathrm{SlO}_{3}$ |  | $\mathrm{SIO}_{0}$ | Q Reg \& Shifter Function | $\mathrm{OlO}_{3}$ | $\mathrm{QlO}_{0}$ | WRITE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | Most Sig/ Slice | Other Slices |  |  |  |  |  |
| 0 | L | 0 | Unsigned Multiply | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=R+S+C_{n} \text { if } Z=H \end{aligned}$ | $\underset{(\text { Note }}{\log \mathrm{F}}{ }^{\mathrm{Log}}$ | Z | Input | Fo | $\begin{array}{\|c\|} \hline \log \mathrm{Q} / \\ 2 \rightarrow \mathrm{Q} \end{array}$ | Input | $Q_{0}$ | L |
| 1 | L | 0 | BCD to Binary Conversion | (Note 4) | $\log \mathrm{F} / 2 \rightarrow \mathrm{Y}$ | input | input | Fo | $\begin{array}{\|l\|} \hline \log Q 1 \\ 2 \rightarrow Q \end{array}$ | Input | $Q_{0}$ | L |
| 1 | H | 0 | Multiprecision BCD to Binary | (Note 4) | $\log \mathrm{F} / 2 \rightarrow \mathrm{Y}$ | Input | input | Fo | HOLD | Z | $Q_{0}$ | L |
| 2 | L | 0 | Two's Complement Multiply | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=R+S+C_{n} \text { if } Z=H \end{aligned}$ | $\underset{(\text { Note } 2)}{\log F / 2}$ | Z | Input | F0 | $\begin{array}{\|c\|} \hline \log \mathrm{Q} / \\ 2 \rightarrow \mathrm{Q} \end{array}$ | Input | $Q_{0}$ | L |
| 3 | L | 0 | Decrement by One or Two | $\mathrm{F}=\mathrm{S}-2+\mathrm{C}_{\mathrm{n}}$ | $F \rightarrow Y$ | $Z$ | Z | Parity | Hold | Z | Z | L |
| 4 | L | 0 | Increment by One or Two | $F=S+1+C_{n}$ | $F \rightarrow Y$ | Input | Input | Parity | Hold | z | Z | L |
| 5 | L | 0 | Sign/Magnitude Two's Complement | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=S+C_{n} \text { if } Z=H \end{aligned}$ | $\begin{gathered} \mathrm{F} \rightarrow \mathrm{Y} \\ \text { (Note 3) } \end{gathered}$ | Input | Input | Parity | Hold | Z | Z | L |
| 6 | L. | 0 | Two's Complement Multiply, Last Cycle | $\begin{aligned} & F=S+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $\underset{(N o t e ~ 2)}{\log F / 2}$ | Z | Input | $\mathrm{F}_{0}$ | $\left\|\begin{array}{l} \log Q / \\ 2 \rightarrow Q \end{array}\right\|$ | Input | $\mathrm{Q}_{0}$ | L |
| 7 | L | 0 | BCD Divide by Two | (Note 4) | $F \rightarrow Y$. | Z | Z | Parity | Hold | Z | Z | L |
| 8 | L | 0 | Single Length Normalize | $\mathrm{F}=\mathrm{S}+\mathrm{C}_{\mathrm{n}}$ | $F \rightarrow Y$ | F3 | F3 | Z | $\begin{gathered} \hline \log 2 \mathrm{Q} \\ \rightarrow \mathrm{Q} \\ \hline \end{gathered}$ | Q | Input | L |
| 9 | L | 0 | Binary to BCD Conversion | (Note 5) | $\log 2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $F_{3}$ | $F_{3}$ | Input | $\begin{gathered} \hline \log 2 \mathrm{Q} \\ \rightarrow \mathrm{Q} \\ \hline \end{gathered}$ | Q | Input | L |
| 9 | H | 0 | Multiprecision Binary to BCD | (Note 5) | Log $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | F3 | $\mathrm{F}_{3}$ | Input | Hold | Z | Input | L |
| A | L | 0 | Double Length Normalize and First Divide Op | $F=S+C_{n}$ | Log $2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\mathrm{R}_{3} \nabla \mathrm{~F}_{3}$ | $F_{3}$ | Input | $\begin{gathered} \log 2 Q \\ \rightarrow Q \end{gathered}$ | Q | Input | L |
| B | L | 0 | BCD Add | $\begin{aligned} & F=R+S+C_{n} B C D \\ & \text { (Note 6) } \end{aligned}$ | $F \rightarrow Y$ | 0 | 0 | Z | Hold | Z | Z | L |
| C | L | 0 | Two's Complement Divide | $\begin{aligned} & F=S+R+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $\log 2 \mathrm{~F} \rightarrow \mathrm{Y}$ | $\overline{R_{3} \nabla F}$ | F3 | Input | $\begin{gathered} \hline \log 2 \mathrm{Q} \\ \rightarrow \mathrm{Q} \\ \hline \end{gathered}$ | Q | Input | L |
| D | L | 0 | BCD Subtract | $\begin{aligned} & F=R-S-1+C_{n} B C D \\ & \text { (Note 6) } \end{aligned}$ | $F \rightarrow Y$ | 0 | 0 | $z$ | Hold | Z | Z | L |
| $E$ | L | 0 | Two's Complement Divide Correction and Remainder | $\begin{aligned} & F=S+R+C_{n} \text { if } Z=L \\ & F=S-R-1+C_{n} \text { if } Z=H \end{aligned}$ | $F \rightarrow Y$ | $F_{3}$ | $F_{3}$ | Z | $\underset{\substack{\log 2 Q \\ \rightarrow Q}}{ }$ | $Q_{3}$ | Input | L |
| F | L | 0 | BCD Subtract | $\begin{aligned} & F=S-R-1+C_{n} B C D \\ & \text { (Note 6) } \end{aligned}$ | $F \rightarrow Y$ | 0 | 0 | Z | Hold | Z | Z | L |

Notes: 1. At the most significant slice only, the $C_{n}+4$ signal is internally gated to the $Y_{3}$ output.
2. At the most significant slice only, $F_{3} \nabla$ OVR is internally gated to the $Y_{3}$ output.
3. At the most significant slice only, $S_{3} \nabla F_{3}$ is generated at the $Y_{3}$ output
4. On each slice, $F=S$ if magnitude of $S_{0-3}$ is less than 8 and $F=S$ minus 3 if magnitude of $S_{0-3}$ is 8 or greater.
5. On each slice, $F=S$ if magnitude of $S_{0-3}$ is less than 5 and $F=S$ plus 3 if magnitude of $S_{0-3}$ is 5 or greater. Addition is module 16.
6. Additions and subtractions are $B C D$ adds and subtracts. Results are undefined if $R$ or $S$ are not in valid BCD format.
7. The Q Register cannot be used explicitly as an operand for any Special Functions. It is defined implicitly within the functions.
$L=L O W$
$\mathrm{Hi}-\mathrm{Z}=$ High Impedance
$H=H I G H$
$\nabla=$ Exclusive OR
Parity $=\mathrm{SIO}_{3} \nabla \mathrm{~F}_{3} \nabla \mathrm{~F}_{2} \nabla \mathrm{~F}_{1} \nabla \mathrm{~F}_{0}$

Figure B. Sign Compare Flip-Flop


DF000760
The sign compare signal appears at the $Z$ output of the most significant slice during special functions $C, D$ and E, F. Refer to Table 5.

## Output Buffers

The DB, DA, and $Y$ ports are bidirectional I/O ports driven by three-state output buffers with external output enable controls.
The $Y$ output buffers are enabled when the $\overline{O E Y}$ input is LOW and are in the high impedance state when $\overline{\mathrm{OEY}}$ is HIGH. The DB output buffers are enabled when the $\overline{\mathrm{OEB}}$ input is LOW and the DA buffers are enabled when $\overline{E A}$ is LOW.
The zero, $Z$, pin is an open collector input/output that can be wire-OR'ed between slices. As an output it can be used as a zero detect status flag and generally indicates that the $\mathrm{Y}_{0-3}$ pins are all LOW. To some extent the meaning of this signal varies with the instruction being performed. Refer to Table 5 for an exact definition of this signal as a function of the Am29203 instructions. On the Am29203, the $Z$ pin will be HIGH if $\overline{\mathrm{OEY}}$ is HIGH, allowing zero detection on less than the full word.

## Instruction Decoder

The Instruction Decoder generates required internal control signals as a function of the nine instruction inputs, $1_{0-8}$; the Instruction Enable input, IEN; the $\overline{\mathrm{LSS}}$ input; and the $\overline{\text { WRITE/ }}$ MSS input/output.

The WRITE output is LOW when an instruction which writes data into the RAM is being executed. Refer to Tables 3 and 4 for a definition of the WRITE output as a function of the Am29203 instruction inputs.
On the Am29203, when IEN is HIGH, the Q register and Sign Compare Flip-Flop contents are preserved. When IEN is LOW, the $Q$ register and Sign Compare Flip-Flop can be written according to the Am29203 instruction. The Sign Compare FlipFlop is an on-chip flip-flop which is used during an Am29203 divide operation (see Figure B). On the Am29203, IEN controls internal writing, but does not affect $\overline{\text { WRITE }}$. The IEN signal can then be controlled separately at each chip to facilitate byte operations.

## Programming the Am29203 Slice Position

Tying the $\overline{\text { LSS }}$ input LOW programs the slice to operate as a least significant slice (LSS) and enables the WRITE output signal onto the WRITE/MSS bidirectional I/O pin. When $\overline{\text { LSS }}$ is tied HIGH, the $\overline{\text { WRITE }} / \overline{M S S}$ pin becomes an input pin; tying the $\overline{\text { WRITE }} / \overline{\mathrm{MSS}}$ pin HIGH programs the slice to operate as an intermediate slice (IS) and tying it LOW programs the slice to operate as a most significant slice (MSS). The $\bar{W} / \overline{M S S}$ pin must be tied HIGH through a resistor. $\bar{W} / \overline{\mathrm{MSS}}$ and $\overline{\mathrm{LSS}}$ should not be connected together.

## Am29203 SPECIAL FUNCTIONS

The Am29203 provides 16 Special Functions which facilitate the implementation of the following operations:

- Single- and Double-Length Normalization
- Two's Complement Division
- Unsigned and Two's Complement Multiplication
- Conversion Between Two's Complement and Sign/Magnitude Representation
- Incrementation and Decrementation by One or Two
- BCD add, subtract, and divide by two.
- Single-and double-precision BCD to Binary and Binary to BCD conversion.

Table 4 defines these Special Functions.
The Single-Length and Double-Length Normalization functions can be used to adjust a single-precision or double-precision floating point number in order to bring its mantissa within a specified range.

Three Special Functions which can be used to perform a two's complement, non-restoring divide operation are provided by the Am29203. These functions provide both single- and double-precision divide operations and can be performed in " $n$ " clock cycles, where " $n$ " is the number of bits in the quotient.

The Unsigned Multiply Special Function and the two Two's Complement Multiply Special Functions can be used to multiply two n-bit, unsigned or two's complement numbers, respectively, in $n$ clock cycles. These functions utilize the conditional add and shift algorithm. During the last cycle of the two's complement multiplication, a conditional subtraction, rather than addition, is performed because the sign bit of the multiplier carries negative weight.

The Sign/Magnitude-Two's Complement Special Function can be used to convert number representation systems. A number expressed in Sign/Magnitude representation can be converted to the Two's Complement representation, and vice-versa, in one clock cycle.

The Increment by One or Two Special Function can be used to increment an unsigned or two's complement number by one or two. This is useful in 16-bit word, byte-addressable machines, where the word addresses are multiples of two.

The BCD arithmetic special functions can be used to add or subtract two BCD numbers and generate a valid BCD result in one microcycle. In addition a BCD divide by two adjust instruction can be used to obtain a valid BCD representation after shifting a number down by one bit.

The BCD/Binary conversion special function instructions facilitate single- and double-precision algorithms to convert from $B C D$ to Binary and from Binary to BCD.

Refer to Am29203 applications section for a more detailed description of these Special Functions.

| $\begin{array}{\|c} \begin{array}{c} \text { Hex) } \\ \text { ch } \\ 887616 \\ \hline \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \text { (Hex) } \\ & 14 / 3 / 2 l_{1} \\ & \hline \end{aligned}$ | 10 | $\begin{aligned} & (1=0 \text { to } 3) \end{aligned}$ | $\begin{aligned} & \mathrm{Pi} \\ & (\mathrm{Ii}=0 \text { to } 3) \end{aligned}$ | $\mathrm{c}_{\mathrm{n}+4}$ | $\overline{\text { P/OVR }}$ |  | $\overline{\mathbf{G}} / \mathbf{N}$ |  | X ( $\overline{\mathrm{OEY}}=\mathrm{L}$ ) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | Most Sig. Slice | Other Slices | Most Sig. Slice | Other Slices | Most Sig. Slice | $\begin{gathered} \begin{array}{c} \text { Intermediate } \\ \text { Slice } \end{array} \\ \hline \end{gathered}$ | Least Sig. Slice |
| X | 0 | H | 0 | 1 | 0 | 0 | 0 | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | 1 | X | $\overline{\bar{R}_{i}} \wedge \mathrm{~S}_{\mathrm{i}}$ | $\overline{\mathrm{R}_{\mathrm{i}}} \vee \mathrm{S}_{\mathrm{i}}$ | $G \vee P C_{n}$ | $C_{n+3} \nabla c_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0} Y_{1} \overline{V_{2}} \bar{Y}_{3}}$ |
| X | 2 | x | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \mathrm{S}_{\mathrm{i}}$ | $G \vee P C_{n}$ | $C_{n+3} \nabla C_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0} Y_{1} \overline{r_{2}} \bar{Y}_{3}}$ |
| X | 3 | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \mathrm{S}_{\mathrm{i}}$ | $G \vee P C_{n}$ | $C_{n+3} \nabla C_{n+4}$ | $\overline{\bar{p}}$ | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0} Y_{1} \overline{Y_{2}} \overline{Y_{3}}}$ |
| X | 4 | X | 0 | $\mathrm{S}_{\mathrm{i}}$ | $G \vee P C_{n}$ | $C_{n+3} \nabla C_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | 5 | X | 0 | $\overline{\mathrm{S}}$ | $\mathrm{G} v \mathrm{PC}_{n}$ | $c_{n+3} \nabla C_{n+4}$ | $\overline{\bar{p}}$ | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{V_{2}} \overline{Y_{3}}$ |
| X | 6 | x | 0 | $\mathrm{R}_{\mathrm{i}}$ | $G \vee P C_{n}$ | $C_{n+3} \nabla C_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\overline{\bar{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \bar{Y}_{2} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | 7 | X | 0 | $\overline{\bar{i}}$ | $\mathrm{G} v \mathrm{PC}_{\mathrm{n}}$ | $c_{n+3} \nabla c_{n+4}$ | $\overline{\bar{p}}$ | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}}$ |
| X | 8 | H | 0 | 1 | 0 | 0 | 0 | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{V_{2}} \overline{Y_{3}}$ |
| X | 9 | X | $\overline{\mathrm{R}_{\mathrm{i}}} \wedge \mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $F_{3}$ | $\overline{\text { G }}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \bar{Y}_{2} Y_{3}$ | Y0 $\overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | A | X | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \mathrm{S}_{\mathrm{i}}$ | 0 | 0 | 0 | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | B | X | $\overline{\bar{R}_{i}} \wedge \mathrm{~S}_{\mathrm{i}}$ | $\overline{\bar{R}_{i}} \vee \mathrm{~S}_{\mathrm{i}}$ | 0 | 0 | 0 | $F_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | C | x | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \cdot \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ |
| X | D | x | $\overline{\bar{R}_{i}} \wedge \overline{\mathrm{~S}}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\bar{G}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ |
| x | E | x | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | F3 | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| X | F | x | $\overline{\mathrm{R}_{\mathrm{i}}} \wedge \overline{\mathrm{S}}_{\mathrm{i}}$ | 1 | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \bar{Y}_{2} \bar{Y}_{3}$ | Y $\bar{Y}_{0} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| 0 | 0 | L | $\begin{gathered} 0 \text { if } Z=L \\ R_{i} \wedge S_{i} \text { if } Z=H \end{gathered}$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & R_{i} v S_{i} \text { if } \\ & Z=H \end{aligned}$ | $\mathrm{G} v \mathrm{PC}_{\mathrm{n}}$ | $c_{n+3} \nabla c_{n+4}$ | $\bar{p}$ | $F_{3}$ | $\bar{G}$ | Input | Input | $Q_{0}$ |
| 1 | 0 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | G v PC, | $C_{n+3} \nabla C_{+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\overline{\text { G }}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{\gamma_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| 1 | 8 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{\gamma_{0}} \overline{\gamma_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | Yo $\overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| 2 | 0 | L | $\begin{gathered} 0 \text { if } Z=L \\ R_{i} \wedge S_{i} \text { if } Z=H \end{gathered}$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & R_{i} V S_{i} \text { if } \\ & Z=H \end{aligned}$ | Gv PC ${ }_{n}$ | $C_{n+3} \nabla C_{n+4}$ | $\overline{\text { ¢ }}$ | $F_{3}$ | $\bar{G}$ | Input | Input | Qo |
| 3 | 0 | L | (Note 6) | (Note 7) | $\mathrm{G} v \mathrm{PC}_{n}$ | $C_{n+3} \nabla C_{N+4}$ | $\overline{\mathrm{P}}$ | F3 | $\bar{G}$ | $\overline{\gamma_{0}} \overline{Y_{1}} \overline{\gamma_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \bar{Y}_{1} \bar{Y}_{2} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| 4 | 0 | L | (Note 1) | (Note 2) | GvPC | $C_{n+3} \nabla C_{N+4}$ | $\overline{\bar{p}}$ | F3 | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{\gamma_{1}} \overline{\bar{Y}_{2}} \overline{\gamma_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| 5 | 0 | L | 0 |  | Gv PCn | $c_{n+3} \nabla c_{n+4}$ | $\overline{\text { ¢ }}$ | $\begin{gathered} F_{3} \text { if } Z=L \\ F_{3} \nabla S_{3} \text { if } Z=H \end{gathered}$ | $\bar{G}$ | $\mathrm{S}_{3}$ | Input | Input |
| 6 | 0 | L | $\begin{gathered} 0 \text { if } Z=L \\ \bar{R}_{i} \wedge S_{i} \text { if } Z=H \end{gathered}$ | $\begin{aligned} & S_{i} \text { if } Z=L \\ & i_{i} V S_{i} \text { if } \\ & Z=H \end{aligned}$ | G v PCn | $C_{n+3} \nabla c_{n+4}$ | $\overline{\text { F }}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | Input | Input | $Q_{0}$ |
| 7 | 0 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | G v PC ${ }_{n}$ | $c_{n+3} \nabla c_{n+4}$ | $\overline{\mathrm{P}}$ | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{\gamma_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{\bar{Y}_{2}} \overline{Y_{3}}$ |
| 8 | 0 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | (Note 3) | $Q_{2} \nabla Q_{1}$ | $\overline{\bar{p}}$ | $Q_{3}$ | $\overline{\mathrm{G}}$ | $\bar{Q}_{0} \overline{Q_{1}} \bar{Q}_{2} \bar{Q}_{3}$ | $\bar{Q}_{0} \bar{Q}_{1} \bar{Q}_{2} \bar{Q}_{3}$ | $\overline{Q_{0}} \overline{Q_{1}} \overline{Q_{2}} \overline{Q_{3}}$ |
| 9 | 0 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | Gv PC, | $C_{n+3} \nabla c_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | $\bar{Q}_{0} \overline{Q_{1}} \bar{Q}_{2} \bar{Q}_{3}$ | $\bar{Q}_{0} \bar{Q}_{1} \bar{Q}_{2} \bar{Q}_{3}$ | $\overline{Q_{0}} \overline{Q_{1}} \bar{Q}_{2} \bar{Q}_{3}$ |
| 9 | 8 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | 0 | 0 | 0 | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{\mathrm{Q}}_{0} \overline{\mathrm{Q}_{1}} \overline{\mathrm{Q}}_{2} \overline{\mathrm{Q}}_{3}$ | $\overline{Q_{0}} \overline{Q_{1}} \overline{Q_{2}} \overline{\mathrm{Q}}_{3}$ | $\overline{Q_{0}} \overline{Q_{1}} \overline{Q_{2}} \overline{Q_{3}}$ |
| A | 0 | L | 0 | $\mathrm{S}_{\mathrm{i}}$ | (Note 4) | $\mathrm{F}_{2} \nabla \mathrm{~F}_{1}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | (Note 5) | (Note 5) | (Note 5) |
| B | 0 | L | $\mathrm{R}_{\mathrm{i}} \wedge \mathrm{S}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \mathrm{S}_{\mathrm{i}}$ | G v PC, | (Note 8) | (Note 8) | (Note 9) | (Note 9) | $\overline{Y_{0}} \overline{Y_{1}} \overline{\gamma_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \bar{Y}_{2} \bar{Y}_{3}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |
| C | 0 | L | $\begin{aligned} & \frac{R_{i}}{R_{i}} \wedge S_{i} \text { if } Z=L \\ & S_{i} \text { if } Z=H \end{aligned}$ | $\begin{gathered} R_{i} \vee S_{i} \text { if } \\ \bar{M}_{i} \vee L_{i} \text { if } \\ z=H \end{gathered}$ | $\mathrm{Gv} P \mathrm{C}_{n}$ | $C_{n+3} \nabla c_{n+4}$ | $\overline{\text { ¢ }}$ | $F_{3}$ | $\bar{G}$ | Sign Compare | Input | Input |
| D | 0 | L | $\mathrm{R}_{\mathrm{i}} \wedge \overline{\mathrm{S}}_{\mathrm{i}}$ | $\mathrm{R}_{\mathrm{i}} \vee \overline{\mathrm{S}}_{\mathrm{i}}$ | G v PC, | $c_{n+3} \nabla c_{n+4}$ | $\overline{\bar{p}}$ | $\mathrm{F}_{3}$ | $\bar{G}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}}$ |
| E | 0 | L | $\begin{aligned} & \frac{R_{i}}{R_{i}} \wedge S_{i} \text { if } Z=L \\ & S_{i} \\ & \text { if } \\ & \hline \end{aligned}$ | $\begin{gathered} R_{i} \vee S_{i} \text { if } \\ \bar{R}_{i} \vee=_{i} \text { if } \\ Z=H \end{gathered}$ | Gv PC, | $c_{n+3} \nabla c_{n+4}$ | $\overline{\text { P }}$ | $F_{3}$ | $\bar{G}$ | Sign Compare F Output | Input | Input |
| F | 0 | L | $\overline{\mathrm{K}_{\mathrm{i}}} \wedge \mathrm{s}_{\mathrm{i}}$ | $\overline{\bar{R}_{i}} \vee \mathrm{~S}_{\mathrm{i}}$ | G v $\mathrm{PC}_{n}$ | $C_{n+3} \nabla c_{n+4}$ | $\overline{\text { ¢ }}$ | $\mathrm{F}_{3}$ | $\overline{\mathrm{G}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ | $\overline{Y_{0}} \overline{Y_{1}} \overline{Y_{2}} \overline{Y_{3}}$ |

Notes: 1. If $\overline{L S S}$ is LOW, $G_{0}=S_{0}$ and $G_{1,2,3}=0$. If $\overline{L S S}$ is $H I G H, G_{0,1}, 2,3=0$.
2. If $\overline{L S S}$ is LOW, $P_{0}=1$ and $P_{1}, 2,3=S_{1}, 2$, 3. If $\overline{L S S}$ is HIGH, $P_{i}=S_{i}$
3. At the most significant slice, $C_{n+4}=Q_{3} \nabla Q_{2}$. At other slices, $C_{n+4}=G \vee P C_{n}$. 4. At the most significant slice, $C_{n}+4=F_{3} \nabla F_{2}$. At other slices, $C_{n+4}=G \vee P C_{n}$. 5. $Z=\overline{Q_{0}} \overline{Q_{1}} \overline{Q_{2}} \overline{Q_{3} F_{0}} \overline{F_{1}} \overline{F_{2}} \overline{F_{3}}$.
6. If $\overline{\mathrm{LSS}}$ is LOW, $\mathrm{G}_{0}=0$ and $\mathrm{G}_{1}, 2,3=\mathrm{S}_{1}, 2,3$. If $\overline{\mathrm{LSS}}$ is HIGH, $\mathrm{G}_{0,1}, 2,3=\mathrm{S}_{0}, 1,2,3$.
7. If $\overline{L S S}$ is LOW, $P_{0}=S_{0}$ and $P_{1}, 2,3=1$. If $\overline{L S S}$ is HIGH, $P_{0}, 1,2,3=1$
8. On all slices $\overline{\mathrm{P}}=\left(\overline{\mathrm{P}}_{0}+\overline{\mathrm{P}}_{3}\right)\left(\bar{P}_{0}+\bar{G}_{2}\right)\left(\bar{P}_{0}+\overline{\mathrm{G}}_{1}+\bar{P}_{2}\right)$.
9. On all slices $\bar{G}=\bar{G}_{3}\left(\bar{G}_{0}+\bar{G}_{1}+\bar{P}_{2}\right)\left(\bar{G}_{0}+\bar{G}_{1}\right)\left(\bar{P}_{1}+\bar{G}_{2}\right)\left(\bar{P}_{3}+\bar{P}_{1} \cdot \overline{\mathrm{P}} 2 \cdot \bar{G}_{0}\right)$.
$L=L O W=0$
$H=H I G H=1$
$V=O R$
$\hat{\nabla}=$ AND
$\nabla=$ EXCLUSIVE OR
$P=P_{3} P_{2} P_{1} P_{0}$
$G=G_{3} \vee G_{2} P_{3} G_{1} P_{2} P_{3} \vee G_{0} P_{1} P_{2} P_{3}$
$C_{n+3}=G_{2} \vee G_{1} P_{2} \vee G_{0} P_{1} P_{2}$
$v C_{n} P_{0} P_{1} P_{2}$

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$
$\qquad$ .-0.5 V to +5.5 V
DC Output Current, Into Outputs $\qquad$ ............. 30mA
DC Input Current ............................. 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $\ldots 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$
Military (M) Devices
Temperature
re ... $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


| Parameters | Description | Test Conditions (Note 1) |  |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| $\begin{aligned} & \mathrm{lozH} \\ & \mathrm{IOZL} \end{aligned}$ | Off State (HIGH Impedance) Output Current | $\begin{aligned} & V_{C C}=M A X, \\ & \text { (Note 4) } \end{aligned}$ | $Y_{0}-Y_{3}$ |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 110 |  |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -1130 |  |
|  |  |  | $\mathrm{DB}_{0}, 3, \mathrm{QlO}_{0}, \mathrm{QlO}_{3}$$\mathrm{SIO}_{0}, \mathrm{SIO}_{3}, \mathrm{WRITE} /$ MSS |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 90 | $\mu \mathrm{A}$ |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -770 |  |
| los | Output Short Circuit Current (Note 3) | $\begin{aligned} & V_{C C}=M A X+0.5 V \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -30 |  | -85 | mA |
| Icc | Power Supply Current (Note 5) | $\mathrm{V}_{C C}=\mathrm{MAX}$ | COM'L | $T_{A}=$ | to $70^{\circ} \mathrm{C}$ |  |  | 350 | mA |
|  |  |  |  | $\mathrm{T}^{\prime}=$ |  |  |  | 291 |  |
|  |  |  | MIL | $\mathrm{T}^{\text {c }}$ = | 55 to $125^{\circ} \mathrm{C}$ |  |  | 395 |  |
|  |  |  |  | $T_{C}=$ | $5^{\circ} \mathrm{C}$ |  |  | 258 |  |

Notes:

1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the apolicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{C}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. $\mathrm{Y}_{0-3}, \mathrm{DB}_{0-3}, \mathrm{SIO}_{0,3}, \mathrm{QIO}_{0,3}$, and WRITE/MSS are three state outputs internally connected to TTL'inputs. $Z$ is an open-collector output internally connected to a TTL input. Input characteristics are measured under conditions such that the outputs are in the OFF state.
5. Worse case ICC is at minimum temperature
6. Three input levels provide zero noise immunity and should only be static tested in a noise-free environment (not functionally tested).


## Notes on Testing

Incoming test procedures on this device should be carefully planned taking into account the high complexity and power levels of the part. The following notes may be useful:
1.Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current when the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2.Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3.Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable
may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{I L}$ or $\mathrm{V}_{\text {IH }}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function and AC tests as three distinct groups of tests.
6. To assist in testing AMD, offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS
C. OPEN-COLLECTOR OUTPUTS


TC001430

$$
R_{1}=\frac{5.0-V_{B E}-V_{O L}}{\frac{1 O L+V_{O L}}{1 K}} \quad R_{2}=\frac{2.4 \mathrm{~V}}{1 \mathrm{KH}}=\frac{5.0-}{\frac{\mathrm{IO}}{}}
$$




TC001420

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in hand in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function test and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $C_{L}=5.0 \mathrm{pF}$ for output disable tests.

TEST OUTPUT LOADS FOR Am29203

| Pin\# | Pin Label | Test <br> Circuit | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{QIO}_{0}$ | A | 458 | 1 K |
| 11 | $\mathrm{C}_{n}+4$ | B | 478 | 3 K |
| 12 | $\overline{\mathrm{P} / O \mathrm{VR}}$ | B | 383 | 3 K |
| 14 | $\overline{\mathrm{G}} / \mathrm{N}$ | B | 212 | 1.5 K |
| $16-19$ | $\mathrm{Y}_{0-3}$ | A | 241 | 1 K |
| 20 | $\mathrm{SIO}_{0}$ | A | 458 | 1 K |
| 21 | $\mathrm{SIO}_{3}$ | A | 458 | 1 K |
| 22 | Z | C | 281 | - |
| $23-26$ | $\mathrm{DB}_{0-3}$ | A | 458 | 1 K |
| 40 | $\overline{\mathrm{WRITE}} / \overline{\mathrm{MSS}}$ | A | 458 | 1 K |
| 48 | $\mathrm{QIO}_{3}$ | A | 458 | 1 K |

For additional information on testing, see section
"Guidelines on Testing Am2900 Family Devices."

## Am 290203 GUARANTEED COMMERCIAL RANGE PERFORMACE

The Am290203 switching characteristics are a function of the power supply voltage, the temperature, and the operating
index to switching tables

| Table | Data Type | Conditions | Applicable To |
| :--- | :---: | :---: | :--- |
| A | Clock and Write Pulse | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| B | Enable/Disable Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| C | Setup and Hold Times | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | All Functions |
| I-2 | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Standard and Increment/Decrement by 1 or 2 |
| I-3 | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Multiply Instructions |
| I-4 | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Divide Instructions |
| $1-5$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | BCD Instructions |
| $1-6$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Sign Magnitude to Two's Complement Conversion |
| $1-7$ | Combinational Delays | 4.75 to $5.25 \mathrm{~V}, 0$ to $70^{\circ} \mathrm{C}$ | Single Length Normalization |

## Am29203 Guaranteed Commercial Range Performance

TABLE B. ENABLE/DISABLE TIMES ALL FUNCTIONS

The tables below specify the guaranteed performance of the Am29203 over the commercial operating range of 0 to $+70^{\circ} \mathrm{C}$, with $\mathrm{V}_{\mathrm{CC}}$ from 4.75 to 5.25 V . All data are in ns, with inputs switching between 0 and 3 V at $1 \mathrm{~V} / \mathrm{ns}$ and measurements made at 1.5 V . All outputs have maximum DC load.

TABLE A. CLOCK AND WRITE PULSE CHARACTERISTICS ALL FUNCTIONS

| Minimum Clock LOW Time | 30ns |
| :--- | :---: |
| Minimum Clock HIGH Time | 30ns |
| Minimum Time CP and $\overline{\text { WE }}$ <br> both LOW to Write | 15 ns |

mode of the devices. The data has been condensed onto the tables below.

| From | To | Enable | Disable |
| :--- | :--- | :---: | :---: |
| $\overline{\mathrm{OEY}}$ | Y | 25 | 21 |
| $\overline{\mathrm{OEB}}$ | DB | 25 | 21 |
| $\overline{\mathrm{EA}}$ | DA | 25 | 21 |
| $\mathrm{I}_{8}$ | SIO | 25 | 21 |
| $I_{8}$ | QIO | 38 | 38 |
| $I_{8765}$ | QIO | 38 | 38 |
| $I_{43210}$ | QIO | 38 | 38 |
| $\overline{\text { LSS }}$ | $\overline{\mathrm{WR}}$ | 25 | 21 |

Note: $C_{L}=5 p F$ for output disable tests. Measurement is made to a 0.5 V change on the output.

## COMBINATIONAL PROPAGATION DELAYS

$C_{L}=50 \mathrm{pF}$
1-2 STANDARD AND INCREMENT/DECREMENT BY ONE OR TWO INSTRUCTIONS

|  | To |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From | Y | $C_{n+4}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | Z | N | OVR | DA, DB | $\bar{W}$ | $\mathrm{QOO}_{0}, 3$ | $\mathrm{SIO}_{0}$ | $\mathbf{S I O}_{3}$ | $\underset{\text { Parity }}{\mathrm{SIO}_{0}}$ |
| A, B Addr | 67 | 55 | 52 | 74 | 64 | 71 | 30 | - | - | 44 | 62 | 84 |
| DA, DB | 58 | 50 | 44 | 65 | 54 | 60 | - | - | - | 35 | 59 | 68 |
| $\mathrm{C}_{\mathrm{n}}$ | 30 | 18 | - | 35 | 26 | 26 | - | - | - | 21 | 27 | 40 |
| $18-0$ | 64 | 64 | 50 | 72 | 59 | 62 | - | 34 | 26 | 48 | 62 | 74 |
| CK | 58 | 42 | 43 | 61 | 54 | 60 | 21 | - | 21 | 35 | 54 | 65 |
| $\overline{\mathrm{MSS}}$ | 33 | - | 41 | 40 | 36 | 44 | - | - | - | 40 | 40 | 44 |
| $\mathrm{SIO}_{0,3}$ | 23 | - | - | 29 | - | - | - | - | - | - | 29 | 19 |

table c. set-up and hold times all functions

|  |  | HIGH-to-LOW |  | LOW-to-HIGH |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| From | With Respect to | Set-up | Hold | Set-up | Hold | Comments |
| Y | CP | Don't Care | Don't Care | 14 | 3 | Store Y in RAM/Q |
| $\overline{\text { WE HIGH }}$ | CP | 15 |  |  | 0 | Prevent Writing |
| $\overline{\text { WE LOW }}$ | CP | Don't Care | Don't Care | 15 | 0 | Write into RAM |
| A, B Source | CP | 20 | 3 | Don't Care | Don't Care | Latch Data from RAM Out |
| $B$ Destination | CP | 6 |  |  | 3 | Write Data into B Address |
| $\mathrm{QlO}_{0}, 3$ | CP | Don't Care | Don't Care | 17 | 3 | Shift Q |
| 18765 | CP | 28 |  |  | 0 |  |
| IEN HIGH | CP | 24 |  |  | 0 | Prevent Writing into Q |
| IEN LOW | CP | Don't Care | Don't Care | 21 | 0 | Write into Q |
| 143210 | CP | 24 | Tp |  | 0 |  |

Note: 1. The internal Y-bus to RAM set-up condition will be met 5 ns after valid $Y$ output $(\overline{\mathrm{OEY}}=0)$.
1-5 BCD INSTRUCTIONS (SF 1, SF 7, SF 9, SF B, SF D, SF F)

| From | To |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $C_{n+4}$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z | N | OVR | $\begin{aligned} & \text { DA } \\ & \text { DB } \end{aligned}$ | $\overline{\text { WR }}$ | Q10 | $\mathrm{SIO}_{0}$ | $\mathrm{SIO}_{3}$ | SIO <br> Parity |
| A, B Addr | MSS | 77 | 55 | - | 72 | 68 | 68 | 30 | - | - | 44 | 62 | 84 |
|  | IS | 77 | 55 | 61 | 72 | - | - | 30 | - | - | 44 | 62 | 84 |
|  | LSS | 77 | 55 | 61 | 72 | - | - | 30 | - | - | 44 | 62 | 84 |
| DA, DB | MSS | 61 | 50 | - | 65 | 58 | 59 | - | - | - | 35 | 59 | 68 |
|  | IS | 61 | 50 | 49 | 65 | - | - | - | - | - | 35 | 59 | 68 |
|  | LSS | 61 | 50 | 49 | 65 | - | - | - | - | - | 35 | 59 | 68 |
| $C_{n}$ | MSS | 36 | 23 | - | 35 | 33 | 33 | - | - | - | 29 | 34 | 40 |
|  | IS | 36 | 23 | - | 35 | - | - | - | - | - | 29 | 34 | 40 |
|  | LSS | 36 | 23 | - | 35 | - | - | - | - | - | 29 * | 34 | 40 |
| $18-0$ | MSS | 72 | 64 | - | 72 | 59 | 62 | - | - | 26 | 48 | 62 | 74 |
|  | IS | 72 | 64 | 60 | 72 | - | - | - | - | 26 | 48 | 62 | 74 |
|  | LSS | 72 | 64 | 60 | 72 | - | - | - | 34 | 26 | 48 | 62 | 74 |
| CK | MSS | 68 | 52 | - | 68/29 ${ }^{1}$ | 64 | 60 | 21 | - | 21 | 35 | 54 | 65 |
|  | IS | 68 | 52 | 55 | $68 / 29^{1}$ | - | - | 21 | - | 21 | 35 | 54 | 65 |
|  | LSS | 68 | 52 | 55 | $68 / 29^{1}$ | - | $-$ | 21 | - | 21 | 35 | 54 | 65 |
| Z | MSS | - | - | - | - | - | - | - | - | - | - | - | - |
|  | IS | - | - | - | - | - | - | - | - | - | - | - | - |
|  | LSS | - | - | - | - | - | - | - | - | - | - | - | - |
| IEN | Any | - | - | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SIO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - | - | - |

Note 1: Binary to $B C D$ and multiprecision Binary to $B C D$ Instructions only.
$B C D$ to Binary conversion (SF 1)
BCD divide by two (SF 7)

Binary to BCD conversion (SF 9)
$B C D$ add (SF B)
$B C D$ substract (SF D, SF F)


## Guaranteed Combinational Delays

$T_{A}=0$ to $+70^{\circ} \mathrm{C}, V_{C C}=4.75$ to 5.25 V
1-6 SIGN MAGNITUDE TO TWO'S COMPLEMENT CONVERSION (SF 5)

| From | To |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | Y | $C_{n+4}$ | $\overline{\mathbf{G}, ~ \overline{\mathbf{P}}}$ | Z | N | OVR | $\begin{aligned} & \text { DA } \\ & \text { DB } \end{aligned}$ | $\overline{W R}$ | Q10 | $\overline{\text { SIO }}$ | $\mathrm{SIO}_{0}$ <br> Parity |
| A,B Addr | MSS | 98 | 88 | - | 42 | 97 | 104 | 30 | - | - | - | 132 |
|  | IS | 67 | 55 | 52 | - | - | - | 30 | - | - | - | 84 |
|  | LSS | 67 | 55 | 52 | - | - | - | 30 | - | - | - | 84 |
| DA, DB | MSS | 93 | 83 | - | 37 | 92 | 99 | - | - | - | - | 127 |
|  | IS | 58 | 50 | 44 | - | - | - | - | - | - | $\cdots$ | 68 |
|  | LSS | 58 | 50 | 44 | - | - | - | - | - | - | - | 68 |
| $C_{n}$ | MSS | 30 | 18 | - | - | 29 | 26 | - | - | - | - | 40 |
|  | IS | 30 | 18 | - | - | - | - | - | - | - | - | 40 |
|  | LSS | 30 | 18 | - | - | - | - | - | - | - | -. | 40 |
| $18-0$ | MSS | 89 | 73 | - | 28 | 91 | 84 | - | - | - | - | 118 |
|  | IS | 86 | 73 | 72 | - | - | - | - | - | - | - | 96 |
|  | LSS | 86 | 73 | 72 | - | - | - | - | 34 | - | - | 96 |
| CK | MSS | 96 | 82 | - | 36 | 89 | 98 | 21 | - | - | - | 126 |
|  | IS | 58 | 42 | 43 | - | - | - | 21 | - | - | - | 65 |
|  | LSS | 58 | 42 | 43 | - | - | - | 21 | - | - | - | 65 |
| z | MSS | - | - | - | - | - | - | - | - | - | - | - |
|  | IS | 62 | 46 | 44 | - | - | - | - | - | - | - | 90 |
|  | LSS | 62 | 46 | 44 | - | - | - | - | - | - | - | 90 |
| IEN | Any | - | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SIO}_{0}-3$ | Any | - | - | - | - | - | - | - | - | - | - | - |

$\begin{array}{ll}\text { SF 5: } & =S+C_{n} \text { if } Z=L \\ F & =S+C_{n} \text { if } Z=H \\ F & =S_{3} \\ Y_{3} & =S_{3} F_{3} \text { (MSS) }\end{array}$
$\begin{aligned} & \left.=S_{3} \nabla F_{3}\right) \\ & =S_{3} \text { (MSS) }\end{aligned}$


Guaranteed Combinational Delays
$T_{A}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=4.75$ to 5.25 V
1-4 DIVIDE INSTRUCTIONS (SF A, SF C, SF E)

| From | To |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slice | $\mathbf{Y}$ | $C_{n+4}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | Z | N | OVR | $\mathrm{SIO}_{3}$ | DA, DB | $\mathrm{ClO}_{3}$ | $\overline{\text { WR }}$ | SIO <br> Parity |
| A, B Addr | MSS | 67 | 55/60 ${ }^{1}$ | - | 74 | 64 | 71 | 30 | - | - | 62 | - |
|  | IS | 67 | 55 | 52 | 74 | - | - | 30 | - | - | 62 | - |
|  | LSS | 67 | 55 | 52 | 74 | - | - | 30 | - | - | 62 | - |
| DA, DB | MSS | 58 | 50/55 ${ }^{1}$ | - | 65 | 54 | 60 | - | - | - | 59 | - |
|  | IS | 58 | 50 | 44 | 65 | - | - | - | - | - | 59 | - |
|  | LSS | 58 | 50 | 44 | 65 | - | - | - | - | - | 59 | - |
| $C_{n}$ | MSS | 30 | 18/41 ${ }^{1}$ | - | 35 | 26 | 26 | - | - | - | 30/27 ${ }^{1}$ | - |
|  | IS | 30 | 18 | - | 35 | - | - | - | - | - | 27 | - |
|  | LSS | 30 | 18 | - | 35 | - | - | - | - | - | 27 | - |
| 18-0 | MSS | $80 / 55^{1}$ | 75 | - | $47^{1} / 31^{2}$ | 77 | 77 | - | - | 26 | 90/71 ${ }^{1}$ | - |
|  | IS | 80/55 ${ }^{1}$ | 75 | - | $47^{1}$ | - | - | - | - | 26 | 85/52 ${ }^{1}$ | - |
|  | LSS | $80 / 55^{1}$ | 75 | - | $47^{1}$ | - | - | - | 34 | 26 | 85/52 ${ }^{1}$ | - |
| CK | MSS | $58^{1 / 89}{ }^{2}$ | $50^{1 / 73^{2}}$ | - | $61^{1 / 29^{2}}$ | $54^{1 / 92}{ }^{2}$ | $60^{1 / 92}{ }^{2}$ | 21 | - | 21 | $87^{2} / 54^{1}$ | - |
|  | IS | 58 | 42 | 43 | $61^{1}$ | - | - | 21 | - | 21 | 54 | - |
|  | LSS | 58 | 42 | 43 | $61^{1}$ | - | - | 21 | - | 21 | 54 | - |
| z | MSS | - | - | - | - | - | - | - | - | - | - | - |
|  | IS | 61 | 44 | 46 | - | - | - | - | - | - | 58 | $-$ |
|  | LSS | 61 | 44 | 46 | - | - | - | - | - | - | 58 | - |
| IEN | Any | - | - | - | - | - | - | - | - | - | - | - |
| $\mathrm{SIO}_{0-3}$ | Any | 23 | - | - | - | - | - | - | - | - | - | - |
| Notes: <br> 1. Only 1st divide and normalization. <br> 2. Only two's complement divide and two's complement divide correction |  |  |  |  |  |  |  |  |  |  |  |  |

Double Length Normalize and First Divide Op
SF A:
$F=S+C N$
$N=F_{3}(M S S)$
$S O_{3}=F_{3} \nabla R_{3}$ (MSS),
$C_{n}+4=F_{3} \nabla F_{2}$ (MSS),
$O V R=F_{2} \nabla F_{1}$ (MSS)
$Z=Q_{0} Q_{1} \overline{Q_{2}} Q_{3} F_{0} \overline{F_{1}} \overline{F_{2}} \overline{F_{3}}$

Two's Complement Divide
SF C: $\quad F=R+S+C n$ if $Z=L$
$F=S-R-1+C n$ if $Z=H$
$\mathrm{SIO}_{3}=\mathrm{F}_{3} \nabla \mathrm{R}_{3}$ (MSS)
$Z=\overline{F_{3} \nabla R_{3}}$ (MSS) from previous cycle
Two's Complement Divide Correction and Remainder
SF E:
$\mathrm{F}=\mathrm{R}+\mathrm{S}+\mathrm{Cn}$ if $\mathrm{Z}=\mathrm{L}$
$\mathrm{F}=\mathrm{S}-\mathrm{R}-1+\mathrm{Cn}$ if $\mathrm{Z}=\mathrm{H}$
$Z=\overline{F_{3} \nabla R_{3}}$ (MSS) from previous cycle

## Am29803A

16-Way Branch Control Unit

## DISTINCTIVE CHARACTERISTICS

- 16 separate instructions $-2,4,8$ or 16-way branch in one microprogram execution cycle
- Four individual test inputs
- Advanced Low-Power Schottky processing
- Four individual outputs for driving the four OR inputs on the Am2909A Microprogram Sequencer
- Provides maximum branch capability in a microprogram control unit using the Am2909

GENERAL DESCRIPTION

The Am29803A is a Low-Power Schottky processed device that provides 16-way branch control when used in conjunction with the Am2909A Microprogram Sequencer.

The device features 16 instructions that provide all combinations of simultaneous testing of four different inputs. The device has four outputs that are used to drive the four OR inputs of the Am2909A Microprogram Sequencer.

The 'zero" instruction inhibits the testing of any of the four test ( T ) inputs. The remaining 15 instructions are used to
test combinations of $1,2,3$ or 4 of the $T$ inputs simultaneously. If one $T$ input is being tested, the Am29803A will select one of two possible addresses. If two $T$ inputs are being tested, the device will select one of four possible addresses. If three $T$ inputs are being tested, the device will select one of eight possible addresses. If all four T inputs are being tested, the device will select one of sixteen addresses as the field used to drive the OR inputs of the Am2909A.

BLOCK DIAGRAM


BD002570

CONNECTION DIAGRAM Top View

D16
P16
F-16*

*F-16 pin configuration identical to D-16, P16.
Note: Pin 1 is marked for orientation

## LOGIC SYMBOL



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am29803A
```



```
Device type
16-Way Branch Control Unit
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-16-pin CERDIP
F-16-pin flatpak
P-16-pin plastic DIP
```

| Valid Combinations |  |
| :--- | :--- |
| Am29803A | PC <br> DC, DCB, DMB <br> FMB |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{array}{ll} \hline 3,2 \\ 1,15 \end{array}$ | $\begin{array}{\|ll\|} \hline l_{0} & 1_{1}, \\ l_{2} & 1 \\ \hline \end{array}$ | 1 | The four instruction inputs to the device. |
| $\begin{aligned} & 5,6 \\ & 7,4 \\ & \hline \end{aligned}$ | $\begin{array}{ll} \hline \mathrm{T}_{0}, & \mathrm{~T}_{1}, \\ \mathrm{~T}_{2}, & \mathrm{~T}_{3} \\ \hline \end{array}$ | 1 | The four test inputs for the device. |
| $\begin{aligned} & 9,10,11, \\ & 12 \end{aligned}$ | $\begin{aligned} & \mathrm{OR}_{0}, \mathrm{OR}_{1} \\ & \mathrm{OR}_{2}, \mathrm{OR}_{3} \end{aligned}$ | 0 | The four outputs of the device that are connected to the four OR inputs of the Am2909. |
| 13, 14 | $\overline{\mathrm{OE}}_{1}, \overline{\mathrm{OE}}_{2}$ | 1 | Output Enable. When either $\overline{\mathrm{OE}}$ input is HIGH, the $\mathrm{OR}_{\mathrm{i}}$ outputs are in the high impedance state. When both the $\overline{\mathrm{OE}}{ }_{1}$ and $\overline{\mathrm{OE}} 2$ inputs are LOW, the OR outputs are enabled and the selected data will be present. |

GUARANTEED LOADING RULES
OVER OPERATING RANGE (In Unit Loads)

A Low-Power Schottky TTL Unit Load is defined as $20 \mu \mathrm{~A}$ measured at 2.7 V HIGH and $\mathbf{- 0 . 3 6 m A}$ measured at 0.4 V Low.

| Pin <br> No.'s | input/ <br> Output | Input <br> Load | Output <br> HIGH | Output <br> LIL |  |
| :---: | :--- | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{I}_{2}$ | 0.5 | - | - | - |
| 2 | $\mathrm{I}_{1}$ | 0.5 | - | - | - |
| 3 | $\mathrm{I}_{0}$ | 0.5 | - | - | - |
| 4 | $\mathrm{~T}_{3}$ | 0.5 | - | - | - |
| 5 | $\mathrm{~T}_{0}$ | 0.5 | - | - | - |
| 6 | $\mathrm{~T}_{1}$ | 0.5 | - | - | - |
| 7 | $\mathrm{~T}_{2}$ | 0.5 | - | - | - |
| 8 | $\mathrm{GND}^{2}$ | - | - | - | - |
| 9 | $\mathrm{OR}_{0}$ | - | 100 | 44 | 44 |
| 10 | $\mathrm{OR}_{1}$ | - | 100 | 44 | 44 |
| 11 | $\mathrm{OR}_{2}$ | - | 100 | 44 | 44 |
| 12 | $\mathrm{OR}_{3}$ | - | 100 | 44 | 44 |
| 13 | $\mathrm{OE}_{1}$ | 0.5 | - | - | - |
| 14 | $\overline{\mathrm{OE}}_{2}$ | 0.5 | - | - | - |
| 15 | $\mathrm{I}_{3}$ | 0.5 | - | - | - |
| 16 | $\mathrm{~V}_{\mathrm{CC}}$ | - | - | - | - |



## FUNCTION TABLE (Cont.)

| Function | $\mathrm{I}_{3}$ | $\mathrm{I}_{2}$ | $\mathrm{I}_{1}$ | $\mathrm{I}_{0}$ | T3 | $\mathrm{T}_{2}$ | $\mathrm{T}_{1}$ | $\mathrm{T}_{0}$ | $\mathrm{OR}_{3}$ | $\mathrm{OR}_{2}$ | $\mathrm{OR}_{1}$ | $\mathrm{OR}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test $T_{0}, T_{1}, T_{2} \& T_{3}$ | H | H | H | H | L | L | L | L | L | L | L | L |
|  |  |  |  |  | $L$ | L | L | H L | $L_{L}^{L}$ | $L$ | L | H L |
|  |  |  |  |  | $L$ | $L$ | H | H | L | L | H | H |
|  |  |  |  |  | L | H | L | L | L | H | L | L |
|  |  |  |  |  | L | H | L | H | L | H | L | H |
|  |  |  |  |  | L | H | H | L | L | H | H | L |
|  |  |  |  |  |  | H | ${ }_{\mathrm{H}}$ | H | L | ${ }_{H}$ | H | H |
|  |  |  |  |  | H H | L | $L$ | L H | H H H | L | L | L H |
|  |  |  |  |  | H | $L$ | H | L | H | L | H | H L |
|  |  |  |  |  | H | $L$ | H | H | H | L | H | H |
|  |  |  |  |  | H | H | L | L | H | H | L | L |
|  |  |  |  |  | H | H | L | H | H | H | L | H |
|  |  |  |  |  | H | H | H | L | H | H | H | L |
|  |  |  |  |  | H | H | H | H | H | H | H | H |

## $H=H I G H$

X $=$ Don't care

APPLICATION


AF001831
A typical computer control unit using the Am2909, Am2911, Am29803A and Am29811A. Note that the least significant microprogram sequencer is an Am2909 and the more significant sequencers are Am2911's.

## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature ....................... $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Ambient Temperature Under Bia | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential |  |
| DC Voltage Applied to Outputs For |  |
| High Output State | V to $+\mathrm{V}_{\mathrm{Cc}} \mathrm{max}$ |
| DC Input Voltage. | -0.5 V to +5.5 V |
| Output Current, Into O |  |
|  | 30mA to +5.0 mA |

Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
upply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous...
High Output Stat, Into Outputs -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

## Military (M) Devices

Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | 2.4 |  |  | Volts |
| Vol | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IOL}=16 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ |  |  |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=0.45 \mathrm{~V}$ |  |  | -0.010 | -0.250 | mA |
| $\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 | $V_{C C}=M A X, V_{I N}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ (Note 2) |  | -20 | -40 | -90 | mA |
| ICC | Power Supply Current | $\begin{aligned} & \text { All inputs }=\text { GND } \\ & V_{C C}=M A X \end{aligned}$ |  |  | 95 | 130 | mA |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ICEX | Output Leakage Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{C S 1}=2.4 V \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 40 |  |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -40 |  |
| $\mathrm{CIN}_{1}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V} @ f=1 \mathrm{MHz}$ (Note 3) |  |  | 4 |  | pF |
| COUT | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=\mathrm{MHz}$ (Note 3) |  |  | 8 |  |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
2. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
3. These parameters are not $100 \%$ tested, but are periodically sampled.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | $l_{i}$ to $\mathrm{OR}_{\mathrm{i}}$ | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 25 | 35 | ns |
| tPHL |  |  |  |  |  |  |
| tPLH | $\mathrm{T}_{\mathrm{i}}$ to $O \mathrm{R}_{\mathrm{i}}$ |  |  |  |  | ns |
| tPHL |  |  |  | 25 | 35 |  |
| ${ }_{\text {Z }} \mathrm{H}$ | $\overline{O E} E_{i}$ to $O R_{i}$ |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 15 | 18 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{\mathrm{OE}} \mathrm{E}_{\mathrm{i}}$ to $\mathrm{OR}_{\mathrm{i}}$ | $\begin{aligned} C_{L} & =5.0 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 15 | 18 | ns |
| ${ }_{\text {t }}$ |  |  |  |  |  |  |


| SWITCHING CHARACTERISTICS over operating range unless otherwise specified |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| Parameters |  |  | Min | Max | Min | Max |  |
| tplH | $\mathrm{I}_{\mathrm{i}}$ to $\mathrm{OR}_{\mathrm{i}}$ | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  |  |  |  |  |
| tpHL |  |  |  | 45 |  | 60 | ns |
| tPLH | $\mathrm{T}_{\mathrm{i}}$ to $\mathrm{OR}_{\mathrm{i}}$ |  |  | 45 |  | 60 | ns |
| tphL |  |  |  |  |  |  | ns |
| $\mathrm{t}^{\mathrm{t} \mathrm{H}} \mathrm{H}$ | $\overline{\mathrm{C}} \mathrm{E}_{\mathrm{i}}$ to $\mathrm{OR}_{\mathrm{i}}$ |  |  | 30 |  | 30 | ns |
| tzL |  |  |  |  |  |  | ns |
| ${ }^{\text {thz }}$ | $\overline{\mathrm{O}} \mathrm{E}_{\mathrm{i}}$ to $\mathrm{OR} \mathrm{i}_{\mathrm{i}}$ |  |  | 20. |  | 20 | ns |
| tLz |  |  |  |  |  |  |  |

## LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

## Am29811A

Next Address Control Unit

## DISTINCTIVE CHARACTERISTICS

- Next address control unit for the Am2911A Microprogram Sequencer
- 16 next address instructions
- Test input for conditional instructions
- Separate outputs to control the Am2911A, an independent event counter, and a mapping PROM/branch address interface
- Advanced Low-Power Schottky technology


## GENERAL DESCRIPTION

The Am29811A is a Low-Power Schottky device designed specifically for next address control of the Am2911A Microprogram Sequencer. The device contains all outputs required to control a high-performance computer control unit or a structured state machine design using microprogramming techniques.

Sixteen instructions are available by using a four-bit instruction field $\mathrm{I}_{0-3}$. In addition, a test input is available such that conditional instructions can be performed based on a condition code test input.

The full instruction set consists of such functions as conditional jumps, conditional jump-to-subroutine, conditional return-from-subroutine, conditional repeat loops, conditional branch to starting address, and so forth.

One Am29811A can be used to control any number of Am2911A Microprogram Sequencers. The Am2911A Sequencer is a four-bit slice itself. Thus, one Am29811A Next Address Control Unit and three Am2911A Microprogram Sequencers can be used to build a powerful, microprogram sequencer capable of controlling 4 k words of microprogram memory.



LOGIC SYMBOL


LS001090
ORDERING INFORMATION
AMD products are available in several packages and operating ranges．The order number is formed by a combination of the following： Device number，speed option（if applicable），package type，operating range and screening option（if desired）．

Am29811A


Device type
Next Address Control Unit

| Valid Combinations |  |
| :--- | :--- |
| Am29811A | PC <br> DC，DCB，DMB <br> FMB |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish．

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 11,12 \\ & 13,14 \\ & \hline \end{aligned}$ | $\begin{aligned} & 10,1_{1} \\ & 1_{2}, 1_{3} \\ & \hline \end{aligned}$ | 1 | The four instruction inputs to the Am29811A. |
| 10 | TEST | 1 | The condition code input to the device. When the test input is LOW, the device assumes the test has failed. When the test input is HIGH, the device assumes the condition code required has been met; the test has passed. |
| 6 | $\begin{array}{\|l} \hline \frac{\text { Counter }}{} \\ \hline \text { Load } \end{array}$ | 0 | This output is used to drive the parallel load input of an Am25LS2569 up/down counter. |
| 7 | $\begin{array}{\|l} \hline \overline{\text { Counter }} \\ \hline \text { Enable } \end{array}$ | 0 | This output is used to drive the counter enable input of an Am25LS2569 up/down counter. |
| 1 | $\overline{\overline{\text { Map }}} \overline{\text { Enable }}$ | 0 | This output is used to control the three-state outputs of the mapping PROM or PLA used to provide the initial starting address for each machine instruction. |
| 9 | $\begin{array}{\|l} \hline \text { Pipeline } \\ \hline \text { Enable } \\ \hline \end{array}$ | 0 | This output is used to control the three-state output of the pipeline register (Am2918) containing the branch address for the computer control unit. |
| 3 | FE File Enable | 0 | This output is used to drive the file enable input of the Am2911. When the file enable output is LOW, a stack operation will take place. |
| 2 | PUP | 0 | Push/Pop. The PUP output is used to drive the push/pop input of the Am2911 Microprogram Sequencer. When the PUP output is HIGH, a push will take place when the file is enabled. When the PUP output is LOW, a pop will take place when the file is enabled. |
| 5, 4 | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ | $\bigcirc$ | These two outputs are used to drive the $\mathrm{S}_{0}$ and $\mathrm{S}_{1}$ inputs to the Am2911 Microprogram Sequencer. These outputs control whether the direct input, the register, the microprogram counter, or the stack is selected as the source of the next address for the microprogram memory. |

## GUARANTEED LOADING RULES

OVER OPERATING RANGE (In Unit Loads)

A Low-Power Schottky TTL Unit Load is defined as
$20 \mu \mathrm{~A}$ measured at 2.7 V HIGH and -0.36 mA measured at 0.4 V LOW.

|  | Input/ <br> Output | Input <br> Load | Output <br> HIGH |  |  |  | MIL <br> LOW <br> COM'L |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\overline{\text { MAP E }}$ | - | 100 | 44 | 44 |  |  |
| 2 | PUP | - | 100 | 44 | 44 |  |  |
| 3 | $\overline{\text { FE }}$ | - | 100 | -44 | 44 |  |  |
| 4 | $\mathrm{~S}_{1}$ | - | 100 | 44 | 44 |  |  |
| 5 | $\mathrm{~S}_{0}$ | - | 100 | 44 | 44 |  |  |
| 6 | $\overline{\text { CNT LOAD }}$ | - | 100 | 44 | 44 |  |  |
| 7 | $\overline{\mathrm{CNT} \mathrm{E}}$ | - | 100 | 44 | 44 |  |  |
| 8 | GND | - | - | - | - |  |  |
| 9 | $\overline{\text { PL E }}$ | - | 100 | 44 | 44 |  |  |
| 10 | TEST | 0.5 | - | - | - |  |  |
| 11 | $\mathrm{I}_{0}$ | 0.5 | - | - | - |  |  |
| 12 | $\mathrm{I}_{1}$ | 0.5 | - | - | - |  |  |
| 13 | $\mathrm{I}_{2}$ | 0.5 | - | - | - |  |  |
| 14 | $\mathrm{I}_{3}$ | 0.5 |  | - | - |  |  |
| 15 | $\overline{\mathrm{OE}}$ | - | 100 | 44 | 44 |  |  |
| 16 | $\mathrm{~V}_{\mathrm{CC}}$ | - | - | - | - |  |  |

## INSTRUCTION TABLE

| MNEMONIC | $l_{3} \quad \mathrm{I}_{2}$ | $l_{1} \quad l_{0}$ | INSTRUCTION |
| :---: | :---: | :---: | :---: |
| JZ | L | L | Jump to Address Zero. |
| CJS | L L | L H | Conditional Jump-to-Subroutine with Jump Address in Pipeline Register. |
| JMAP | L L | H L | Jump to Address at Mapping PROM Output. |
| CJP | L L | H H | Conditional Jump to Address in Pipeline Register. |
| PUSH | L H | L L | Push Stack and conditionally load counter. |
| JSRP. | L H | L H | Jump-to-Subroutine with starting address conditionally selected from Am2911 R-Register or Pipeline Register. |
| CJV | L H | H | Conditional Jump to Vector Address. |
| JRP | L H | H H | Jump to Address conditionally selected from Am2911 R-Register or Pipeline Register. |
| RFCT | H L | L L | Repeat Loop if counter is not equal to Zero. |
| RPCT | H L | L. H | Repeat Pipeline Address if counter is not equal to Zero. |
| CRTN | H L | H L | Conditional Return-from-Subroutine. |
| CJPP | H L | H H | Conditional Jump to Pipeline Address and Pop Stack. |
| LDCT | H H | L L | Load Counter and continue. |
| LOOP | H H | L H | Test end of Loop. |
| CONT | H H H | H H L | Continue to next address. |
| JP | H H | H H | Jump to Pipeline Register Address. |

Am29811A FUNCTION TABLE

| MNEMONIC | INPUTS |  |  | OUTPUTS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | INSTRUCTION <br> $\begin{array}{llll}l_{3} & l_{2} & l_{1} & l_{0}\end{array}$ | FUNCTION | TEST <br> INPUT | $\begin{aligned} & \text { NEXT } \\ & \text { ADDR } \\ & \text { SOURCE } \end{aligned}$ | FILE | COUNTER | MAP-E | PL-E |
| JZ | L L L L | JUMP ZERO | X | D | HOLD | LL* | H | L |
| CJS | L L L H | COND JSB PL | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} P C \\ D \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { PUSH } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| JMAP | L L H L | JUMP MAP | X | D | HOLD | HOLD | L | H |
| CJP | L L H H | COND JUMP PL | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{gathered} \hline \mathrm{PC} \\ \mathrm{D} \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| PUSH | L H L L | PUSH/COND LD CNTR | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{PC} \\ & \mathrm{PC} \end{aligned}$ | $\begin{aligned} & \text { PUSH } \\ & \text { PUSH } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { LOAD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ |
| JSRP | L H L H | COND JSB R/PL | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & R \\ & D \end{aligned}$ | $\begin{aligned} & \text { PUSH } \\ & \text { PUSH } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| CJV | L H H L | COND JUMP VECTOR | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{PC} \\ \mathrm{D} \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ |
| JRP | L H H H | COND JUMP R/PL | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{R} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| RFCT | H L L L | $\begin{aligned} & \text { REPEAT } \\ & \text { LOOP,CNTR } \neq 0 \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{F} \\ \mathrm{PC} \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { POP } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| RPCT | H L L H | REPEAT PL, CNTR $\neq 0$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \hline D \\ P C \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| CRTN | H L H L | COND RTN | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{PC} \\ \mathrm{~F} \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { POPP } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| CJPP | H L H H | COND JUMP PL \& POP | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \hline \mathrm{PC} \\ \mathrm{D} \end{gathered}$ | $\begin{array}{\|l} \text { HOLD } \\ \text { POP } \end{array}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ |
| LDCT | H H L L | LOAD CNTR \& CONTINUE | X | PC | HOLD | LOAD | H | L |
| LOOP | H H L H | TEST END LOOP | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{F} \\ \mathrm{PC} \end{gathered}$ | $\begin{aligned} & \text { HOLD } \\ & \text { POP } \end{aligned}$ | $\begin{aligned} & \text { HOLD } \\ & \text { HOLD } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| CONT | H H H L | CONTINUE | X | PC | HOLD | HOLD | H | L |
| JP | H H H H | JUMP PL | X | D | HOLD | HOLD | H | L |
| $\begin{aligned} & \mathrm{H}=\mathrm{HIGH} \\ & \mathrm{~L}=\mathrm{LOW} \\ & \mathrm{X}=\text { Don't Care } \end{aligned}$ |  | DEC = Decrement <br> *LL = Special Case |  |  |  |  |  |  |

Am29811A TRUTH TABLE

| MNEMONIC | FUNCTION | INPUTS |  |  |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{lllll}l_{3} & l_{2} & l_{1} & l_{0} & \text { TEST }\end{array}$ |  |  |  |  | NEXT ADDR SOURCE $S_{1} \quad S_{0}$ |  | FILE <br> FE PUP |  | COUNTER <br> LOAD EN |  | MAP E | $\overline{\text { PL E }}$ |
|  | PIN NO. | 14 | 13 | 12 | 11 | 10 | 4 | 5 | 3 | 2 | 6 | 7 | 1 | 9 |
| JZ | JUMP ZERO | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\mathrm{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| CJS | COND JSB PL | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| JMAP | JUMP MAP | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ |
| CJP | COND JUMP PL | $\stackrel{L}{L}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| PUSH | PUSH/COND LD CNTR | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\stackrel{L}{L}$ |
| JSRP | COND JSB R/PL | $\stackrel{L}{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $L$ |
| CJV | COND JUMP VECTOR | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ |
| JRP | COND JUMP R/PL | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| RFCT | REPEAT LOOP, CTR $\neq 0$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $L$ | $\begin{gathered} H \\ L \end{gathered}$ | $\stackrel{L}{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| RPCT | REPEAT PL, CTR $=0$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | L | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| CRTN | COND RTN | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{gathered} H \\ L \end{gathered}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ |
| CJPP | COND JUMP PL \& POP | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ |
| LDCT | LD CNTR \& CONTINUE | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $L$ | $\begin{aligned} & L \\ & H \end{aligned}$ | $L$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ |
| LOOP | TEST END LOOP. | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{gathered} H \\ L \end{gathered}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\stackrel{L}{L}$ |
| CONT | CONTINUE | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |
| jp | JUMP PL | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H}^{\prime} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ |

$\mathrm{H}=\mathrm{HIGH}$
$L=$ LOW


A Typical Computer Control Unit Using the Am2911 and Am29811A.

## ABSOLUTE MAXIMUM RATINGS

| pply Voltage to Ground Potential (Pin 16 to Pin 8)Continuous ............................-0.5V to +Voltage Applied to Outputs ForHigh Output State ...................-0.5V to +V CC |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MIN}, I_{O H}=-2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } V_{I L} \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} \end{aligned}$ |  |  |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Voits |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  |  | -0.010 | -0.250 | mA |
| IH | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 \mathrm{~V}$ |  |  |  | 25 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $V_{C C}=M A X, V_{I N}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ ( Note 2) |  | -20 | -40 | -90 | mA |
| ICC | Power Supply Current | $\begin{aligned} & \text { All inputs }=\text { GND } \\ & V_{C C}=M A X \end{aligned}$ |  |  | 90 | 115 | mA |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ICEX | Output Leakage Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{C S}=2.4 V \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | $\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}_{\mathrm{IN}}=2.0 \mathrm{~V} @ \mathrm{f}=\mathrm{MHz}$ (Note 3) |  |  | 4 |  | pF |
| COUT | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 3) |  |  | 8 |  |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
2. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
3. These parameters are not $100 \%$ tested but are periodically sampled.

## LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000090
Note: Actual current flow direction shown.

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | $i_{i}$ to Any Output | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  |  |  | ns |
| tphL |  |  |  | 25 | 35 |  |
| tple | Test to Any Output |  |  |  |  | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 25 | 35 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to Any Output |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 15 | 20 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to Any Output | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 15 | 20 | ns |
| tLZ |  | $R_{L}=2.0 \mathrm{k} \Omega$ |  | 15 | 20 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | If to Any Output | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  |  |  |  |  |
| PHL |  |  |  | 40 |  | 50 | ns |
| tplH |  |  |  | 40 |  |  |  |
| tPHL | Test to Any Output |  |  | 40 |  | 50 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{\mathrm{OE}}$ to Any Output |  |  | 25 |  | 30 |  |
| tzL | OE to Any Output |  |  | 25 |  | 30 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  |  |  |  |  |
| tLZ | OE to Any Output |  |  | 25 |  | 30 | ns |



## Am29100 <br> Controller Family Products Index

| Am29100 | H |
| :---: | :---: |
| Am29112 | A High-Performance 8-Bit Slice Microprogram Sequencer ........6-2 |
| Am29114 | Real-Time Interrupt Controller......................................6-18 |
| Am29116 | A High-Performance 16-Bit Bipolar Microprocessor...............6-19 |
| Am29116A/L116A | A High-Performance 16-Bit Bipolar Microprocessor..............6-50 |
| Am29117 | A High-Performance 16-Bit Bipolar Microprocessor..............6-51 |
| Am29118 | Eight-Bit Am29116 I/O Support ....................................6-52 |
| Am29PL141 | Fuse Programmable Controller (FPC) ..............................6-5 |

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry.
For specific testing details contact your local AMD sales representative.
The company assumes no responsibility for the use of any circuits described herein.

# Am29100 High-Performance Controller Products 

Application Note

## INTRODUCTION

## MICROPROGRAMMING; BEST FOR COMPUTERS, BEST FOR CONTROLLERS

Microprogramming, long the preferred approach for computer design, offers lots of advantages in controllers as well. The ease with which the functions of a microprogrammed controller can be enhanced and modified made the original 2900 Family popular for many disk, printer and communications controllers. The high-speed operation of these microprogrammed systems makes it possible to handle higher data rates from newer peripheral devices and to build intelligence into the controller.

But the original 2900 products are architecturally oriented toward computers, with design features optimized for arithmetic functions and short sequences of microinstructions. MOS processors are good choices for many lowspeed applications, but when the demand for speed and intelligence goes up, they cannot keep pace. Controllers need something better: the 29100 Family.
The 29100 Family products have been designed from the ground up with peripheral control applications in mind. They are fast; they are optimized for bit-manipulation, character handling, data communication and long, sophisticated microprograms; and they are designed to work together in a system.

## FAST LIKE YOU'VE NEVER HAD

The central element of our new high-speed controller family is the Am29116-a 16-bit bipolar microprocessor. It's not a slice - it's a complete 16 -bit processor, with three-input ALU, 32 scratchpad registers, an accumulator, data latch, barrel shifter, priority encoder and status register with conditional code generation logic. But the Am29116 is far
more than a very fast number cruncher - it's been optimized for controller-oriented applications. It instruction set has instructions often needed in controllers that are not available in any other processor.

## A WHOLE FAMILY OF FAST LSI CONTROLLER PARTS

There's more to our controller family than just the Am29116. A new sequencer, the Am29112, has been expressly designed for 10 MHz microprogram control, with features like real-time interrupt servicing and deep subroutining. Rapid internal data transfer is handled by the Am2940 DMA Address Generator and by the Am2950 handshaking I/O port. The Am9520 Burst Error Processor will provide a solution for error correction on disk reads. Now, more than ever, the 2900 Family is the better solution for high data rate and highly intelligent control problems.

## TYPICAL CONFIGURATION USING THE 2900 CONTROLLER FAMILY

A typical intelligent controller configuration is shown below. The basic controller consists of the Am29116, a microprogram control unit and a high-speed buffer memory. Each microinstruction includes: a 16 -bit instruction field to the Am29116, next-microinstruction selection bits, control for the buffer memory, control for the interface circuits and possibly an 8 - or 16 -bit data field.

Interface circuits like the Am2940 and Am2950 are used to provide DMA and to pass data between the controller and the host computer. Other circuits are used to interface to the peripheral. In this example, a disk interface is shown with a serial-parallel converter, a FIFO and a burst error processor. Controllers for other peripherals use identical hardware except for the peripheral interface itself.

HIGH-PERFORMANCE INTELLIGENT CONTROLLER


## DISTINCTIVE CHARACTERISTICS

- Expandable

8 -bit Slice, cascadable up to 16 -bits

- Deep stack

A 33 deep on-chip stack is used for subroutine linkage, interrupt handling and loop control.

- Hold feature

A hold pin facilitates multiple sequencer implementations.

- Interruptible at the microprogram level

Two kinds of interrupts: maskable and unmaskable.

- Powerful loop control

When cascaded, two counters can act as a single 16 -bit counter or two independent 8 -bit counters.

- Powerful addressing modes

Features direct, multiway, multiway relative and program counter relative addressing.

## GENERAL DESCRIPTION

The Am29112 is a high performance interruptible microprogram sequencer intended for use in very high speed microprogrammed machines and optimized for the new state-of-the-art ALU's and other processing components.

The Am29112 is designed to operate in 10 MHz microprogrammed systems.

It has an instruction set featuring relative and multiway branching, a rich variety of looping constructs, and provision for loading and unloading the on-chip stack.

Interrupts are accepted at the microcycle level and serviced in a manner completely transparent to the interrupted microcode.

## APPLICATION NOTES REFERENCE

- Microprogrammed CPU using Am29116
- An intelligent fast disk controller
- Am29116 architecture speeds pixel manipulation in interactive bit-mapped graphics


Figure 1. Am29112 in a Single Pipelined System.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29116 | A 16-Bit Bipolar Microprocessor |
| Am2904 | Status and Shift Control Unit |
| Am2910A | Microprogram Controller |
| Am29114 | Vectored Priority Interrupt Controller |
| Am2925 | System Clock Generator and Driver |
| Am2940 | DMA Address Generator |
| Am2942 | Programmable Timer/Counter/DMA |
| Am2950/ <br> $51 / 52 / 53$ | 8-Bit Bidirectional I/O Port |
| Am29118 | 8-Bit Bidirectional I/O Port/Accumulator |

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 1/O | Bidirectional data input for direct input to address multiplexer, counter and other control registers and stack output. |
|  | $\mathrm{Y}_{0}-\mathrm{Y}_{7}$ | 1/0 | Bidirectional microprogram address bus outputs microprogram address and inputs interrupt vector. |
|  | $\mathrm{M}_{0}-\mathrm{M}_{3}$ | 1 | Multiway input pins for up to 16 -way branches. |
|  | HOLD | 1 | When this signal is high, the Y bus is three-stated and the carry-in to the program counter incrementer is forced low. Also, the CMUX output is selected at the incrementer input. |
|  | CC | 1 | Test input for the sequèncer. (See Table 2.) |
|  | CCEN | 1 | Test enable for the sequencer. (See Table 2.) |
|  | POL | 1 | Polarity input for test. (See Table 2.) |
|  | $\mathrm{I}_{0}-\mathrm{I}_{4}$ | 1 | Instruction input. |
|  | $15-16$ | 1 | Mode control input. Select one of three modes: normal, extended or forced continue. (See Table 1.) |
|  | STKERR | 0 | Indicates stack overflow or underflow. |
|  | UINTR | 1 | Unmaskable interrupt request input. |
|  | MINTR | 1 | Maskable interrupt request input. |
|  | INTD | 1 | Disable for maskable interrupts. |
|  | $\overline{\text { MINTA }}$ | 0 | Maskable interrupt acknowledge. |
|  | LSS | 1 | Programs the least significant chip when high, most significant chip when low. |
|  | RST | 1 | Reset input. Selects zero as the next microprogram address, resets the stack pointer and interrupt logic, and disables maskable interrupts. |
|  | CP | 1 | Clock input. |
|  | ACIO | 1/0 | Bidirectional adder I/O line for cascaded Am29112s. |
|  | PCIO | 1/O | Bidirectional program counter 1/O line for cascaded Am29112s. |
|  | ClO | 1/O | Bidirectional counter 1/O line for cascaded Am29112s. |
|  | CZIO | 1/O | Bidirectional counter zero I/O line for cascaded Am29112s. |

## PRODUCT OVERVIEW

The Am29112 is designed for use in single－level pipelined systems．A typical configuration is shown in Figure 2.
Branch addresses，constants for the various registers，and stack pointer values are supplied to the Am29112 through the D port which is bidirectional to allow the stack to be unloaded onto an external LIFO．The next address generated by the sequencer is output on the Y port and directly drives the microprogram memory．A single register at the output of the microprogram memory contains the microinstruction being executed，while the next is being fetched．External conditions are applied to the CC input of the Am29112 via the condition code MUX and also to the multiway inputs．

A vectored priority interrupt controller generates a prioritized interrupt request（MINTR）to the Am29112，which acknowl－
edges the request via the MINTA pin．Upon receiving the acknowledge，the priority interrupt control puts out the en－ coded priority of the interrupt，which is translated to a vector by the vector mapping PROM．The MINTA output of the Am29112 turns on the PROM output and simultaneously turns off the Y port，enabling the interrupt vector onto the micropro－ gram address bus．In the Am29112，internal states are automatically saved on the stack while the interrupt vector is transmitted through the $Y$ port and incremented to form the next microprogram address．

The emergency detect circuit generates an unmaskable inter－ rupt request upon power failure or stack error．On receiving an unmaskable interrupt，the sequencer branches to the unmask－ able interrupt routine；the address of this routine is stored on the Am29112 in the INTVECT register．Detailed interrupt handling is discussed in a later section．


Figure 2．Control Path in a Single Pipelined System Using the Am29112．

## ARCHITECTURE OF THE Am29112

The internal organization of the Am29112 is shown in Figure 3. The most important control loop inside the sequencer consists of the CMUX, incrementer, and PC register. The CMUX selects the next microprogram address based on the instruction and condition code inputs. The next microprogram address is selected from the PC register for a continue, the D port for a branch, the adder for relative and multiway branches, the interrupt register for unmaskable interrupts, the stack for subroutine returns or loop repeats, or all zeros for the JUMP ZERO instruction.

The Am29112 has many registers other than the PC register and the interrupt register. There is an 8-bit counter used for loop control; the DWIDTH register is a 4-bit register which programs the number of least significant bits of the D port that are added to the PC in relative addressing modes; the stack pointer is a 6-bit counter/register that points to the top of stack element; the 3-bit command register is used to program the chip on power-up for compatibility with the external hardware
configuration; finally, there is the INTRTN register which is used for saving the CMUX output on the stack when an interrupt occurs.

With the exception of the INTRTN register and the stack pointer, each of the above registers can be loaded directly from the D port of the Am29112.

The Am29112 features a high speed adder with full carry lookahead across 8 -bits. The adder is used for PC relative addressing (branch address is PC + D), multiway relative addressing (branch address is $D+M$, where $M$ is the 4-bit multiway input), and for testing the stack pointer against the $D$ bus. In cascaded configurations, carry ripples from the LSS adder to the MSS adder over the CIO line.

The on-chip stack is 33 deep, and the Am29112 has instructions to save the D inputs, counter, multiway register, and PCregister on the stack. The stack output bus is connected via three-state buffers to the D port. It is possible to pop the stack to the D port.


BD001931
Figure 3. Am29112 48-Pin Package.

## INSTRUCTION SET OF THE Am29112

## MODE BITS $\left(\mathbf{I}_{6}, 5\right)$

The Am29112 is controlled by 5 instruction inputs，two mode inputs，and the condition code．In typical applications it is expected that the instruction inputs are driven directly from the pipeline，whereas the mode inputs are either permanently wired high or low to select the desired operating mode，or driven indirectly via external logic．（In some applications it might be justifiable to drive the mode bits directly from the pipeline．）The two mode bits select among three operating modes：normal（ 00 ），extended（ 01 ）and forced continue（ 10 and 11）．In the normal mode，the entire instruction set of the Am29112 applies．

TABLE 1．MODE CONTROLS

| $\mathbf{I}_{6,5}$ | Mode | Description |
| :---: | :--- | :--- |
| 00 | Normal | For cascaded Am29112s，two inde－ <br> pendent 8－bit counters |
| 01 | Extended | For cascaded Am29112s，one 16－bit <br> counter |
| 10 | Forced <br> Continue | The Am29112 executes a continue <br> instruction regardless of instruction， <br> condition code，and multiway inputs． |
| 11 |  |  |

## EXTENDED MODE

The instruction set includes instructions that differentiate between upper and lower counters（when there are two cascaded Am29112s）．In the normal mode，the two counters on cascaded Am29112s function independently，and it is possible to set up a doubly nested loop without having to save and restore counter values on the stack．In the extended mode，however，the counters on cascaded Am29112s behave like one 16 －bit counter and instructions that differentiate between the counters degenerate into identical instructions． Hence in a system with only one Am29112 there is no use for the extended mode．

## FORCED CONTINUE MODE

In the forced continue mode the Am29112 executes a continue in every cycle regardless of the instruction bits， condition code，and multiway inputs．The simplest application （if mode bits are driven directly from the pipeline）is to use forced continue for straight－line segments of code thereby permitting most of the sequencer control fields of the pipeline to be shared．The forced continue also has an important application in systems with a writeable control store where it is
necessary to step through the addresses sequentially while loading the WCS．

The instructions of the Am29112 are classified into four groups：
－Branching and subroutine linkage
－Looping
－Stack and register
－Interrupt
The sequencer has an instruction repertoire of altogether 40 different instructions．In order to encode these instructions with only 5 instruction lines，the condition code is used in some cases to differentiate between two distinct instructions sharing the same opcode．This way of encoding is used for the stack and register，and interrupt groups of instructions．For these instructions，therefore，the condition code multiplexer is not used to select an external condition．However it is required to force the condition code to unconditional Pass or Fail．The condition code enable and polarity logic has been designed with this in mind．Using the enable and polarity，it is possible to generate both unconditional Pass and unconditional Fail （regardless of the condition code input）．Hence the condition code for these instructions is like a sixth instruction line，and the condition code multiplexer field of the pipeline can be shared for these instructions（see Figure 4 and Table 2）．


PF001060
Figure 4．Condition Code Circuit．
table 2．CONDITION CODE TABLE

| CCEN | $\overline{\mathbf{C C}}$ | POL | Condition |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | PASS |
| 0 | 1 | 0 | FAIL |
| 0 | 0 | 1 | FAIL |
| 0 | 1 | 1 | PASS |
| 1 | 0 | 0 | PASS |
| 1 | 1 | 0 | PASS |
| 1 | 0 | 1 | FAIL |
| 1 | 1 | 1 | FAIL |


| Am29112 Instruction Set |  |  |  |
| :---: | :---: | :---: | :---: |
| Opcode (140) | Condition | Mnemonic | Description |
| 0 | X | JZ.U | UNCONDITIONAL JUMP ZERO |
| 1 | PASS | PUSHD.P | PUSH D (PASS) |
| 1 | FAIL | LDCMD.F | LOAD COMMAND REGISTER FROM D (FAIL) |
| 2 | COND | POP.C | POP; CONDITIONAL STACKOUT TO D |
| 3 | COND | CJD.C | CONDITIONAL JUMP D |
| 4 | COND | CJSD.C | CONDITIONAL JUMP SUBROUTINE D |
| 5 | COND | CJMW.C | CONDITIONAL JUMP MULTIWAY D |
| 6 | COND | CJSMW.C | CONDITIONAL JUMP SUBROUTINE MULTIWAY D |
| 7 | COND | CRTN.C | CONDITIONAL RETURN |
| 8 | COND | PUSHPL.C | PUSH PC; COND LOAD LOWER COUNTER |
| 9 | COND | LDLC.C | LOAD LOWER COUNTER; COND PUSH COUNTER |
| 10 | X | POPLC.U | POP TO LOWER COUNTER |
| 11 | PASS | RSTSP.P | RESET STACK POINTER (PASS) |
| 11 | FAIL | LDINTV.F | LOAD UNMASKABLE INTERRUPT VECTOR (FAIL) |
| 12* | PASS | RFCTU.P | REPEAT LOOP, UPPER COUNTER $=0$ (PASS). |
| 12* | FAIL | RFCTL.F | REPEAT LOOP, LOWER COUNTER $=0$ (FAIL) |
| 13** | PASS | RPCTU.P | REPEAT PIPELINE, UPPER COUNTER $=0$ (PASS) |
| 13** | FAIL | RPCTL.F | REPEAT PIPELINE, LOWER COUNTER $=0$ (FAIL) |
| 14 | COND | LOOP.C | TEST END LOOP |
| 15 | PASS | ENINT.P | ENABLE INTERRUPTS (PASS) |
| 15 | FAIL | DISINT.F | DISABLE INTERRUPTS (FAIL) |
| 16*** | COND | TWBL.C | THREE-WAY BRANCH, LOWER COUNTER |
| 17*** | COND | TWBU.C | THREE-WAY BRANCH, UPPER COUNTER |
| 18 | PASS | TSTSP.P | TEST SP WITH D (PASS) |
| 18 | FAIL | TSTMT.F | JUMP D IF STACK NOT EMPTY |
| 19 | COND | CJDF.C | COND JUMP D/STACK AND POP |
| 20 | COND | CJSDF.C | COND JUMP SUBROUTINE D/STACK AND POP |
| 21 | COND | CJMWR.C | COND JUMP MULTIWAY RELATIVE D |
| 22 | COND | CJSMWR.C | COND JUMP SUBROUTINE MULTIWAY RELATIVE D |
| 23 | COND | CJPP.C | COND JUMP PIPELINE AND POP |
| 24 | COND | PUSHPU.C | PUSH PC; COND LOAD UPPER COUNTER |
| 25 | COND | LDUC.C | LOAD UPPER COUNTER; COND PUSH COUNTER |
| 26 | PASS | POPUC.P | POP TO UPPER COUNTER (PASS) |
| 26 | FAIL | POPDW.F | POP TO DISPLACEMENT WIDTH (FAIL) |
| 27 | COND | LDDW.C | LOAD DISPLACEMENT WIDTH; COND PUSH DW |
| 28 | COND | CJR.C | COND JUMP D PC REL |
| 29 | COND | CJRN.C | COND JUMP D PC REL NEGATIVE |
| 30 | COND | CJSR.C | COND JUMP SUBROUTINE D PC REL |
| 31 | COND | CJSRN.C | COND JUMP SUBROUTINE D PC REL NEGATIVE |

* These instructions are identical in the extended mode.
**These too.
***These too.
Extensions: U - unconditional; C - conditional; P - PASS condition; F - FAIL condition.
Note: PASS/FAIL condition can be produced as follows. P stands for polarity and I for input:

| $\overline{\text { CC }}$ | CCEN | POL | Condition |
| :---: | :---: | :---: | :---: |
| $X$ | 1 | 0 | PASS |
| $X$ | 1 | 1 | FAIL |
| 1 | 0 | $P$ | COND |


| 0 Jump Zero（JZ．U） <br> UNCONDITIONAL | 1 Push D（PUSHD．P） <br> PF000620 <br> FORCED PASS | 1 Load Command Register from D （LDCMD．F） |
| :---: | :---: | :---: |
| 2 Pop and Conditional Stack－ out to D（POP．C） <br> CONDITIONAL | 3 Conditional Jump D（CJD．C） | 4 Conditional Jump Subroutine D（CJSD．C） <br> CONDITIONAL |
| 5 Conditional Jump Multiway D （CJMW．C） <br> CONDITIONAL | 6 Conditional Jump Subroutine Multiway D（CJSMW．C） <br> CONDITIONAL | 7 Conditional Return（CRTN．C） <br> CONDITIONAL |


| 8 Push PC and Conditional Load Lower Counter (PUSHPL.C) <br> CONDITIONAL | 9 Load Lower Counter and Conditional Push Counter (LDLC.C) <br> CONDITIONAL | 10 Pop to Lower Counter (POPLC.U) <br> PF000531 <br> UNCONDITIONAL |
| :---: | :---: | :---: |
| 11 Reset Stack Pointer (RSTSP.P) <br> PF000460 <br> FORCED PASS | 11 Load Unmaskable Interrupt Vector (LDINTV.F) | 12 Repeat Loop, Upper Counter (RFCTU.P) <br> FORCED PASS |
| 12 Repeat Loop, Lower Counter (RFCTL.F) <br> PF000440 <br> FORCED FAIL | 13 Repeat Pipeline, Upper Counter (RPCTU.P) <br> FORCED PASS | 13 Repeat Pipeline, Lower Counter (RPCTL.F) <br> FORCED FAIL |



| 21 Conditional Jump Multiway Relative D (CJMWR.C) <br> CONDITIONAL | 22 Conditional Jump Subroutine Multiway Relative D (CJSMWR.C) <br> CONDITIONAL | 23 Conditional Jump Pipeline and Pop (C.JPP.C) <br> PF000760 <br> CONDITIONAL |
| :---: | :---: | :---: |
| 24 Push PC and Conditional Load Upper Counter (PUSHPU.C) | 25 Load Upper Counter and Conditional Push Counter (LDUC.C) <br> PF000710 <br> CONDITIONAL | 26 Pop to Upper Counter (POPUC.P) <br> PF000770 <br> FORCED PASS |
| 26 Pop to Displacement Width (POPDW.F) | 27 Load Displacement Width and Conditional Push DW (LDDW.C) <br> PF000740 <br> CONDITIONAL | 28 Conditional Jump D PC Relative (CJR.C) <br> PF000750 <br> D** is displacement (see Note 1). CONDITIONAL |

## 29 Conditional Jump D PC Rel－ ative Negative（CJRN．C）



PF000490
$D^{* *}=-2$ ，should be two＇s comple－ ment（see Note 2）．
CONDITIONAL

## 30 Conditional Jump Subrou－ tine D PC Relative（CJSR．C）

31 Conditional Jump Subrou－
tine D PC Relative Negative （CJSRN．C）


PF000480
D＊＊is displacement（see Note 1）． CONDITIONAL


PF000500
$D^{* *}=-2$ ，should be two＇s comple－ ment（see Note 2）．
CONDITIONAL

Notes：1．The number of bits of D used as displacement is stored in DWIDTH register．The remaining high order bits are zero－extended．
2．The number of bits of $D$ used as displacement is stored in DWIDTH register．The remaining high order bits are one－extended．

## BRANCHING INSTRUCTIONS

## Direct Branching

Instruction 0 is the unconditional jump to zero instruction．This instruction also resets the stack pointer and the interrupt logic as well as setting command register as follows： $\mathrm{CR}(0)=1$ ， $C R(1)=\operatorname{LSS}, \operatorname{CR}(2)=1$.
Direct branching is implemented by instruction 3 （COND JUMP D）and 4 （COND JSB D）．The branch address is input through the $D$ port．If the condition is PASS，the branch is taken， otherwise the sequencer executes a continue．Two－way direct branching is implemented by instruction 19 （COND JMP D／ STACK）and instruction 20 （COND JSB D／STACK）．If the condition is Pass，the branch address is taken from the $D$ input port，otherwise，the branch address is taken from the stack．In either case the stack is popped．This instruction assumes that the alternative address was pushed on the stack by a previous instruction．Jump to subroutine differs from JUMP in that the PC register is pushed on the stack．This enables the subrou－ tine to use COND RETURN（7）to return to the point of call． Note that the two－way jump to subroutine（20）causes a simultaneous pop and push so that the stack pointer is unaffected but the top of stack element is replaced by the return address

## Relative Branching

In the relative branch instructions，a dynamically alterable subfield of the D inputs is added to the PC to form the branch address．The remaining most significant bits of the $D$ inputs are ignored and internally converted to all 0 ＇s for forward branches and all 1＇s for backward branches．The displace－ ment width（DWIDTH）register in the Am29112 holds the number of least significant bits of $D$ that participate in the relative branch as the displacement，and can be loaded from the lower four bits of the D port．In cascaded systems，the displacement width has to be loaded consistently in the two chips．For example，for a displacement width of 9 ，the lower order chip gets a displacement width of 8 and the higher order chip gets a displacement width of 1 ．As another example，if the lower order chip has a displacement width of less than 8 bits， the higher order chip must have a displacement width of zero． If the displacement width register is loaded with any value greater than 8 ，it is exactly as if it were loaded with 8.

Instruction 28 （29）is the relative jump（jump back）instruction， and instruction 30 （31）is the relative jump to subroutine（jump back to subroutine）instruction．For backward relative branch－ es，the displacement must be coded as a two＇s complement negative number．When the displacement width is the same as the microaddress width the forward and backward relative branch instructions are identical．When the displacement width is less than the microaddress width，the more significant bits of $D$ outside the displacement are forced to all zeros for positive branches and to all ones for negative branches．This is effectively sign extension except that the sign information is contained in the instruction rather than the displacement，and there is no need for sign information to propagate between cascaded chips since it is assumed that the displacement width registers in the two chips have been consistently loaded．

The disadvantage of having the sign information in the instruction rather than the displacement can be overcome by a judicious choice of instruction format．The opcodes for forward and backward relative branch instructions have been chosen to differ in the least significant bit position only，with a＇ 0 ＇in that bit for forward branches and a＇1＇for backward branches． If the sequencer instruction field is contiguous with and on the more significant side of the displacement field in the pipeline register，then the least significant instruction bit is like the sign bit for the displacement for relative branch instructions．This permits the assembler to use the same opcode for forward and backward relative branch instructions，but overlap the displacement field（now declared to be one bit longer than the actual displacement field in the pipeline）with the sequencer instruction field by one bit．If the assembler now generates a negative displacement，the sequencer opcode formed is the backward branch；while if the displacement is positive，the sequencer opcode formed is forward branch．
When the instruction is executed，the PC already has been incremented and points to the next sequential instruction， hence a forward branch with a displacement of 0 causes the next sequential instruction to be executed．

## Multiway Branching

Two variants of multiway branching are available on the Am29112－multiway substitute D and multiway relative D．In multiway substitute $D$ the 4 multiway inputs directly replace the 4 least significant bits of the branch address input at $D$ ．

Instruction 5 is a conditional multiway branch and instruction 6 a conditional multiway subroutine call. In these instructions, the least significant 4 bits of the $D$ input port are not used by the sequencer, and may be shared, for instance to select among different sets of multiway inputs.

Multiway branching has the disadvantage that the jump table must be aligned on a 16 word boundary. This disadvantage is overcome in the Am29112 multiway relative branching instructions. In these instructions, the number input on the multiway pins is added to the branch address input at D. Instruction 21 is a conditional multiway relative branch and instruction 22 a conditional multiway relative subroutine call.

One of the advantages of multiway branching is that it enables a 16 way decision to be made in exactly one microcycie. However, the 16 target addresses are constrained to be contiguous in memory. Hence, if the target routines need more than one microword each, as is very likely, they are addressed indirectly through a table of 16 contiguous branch instructions. For very high speed applications, the extra microcycle needed to branch indirectly off the jump table may not be acceptable. This penalty is avoidable if the multiway bits are offset with respect to the D inputs. When two cascaded Am29112s are used, there are two sets of 4-bit multiway inputs. The least significant chip has a multiway input with no offset, while the most significant chip has a multiway input with an 8 -bit offset. The Am29112 command register has a bit CR(1) that enables or disables multiway branching on the chip. In a system with two cascaded Am29112s, each chip has a command register bit. Multiway branching may be disabled in either chip by resetting the command register bit on that chip, or enabled by setting the command register bit. When multiway branching is disabled on a chip, for that chip both multiway and multiway relative branches are converted to direct branches, and the multiway inputs are a Don't Care. Multiway branching with an 8 -bit offset is implemented by disabling multiway in the least significant slice and enabling it in the most significant slice. In this case, the 16 target addresses are dispersed in memory, separated by 256 locations each. Another useful configuration is obtained by enabling multiway on both chips. In this case, up to 16 sets of target addresses are dispersed in memory, separated by 256 locations each.

The Am29112 does not have an unconditional continue in its instruction set. This is not expected to be a drawback because the instruction set requires that both unconditional PASS and unconditional FAIL are programmable by the sequencer to select among different instructions sharing the same opcode. Hence, a continue is obtained by executing instruction 3 (COND JUMP D) with a forced FAIL condition.

## LOOPING INSTRUCTIONS

The looping instructions on the Am29112 are of two kinds: conditional, which depend on an external condition to signal loop termination, and iterative, which decrement the Am29112 counter and check for a count of zero. There is also a threeway branch instruction that combines the check for external condition with the check for count of zero in a single instruction.

All the looping instructions are similar in two respects. Firstly, the check for the loop condition is done at the end of the loop. This implies that the loop body is always executed at least once. Secondly, in the case that the loop has to be repeated, a backward branch to the loop head is made by using the address on top of stack. This frees the D inputs for other use, but makes it necessary to push the address of the start of the loop on the stack before entering the loop. Also, if the loop is iterative, it is necessary to load a count value in the counter at the same time. Instructions 24 (PUSH PC; COND LOAD

UPPER COUNTER) and 8 (PUSH PC; COND LOAD LOWER COUNTER) combine both these requirements.

Instruction 14 implements a simple conditional repeat loop. If the condition is FAIL the sequencer loops back using the top of stack address, and if the condition is PASS, the sequencer performs a continue to the next sequential address, and simultaneously pops the stack to remove the address of the loop head. The instruction may be described in Pascal-like syntax as:

## repeat PUSH PC <br> LOOP BODY <br> until condition = TRUE;

Instruction 23 (COND LOOP EXIT) implements a loop exit that may be used with any of the Am29112 loop instructions. It is a conditional jump to D, which simultaneously pops the stack. If the condition is FAIL, it simply performs a continue.

As discussed earlier, the counters present in cascaded Am29112s may be used independently or cascaded as a single 16-bit counter under microprogram control. The mode bits select the cascaded configuration only in the extended mode. There are separate repeat and three-way branch instructions for upper and lower counters. In the case of the repeat instructions, the condition code is used to differentiate between the repeat on the upper and the repeat on lower counter (a condition of PASS selects the upper counter). In the case of the three-way branch, which needs the condition code input for the external condition, there are two separate opcodes for three-way branch on upper (opcode 17) and three-way branch on lower (opcode 16). When a single Am29112 is used only the repeat on lower counter instructions are useful; and when two Am29112s are cascaded but operated in the extended mode, the repeat instructions on upper and lower counter are identical in effect and both operate on the 16 -bit cascaded counter.
Instruction 12 (REPEAT LOOP IF COUNTER NOT ZERO) is the iterative analog of instruction 14 (CONDITIONAL REPEAT LOOP). Instruction 8 (PUSH PC; COND LOAD COUNTER) is used with condition code as forced PASS and the desired count in the D field of pipeline. This causes the address of the loop head to be pushed on the stack, and the lower counter loaded with the count. At the end of the loop body, the repeat instruction checks if the count is zero. If it is not zero, it performs a loop back using the top of stack address and simultaneously decrements the counter; if it is zero, it pops the address of the loop head off the stack and simultaneously selects the next sequential address thereby exiting the loop. A repeat loop on the upper counter can be set up using instruction 24 instead of 8 to push PC and load upper counter and using instruction 14 to loop back with condition code as forced PASS. Note the potential off-by-one error: since the count is checked before it is decremented, a count of 1 causes two iterations: the first iteration finds a count of 1 and decrements; on the second iteration the count is found to be zero and the loop terminates. Hence, the value of count loaded should be one less than the desired number of iterations. In the example above, loading the counter with 7 resulted in 8 iterations.
The single instruction repeat (instruction 13) is provided for applications where the loop body is a single microinstruction, for example, an ALU shift. The loop is set up as before using instruction 9 or 25 (LOAD COUNTER AND COND PUSH COUNTER). The repeat instruction then presents its own address to the $D$ inputs of the sequencer. As with the repeat loop instruction, the single instruction repeat checks for counter $=0$. If the counter is equal to zero, it continues to the next sequential instruction; otherwise it repeats the address presented to the D inputs, which is its own address, and
decrements the count by one．Instruction 13 can also be used in place of instruction 12 where there is no stack location available to hold the address of the loop head．

Often it is necessary to repeat an action until either some external condition becomes true or a predetermined count is reached：for example，searching a character string for an occurrence of some character．The three－way branch instruc－ tions of the Am29112 combine the test for count and external condition in one cycle．At any loop iteration，if the condition becomes PASS when the three－way branch is executed，then the sequencer performs a continue to the next sequential instruction，and pops the stack．If the condition is FAIL when the three－way branch is＇xecuted，the sequencer tests the count．If the count is zero，then the search is unsuccessful and the sequencer performs a branch to the address input at the $D$ port，simultaneously popping the stack．If the count is not zero， and the condition is FAIL，the sequencer performs a loop back via the stack．The instruction always decrements the counter by one if the counter is non－zero．

Since interrupts may occur at any point in the execution of microcode，it is necessary to be able to save counter values on the stack so that the interrupt routines can use the counter without interfering with the operation of the interrupted code． The sequencer provides instructions that permit arbitrary nesting of loops and subroutine calls．Instruction 9 （LOAD LOWER COUNTER；CONDITIONAL PUSH COUNTER）can be used to load the lower counter from the $D$ port．If the condition is PASS，then the instruction also causes the old counter value to be pushed on the stack．To restore the counter from the stack，instruction 10 （POP TO LOWER COUNTER）can be used with a forced FAIL condition． Instructions 25 （LOAD UPPER COUNTER；CONDITIONAL PUSH COUNTER）and 26 （COND POP TO UPPER COUNT－ ER／POP TO DISPLACEMENT WIDTH）are the counterparts for operating on the upper counter．Note that in cascaded systems，when the counter is pushed，regardless of whether instruction 25 or instruction 10 is executed，the entire counter is pushed to keep the stack balanced in the two Am29112s．

## STACK AND REGISTER INSTRUCTIONS

In addition to all the instructions mentioned earlier that explicitly or implicitly alter the stack，the Am29112 has some specialized instructions for stack manipulation．

The stack on the Am29112 is 33 deep．Attempting to push when the stack is full or to pop when the stack is empty causes the STACK ERROR signal out of the Am29112 to be generated．The error is latched internally and persists until either the chip is reset or the－stack is popped in case of overflow or pushed in case of underflow．When the stack overflows，the stack pointer does not wrap around，and all subsequent pushes on the full stack write over the top－of－ stack location．

The stack on the Am29112 can be loaded through the $D$ port using instruction 1 （COND PUSH D／LOAD COMMAND REG－ ISTER）with condition as forced PASS and unloaded out of the D port using instruction 2 （POP；COND STACKOUT TO D）with a forced PASS condition．In the stackout instruction the D port becomes an output port．Care must be taken to avoid contention on the D bus when this instruction is executed．The D bus is output enabled while CP is low for this instruction．The ability to load and unload the stack is useful for implementing context switches．For fast unloading of the stack，a tight two－ instruction loop can be set up using instruction 12 （POP； COND STACKOUT TO D）with a forced FAIL condition and instruction 18 （COND TEST SP／BRANCH STACK NOT EMP－ TY）also with a forced FAIL condition．The branch instruction performs a branch to $D$ if the stack is not empty．

The stack nesting level in an interruptible sequencer varies dynamically．Hence，the Am29112 is provided with instructions for checking the available stack space：instruction 18 （COND TEST SP／BRANCH STACK NOT EMPTY）．Two distinct in－ structions for testing the stack pointer have been packed into the same opcode and are differentiated by the condition code． A condition code of PASS selects the Test Stack Pointer instruction．In this instruction，the sequencer tests the stack to see if there is enough space，as determined by a constant input at the $D$ port；if there is enough space，the sequencer performs a continue，whereas if there is not enough space，the sequencer performs a subroutine return．The number of stack locations required is input at the D port．In a system with only one Am29112，the least significant 6 bits of the $D$ are used within the chip for this instruction．In a system with two cascaded Am29112s the determination is made independently in the two chips（since the stack pointer is at all times identical in the two chips）．Hence，the same number must be presented to the two chips．The adders in the two Am29112s are not cascaded for this instruction but function independently．In both Am29112s only the 6 LSBs of the $D$ port are actually used in the comparison．

## INTERRUPT HANDLING

The Am29112 recognizes two kinds of interrupts：maskable and unmaskable．Maskable interrupts cause automatic saving of status on the internal stack and can be inhibited，either externally via the INTERRUPT DISABLE pin，or internally via instruction 15 （COND ENABLE／DISABLE INTERRUPT）．In addition，maskable interrupts are disabled when there is not enough space on the stack to service the interrupt，though this internal inhibit can be overridden be clearing a bit in the command register．The unmaskable interrupt，on the other hand，cannot be disabled and does not cause saving of status on the internal stack．It is intended for handling abnormal and irrecoverable situations like power failure or stack overflow． When an unmaskable interrupt occurs，the sequencer branch－ es to the address of the unmaskable interrupt routine stored in the INTVECT register．This address is stored on chip at system initialize time using instruction 11 （COND RESET SP／ LOAD INTERRUPT REGISTER）with a condition of FAIL．If a maskable interrupt is being processed when the unmaskable interrupt occurs，the unmaskable interrupt may be delayed at most one cycle to prevent contention on the $Y$ bus．In any case，the unmaskable interrupt request should persist for at least one clock edge．

The Am29112 contains an interrupt disable flip－flop on－chip． The flip－flop is set by the DISABLE INTERRUPT instruction （opcode 15 with forced FAIL）and reset by the ENABLE INTERRUPT instruction（opcode 15 with forced PASS）．The flip－flop output performs the same function as the interrupt disable pin．On reset，or on receiving an unmaskable interrupt， the flip－flop is set thereby disabling maskable interrupts． Hence，at the end of initialization，the ENABLE INTERRUPT instruction will have to be executed to reset the flip－flop and enable maskable interrupts．

In the case of maskable interrupts，the interrupt return address is saved on the stack automatically using the INTRTN register． the INTRTN register is loaded with the CMUX output with every clock．When an interrupt is acknowledged，the Am29112 output is turned off and the vector applied externally．Howev－ er ，the sequencer executes the instruction which is in the pipeline register in that cycle．The reşult of executing the interrupted instruction，namely the next address，does not come out of the Am29112 Y bus because the Y bus is used to input the interrupt vector．It is clocked into the INTRTN register．On the first cycle of the interrupt routine，the sequencer pushes the return address on the stack so that the
interrupt routine returns by doing a COND RETURN, like any other subroutine.

> THE INVISIBLE STACK PUSH THAT THE SEQUENCER EXECUTES WHEN IT IS INTERRUPTED OCCURS IN THE FIRST CYCLE OF THE INTERRUPT SERVICE ROUTINE. HENCE, THE FIRST INSTRUCTION OF THE INTERRUPT SERVICE ROUTINE MAY NOT BE ANY INSTRUCTION THAT USES THE STACK.

Before acknowledging an interrupt, the sequencer checks the stack to see if there is a minimum of five locations to handle the interrupt. If there is insufficient space on the stack, the acknowledge is not generated. This feature may be disabled by a bit in the command register.

$$
\begin{aligned}
& \text { CR }(0)= 1 \text { INHIBIT ACKNOWLEDGE ON STACK FULL (DE- } \\
& \text { FAULT) } \\
& \text { CR }(0)=0 \text { GENERATE ACKNOWLEDGE ON STACK FULL }
\end{aligned}
$$

MASKABLE INTERRUPTS
The branch vector for maskable interrupts is applied externally to the Y port of the Am29112. This section discusses the system timing considerations and their impact on interrupt handling in the Am29112.

Figure 5(a) shows a general system configuration highlighting the interrupt portion of the circuitry and the control loop. A priority interrupt controller generates an interrupt request for the highest priority pending interrupt. This request is applied to the MINTR pin of the Am29112. If the request is not masked, the Am29112 puts out an acknowledge on the MINTA pin. The interrupt controller then puts out the encoded priority of the highest priority interrupt to the vector PROM, which maps the priority code into a vector.

The MINTA line turns on the vector PROM output at the same time as the Y port on the Am29112 is three-stated. Hence, the interrupt vector gets onto the micromemory address bus and is also input into the Am29112, and incremented to form the next address. The Am29112 saves the return address on the stack so that when the interrupt service routine does a subroutine return, control returns to the instruction following the interrupted instruction.

The maskable interrupt request is synchronized on the Am29112. If there is no disable, therefore, the acknowledge always is active in the cycle following the request. However, the acknowledge to $Y$ bus three-stating delay is programmable: the Y bus three-stating signal can occur either in the same cycle as, or in the cycle following, the $\overline{M I N T A}$ acknowledge, depending on a bit in the command latch of the Am29112.

The command register bit that programs the postdelay option is bit 2, the third least significant bit. The command register has 3 bits altogether and is loaded from the 3 LSBs of the D inputs using instruction 1 (COND PUSH D/LOAD COMMAND REGISTER) with a condition of PASS. Note that in a system with two cascaded Am29112s, the 0 and 2 bits of the command registers in the two chips must both be loaded with the same data on system initialization. The postdelay bit in the command register selects the postdelay option when it is zero.

Figure 5(b) shows the configuration without postdelay, including a simplified view of the acknowledge circuit. The acknowledge is granted at the same time the Y output of the Am29112 is three-stated and the vector PROM enabled by the MINTA signal out of the Am29112. The critical delay path in this case is clock to acknowledge (Am29112) + acknowledge to priority out (interrupt controller) + vector PROM access
time + microprogram memory access time + pipeline setup time. Obviously, this delay will have a significant impact on overall cycle time. However, in slow systems or in systems where the vector is always available immediately with acknowledge, this configuration is acceptable. It is also acceptable if the vector mapping PROM is made part of the microprogram memory by dedicating the locations in low memory addressed by the priority to hold vectors to the corresponding interrupt routines.

Figure 5(c) shows a simplified view of the Am29112 configured with postdelay active. An external D-type flip-flop adds a one cycle delay to the MINTA signal before it switches the output enable on the vector register. The interrupt request to ac knowledge delay is the same as in the circuit with postdelay inactive, but the $Y$ bus three-stating signal occurs one cycle later than the acknowledge. The critical path has been broken into two with the register at the vector PROM output. In this case the critical delay path is cut short by the microprogram memory access time. While the vector PROM accesses the interrupt vector, the microprogram memory accesses the next sequential instruction. This implies that one more instruction of the interrupted code executes after the cycle in which the acknowledge is granted. (If that instruction happens to be a DISABLE INTERRUPT instruction, then even though no more interrupts will be accepted by the Am29112, the interrupt which has been acknowledged goes through and the corresponding interrupt service routine may enable interrupts again using the ENABLE INTERRUPT instruction.)

The command register bits are summarized below:
CR(0) : Interrupt acknowledge on stack full
$C R(0)=1$ : inhibit acknowledge on stack full (default)
$\mathrm{CR}(0)=0$ : generate acknowiedge on stack full
CR(1) : Multiway enable
$C R(1)=1$ : enable multiway branching (default for LSS
$C R(1)=0$ : disable multiway branching (default for MSS)

CR(2) : Interrupt postdelay flip-flop
$\mathrm{CR}(2)=1:$ no postdelay (default) $C R(2)=0:$ postdelay

On reset \& JZU: CR(0) $=1$

$$
C R(1)=L S S
$$

$$
C R(2)=1
$$

## HOLD

The Am29112 is equipped with a HOLD pin for configurations utilizing more than one sequencer driving a common microprogram address bus. In such situations, it is necessary to cause the unselected sequencer to hold its internal state while some other sequencer executes, so that it can resume execution at the point where it was held. The HOLD pin, when asserted, three-states the $Y$ bus, forces low the carry into the PC incrementer, and selects the internal CMUX output (instead of the $Y$ bus) at the incrementer input. To complete the HOLD function, it is also necessary to disable interrupts and to put the sequencer into the forced continue mode. Under these conditions, the value of the PC is recirculated through the CMUX and the incrementer until the HOLD is released, and all the remaining state bits in the sequencer are not altered because of the forced continue.


PF001112
Figure 5b．No Postdelay．

Figure 5a．Interrupt Control Loop．
Note：The INTD connection directly from microprogram memory．


Figure 5c．With Postdelay．

## Am29114

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Accepts 8 Interrupt Inputs

Interrupts may be pulses or levels and they are stored internally.

- Supports Real-Time Interrupts Interrupts are handled at microinstructions boundary.
- Built-In Mask Register

Enables or disables individual interrupt inputs.

- Built-In In-Service Register
- Vectored Output

Output is binary code for highest priority unmasked input.

## - Expandable

Any number of the Am29114's may be cascaded for larger interrupt systems.

## GENERAL DESCRIPTION

The Am29114 is a high-speed eight-bit priority interrupt controller that is cascadable to handle any number of interrupt request levels. Its interface specification is designed to make it suitable for use with the Am29112 microsequencer facilitating the handling of real-time microinterrupts.

The Am29114 contains an interrupt register which is used to store requests until they are serviced, and an eight-bit in-
service register which is used to store requests that are currently being serviced.

The contents of the in-service register are compared with the contents of the interrupt register. Interrupt requests having a lower or equal priority to the highest priority bit in the in-service register are disallowed, thus forming a fixed priority resolution scheme.


# Am29116 

## A High－Performance 16－Bit Bipolar Microprocessor

## PRELIMINARY

## DISTINCTIVE CHARACTERISTICS

－Optimized for High－Performance Controllers Excellent solution for applications requiring speed and bit－manipulation power．
－Fast
Supports 100ns microcycle time／10MHz data rate for all instructions．
－16－Bit Barrel Shifter
Contains a 16 －bit Barrel Shifter which can shift or rotate a word up to 15 positions in a single instruc－ tion cycle．
－Immediate Instruction Capability
May be used for storing constants in microcode or for configuring a second data port．
－Powerful Field Insertion／Extraction and Bit Ma－ nipulation Instructions
Rotate and Merge，Rotate and Compare and bit manipulation instructions provided for complex bit control．
－32－Working Registers
Single port RAM may be configured to accept dif－ ferent source and destination addresses within sin－ gle cycle．
－52－Pin Hermetic DIP

## GENERAL DESCRIPTION

The Am29116 is a microprogrammable 16－bit bipolar micro－ processor whose architecture and instruction set is opti－ mized for high performance peripheral controllers，like graphics controllers，disk controllers，communications con－ trollers，front－end concentrators and modems．The device also performs well in microprogrammed processor applica－ tions，especially when combined with the Am29517 $16 \times 16$
multiplier（ 65 ns worst－case $16 \times 16$ multiply）．In addition to its complete arithmetic and logic instruction set，the Am29116 instruction set contains functions particularly useful in controller applications；bit set，bit reset，bit test， rotate and merge，rotate and compare，and cyclic－redun－ dancy－check（CRC）generation．

BLOCK DIAGRAM


Am29116 BASED HIGH PERFORMANCE PERIPHERAL CONTROLLER

## RELATED PRODUCTS

OTHER LITERATURE

- An Intelligent Fast Disk Controller using the Am29116 Application Note.
- A Microprogrammed CPU Using the Am29116 Application Note.

CONNECTION DIAGRAM Top View

Note: Pin 1 is marked for orientation

## METALLIZATION AND PAD LAYOUT




CD004201
Notes: 1. All $\mathrm{V}_{\mathrm{CC}}$ and all GND pins must be connected as shown. Offsets between any two $\mathrm{V}_{\mathrm{CC}}$ pins or between any two GND pins should be avoided.
2. $\mathrm{C}_{1}=1.0 \mu \mathrm{~F}, \mathrm{C}_{2}=\mathrm{C}_{3}=0.01 \mu \mathrm{~F}$.

The $\mathrm{C}_{1}, \mathrm{C}_{2}$, and $\mathrm{C}_{3}$ capacitors should be used to shunt low- and high-frequency noise from $\mathrm{V}_{\mathrm{CC}}$. Do not replace with one capacitor.

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am29116


Blank - Standard processing
B - Burn-in
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-52-pin CERDIP
L-52-pin Chip-Pak
X-Dice
Device type
A High-Performance 16-Bit Bipolar Microprocessor

| Valid Combinations |  |
| :--- | :--- |
| Am29116 | DC, DCB, DMB <br>  <br>  <br> LC, LMB <br> XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |
|  | $\mathrm{Y}_{0}-\mathrm{Y}_{15}$ | 1/0 | Data Input/Output Lines. When $\overline{\mathrm{OE}}_{\mathrm{Y}}$ is $\mathrm{HIGH}, \mathrm{Y}_{0}-\mathrm{Y}_{15}$ are used as external data inputs which allow data to be directly loaded into the 16 -bit data latch. Having $\overline{O E}_{Y}$ LOW allows the ALU data to be output on $Y_{0}-Y_{15}$. |
| 36 | DLE | 1 | Data Latch Enable. When DLE is HIGH, the 16 -bit data latch is transparent and is latched when DLE is LOW. |
| 43 | $\overline{O E}_{Y}$ | 1 | Output Enable. When $\bar{O}_{Y}$ is HIGH, the 16-bit $Y$ outputs are disabled (high-impedance); when $\overline{O E}_{Y}$ is LOW, the 16-bit Y outputs are enabled (HIGH or LOW). |
|  | ${ }^{10-1} 15$ | 1 | Sixteen Instruction Inputs. Used to select the operations to be performed in the Am29116. Also used as data inputs while performing immediate instructions. |
| 19 | IEN | 1 | Instruction Enable. With IEN LOW, data can be written into the RAM when the clock is LOW. The Accumulator can accept data during the LOW-HIGH transition of the clock. Having IEN LOW, the Status Register can be updated when SRE is LOW. With IEN HIGH, the conditional test output, CT, is disabled as a function of the instruction inputs. IEN should be LOW for the first half of the first cycle of an immediate instruction. |
| 20 | SRE |  | Status Register Enable. When SRE and IEN are both LOW, the Status Register is updated at the end of all instructions with the exception of NO-OP, Save Status, and Test Status. Having either SRE or IEN HIGH will inhibit the Status Register from changing. |
| 18 | CP | 1 | Clock Pulse. The clock input to the Am29116. The RAM latch is transparent when the clock is HIGH. When the clock goes LOW, the RAM output is latched. Data is written into the RAM during the low period of the clock provided IEN is LOW and if the instruction being executed designates the RAM as the destination of operation. The Accumulator and Status Register will accept data on the LOW-HIGH transition of the clock if IEN is also LOW. The instruction latch becomes transparent when it exits an immediate instruction mode during a LOW-HIGH transition of the clock. |
| $\begin{aligned} & 27,26, \\ & 24,23 \end{aligned}$ | $\mathrm{T}_{1}-\mathrm{T}_{4}$ | 1/0 | Input/Output Pin. Under the control of OET, the four lower status bits $\mathrm{Z}, \mathrm{C}, \mathrm{N}, \mathrm{OVR}$ become outputs on $\mathrm{T}_{1}-\mathrm{T}_{4}$, respectively when OET goes HIGH. When OET is LOW, $\mathrm{T}_{1}-\mathrm{T}_{4}$ are used as inputs to generate the CT output. |
| 22 | $\mathrm{OE}_{\mathrm{T}}$ | 1 | Output Enable. When OE $T$ is LOW, the 4-bit T outputs are disabled (high-impedance); when OE $T_{T}$ is HIGH, the 4-bit $T$ outputs are enabled (HIGH or LOW). |
| 21 | CT | 0 | Conditional Test. The condition code multiplexer selects one of the twelve condition code signals and places them on the CT output. A HIGH on the CT output indicates a passed condition and a LOW indicates a failed condition. |



Figure 1. Detailed Am29116 Block Diagram.

## ARCHITECTURE OF THE Am29116

The Am29116 is a high-performance, microprogrammable 16bit bipolar microprocessor.

As shown in the Block Diagram, Figure 1, the device consists of the following elements interconnected with 16-bit data paths.

- 32-Word by 16-Bit RAM
- Accumulator
- Data Latch
- Barrel Shifter
- ALU
- Priority Encoder
- Status Register
- Condition-Code Generator/Multiplexer
- Three-State Output Buffers
- Instruction Latch and Decoder


## 32-Word by $\mathbf{1 6 - B i t}$ RAM

The 32 -Word by 16 -Bit RAM is a single-port RAM with a 16 -bit latch at its output. The latches are transparent when the clock input (CP) is HIGH and latched when the clock input is LOW. Data is written into the RAM while the clock is LOW if the IEN input is also LOW and if the instruction being executed defines the RAM as the destination of the operation. For byte instructions, only the lower eight RAM bits are written into; for word instructions, all 16 bits are written into. With the use of an external multiplexer on five of the instruction inputs, it is possible to select separate read and write addresses for the same instruction. This two-address operation is not allowed for immediate instructions.

## Accumulator

The 16-bit Accumulator is an edge-triggered register. The Accumulator accepts data on the LOW-to-HIGH transition of the clock input if the IEN input is LOW and if the instruction being executed defines the Accumulator as the destination of the operation. For byte instructions, only the lower eight bits of the Accumulator are written into; for word instructions, all 16 bits are written into.

## Data Latch

The 16-bit Data Latch holds the data input to the Am29116 on the bi-directional $Y$ bus. The latch is transparent when the DLE input is HIGH and latched when the DLE input is LOW.

## Barrel Shifter

A 16-bit Barrel Shifter is used as one of the ALU inputs. This permits rotating data from either the RAM, the Accumulator or the Data Latch up to 15 positions. In the word mode, the Barrel Shifter rotates a 16-bit word; in the byte mode, it rotates only the lower eight bits.

## Arithmetic Logic Unit

The Am29116 contains a 16-bit ALU with full carry lookahead across all 16 bits in the arithmetic mode. The ALU is capable of operating on either one, two or three operands, depending upon the instruction being executed. It has the ability to execute all conventional one and two operand operations, such as pass, complement, two's complement, add, subtract, AND, NAND, OR, NOR, EXOR, and EX-NOR. In addition, the ALU can also execute three-operand instructions such as rotate and merge and rotate and compare with mask. All ALU operations can be performed on either a word or byte basis, byte operations being performed on the lower eight bits only.

The ALU produces three status outputs, C (carry), N (negative) and OVR (overflow). The appropriate flags are generated at
the byte or word level, depending upon whether the device is executing in the byte or word mode. The $Z$ (zero) flag, although not generated by the ALU, detects zero at both the byte and word level.

The carry input to the ALU is generated by the Carry Multiplexer which can select an input of zero, one, or the stored carry bit from the Status Register, QC. Using QC as the carry input allows execution of multiprecision addition and subtractions.

## Priority Encoder

The Priority Encoder produces a binary-weighted code to indicate the locations of the highest order ONE at its input. The input to the Priority Encoder is generated by the ALU which performs an AND operation on the operand to be prioritized and a mask. The mask determines which bit locations to eliminate from prioritization. In the word mode, if no bit is HIGH, the output is a binary zero. If bit 15 is HIGH, the output is a binary one. Bit 14 produces a binary two, etc. Finally, if only bit 0 is HIGH, a binary 16 is produced.

In the byte mode, bits 8 thru 15 do not participate. If none of bits 7 thru 0 are HIGH, the output is a binary zero. If bit 7 is HIGH a binary one is produced. Bit 6 produces a binary two, etc. Finally, if only bit 0 is HIGH, a binary 8 is produced.

## Status Register

The Status Register holds the 8-bit status word. With the Status-Register Enable, (SRE) input LOW and the IEN input LOW, the Status Register is updated at the end of all instructions except NO-OP, Save-Status and Test-Status instructions. $\overline{\text { SRE }}$ going HIGH or IEN going HIGH inhibits the Status Register from changing.

The lower four bits of the Status Register contain the ALU status bits of Zero (Z), Carry, (C) Negative (N), and Overflow (OVR). The upper four bits contain a Link bit and three userdefinable status bits (Flag 1, Flag 2, Flag 3).

With SRE LOW and IEN LOW, the lower four status bits are updated after each instruction except those mentioned above, NO-OP, Save Status, Status Test and the Status Set/Reset instruction for the upper four bits. Under the same conditions, the upper four status bits are changed only during their respective Status Set/Reset instructions and during Status Load instructions in the word mode. The Link-Status bit is also updated after each shift instruction.

The Status Register can be loaded from the internal Y-bus, and can also be selected as a source for the internal $Y$-bus. When the Status Register is loaded in the word mode, all 8bits are updated; in the byte mode, only the lower 4 bits (Z, C, $\mathrm{N}, \mathrm{OVR}$ ) are updated.

When the Status Register is selected as a source in the word mode, all eight bits are loaded into the lower byte of the destination; the upper byte of the destination is loaded with all zeros. In the byte mode, the Status Register again loads into the lower byte of the destination, but the upper byte remains unchanged. This Store and Load combination allows saving the restoring the Status Register for interrupt and subroutine processing. The four lower status bits ( $Z, C, N, O V R$ ) can be read directly via the bidirectional $T$ bus. These four bits are available as outputs on the $T_{1-4}$ outputs whenever OET is HIGH.

## Condition-Code Generator/Multiplexer

The Condition-Code Generator/Multiplexer contains the logic necessary to develop the 12 condition-code test signals. The
multiplexer portion can select one of these test signals and place it on the CT output for use by the microprogram sequence. The multiplexer may be addressed in two different ways. One way is through the Test Instruction. This instruction specifies the test condition to be placed in the CT output, but does not allow an ALU operation at the same time. The second method uses the bidirectional $T$ bus as an input. This requires extra bits in the microword, but provides the ability to simultaneously test and execute. The test instruction lines $l_{0-4}$, have priority over $T_{1-4}$, for testing status.

## Three-State Output Buffers

There are two sets of Three-State Output Buffers in the Am29116. One set controls the bidirectional, 16-bit $Y$ bus These outputs are enabled by placing a LOW on the $\overline{\mathrm{OE}}$ input. A HIGH puts the $Y$ outputs in the high-impedance state allowing data to be input to the Data latch from an externa source.

The second set of Three-State Output Buffers controls the bidirectional 4-bit T bus and is enabled by placing a HIGH on the OET input. This allows storing the four internal ALU status
bits (Z, C, N, OVR) externally. A LOW OET input forces the T outputs into the high-impedance state. External devices can then drive the T bus to select a test condition for the CT output.

## Instruction Latch and Decoder

The 16 -bit Instruction Latch is normally transparent to allow decoding of the Instruction Inputs by the Instruction Decoder into the internal control signals for the Am29116. All instructions except Immediate Instructions are executed in a single clock cycle.

Immediate instructions require two clock cycles for execution. During the first clock cycle, the Instruction Decoder recognizes that an Immediate Instruction is being specified and captures the data on the Instruction Inputs in the Instruction Latch. During the second clock cycle, the data on the Instruction Inputs is used as one of the operands for the function specified during the first clock cycle. At the end of the second clock cycle, the Instruction Latch is returned to its transparent state.

## INSTRUCTION SET

The instruction set of the Am29116 is very powerful. In addition to the single and two operand logical and arithmetic instructions, the Am29116 instruction set contains functions particularly useful in controller applications: bit set, bit reset, bit test, rotate and merge, rotate and compare, and cyclic-redundancy-check (CRC) generation. Complex instructions like rotate and merge, rotate and compare, and prioritize are executed in a single microcycle.

Three data types are supported by the Am29116.

- Bit
- Byte
- Word (16-bit)

In the byte mode data is written into the lower half of the word and the upper half is unchanged. The special case is when the status register is specified as the destination. In the byte mode the LSH (OVR, N, C, Z) of the status register is updated and in the word mode all eight bits of the status register are updated. The status register does not change for save status and test status instructions. In the test status instructions the CT output has the result and the Y -bus is undefined.

The Am29116 Instruction Set can be divided into eleven types of instructions. These are:

- Single Operand
- Rotate and Compare
- Two Operand
- Prioritize
- Single Bit Shift
- Cyclic-Redundancy-Check
- Rotate and Merge
- Status
- Bit Oriented
- No-Op
- Rotate by $n$ Bits

Each instruction type is arbitrarily divided into quadrants. Two of the sixteen instruction lines decode to four quadrants labelled from 0 to 3 . The quadrants were defined mainly for convenience in classification of the instruction set and addressing modes and can be used together with the OP CODES to distinguish the instructions.

The following pages describe each of the instruction types in detail. Throughout the description $\overline{\mathrm{OEy}}$ is assumed to be LOW allowing ALU outputs on the Y-bus.

Table 1 illustrates operand source-destination combinations for each instruction type.

TABLE 1. OPERAND SOURCE DESTINATION COMBINATIONS

| Instruction Type | Operand Combinations (Note 1) |  |  |
| :---: | :---: | :---: | :---: |
| Single Operand | Source (R/S) |  | Destination |
|  | RAM (Note 2)ACC$D$$D(0 E)$$D(S E)$10 |  | RAM ACC Y Bus Status ACC and Status |
| Two Operand | Source (R) | Source (S) | Destination |
|  | RAM RAM D D ACC D | ACC <br> I <br> RAM <br> ACC 1 | RAM <br> ACC <br> Y Bus Status ACC and Status |
| Single Bit Shift | Source (U) |  | Destination |
|  | $\begin{gathered} \text { RAM } \\ \text { ACC } \\ \text { ACC } \\ \text { D } \\ \text { D } \\ \text { D } \end{gathered}$ |  | RAM ACC Y Bus RAM ACC $Y$ Bus |
| Rotate n Bits | Source (U) |  | Destination |
|  | $\begin{gathered} \text { RAM } \\ \text { ACC } \\ \text { D } \end{gathered}$ |  | $\begin{aligned} & \text { RAM } \\ & \text { ACC } \\ & \text { Y Bus } \end{aligned}$ |
| Bit Oriented | Source (R/S) |  | Destination |
|  |  |  | $\begin{aligned} & \text { RAM } \\ & \text { ACC } \\ & \text { Y Bus } \end{aligned}$ |
| Rotate and Merge | Rotated <br> Source (U) | Mask (S) | Non-Rotated Source/ <br> Destination ( $R$ ) |
|  | $\begin{gathered} D \\ D \\ D \\ D \\ \text { ACC } \\ \text { RAM } \end{gathered}$ |  | ACC <br> ACC <br> RAM <br> RAM <br> RAM <br> ACC |
| Rotate and Compare | Rotated <br> Source (U) | Mask (S) | Non-Rotated Source/ <br> Destination (R) |
|  | $\begin{gathered} D \\ D \\ D \\ \text { RAM } \end{gathered}$ | $\begin{gathered} 1 \\ 1 \\ A C C \end{gathered}$ | RAM RAM ACC |


| Instruction Type | Operand Combinations (Note 1) |  |  |
| :---: | :---: | :---: | :---: |
| Prioritize (Note 3) | Source (R) | Mask (S) | Destination |
|  | $\begin{gathered} \text { RAM } \\ \text { ACC } \\ \text { D } \end{gathered}$ | $\begin{gathered} \text { RAM } \\ \text { ACC } \\ 1 \\ 0 \end{gathered}$ | RAM ACC <br> $Y$ Bus |
| Cyclic <br> Redundancy <br> Check | Data In | Destination | Polynomial |
|  | QLINK | RAM | ACC |
| No Operation | - |  |  |
| Set Reset Status | Bits Affected |  |  |
|  | $\begin{gathered} \text { OVR, N, } \mathrm{C}, \mathrm{Z} \\ \text { LINK } \\ \text { Flag1 } \\ \text { Flag2 } \\ \text { Flag3 } \end{gathered}$ |  |  |
| Store Status | Source |  | Destination |
|  | Status |  | $\begin{aligned} & \text { RAM } \\ & \text { ACC } \\ & \text { Y Bus } \end{aligned}$ |
| Status Load | Source (R) | Source (S) | Destination |
|  | $\begin{gathered} \mathrm{D} \\ \mathrm{ACC} \\ \mathrm{D} \end{gathered}$ | ACC $1$ <br> I | Status Status and ACC |
| Test Status | Test Condition (CT) |  |  |
|  | $\begin{gathered} (N \oplus O V R)+Z \\ N \oplus O V R \\ Z \\ \text { OVR } \\ \text { Low } \\ \mathrm{C} \\ Z+\overline{\mathrm{C}} \\ \mathrm{~N} \\ \text { LINK } \\ \text { Flag } 1 \\ \text { Flag } 2 \\ \text { Flag } 3 \end{gathered}$ |  |  |

Notes: 1. When there is no dividing line between the R\&S OPERAND or SOURCE and DESTINATION, the two must be used as a given pair. But where there exists such a separation, any combination of them is possible.
2. In the SINGLE OPERAND INSTRUCTION, RAM cannot be used when both ACC and STATUS are designated as a DESTINATION.
3. In the PRIORITIZE INSTRUCTION, OPERAND and MASK must be different sources.

## SINGLE OPERAND INSTRUCTIONS

The Single Operand Instructions contain four indicators: byte or word mode, opcode, source and destination. They are further subdivided into two types. The first type uses RAM as a source or destination or both, and the second type does not use RAM as a source or destination. Both types have different instruction formats as shown below. Under the control of instruction inputs, the desired function is performed on the source and the result is either stored in the specified destination or placed on the Y -bus or both. For a special case where

8 -bit to 16 -bit conversion is needed, the Am29116 is capable of extending sign bit ( $D(S E)$ ) or binary zero ( $D(O E)$ ) over 16 -bits in the word mode. The least significant four bits of the Status Register (OVR, N, C, Z) are affected by the function performed in this category. The most significant bits of status register (FLAG1, FLAG2, FLAG3, LINK) are not affected. The only limitation in this type is that the RAM cannot be used as a source when both ACC and the Status Register are specified as a destination.

## SINGLE OPERAND FIELD DEFINITIONS

SOR


## SINGLE OPERAND INSTRUCTION



Notes: 1. The instruction mnemonic gesignates different instruction formats used in the Am29116. They are useful in assembly microcode with the System 29 AMDASM $^{\text {¹M }}$ meta assembler.
2. $\mathrm{B}=$ Byte Mode, $\mathrm{W}=$ Word Mode.
3. See Instruction Set description.
4. $R=$ Source; $S=$ Source; Dest $=$ Destination.
5. When status is destination,

Status $i \leftarrow Y i i=0$ to 3 (Byte mode) $i=0$ to 7 (Word mode)

Y BUS AND STATUS - SINGLE OPERAND INSTRUCTIONS

| Instruction | Opcode | Description | B/W | Y - Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SOR SONR | MOVE | SRC $\rightarrow$ Dest | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | $Y \leftarrow$ SRC | NC | NC | NC | NC | 0 | U | 0 | U |
|  | COMP | $\overline{\text { SRC }} \rightarrow$ Dest |  | $Y \leftarrow \overline{\text { SRC }}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | INC | SRC +1 $\rightarrow$ Dest |  | $Y \leftarrow$ SRC +1 | NC | NC | NC | NC | U | U | U | U |
|  | NEG | $\overline{\text { SRC }+1 \rightarrow \text { Dest }}$ |  | $Y \leftarrow \overline{\text { SRC }}+1$ | NC | NC | NC | NC | U | U | U | U |

```
SRC = Source
    U = Update
```

    NC = No Change
    $0=$ Reset
$1=$ Set
$i=0$ to 15 when not specified

## TWO OPERAND INSTRUCTIONS

The Two Operand Instructions contain five indicators: byte or word mode, opcode, R source, S source, and destination. They are further subdivided into two types. The first type uses RAM as the source and/or destination and the second type does not use RAM as source or destination. The first type has two formats; the only difference is in the quadrant. Under the control of instruction inputs, the desired function is performed on the specified sources and the result is stored in the
specified destination or placed on the Y -bus or both. The least significant four bits of the status register (OVR, N, C, Z) are affected by the arithmetic functions performed and only the N and $Z$ bits are affected by the logical functions performed. The OVR and C bits of the status register are forced to ZERO for logical functions. Add with carry and Subtract with carry instructions are useful for Multiprecision Add or Subtract.

TWO OPERAND FIELD DEFINITIONS


TWO OPERAND INSTRUCTIONS

| Instruction | B/W | Quad |  |  | $\mathrm{R}^{1}$ | $S^{1}$ | Dest ${ }^{1}$ |  | Opco |  |  | RAM | Address |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TOR1 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 00 | 0000 0010 0011 1000 1010 1011 1100 1110 1111 | TORAA TORIA TODRA TORAY TORIY TODRY TORAR TORIR TODRR | RAM <br> RAM <br> D <br> RAM <br> RAM <br> D <br> RAM <br> RAM <br> D | ACC <br> I <br> RAM <br> ACC <br> 1 <br> RAM <br> ACC <br> 1 <br> RAM | ACC <br> ACC <br> ACC <br> Y Bus <br> Y Bus <br> Y Bus <br> RAM <br> RAM <br> RAM | $\begin{aligned} & \hline 0000 \\ & 0001 \\ & 0010 \\ & 0011 \\ & 0100 \\ & 0101 \\ & \\ & 0110 \\ & 0111 \\ & 1000 \\ & 1001 \\ & 1010 \\ & 1011 \\ & \hline \end{aligned}$ | SUBR <br> SUBRC $^{2}$ <br> SUBS <br> SUBSC $^{2}$ <br> ADD <br> ADDC <br> AND <br> NAND <br> EXOR <br> NOR <br> OR <br> EXNOR | $S$ minus $R$ $S$ minus $R$ with carry $R$ minus $S$ $R$ minus $S$ with carry R plus S R plus $S$ with carry <br> R.S <br> R.S <br> $\frac{R \oplus S}{R+S}$ <br> $\frac{R+S}{R \oplus S}$ | $\begin{aligned} & 00000 \\ & \cdots+1111 \end{aligned}$ | $\begin{aligned} & \text { R00 } \\ & \text { R31 } \end{aligned}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B/W | Quad |  |  | $\mathrm{R}^{1}$ | $\mathrm{S}^{1}$ | Dest ${ }^{1}$ |  | Opco |  |  | RAM | Address |
| TOR2 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | $\begin{array}{\|l\|} \hline 0001 \\ 0010 \\ 0101 \end{array}$ | TODAR TOAIR TODIR | ACC <br> D | $\begin{aligned} & \text { ACC } \\ & 1 \\ & 1 \end{aligned}$ | RAM RAM RAM | 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 | SUBR <br> SUBRC $^{2}$ <br> SUBS <br> SUBSC ${ }^{2}$ <br> ADD <br> ADDC <br> AND <br> NAND <br> EXOR <br> NOR <br> OR <br> EXNOR | $S$ minus $R$ $S$ minus $R$ with carry $R$ minus $S$ R minus $S$ with carry R plus S $R$ plus $S$ with carry <br> $\frac{R \cdot S}{R \cdot S}$ <br> $B \in S$ <br> $R+S$ <br> $\frac{R+S}{R+S}$ <br> $A \oplus S$ | $\begin{aligned} & 00000 \\ & \cdots \dot{11111} \end{aligned}$ | $\begin{aligned} & \text { R00 } \\ & \dot{R} 31 \end{aligned}$ | RAM Reg 00 RAM Reg 31 |
| Note 1: $\mathrm{R}=$ Source $S=\text { Source }$ <br> Dest $=$ Destination <br> Note 2: During subtraction the carry is interpreted as borrow. |  |  |  |  |  |  |  |  |  |  |  |  |  |

TWO OPERAND INSTRUCTIONS

| Instruction | B/W | Quad |  |  | $\mathrm{R}^{1}$ | $\mathrm{s}^{1}$ |  |  | code |  | Dest | tination |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TONR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | $\begin{aligned} & 0001 \\ & 0010 \\ & 0101 \end{aligned}$ | $\begin{aligned} & \text { TODA } \\ & \text { TOAI } \\ & \text { TODI } \end{aligned}$ | D <br> ACC <br> D | $\begin{aligned} & \text { ACC } \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0000 \\ & 0001 \\ & \\ & 0010 \\ & 0011 \\ & \\ & 0100 \\ & 0101 \\ & \\ & 0110 \\ & 0111 \\ & 1000 \\ & 1001 \\ & 1010 \\ & 1011 \end{aligned}$ | SUBR <br> SUBRC <br> SUBS <br> SUBSC <br> ADD <br> ADDC <br> AND <br> NAND <br> EXOR <br> NOR <br> OR <br> EXNOR | $S$ minus $R$ <br> $S$ minus R with carry <br> R minus $S$ <br> R minus $S$ with carry <br> R plus S <br> $R$ plus $S$ with carry R.S <br> R.S <br> $R \oplus S$ <br> R+S <br> R+S <br> $\mathrm{R} \oplus \mathrm{S}$ | $\begin{aligned} & 00000 \\ & 00001 \\ & 00100 \\ & 00101 \end{aligned}$ | NRY <br> NRA <br> NRS <br> NRAS | Y Bus ACC Status ${ }^{2}$ ACC, Status $^{2}$ |
| Notes $\begin{aligned} & R=\text { Source } \\ & S=\text { Source } \end{aligned}$ <br> 2: When status is destination, <br> Status $i_{\leftarrow} \leftarrow Y_{i} i=0$ to 3 (Byte mode) $i=0 \text { to } 7 \text { (Word mode) }$ <br> 3: During subtraction the carry is interpreted as borrow. |  |  |  |  |  |  |  |  |  |  |  |  |

Y BUS AND STATUS CONTENTS - TWO OPERAND INSTRUCTIONS

| Instruction | Opcode | Description | B/W | Y - Bus | Flag3 | Flag2 | Flag 1 | LINK | OVR | N | C | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TOR1 TOR2 TONR | SUBR | $S$ minus R | $\begin{aligned} & 0=B \\ & 1=w \end{aligned}$ | $Y \leftarrow S+\bar{R}+1$ | NC | NC | NC | NC | U | U | U | U |
|  | SUBRC | $S$ minus $R$ with carry |  | $Y \leftarrow S+\bar{R}+Q C$ | NC | NC | NC | NC | U | U | U | U |
|  | SUBS | $R$ minus $S$ |  | $Y \leftarrow R+\bar{S}+1$ | NC | NC | NC | NC | U | U | U | U |
|  | SUBSC | $R$ minus $S$ with carry |  | $Y \leftarrow R+\bar{S}+Q C$ | NC | NC | NC | NC | U | U | U | U |
|  | ADD | R plus S |  | $Y \leftarrow R+S$ | NC | NC | NC | NC | U | U | U | U |
|  | ADDC | $R$ plus $S$ with carry |  | $Y_{\leftarrow} R+S+Q C$ | NC | NC | NC | NC | U | U | U | U |
|  | AND | R.S |  | $Y \in R_{i}$ AND $S_{i}$ | NC | NC | NC | NC | 0. | U | 0 | U |
|  | NAND | $\overline{\mathrm{R} \cdot \mathrm{S}}$ |  | $Y_{i}-R_{i}$ NAND $S_{i}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | EXOR | $\mathrm{R} \oplus \mathrm{S}$ |  | $Y_{i} \leftarrow R_{i}$ EXOR $S_{i}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | NOR | $\overline{R+S}$ |  | $Y_{i}-R_{i}$ NOR $S_{i}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | OR | R+S |  | $Y_{i}-R_{i}$ OR $S_{i}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | EXNOR | $\overline{\mathrm{R} \oplus \mathrm{S}}$ |  | $Y_{i}-R_{i}$ EXNOR $S_{i}$ | NC | NC | NC | NC | 0 | 0 | 0 | U |

[^13]
## SINGLE BIT SHIFT INSTRUCTIONS

The Single Bit Shift Instructions contain four indicators: byte or word mode, direction and shift linkage, source and destination. They are further subdivided into two types. The first type uses RAM as the source and/or destination and the second type does not use RAM as source or destination. Under the control of the instruction inputs, the desired shift function is performed on the specified source and the result is stored in the specified destination or placed on the $Y$-bus or both. The direction and shift linkage indicator defines the direction of the shift (up or down) as well as what will be shifted into the vacant bit. On a shift-up instruction, the LSB may be loaded with ZERO, ONE,
or the Link-Status bit (QLINK). The MSB is loaded into the Link-Status bit as shown in Figure 2. On a shift-down instruction, the MSB may be loaded with ZERO, ONE, the contents of the Status Carry flip-flop, (QC), the Exclusive-OR of the Negative-Status bit and the Overflow-Status bit (QN $\oplus$ QOVR) or the Link-Status bit. The LSB is loaded into the LinkStatus bit as shown in Figure 3. The N and Z bits of the Status register are affected but the OVR and C bits are forced to ZERO. The Shift-Down with QN $\oplus$ QOVR is useful for Two's Complement multiplication.

SINGLE BIT SHIFT FIELD DEFINITIONS:

| $15: 141312$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SHFTR | 98 |  |  |  |  |  | 54 |  |
|  | B/W | Quad | SRC-Dest | Opcode | RAM Address |  |  |  |
|  |  |  |  |  |  |  |  |  |
| SHFTNR | B/W | Quad | SRC | Opcode | Dest |  |  |  |



PF000360

Figure 2. Shift Up Function.


PF000350

Figure 3. Shift Down Function.


## BIT ORIENTED INSTRUCTIONS

The Bit Oriented Instructions contain four indicators: byte or word mode, operation, source/destination, and the bit position of the bit to be operated on (Bit 0 is the least significant bit). They are further subdivided into two types. The first type uses the RAM as both source and destination and has two kinds of formats which differ only by quadrant. The second type does not use the RAM as a source or a destination. Under the control of the instruction inputs, the desired function is performed on the specified source and the result is stored in the specified destination or placed on the Y-bus or both. The operations which can be performed are: Set Bit $n$ which forces the $\mathrm{n}^{\text {th }}$ bit to a ONE leaving other bits unchanged; Reset Bit n
which forces the $n^{\text {th }}$ bit to ZERO leaving the other bits unchanged; Test Bit n, which sets the ZERO Status Bit depending on the state of bit $n$ leaving all the bits unchanged; Load $2^{n}$, which loads ONE in Bit position $n$ and ZERO in all other bit positions; Load $2^{n}$ which loads ZERO in bit position $n$ and ONE in all other bit positions; increment by $2^{n}$, which adds $2^{n}$ to the operand; and decrement by $2^{n}$ which subtracts $2^{n}$ from the operand. For all the Load, Set, Reset and Test instructions, the N and Z bits are affected and OVR and C bit of the Status register are forced to ZERO. For all arithmetic instructions the LSH (OVR, C, N, Z bits) of the Status register is affected.

BIT ORIENTED FIELD DEFINITIONS


BIT ORIENTED INSTRUCTIONS

| Instruction | B/W | Quad | n | Opcode |  |  | RAM Address |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BOR1 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | 0 to 15 | $\begin{aligned} & 1101 \\ & 1110 \\ & 1111 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SETNR } \\ & \text { RSTNR } \\ & \text { TSTNR } \end{aligned}$ | Set RAM, bit $n$ Reset RAM, bit n Test RAM, bit n | $\begin{array}{r} \hline 00000 \\ \ldots \\ 11111 \\ \hline \end{array}$ | $\begin{array}{r} \mathrm{R} 00 \\ \ldots \\ \mathrm{R} 31 \\ \hline \end{array}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B/W | Quad | n | Opcode |  |  | RAM Address |  |  |
| BOR2 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | 0 to 15 | $\begin{aligned} & 1100 \\ & 1101 \\ & 1110 \\ & 1111 \\ & \hline \end{aligned}$ | LD2NR LDC2NR A2NR S2NR | $\begin{aligned} & 2^{n} \rightarrow \text { RAM } \\ & 2^{n} \rightarrow \text { RAM } \\ & \text { RAM plus } 2^{n} \rightarrow \text { RAM } \\ & \text { RAM minus } 2^{n} \rightarrow \text { RAM } \end{aligned}$ | $\begin{aligned} & 00000 \\ & \because \\ & 11111 \end{aligned}$ | $\begin{aligned} & \text { R00 } \\ & \because \\ & \text { R31 } \end{aligned}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B/W | Quad | n |  |  |  | Opcode |  |  |
| BONR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | 0 to 15 | 1100 |  | , | $\begin{array}{\|l\|} \hline 00000 \\ 00001 \\ 00010 \\ 00100 \\ 00101 \\ 00110 \\ 00111 \\ 10000 \\ 10001 \\ 10010 \\ 10100 \\ 10101 \\ 10110 \\ 10111 \\ \hline \end{array}$ | TSTNA RSTNA SETNA A2NA S2NA LD2NA LDC2NA TSTND RSTND SETND A2NDY S2NDY LS2NY LDC2NY | Test ACC, bit $n$ Reset ACC, bit $n$ Set ACC, bit $n$ ACC plus $2^{n} \rightarrow$ ACC ACC minus $2^{n} \rightarrow A C C$ $\frac{2^{n}}{2^{n}} \rightarrow$ ACC <br> Test D, bit n Reset D, bit $n$ Set D, bit $n$ $D$ plus $2^{n} \rightarrow Y$ BUS $D$ minus $2^{n} \rightarrow Y$ Bus $2^{n} \rightarrow Y$ Bus $2^{n}$ |


| Y BUS AND STATUS - BIT ORIENTED INSTRUCTIONS |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Opcode | Description | B/W | $\mathbf{Y}$ - Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | Z |
| BOR1 | $\begin{aligned} & \text { SETNR } \\ & \text { RSTNR } \\ & \hline \end{aligned}$ | Set RAM Bit n Reset RAM, Bit n | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | $\begin{aligned} & Y_{i}-R A M_{i} \text { for } i \neq n ; Y_{n} \leftarrow 1 \\ & Y_{i}-R A M_{i} \text { for } i \neq n ; Y_{n}-0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { NC } \\ & \text { NC } \end{aligned}$ | $\begin{aligned} & \hline \text { NC } \\ & \text { NC } \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{aligned} & \hline \text { NC } \\ & \text { NC } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & U \\ & U \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & U \end{aligned}$ |
|  | TSTNR | Test Ram, Bit $n$ |  | $Y_{i}-0$ for $i \neq n ; Y_{n} \leftarrow$ SRC $_{n}$ | NC | NC | NC | NC | 0 | U | 0 | U |
| BOR2 | LD2NR | $2^{n} \rightarrow$ RAM |  | $Y_{i}+0$ for $i \neq n ; Y_{n}-1$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | LDC2NR | $\overline{2}^{\text {n }} \rightarrow$ RAM |  | $Y_{i}-1$ for $i \neq n ; Y_{n}+0$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | A2NR | RAM + $2^{n} \rightarrow$ RAM |  | $Y_{i}-$ RAM $+2^{n}$ | NC | NC | NC | NC | U | U | U | U |
|  | S2NR | RAM - $2^{n} \rightarrow$ RAM |  | $Y_{i}+R A M-2^{n}$ | NC | NC | NC | NC | U | U | U | U |
| BONR | TSTNA | Test ACC, Bit n |  | $Y_{i}-0$ for $\mathrm{i} \neq \mathrm{n} ; \mathrm{Y}_{\mathrm{n}}-A C C_{n}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | RSTNA | Reset ACC, Bit n |  | $Y_{i}-A C C_{i}$ for $i \neq n ; Y_{n}-0$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | SETNA | Set ACC, Bit n |  | $Y_{i}-A C C_{i}$ for $i \neq n ; Y_{n}-1$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | A2NA | $A C C+2^{n} \rightarrow A C C$ |  | $Y_{i}-A C C+2^{n}$ | NC | NC | NC | NC | U | U | U | U |
|  | S2NA | ACC - $2^{n} \rightarrow$ ACC |  | $Y_{i}-A C C-2^{n}$ | NC | NC | NC | NC | U | U | U | U |
|  | LD2NA | $2^{n} \rightarrow A C C$ |  | $\mathrm{Y}_{\mathrm{i}}+0$ for $\mathrm{i} \neq \mathrm{n} ; \mathrm{Y}_{\mathrm{n}}-1$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | LDC2NA | $\overline{2^{n}} \rightarrow$ ACC |  | $Y_{i} \leftarrow 1$ for $i \neq n ; Y_{n} \leftarrow 0$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | TSTND | Test D, Bit n |  | $Y_{i}+0$ for $i \neq n ; Y_{n}-D_{n}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | RSTND | Reset D, Bit $\mathrm{n}^{*}$ |  | $Y_{i}-D_{i}$ for $i \neq n ; Y_{n}+0$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  | SETND | Set D, Bit ${ }^{*}$ |  | $Y_{i}-D_{i}$ for $i \neq n ; Y_{n}-1$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | A2NDY | $D+2^{n} \rightarrow Y$ Bus |  | $Y \vdash D+2^{n}$ | NC | NC | NC | NC | U | U | U | U |
|  | S2NDY | $D-2^{n} \rightarrow Y$ Bus |  | $Y-D-2^{n}$ | NC | NC | NC | NC | U | U | U | U |
|  | LD2NY | $2^{n} \rightarrow Y$ Bus |  | $Y_{i}+0$ for $i \neq n ; Y_{n}+1$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
|  | LDC2NY | $\overline{2}^{n} \rightarrow Y$ Bus |  | $Y_{i}+1$ for $i \neq n ; Y_{n} \leftarrow 0$ | NC | NC | NC | NC | 0 | U | 0 | 0 |
| $\begin{aligned} & \text { SRC = Source } \\ & U=\text { Update } \\ & N C=N o \text { Change } \\ & 0=R e s e t \\ & 1=\text { Set } \\ & i=0 \text { to } 15 \text { when not specified } \end{aligned}$ <br> *Destination is not $D$ Latch but $Y$ Bus. |  |  |  |  |  |  |  |  |  |  |  |  |

## ROTATE BY $\boldsymbol{n}$ BITS INSTRUCTIONS

The Rotate by $n$ Bits Instructions contain four indicators: byte or word mode, source, destination and the number of places the source is to be rotated. They are further subdivided into two types. The first type uses RAM as a source and/or a destination and the second type does not use RAM as a source or destination. The first type has two different formats and the only difference is in the quadrant. The second type has only one format as shown in the table. Under the control of instruction inputs, the $\mathbf{n}$ indicator specifies the number of bit positions the source is to be rotated up ( 0 to 15), and the result
is either stored in the specified destination or placed on the $Y$ bus or both. An example of this instruction is given in Figure 4. In the Word mode, all 16 -bits are rotated up while in the Byte mode, only lower 8 -bits ( $0-7$ ) are rotated up. In the Word mode, a rotate up by $n$ bits is equivalent to a rotate down by (16-n) bits. Similarly, in the Byte mode a rotate up by $n$ bits is equivalent to a rotate down by (8-n) bits. The $N$ and $Z$ bits of the Status Register are affected and OVR and C bits are forced to ZERO.

EXAMPLE: $\mathrm{n}=4$, Word Mode

| Source | 0001 | 0011 | 0111 | 1111 |
| :--- | :---: | ---: | :--- | :--- |
| Destination | 0011 | 0111 | 1111 | 0001 |
| EXAMPLE: | $\mathbf{n}=$ | 4, | Byte | Mode |
|  | 0001 | 0011 |  |  |
| Source | 00111 | 1111 |  |  |
| Destination | 0001 | 0011 | 1111 | 0111 |

## ROTATE BY n BITS FIELD DEFINITIONS

|  | 15 | 14 | 13 | 1298 | 5 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| ROTR1 | B/W | Quad | $n$ | SRC-Dest | RAM Address |  |

Figure 4. Rotate by $\mathbf{n}$ Example

| ROTNR | B/W | Quad | n | 1100 |
| :---: | :---: | :---: | :---: | :---: |

ROTATE BY n BITS INSTRUCTIONS

| Instruction | B/W | Quad | n |  |  | $U^{1}$ | Dest ${ }^{1}$ | RAM Address |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROTR1 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 00 | 0 to 15 | $\begin{aligned} & \hline 1100 \\ & 1110 \\ & 1111 \\ & \hline \end{aligned}$ | RTRA RTRY RTRR | RAM <br> RAM <br> RAM | $\begin{aligned} & \text { ACC } \\ & \text { Y Bus } \\ & \text { RAM } \end{aligned}$ | $\begin{gathered} 00000 \\ 11111 \end{gathered}$ | $\begin{gathered} \text { R00 } \\ \text { R31 } \end{gathered}$ |  |  |
| Instruction | B/W | Quad | n |  |  | $U^{1}$ | Dest ${ }^{1}$ | RAM Address |  |  |  |
| ROTR2 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 01 | 0 to 15 | $\begin{aligned} & 0000 \\ & 0001 \end{aligned}$ | RTAR RTDR | $\begin{aligned} & \mathrm{ACC} \\ & \mathrm{D} \end{aligned}$ | RAM RAM | $\begin{gathered} 00000 \\ 11111 \\ \hline \end{gathered}$ | $\begin{gathered} \text { R00 } \\ \times 33 \\ \text { R } \end{gathered}$ |  |  |
| Instruction | B/W | Quad | n |  |  |  |  |  |  | $\mathbf{U}^{1}$ | Dest ${ }^{1}$ |
| ROTNR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | 0 to 15 | 1100 |  |  |  | $\begin{aligned} & 11000 \\ & 11001 \\ & 11100 \\ & 11101 \end{aligned}$ | RTDY <br> RTDA <br> RTAY <br> RTAA | D <br> D <br> ACC <br> ACC | Y Bus ACC Y Bus ACC |

## Note 1: $\begin{aligned} & U=\text { Source } \\ & \text { Dest }\end{aligned}=$ Destination

Y BUS AND STATUS - ROTATE BY $\boldsymbol{n}$ BITS INSTRUCTIONS

| Instruction | Opcode | B/W | Y - Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | $\mathbf{N}$ | C | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROTR1 ROTR2 ROTNR |  | $1=W$ | $\mathrm{Y}_{\mathrm{i} \leftarrow} \mathrm{SRC}_{(i-n) \bmod 16}$ | NC | NC | NC | NC | 0 | SRC ${ }_{15-n}$ | 0 | U |
|  |  | $0=B$ | $Y_{i \leftarrow}-S R C_{i+8}=\operatorname{SRC}_{(i-n) \bmod 8}$ for $i=0$ to 7 | NC | NC | NC | NC | 0 | $\mathrm{SRC}_{8-n}$ | 0 | U |

## SRC = Source

## $U=$ No Change

$0=$ Reset
$1=$ Set
$i=0$ to 15 when not specified

## ROTATE AND MERGE INSTRUCTION

The Rotate and Merge Instructions contain five indicators: byte or word mode, rotated source, non-rotated source/ destination, mask and the number of bit positions a source is to be rotated. The function performed by the Rotate and Merge instruction is illustrated in Figure 5. The rotated source, $U$, is rotated up by the Barrel Shifter $n$ places. The mask input then selects, on a bit by bit basis, the rotated $U$ input or $R$
input. A ZERO in bit $i$ of the mask will select the $i^{\text {th }}$ bit of the R input as the $i^{\text {th }}$ output bit, while ONE in bit $i$ will select the $i^{\text {th }}$ rotated $U$ input as the output bit. The output word is stored in the non-rotated operand location. The $N$ and $Z$ bits are affected. The OVR and $C$ bits of the Status register are forced to ZERO. An example of this instruction is given in Figure 6.

ROTATE AND MERGE FIELD DEFINITIONS:


EXAMPLE: $\mathrm{n}=4$, Word Mode

| U | 0011 | 0001 | 0101 | 0110 |
| :--- | :--- | :--- | :--- | :--- |
| Rotated U | 0001 | 0101 | 0110 | 0011 |
| R | 1010 | 1010 | 1010 | 1010 |
| Mask (S) | 0000 | 1111 | 0000 | 1111 |
| Destination | 1010 | 0101 | 1010 | 0011 |

Figure 6. Rotate and Merge Example.

Figure 5. Rotate and Merge Function.

| ROTATE AND MERGE INSTRUCTION |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | B/W | Quad | n |  |  | $u^{1}$ | R/De |  |  | RAM | dress |
| ROTM | $\begin{aligned} & 0=\mathrm{B} \\ & 1=\mathrm{w} \end{aligned}$ | 01 | 0 to 15 | $\begin{aligned} & \hline 0111 \\ & 1000 \\ & 1001 \\ & 1010 \\ & 1100 \\ & 1110 \\ & \hline \end{aligned}$ | MDAI <br> MDAR <br> MDRI <br> MDRA <br> MRAI | $\begin{aligned} & \hline \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \text { ACC } \\ & \text { RAM } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ACC } \\ & \text { ACC } \\ & \text { RAM } \\ & \text { RAM } \\ & \text { AAM } \end{aligned}$ | I RAM 1 ACC 1 | $\begin{gathered} 00000 \\ 11111 \end{gathered}$ | $\begin{aligned} & \text { R00 } \\ & \text { R } \\ & \text { R1 } \end{aligned}$ | RAM Reg 00 RAM Reg 31 |

Note 1. $\quad U=$ Rotated Source
R/Dest = Non-Rotated Source and Destination
S = Mask
Y bus and status - rotated merge

| Instruction | Opcode | B/W | Y - Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROTM |  | 1=W | $\mathrm{Y}_{\mathrm{i}} \leftarrow(\text { Non Rot Op })_{\mathrm{i}} \cdot(\overline{\text { mask }})_{\mathrm{i}}+$ (Rot Op) ${ }_{(i-n) \bmod 16 \cdot(\text { mask })_{i}}$ | NC | NC | NC | NC | 0 | U | 0 | U |
|  |  | $0=B$ | $\mathrm{Y}_{\mathrm{i}}+(\text { Non Rot Op })_{i} \cdot(\overline{\text { mask }})_{i}+$ (Rot Op) (i $_{\mathrm{i}-\mathrm{n}) \bmod 8^{\cdot}(\text { mask })_{i}}$ | NC | NC | NC | NC | 0 | U | 0 | U |

## $\mathrm{U}=$ Update

NC = No Change
$0=$ Reset
1 = Set
$\mathrm{i}=0$ to 15 when not specified

## ROTATE AND COMPARE INSTRUCTIONS

The Rotate and Compare Instructions contain five indicators: byte or word mode, rotated source, non-rotated source, mask, and the number of bit positions the rotated source is to be rotated up. Under the control of instruction inputs, the function performed by the Rotate and Compare instruction is illustrated in Figure 7. The rotated operand is rotated by the Barrel Shifter n places. The mask is inverted and ANDed on a bit-by-bit basis
with the output of the Barrel Shifter and R input. Thus, a ONE in the mask input eliminates that bit from the comparison. A ZERO allows the comparison. If the comparison passes, the Zero flag is set. If it fails, the Zero flag is reset. The $N$ and $Z$ bit are affected. The OVR and C bits of the Status register are forced to ZERO. An example of this instruction is given in Figure 8.

ROTATE AND COMPARE FIELD DEFINITIONS


EXAMPLE: $\mathrm{n}=4$, Word Mode

| U | 0011 | 0001 | 0101 | 0110 |
| :--- | :--- | :--- | :--- | :--- |
| U Rotated | 0001 | 0101 | 0110 | 0011 |
| R | 0001 | 0101 | 1111 | 0000 |
| Mask (S) | 0000 | 0000 | 1111 | 1111 |
| Z (status) $=1$ |  |  |  |  |

Figure 8. Rotate and Compare Examples.

Figure 7. Rotate and Compare Function.

| ROTATE AND COMPARE INSTRUCTIONS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction <br> ROTC | $\begin{gathered} B / W \\ 0=B \\ 1=W \end{gathered}$ | Quad01 | $n$0 to 15 |  |  | $\mathbf{U}^{\mathbf{1}}$DDDRAM | $\mathbf{R}^{1}$ <br> ACC <br> RAM <br> RAM <br> ACC | $\mathbf{s}^{\mathbf{1}}$1ACC1 | RAM Address |  |  |  |  |  |  |
|  |  |  |  | 0010 0011 0100 0101 | $\begin{aligned} & \hline \text { CDAI } \\ & \text { CDRI } \\ & \text { CDRA } \\ & \text { CRAI } \\ & \hline \end{aligned}$ |  |  |  | $\begin{gathered} 00000 \\ \cdots \\ 11111 \end{gathered}$ |  |  | RAM Reg 00 ... RAM Reg 31 |  |  |  |
| Note 1. $\begin{aligned} & U=\text { Rotated Source } \\ & R=\text { Non-Rotated Source } \\ & S=\text { Mask } \end{aligned}$ <br> Y BUS AND STATUS - ROTATE AND COMPARE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Instruction | Opcode | B/W |  |  | Bus |  | Flag3 | Flag2 | Flag1 |  | LINK | OVR | N | C | $\mathbf{Z}$ |
| ROTC |  | 1 = W | $Y_{i}-1$ <br> (Rot | Non Rot Op) $(i-n)$ | $\begin{aligned} & (\overline{\text { mask }})_{i} \oplus{ }_{i}^{\oplus} \\ & \sigma^{\cdot} \cdot(\mathrm{mask})_{i} \end{aligned}$ |  | NC | NC | NC |  | NC | 0 | U | 0 | U |
|  |  | $0=B$ | $\begin{aligned} & Y_{i}+(I) \\ & \text { (Rot } \end{aligned}$ | Non Rot $\mathrm{Op})(\mathrm{i}-\mathrm{n})$ | $\left(\begin{array}{l} (\text { mask }))^{\oplus} \\ (\text { mask }) \end{array}\right.$ |  | NC | NC | NC |  | NC | 0 | U | 0 | U |
| $\begin{aligned} & U=\text { Update } \\ & N C=N o \text { Change } \\ & 0=\text { Reset } \\ & 1=\text { Set } \\ & i=0 \text { to } 15 \text { when not specified } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## PRIORITIZE INSTRUCTION

The Prioritize Instructions contain four indicators: byte or word mode, operand source (R), mask source ( S ) and destination. They are further subdivided into two types. The function performed by the Prioritize instruction is shown in Figure 9. The R operand is ANDed with the complement of the Mask operand. A ZERO in the Mask operand allows the corresponding bit in the R operand to participate in the priority encoding function. A ONE in the Mask operand forces the corresponding bit in the R operand to a ZERO, eliminating it from participation in the priority encoding function.

The priority encoder accepts a 16 -bit input and produces a 5 bit binary-weighted code indicating the bit position of the highest priority active bit. If none of the inputs are active, the output is ZERO. In the Word mode, if input bit 15 is active, the output is 1, etc. Figure 10 lists the output as a function of the highest-priority active-bit position in both the Word and Byte mode. The $N$ and $Z$ bits are affected and the OVR and $C$ bits of the status register are forced to ZERO. The only limitation in this instruction is that the operand and the mask must be different sources.


Figure 9. Prioritize Function.
PRIORITIZE INSTRUCTION FIELD DEFINITIONS


WORD MODE BYTE MODE*

| Highest <br> Priority <br> Active Bit | Encoder <br> Output | Highest <br> Priority <br> Active Bit | Encoder <br> Output |
| :---: | :---: | :---: | :---: |
| None | 0 | None | 0 |
| 15 | 1 | 7 | 1 |
| 14 | 2 | 6 | 2 |
| $\vdots$ | 0 | 0 | $\vdots$ |
| 1 | 15 | 1 | 7 |
| 0 | 16 | 0 | 8 |

*Bits 8 through 15 do not participate.

Figure 10.

PRIORITIZE INSTRUCTION

| Instruction | B/W | Quad | Destination |  |  | Source (R) |  |  | RAM Address/Mask (S) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PRT1 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | $\begin{array}{r} 1000 \\ 1010 \\ 1011 \\ \hline \end{array}$ | $\begin{aligned} & \text { PRIA } \\ & \text { PR1Y } \\ & \text { PR1R } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { ACC } \\ & \text { Y Bus } \\ & \text { RAM } \\ & \hline \end{aligned}$ | $\begin{aligned} & 0111 \\ & 1001 \end{aligned}$ | $\begin{aligned} & \text { RPT1A } \\ & \text { PR1D } \end{aligned}$ | $\begin{aligned} & \mathrm{ACC} \\ & \mathrm{D} \end{aligned}$ | $\begin{gathered} 00000 \\ \because 1111 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { R00 } \\ & \text { R } 31 \\ & \hline \end{aligned}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B/W | Quad | Mask (S) |  |  | Destination |  |  | RAM Address/Source (R) |  |  |
| PRT2 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | $\begin{aligned} & 1000 \\ & 1010 \\ & 1011 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { PRA } \\ & \text { PRZ } \\ & \text { PRI } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { Acc } \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0000 \\ & 0010 \end{aligned}$ | $\begin{aligned} & \text { PR2A } \\ & \text { PR2Y } \end{aligned}$ | $\begin{aligned} & \text { ACC } \\ & Y \text { Bus } \end{aligned}$ | $\begin{gathered} 00000 \\ \ddot{11111} \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{R} 00 \\ \times \mathrm{R} 31 \end{gathered}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B/W | Quad | Mask (S) |  |  | Source (R) |  |  | RAM Address/Dest |  |  |
| PRT3 | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | $\begin{aligned} & 1000 \\ & 1010 \\ & 1011 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { PRA } \\ & \text { PRZ } \\ & \text { PRI } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { ACC } \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0011 \\ & 0100 \\ & 0110 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { PR3R } \\ & \text { PR3A } \\ & \text { PR3D } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { RAM } \\ & \text { ACC } \\ & \mathrm{D} \\ & \hline \end{aligned}$ | $\begin{gathered} 00000 \\ \because \ddot{1} 111 \\ \hline \end{gathered}$ | $\begin{gathered} \text { R00 } \\ \text { R31 } \\ \hline \end{gathered}$ | $\begin{array}{r} \text { RAM Reg } 00 \\ \text { RAM Reg } 31 \\ \hline \end{array}$ |
| Instruction | B/W | Quad | Mask (S) |  |  | Source (R) |  |  | Destination |  |  |
| PRTNR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | $\begin{aligned} & 1000 \\ & 1010 \\ & 1011 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { PRA } \\ & \text { PRZ } \\ & \text { PRI } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { ACC } \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0100 \\ & 0110 \end{aligned}$ | PRTA PRTD | $\begin{aligned} & \text { ACC } \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & 00000 \\ & 00001 \end{aligned}$ | NRY NRA | $Y$ Bus ACC |



## CRC INSTRUCTION

The CRC (Cyclic-Redundancy-Check) Instructions contain one indicator: address of a RAM register to use as the check sum register. The CRC instruction provides a method for generation of the check bits in a CRC calculation. Two CRC instructions are provided - CRC Forward and CRC Reverse. The reason for providing two instructions is that CRC standards do not specify which data bit is to be transmitted first, the LSB or the MSB, but they do specify which check bit must be transmitted first. Figure 11 illustrates the method used to generate these check bits for the CRC Forward function and

Figure 12 illustrates method used for the 2CRC Reverse function. The ACC serves as a polynominal mask to define the generating polynomial while the RAM register holds the partial result and eventually the calculated check sum. The LINK-bit is used as the serial input. The serial input combines with the MSB of the check-sum register, according to the polynomial defined by the polynomial mask register. When the last input bit has been processed, the check-sum register contains the CRC check bits. The LINK, N and Z bits are affected and the OVR and $C$ bits of the Status register are forced to ZERO.

## CYCLIC-REDUNDANCY-CHECK DEFINITIONS:



Figure 11. CRC Forward Function.


Figure 12．CRC Reverse Function．

| CYCLIC REDUNDANCY CHECK |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | B／W | Quad |  |  | RAM Address |  |  |
| CRCF | 1 | 10 | 0110 | 0011 | $\begin{gathered} \hline 00000 \\ \ldots \\ 11111 \\ \hline \end{gathered}$ | $\begin{gathered} \text { R00 } \\ \ldots \\ \text { R31 } \\ \hline \end{gathered}$ | RAM Reg 00 RAM Reg 31 |
| Instruction | B／W | Quad |  |  |  |  | Address |
| CRCR | 1 | 10 | 0110 | 1001 | $\begin{gathered} 00000 \\ \ldots \\ 11111 \\ \hline \end{gathered}$ | $\begin{gathered} \text { R00 } \\ \ldots \\ \text { R31 } \\ \hline \end{gathered}$ | RAM Reg 00 <br> RAM Reg 31 |

Y BUS AND STATUS－CYCLIC REDUNDANCY CHECK

| Instruction | Opcode | B／W | Y－Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | Z |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRCF |  | $1=W$ | $Y_{i} \leftarrow\left[\left(Q L I N K \oplus R_{15} M_{15}\right) \cdot A C C_{i}\right]$ <br> $\oplus$ RAM $_{i-1}$ for $i=15$ to 1 <br> $Y_{0}-\left[\left(Q L I N K \oplus R_{15}\right) \cdot A C C_{0}\right] \oplus 0$ | NC | NC | NC | RAM ${ }_{15}{ }^{*}$ | 0 | U | 0 | U |
| －CRCR |  | $1=W$ | $Y_{i} \leftarrow\left[\left(Q L I N K \oplus R_{A M}\right) \cdot A C C_{i}\right]$ <br> $\oplus$ RAM $_{i}+1$ for $i=14$ to 0 <br> $\mathrm{Y}_{15} \leftarrow\left[\left(\mathrm{QLINK} \oplus \mathrm{RAM}_{0}\right) \cdot \mathrm{ACC}_{15}\right] \oplus 0$ | NC ． | NC | NC | RAM ${ }^{*}{ }^{*}$ | 0 | U | 0 | U |
| $\begin{aligned} & \text { U = Update } \\ & N C=N o \text { Change } \\ & 0=\text { Reset } \\ & 1=\text { Set } \\ & i=0 \text { to } 15 \text { when not specified } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |

## STATUS INSTRUCTIONS

Status Instructions - The Set Status Instruction contains a single indicator. This indicator specifies which bit or group of bits, contained in the status register (Figure 13), are to be set (forced to a ONE).


Figure 13. Status Byte.
The Reset Status Instruction contains a single indicator. This indicator specifies which bit or group of bits, contained in the status register, are to be reset (forced to ZERO).

The Store Status Instruction contains two indicators; byte/ word and a second indicator that specifies the destination of the status register. The Store Status Instruction allows the status of the processor to be saved and restored later, which is an especially useful function for interrupt handling.

The status register is always stored in the lower byte of the RAM or the ACC register. Depending upon byte or word mode the upper byte is unchanged or loaded with all ZEROs respectively.

The Load Status instructions are included in the single operand and two operand instruction types.
The Test Status Instructions contain a single indicator which specifies which one of the 12 possible test conditions are to be placed on the Conditional-Test output. Besides the eight bits in the Status register (QZ, QC, QN, QOVR, QLINK, QFlag1, QFlag 2, and QFlag3), four logical functions (QN $\oplus$ QOVR, $(\mathrm{QN} \oplus \mathrm{QOVR})+\mathrm{QZ}, \mathrm{QZ}+\overline{\mathrm{QC}}$ and LOW may also be selected. These functions are useful in testing results of Two's Complement and unsigned number arithmetic operations. The status register may also be tested via the bidirectional T bus. The code to test the status register via $T$ bus is similar to the code used by instruction lines $I_{1}$ to $I_{4}$ as shown below. Instruction lines $1_{0}-4$ have priority over $T$ bus for testing the
status register on CT output. See the discussion on the status register for a full description.

| $\mathbf{T}_{\mathbf{4}}$ | $\mathbf{T}_{\mathbf{3}}$ | $\mathbf{T}_{\mathbf{2}}$ | $\mathbf{T}_{\mathbf{1}}$ | $\mathbf{C T}$ |
| :--- | :--- | :--- | :--- | :--- |
| $\mathbf{I}_{\mathbf{4}}$ | $\mathbf{I}_{\mathbf{3}}$ | $\mathbf{l}_{\mathbf{2}}$ | $\mathbf{l}_{\mathbf{1}}$ |  |
| 0 | 0 | 0 | 0 | $(\mathrm{~N} \oplus$ OVR $)+\mathrm{Z}$ |
| 0 | 0 | 0 | 1 | $\mathrm{~N} \oplus$ OVR |
| 0 | 0 | 1 | 0 | Z |
| 0 | 0 | 1 | 1 | OVR |
| 0 | 1 | 0 | 0 | LOW |
| 0 | 1 | 0 | 1 | C |
| 0 | 1 | 1 | 0 | $\mathrm{Z}+\overline{\mathrm{C}}$ |
| 0 | 1 | 1 | 1 | N |
| 1 | 0 | 0 | 0 | LINK |
| 1 | 0 | 0 | 1 | Flag1 |
| 1 | 0 | 1 | 0 | Flag2 |
| 1 | 0 | 1 | 1 | Flag3 |

## STATUS

|  | $\begin{array}{llllllllllll}15 & 14 & 13 & 12 & 98 & 8 & 5\end{array}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SETST | 0 | Quad | 1011 | 1010 | Opcode |
| RSTST | 0 | Quad | 1010 | 1010 | Opcode |
| SVSTR | B/W | Quad | 0111 | 1010 | RAM Address/Dest |
| SVSTNR | B/W | Quad | 0111 | 1010 | Destination |

## STATUS INSTRUCTIONS

| Instruction | B/W | Quad |  |  | Opcode |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SETST | 0 | 11 | 1011 | 1010 | $\begin{aligned} & \hline 00011 \\ & 00101 \\ & 00110 \\ & 01001 \\ & 01010 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { SONCZ } \\ & \text { SL } \\ & \text { SF1 } \\ & \text { SF2 } \\ & \text { SF3 } \\ & \hline \end{aligned}$ | ```Set OVR, N, C, Z Set LINK Set Flag1 Set Flag2 Set Flag3``` |
| Instruction | B/W | Quad |  |  | Opcode |  |  |
| RSTST | 0 | 11 | 1011 | 1010 | $\begin{aligned} & \hline 00011 \\ & 00101 \\ & 00110 \\ & 01001 \\ & 01010 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { RONCZ } \\ & \text { RL } \\ & \text { RF1 } \\ & \text { RF2 } \\ & \text { RF3 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { Reset OVR, N, C, Z } \\ & \text { Reset LINK } \\ & \text { Set Flag1 } \\ & \text { Set Flag2 } \\ & \text { Set Flag3 } \\ & \hline \end{aligned}$ |
| Instruction | B/W | Quad |  |  | RAM Address/Dest |  |  |
| SVSTR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 10 | 0111 | 1010 | $\begin{gathered} 00000 \\ \ddot{11111} \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{R} 00 \\ \ldots \\ \mathrm{R} 31 \\ \hline \end{gathered}$ | RAM Reg 00 RAM Reg 31 |
|  |  |  |  |  | Destination |  |  |
| SVSTNR | $\begin{aligned} & 0=B \\ & 1=W \end{aligned}$ | 11 | 0111 | 1010 | $\begin{aligned} & 00000 \\ & 00001 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { NRY } \\ & \text { NRA } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { Y Bus } \\ & \text { ACC } \\ & \hline \end{aligned}$ |



The NO-OP Instruction has a fixed 16 -bit code. This instruction does not change any internal registers in the Am29116. It preserves the status register, RAM register and the ACC register.

NO OPERATION FIELD DEFINITION

|  | $\begin{array}{llll}15 & 141312\end{array}$ |  |  | 98 | 54 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NOOP | 0 | 11 | 1000 | 1010 | 00000 |

NO-OP INSTRUCTION


SRC = Source
$\mathrm{U}=$ Update
NC = No Change
$0=$ Reset
$1=$ Set
$\mathrm{i}=0$ to 15 when not specified
*Y-Bus is undefined.

| SUMMARY OF MNEMONICS |  |  |  |
| :---: | :---: | :---: | :---: |
| Instruction | Type | Two Operand |  |
| SOR | Single Operand RAM | TORAA | Two Operand RAM, ACC to ACC |
| SONR | Single Operand Non-RAM | TORIA | Two Operand RAM, I to ACC |
| TOR1 | Two Operand RAM (Quad 0) | TODRA | Two Operand D, RAM to ACC |
| TOR2 | Two Operand RAM (Quad 2) | TORAY | Two Operand RAM, ACC to $Y$ Bus |
| TONR | Two Operand Non-RAM | TORIY | Two Operand RAM, I to $Y$ Bus |
| SHFTR | Single Bit Shift RAM | TODRY | Two Operand D, RAM to Y Bus |
| SHFTNR | Single Bit Shift Non-RAM | TORAR | Two Operand RAM, ACC to RAM |
| ROTR1 | Rotate n Bits RAM (Quad 0) | TORIR | Two Operand RAM, I to RAM |
| ROTR2 | Rotate $n$ Bits RAM (Quad 1) | TODRR | Two Operand D, RAM to RAM |
| ROTNR | Rotate n Bits Non-RAM | TODAR | Two Operand D, ACC to RAM |
| BOR1 | Bit Oriented RAM (Quad 3) | TOAIR | Two Operand ACC, I to RAM |
| BOR2 | Bit Oriented RAM (Quad 2) | TODIR | Two Operand D, I to RAM |
| BONR | Bit Oriented Non-RAM | TODA | Two Operand D, ACC |
| ROTM | Rotate and Merge | TOAI | Two Operand ACC, I |
| ROTC | Rotate and Compare | TODI | Two Operand D, I |
| PRT1 | Prioritize RAM; Type 1 | Single Bit Shift |  |
| PRT2 | Prioritize RAM; Type 2 | Single Bit |  |
| PRT3 | Prioritize RAM; Type 3 | SHRR | Shift RAM, Store in RAM |
| PRTNR | Prioritize Non-RAM | SHDR | Shift D, Store in RAM |
| CRCF | Cyclic Redundancy Check Forward | SHA | Shift ACC |
| CRCR | Cyclic Redundancy Check Reverse | SHD | Shift D |
| NOOP | No Operation | Rotate n Bits |  |
| SETST | Set Status | RTRA | Rotate RAM, Store in ACC |
| RSTST | Reset Status | RTRY | Rotate RAM, Place on $Y$ Bus |
| SVSTR | Save Status RAM | RTRR | Rotate RAM Store in RAM |
| SVSTNR | Save Status Non-RAM | RTAR | Rotate ACC, Store in RAM |
| TEST | Test Status | RTDR | Rotate D, Store in RAM |
| SOURCE AND DESTINATION |  | RTDY | Rotate D, Place on Y Bus |
| Single Operand |  | RTDA | Rotate D, Store in ACC |
|  |  | RTAY | Rotate ACC, Place on $Y$ Bus |
| SORA | Single Operand RAM to ACC | RTAA | Rotate ACC, Store in ACC |
| SORY | Single Operand RAM to $Y$ Bus |  | Rotate ACC, Store in ACC |
| SORS | Single Operand RAM to Status | Rotate and | Merge |
| SOAR | Single Operand ACC to RAM | MDAI | Merge Disjoint Bits of D and ACC Using |
| SODR | Single Operand D to RAM |  | I as Mask and Store in ACC |
| SOIR | Single Operand I to RAM | MDAR | Merge Disjoint Bits of D and ACC Using |
| SOZR | Single Operand 0 to RAM |  | RAM as Mask and Store in ACC |
| SOZER | Single Operand D(0E) to RAM | MDRI | Merge Disjoint Bits of D and RAM Using |
| SOSER | Single Operand D(SE) to RAM |  | I as Mask and Store in RAM |
| SORR | Single Operand RAM to RAM | MDRA | Merge Disjoint Bits of D and RAM Using |
| SOA | Single Operand ACC |  | ACC as Mask and Store in RAM |
| SOD | Single Operand D | MARI | Merge Disjoint Bits of ACC and RAM |
| SOI | Single Operand I |  | Using I as Mask and Store in RAM |
| SOZ | Single Operand 0 | MRAI | Merge Disjoint Bits of RAM and ACC |
| SOZE | Single Operand $D(0 E)$ |  | Using I as Mask and Store in ACC |
| SOSE | Single Operand $\mathrm{D}(\mathrm{SE})$ | Rotate and |  |
| NRY | Non-RAM Y Bus |  | Compare |
| NRA | Non-RAM ACC | CDAI | Compare Unmasked Bits of D and ACC |
| NRS | Non-RAM Status |  | Using I as M |
| NRAS | Non-RAM ACC, Status |  |  |
|  |  | Mnemonics co Advanced Mic | pyright © 1980 ro Devices, Inc. |



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Case) Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential ... -0.5 V to +7.0 V DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max
DC Input Voltage $\qquad$ . .0 .5 V to +5.5 V
DC Output Current, Into Outputs $\qquad$
DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
0
Temperature

4.75 V to
Supply Voltage
Supply Voltage +4.75 V to +5.25 V +4.75 V to +5.25 V
Military (M) DevicesTemperature$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$Supply Voltage ............................. +4.5 V to +5.5 VOperating ranges define those limits over which the function-ality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\begin{aligned} & Y_{0-5} \\ & T_{1-4} \\ & C T \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-1.6 \mathrm{~mA} /-1.2 \mathrm{~mA} \\ & \left(\mathrm{COM} \mathrm{~L}^{\prime} / \mathrm{MIL}\right) \end{aligned}$ | 2.4 |  |  | Volts |
| 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}$ | $\begin{aligned} & \mathrm{Y}_{0-15} \\ & \mathrm{~T}_{1-4} \\ & \mathrm{CT} \end{aligned}$ | $\mathrm{lOL}=16 \mathrm{~mA} / 12 \mathrm{~mA}$ (COM'L/MIL) |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Guaranteed Input Logical HIGH Voltage (Note 6) |  | All Inputs |  | 2.0 |  |  | Volts |
| VIL | Guaranteed Input Logical LOW Voltage (Note 6) |  | All Inputs |  |  |  | 0.8 | Voits |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$ | All Inputs | $\underline{I N}=-18 \mathrm{~mA}$ |  | . | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{\text {IN }}=0.5 \text { Volts } \\ & \text { (Note 4) } \end{aligned}$ | IEN SRE DLE $10-4$ $l_{5.15}$ $O E T$ $O E Y$ $C P$ $T_{1-4}$ $Y_{0-15}$ |  |  |  | $\begin{aligned} & -0.50 \\ & -0.50 \\ & -1.00 \\ & -1.00 \\ & -0.50 \\ & -0.50 \\ & -0.50 \\ & -1.50 \\ & -0.55 \\ & -0.55 \end{aligned}$ | mA |
| IH | Input HIGH Current | $\begin{aligned} & V_{C C}=\text { MAX } \\ & V_{\mathbb{N}}=2.4 \text { Volts } \\ & \text { (Note 4) } \end{aligned}$ | $\overline{I E N}$ <br> $\overline{S R E}$ <br> $\overline{D L E}$ <br> $I_{0-4}$ <br> $I_{5-15}$ <br> $O E_{T}$ <br> $O E Y$ <br> $C P$ <br> $T_{1-4}$ <br> $Y_{0-15}$ |  |  |  | 50 <br> 50 <br> 100 <br> 100 <br> 50 <br> 50 <br> 50 <br> 150 <br> 100 <br> 100 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{IN}}=5.5 \text { Volts } \end{aligned}$ | All Inputs |  |  |  | 1.0 | mA |
| IOZH | Off State (HIGH Impedance) Output Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \text { Volts (Note 4) } \end{aligned}$ | $\begin{aligned} & T_{1-4} \\ & Y_{0-15} \\ & \hline \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozl | Off State (HIGH Impedance) Output Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \text { Volts (Note 4) } \end{aligned}$ | $\begin{aligned} & T_{1-4} \\ & Y_{0-15} \end{aligned}$ |  |  |  | -550 | $\mu \mathrm{A}$ |
| los | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}+0.5$ Volts $\mathrm{V}_{\mathrm{O}}=0.5$ Volts (Note 3) |  |  | -30 |  | -85 | mA |
|  |  |  | COM'L | $\begin{aligned} & \mathrm{T}_{\mathrm{AL}}=0 \text { to } 70^{\circ} \mathrm{C} \\ & \text { (Note 7) } \end{aligned}$ |  |  | 735 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  | 535 |  |
| Icc | Power Supply Current (Note 5) | $V_{C C}=$ MAX | MIL | $\begin{aligned} & \mathrm{TC}=-55 \text { to } 125^{\circ} \mathrm{C} \\ & \text { (Note 7) } \end{aligned}$ |  | . | 745 | mA |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  | 485 |  |

2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
3. $\mathrm{Y}_{0-15}, \mathrm{~T}_{1-4}$ are three-state outputs internally connected to TTL inputs. Input characteristics are measured under conditions such that the outputs are in the OFF state.
4. Worst case ICC is at minimum temperature.
5. These input levels provide zero noise immunity and should be tested only in a static, noise-free environment
6. Cold start.

## SWITCHING CHARACTERISTICS

GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE
( $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )

$\dagger$ Timing for immediate instruction for first cycle.
$\dagger \dagger$ Status register and accumulator destination only.

## Notes on Testing

Incoming test procedures on this device should be carefull planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failure due to $V_{C C}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground
cable may allow may allow the ground pin at the device to rise by 100s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathbb{I H}}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs, under license.

## SWITCHING CHARACTERISTICS (Cont.)

## GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE

$\left(T_{C}=-55\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )
A. Combinational Delays (nsec)

|  |  | Outputs |  |  |
| :--- | :--- | :---: | :---: | :---: |
|  |  | $\mathbf{T}_{1-4}$ | $\mathbf{C T}$ |  |
|  | $I_{0-4}$ (ADDR) | 100 | 103 | - |
|  | $I_{0-15}$ (DATA) | 100 | 103 | - |
|  | $I_{0-15}$ (INSTR) | 100 | 103 | 50 |
| Input | DLE | 68 | 70 | - |
|  | $T_{1-4}$ | - | - | 46 |
|  | $C P$ | 70 | 73 | 43 |
|  | $Y_{0-15}$ | 70 | 72 | - |
|  | IEN | - | - | 50 |

*Y0-15 must be stored in the Data Latch and its source disabled before the delay to $\mathrm{Y}_{0-15}$ as an output can be measured. **Guaranteed indirectly by other tests.
B. Enable/Disable Times (nsec)
( $C_{L}=5 \mathrm{pF}$ for disable only)

| From Input | To Output | Enable |  | Disable |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{t P Z L}_{\mathbf{P Z}}$ | $\mathbf{t p H Z}$ | $\mathbf{t P L Z}$ |  |
|  | $Y_{0-15}$ | 25 | 25 | 25 | 25 |
| $\mathrm{OE}_{\mathrm{T}}$ | $T_{1-4}$ | 30 | 30 | 30 | 30 |

C. Clock and Pulse Requirements (nsec)

| Input | Min Low Time | Min High Time |
| :---: | :---: | :---: |
| CP | 25 | 50 |
| DLE | - | 20 |
| IEN | 26 | - |

D. Set-up and Hold Times (nsec)

| Input |  | High-to-Low Transition |  | Low-to-High Transition |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | With Respect to | Set-up | Hold | Set-up | Hold |  |  |
| 10-4 (RAM ADDR) | - CP | ( $\mathrm{t}_{\mathbf{1} 1}$ ) 24 | ( $\mathrm{th}_{1}$ ) 0 | - | - |  | Single ADDR (Source) |
| I0-4 (RAM ADDR) | CP and $\overline{E E N}$ both LOW | ( $\mathrm{t}_{\mathbf{2} 2}$ ) 10 | Do Not Change |  | (th7) 0 |  | Two ADDR (Destination) |
| 10-15 (DATA) | CP | - | - | ( $\mathrm{t}_{88}$ ) 76 | (th8) 3 |  |  |
| 10-15 (INSTR) | CP | $\left(\mathrm{t}_{\text {s }}\right)+57$ | $\left(t_{\text {h }}\right.$ ) $\dagger 17$ | $\left(\mathrm{t}_{\text {s }}\right) 76$ | (th9) 3 |  |  |
| $\overline{\text { IEN HIGH }}$ | CP | ( $\mathrm{t}_{54}$ ) 10 | - | - | (th10) 1 |  | Disabie |
| IEN LOW | CP | - ( $\mathrm{t}_{5}$ ) 20 | $\cdots \quad\left(t_{n}\right) \dagger$ ¢ | $\left(t_{\text {s11 }}\right) 28-$ | $\left(t_{n 11}\right)+\dagger 1$ | - | EnableImmediate <br> first cycle |
| SRE | CP | - | - | $\left(\mathrm{t}_{\text {1 }}\right) 19$ | (th12) 0 |  |  |
| $Y$ | CP | - | - | $\left(\mathrm{t}_{\mathrm{s} 13}\right) 50$ | (th13) 2 |  |  |
| $Y$ | DLE | ( $\mathrm{t}_{\text {S } 6}$ ) 11 | (th6) 7 | - | - |  |  |
| DLE | CP | - | - | $\left(\mathrm{t}_{\text {s14 }}\right) 50$ | (th14) 0 |  |  |

$\dagger$ Timing for immediate instruction for first cycle.
$\dagger \dagger$ Status register and accumulator destination only.


## DOUBLE ADDRESS ACCESS TIMING



## IMMEDIATE INSTRUCTION CYCLE TIMING



## Am29116A/29L116A

## A High-Performance 16-Bit Bipolar Microprocessor

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Second Generation of the Am29116 16-Bit Microprocessor
Internal ECL circuitry and second generation of Ion implanted Oxide-Isolated (IMOX ${ }^{\mathrm{TM}}$ ) process technology are combined to provide a faster version of the Am29116 and a lower power version of the 29116
- Plug-in Replacement for the Am29116

The Am29116A and Am29L116A are pin-for-pin replacements for the Am29116

- Improved Speed

The 29116A has $25-30 \%$ speed improvement on the critical paths relative to Am29116

- Reduced Power

The 29L116A operates at reduced power requirements and compatible performace relative to the 29 L116

## GENERAL DESCRIPTION

The Am29116A/L116A microprogrammable 16-bit bipolar microprocessors were fabricated using the second generation of AMD's IMOX process technology. The architectures of the Am29116A/L116A are identical to the Am29116's, optimized for high-performance peripheral controllers such
as graphics controllers, disk controllers, communication controllers, front-end concentrators and modems. The Am29116A is also extremely suitable for high-speed, gen-eral-purpose 16 -bit CPU applications when combined with the Am29517A $16 \times 16$ mulliplier.


## Am29117

## A High-Performance 16-Bit Bipolar Microprocessor

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Optimized for High-Performance Controllers Architecture and instruction set optimized for highperformance, intelligent controllers
- Flow-Through Architecture

Separate input and output ports avoid bus turnaround for higher throughput

- 32 Working Registers

Contains 32 working registers with latched outputs

- Fast

Supports 100 ns microcycle time $/ 10 \mathrm{MHz}$ data rate for all instructions

- 16-Bit Barrel Shifter

Contains a 16-bit Barrel Shifter which can shift or rotate a word up to 15 positions in a single instruction cycle

- 68-Pin Pin Grid Array Package


## GENERAL DESCRIPTION

The Am29117 is a microprogrammable 16-bit bipolar microprocessor whose architecture and instruction set are identical to the Am29116's except for the I/O bus structure. Since the device has separate input and output ports, designers can avoid quick bus turnaround requirements.

The architecture and instruction set are not only optimized for high-performance peripheral controllers, but also suit-
able for microprogrammed processor applications when combined with the Am29517A $16 \times 16$ multiplier.

The instruction set contains unique functions besides ordinary logic and arithmetic functions: bit manipulation instructions (set, reset and test), rotate merge/compare instructions, prioritize instruction and CRC instruction.


## Am29118

Eight-Bit Am29116 I/O Support

## DISTINCTIVE CHARACTERISTICS

- Eight-bit bidirectional I/O port
- Reads both registers on A-port
- Separate clock, clock enable and three-state output enable to synchronize data between two bidirectional buses
- 24mA output current sink capability
- 24-pin slim package
- Additional accumulator to support certain Am29116 applications.


## GENERAL DESCRIPTION

The Am29118 is an eight-bit wide bidirectional parallel data input/output port designed to provide an additional accumulator when used with the Am29116 or with any microprocessor with single bidirectional data port. In addition, it can
be used as a parallel data input/output port, like the Am2952. The Am29118 is a metal mask option of the Am2952A, and so requires no additional pins to support the Am29116 input/output structure.

## BLOCK DIAGRAM



Figure 1

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29116 | High Performance 16-Bit Bipolar <br> Microprocessor |
| Am2910A | Microprogram Controller |
| Am2914 | Vectored Priority Interrupt Controller |
| Am2925 | System Clock Generator and Driver |
| Am2940/2 | DMA Address Generator |
| Am2950-3 | 8-Bit Bidirectional I/O Ports |
| Am29800 <br> Family | High Performance Bus Interface |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am29118

$\stackrel{L}{\text { B }}$ Screening Option
Blank - Standard processing B - 96 hour Burn-in
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-24-pin CERDIP X - Dice

Device type
8-Bit Am29116 I/O Support


Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | A0-7 |  | Eight bidirectional lines carrying the R Register inputs or outputs or S Register outputs. |
|  | B0-7 |  | Eight bidirectional lines carrying the S Register inputs or R Resister outputs. |
|  | CPR |  | The clock for the R Register. When CER is LOW and OEAS is HIGH data is entered into the R Register on the LOW-to-HIGH transition of the CPR signal. |
|  | CER |  | The Clock Enable for the R Register: When CER is LOW and OEAS is HIGH data is entered into the R Register on the LOW-to-HIGH transition of the CPR signal. When CER is HIGH, the R Register holds its contents, regardless of CPR signal transitions. |
|  | OEBR |  | The Output Enable for the R Register. When OEBR is LOW, the R Register three-state outputs are enabled onto the B0-7 lines. When OEBR is HIGH, the R Register outputs are in the high-impedance state. |
|  | CPS |  | The clock for the S Register. When $\overline{\text { CES }}$ is LOW, data is entered into the S Register on the LOW-to-HIGH transition of the CPS signal. |
|  | CES |  | The clock enable for the S Register. When CES is LOW, data is entered into the S Register on the LOW-to-HIGH transition of the CPS signal. When CES is HIGH, the S Register holds its contents, regardless of CPS signal transitions. |
|  | OEAS |  | The output enable for the S Register. When OEAS is LOW, the R or S Register three-state outputs are enabled onto the A0-7 lines. When OEAS is HIGH, the S Register outputs are in the high-impedance state. |

## DETAILED DESCRIPTION

The Am29118 has two eight-bit wide registers (R-Register and S-Register) connected back to back for moving data in both directions between two buses. The R-Register serves the dual purpose of transmitting data from one bus (device's internal bus) to another (system bus), and serving as an additional accumulator for the Am29116.

The accumulator function is implemented by allowing the Aport to provide read and write data from the R-Register and read data from the S-Register; the B-port provides read data for the R-Register and write data for the S-Register (similar to the Am2952). This additional function in the Am29118 is implemented with a two-input multiplexer, as shown in Figure 1. Each register has an individual clock ( $C P_{R}$ and $C P_{S}$ ), a Clock Enable, ( $\overline{\mathrm{CE}}_{\mathrm{R}}$ and $\overline{\mathrm{CE}}_{\mathrm{S}}$ ), and a three-state Output

Enable ( $\overline{O E}_{A S}$ and $\overline{O E}_{B R}$ ). The clock enable signal for the $R$ Register ( $\overline{C E}_{R}$ ) and the Output Enable Signal for the S Register ( $\overline{\mathrm{OE}}_{\mathrm{AS}}$ ) are encoded to make the R-Register an accumulator, in addition to all the Am2952 functions as shown in Table 1. Recause of this encoding, transferring data from the S-Register to the R-Register is not permissible.

TABLE 1.

| $\overline{\mathbf{O E}}_{\mathbf{A S}}$ | $\overline{\mathbf{C E}}_{\mathbf{R}}$ | Function |
| :---: | :---: | :--- |
| $L$ | $L$ | Read R, Disable $\mathrm{CP}_{\mathbf{R}}$ |
| $L$ | $H$ | Read S, Disable $\mathrm{CP}_{\mathrm{R}}$ |
| $H$ | $L$ | Enable $C P_{R}$ |
| $H$ | $H$ | Disable $\mathrm{CP}_{R}$ |

## APPLICATIONS

In the Am29116 system, there is only one I/O port available for data communication with the ALU. In such a system, the Am29118 acts as an additional accumulator (temporary storage) to increase performance, and also provides capability of a bidirectional I/O port (like the Am2952).

Figure 2 shows the connections necessary for the Am29118 to be used as an accumulator as well as a bidirectional I/O port. The A-port is connected to the Y-bus (internal bus) of the Am29116, and B-port is connected to the system data bus. Four microcode are used for source and destination control for the Y -bus and the system data bus. Figure 3 shows the timing waveforms to modify an accumulator (R-Register) in two microcycles. During the first cycle, data is read from the RRegister, modified in the Am29116 and stored in one of the internal registers. A two-address architecture is required if the second operand to modify the R-Register is in one of the RAM registers, and the result has to be stored in another RAM register. For stable operation, data from the R-Register is latched in the D-Latch halfway through the clock during the
first cycle. The instruction is executed and the result stored into a scratchpad register. In the second cycle, data is moved from the internal result register to the R-Register of the Am29118.

Figure 4 shows the timing waveforms to modify an accumulator (R-Register) in a single microcycle. In the first half of the cycle the source register is enabled on the Y -bus into the D Latch of the Am29116. The D-Latch is transparent during the first half of the cycle. In the second half of the cycle, data is latched in the D-Latch and the bus source is disabled. During the second half of the cycle, the output buffer of the Am29116 is enabled to bring the result on the Y -bus to be loaded into the destination. These two techniques provide different advantages and disadvantages to modify the external accumulator using the Am29116. The first technique (Figure 3) takes two microcycles but allows a shorter microcycle time. The second technique (Figure 4) takes only one microcycle but needs a longer microcycle time.

There is also a requirement for the system bus to transfer data as input to the Am29116. The S-Register is used in this case to receive data from the system bus (like the Am2952).


Figure 2. System Configuration.


Figure 3. Timing Waveforms for Modifying R-Register in Two Microcycles using the Am29116.


Figure 4. Timing Waveforms for Modifying R-Register using the Am29116.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature under Bias........ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$
$\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ -0.5 V to +5.5 V
DC Output Current, into Outputs ................ 30mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

## Commercial (C) Devices

Temperature
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

## Military (M) Devices

Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage $\qquad$
$\qquad$ .+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | 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}$ | $A_{0-7}, B_{0-7}$ | $\mathrm{MIL}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  |  | COM'L, $\mathrm{I} \mathrm{OL}=-6.5 \mathrm{~mA}$ | 2.4 | 3.4 |  |  |
| $\mathrm{VOL}^{\text {O }}$ | 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{A}_{0-7}, \mathrm{~B}_{0-7}$ | $\mathrm{MIL}, \mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{lOL}=24 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  | -115 | Volts |
| IIL | Input LOW Current | $V_{C C}=M A X, V_{I N}=0.5 V$ |  | $\mathrm{A}_{0-7}, \mathrm{~B}_{0-7}$ |  |  | -250 | $\mu \mathrm{A}$ |
|  |  |  |  | Others |  |  | -360 | $\mu \mathrm{A}$ |
| IIH | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  | $\mathrm{A}_{0-7, \mathrm{~B}_{0-7}}$ |  |  | 70 | $\mu \mathrm{A}$ |
|  |  |  |  | Others |  |  | 20 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=$ | . 5 V |  |  |  | 1.0 | mA |
|  |  |  |  | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  | 70 |  |
| 10 | Leakage Current | $V_{C C}=M A X$ | $A_{0-7}, B_{0-7}$ | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -250 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -30 |  | -85 | mA |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | 156 | 263 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |  |  | 275 |  |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | M'L | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |  |  | 228 | mA |
|  | (Notes 4, 5) |  |  | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |  |  | 309 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  | 202 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is measured with all inputs at 4.5 V and all outputs open.
5. Worst case ICC is at minimum temperature.

## SWITCHING CHARACTERISTICS PRELIMINARY

The tables below define the Am29118 switching characteristics. Tables A are setup and hold times relative to a clock LOW-to-HIGH transition. Tables B are propagational delays. Tables C are pulse-width requirements. Tables D are enable/disable times. All measurements are made at 1.5 V with input levels at 0 or 3 V . All values are in ns with $R_{L}$ on $A_{i} a_{n d} B_{i}=220 \Omega$ and $R_{L}$ on $F S$ and $\mathrm{FR}=300 \Omega . \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ except output disable times which are specified at $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$.

## GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE

$\left(\mathrm{T}_{\mathrm{A}}=0\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )
A. Setup and Hold Times

| Input | With Respect to | $\mathrm{t}_{5}$ | th |
| :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0-7}$ | CPR I | 7 | 5 |
| $\mathrm{B}_{0-7}$ | CPS If | 7 | 5 |
| $\overline{\mathrm{CE}}$ S | CPS 5 | 7 | 4 |
| ${ }^{\text {CE }}$ | CPR I | 7 | 4 |

C. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS | 20 | 20 |
| CPR | 20 | 20 |

B. Propagation Delays

| Input | $\mathbf{A}_{\mathbf{0}-\mathbf{7}}$ | $\mathbf{B}_{\mathbf{0}-\mathbf{7}}$ |
| ---: | :---: | :---: |
| CPS I | 24 | - |
| CPR I | - | 24 |

D. Enable/Disable Times

| From | To | Disable | Enable |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}_{\mathrm{AS}}$ | $\mathrm{A}_{0-7}$ | 22 | 27 |
| $\overline{\mathrm{OE}}_{\mathrm{BR}}$ | $\mathrm{B}_{0-7}$ | 22 | 27 |

GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE
$\left(T_{C}=-55\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ )
A. Setup and Hold Times

| Input | With <br> Respect to | $\mathbf{t}_{\mathbf{s}}$ | $\mathbf{t}_{\mathbf{h}}$ |
| :--- | :---: | :---: | :---: |
| $A_{0-7}$ | CPR J |  |  |
| $B_{0-7}$ | CPS J |  |  |
| $\overline{C E}$ | CPS J |  |  |
| $\overline{C E_{R}}$ | CPR J |  |  |

C. Pulse-Width Requirements

| Input | Min LOW <br> Pulse Width | Min HIGH <br> Pulse Width |
| :---: | :---: | :---: |
| CPS |  |  |
| CPR |  |  |

B. Propagation Delays

| Input | $\mathbf{A}_{\mathbf{0}-7}$ | $\mathbf{B}_{0-7}$ |
| :---: | :---: | :---: |
| CPS I |  |  |
| CPR I |  |  |

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{I H}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leq 0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geq 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform $D C$, Function, and $A C$ tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs under license.

## Am29PL141

## Fuse Programmable Controller (FPC)

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

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


## GENERAL DESCRIPTION

The Am29PL141 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
self-contained 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.

## CONNECTION DIAGRAM <br> Top View D-28-1

| SDO/ZERO | 102345678891011121314 | 28 | $\square v_{c c}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{P}[0] \square$ |  | 27 | $\square \mathrm{CLK}$ |
| $\mathrm{P}[1]$ |  | 26 | CC/SD |
| $P[2]$ |  |  |  |
|  |  | 25 |  |
| $P[3]$ |  | 24 | $T[1]$ |
| $P[4]$ |  | 23 | $\square \mathrm{T}$ [2] |
| $P[5]$ |  | . 22 | T |
|  |  |  |  |
| MODE/P[6] |  | 21 | T[4] |
| DCLK/P[7] |  | 20 | T[5] |
| $\mathrm{P}[8] \square$ |  | 19 | $\square$ RESET |
| $\mathbf{P}[9]$ |  | 18 | $\square \mathrm{P}$ [15] |
| $P[10]$ |  | 17 | [14] |
| $\mathrm{P}[11]$ |  | 16 |  |
|  |  |  |  |
| GND $\square$ |  | 15 | P[12] |

CDR04480

Note: Pin 1 is marked for orientation
Figure 2.

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 26 | CC[SDI] | 1 | Condition code test input. When the TEST (P[24:22]) field of the executing microinstruction is set to 6 (binary 110), CC is selected to be the conditional input. (Note: In the SSR diagnostic configuration, CC is also the Serial Data Input SDI.) |
| 27 | CLK | 1 | Clock. The rising edge clocks the microprogram counter, count register, subroutine register, pipeline register, and EQ flag. |
|  | P [15:8] | 0 | Upper eight, general-purpose microprogram control outputs. They are enabled by the OE signal from the microprogram pipeline register. When OE is High, P[15:8] are enabled, and when LOW, $\mathrm{P}[15: 8]$ are three-stated. |
|  | $\begin{aligned} & \text { P[7:0] } \\ & \text { [DCLK, } \\ & \text { MODE] } \end{aligned}$ | 0 | Lower eight, general-purpose microprogram control outputs. They are permanently enabled. (Note: in the SSR diagnostic configuration, $\mathrm{P}[7]$ becomes the diagnostic clock input DCLK and P[6] becomes the diagnostic control input MODE.) |
| 19 | RESET | 1 | Synchronous reset input. When it is Low, the output of the PC MUX is forced to the uppermost microprogram address (63). On the next rising clock edge, this address (63) is loaded into the microprogram counter; the microinstruction at location 63 is loaded into the pipeline register and the EQ flag is cleared. |
|  | T[5:0] | 1 | Test inputs. In conditional microinstructions, the inputs can be used as individual condition codes selected by the TEST field in the pipeline register. The T[5:0] inputs can also be used as a branch address when performing a microprogram branch, or as a count value. |
| 1 | $\begin{aligned} & \overline{\text { ZERO }} \\ & \text { [SDO] } \end{aligned}$ | 0 | Zero output. A Low state indicates that the CREG value is zero. (Note: In the SSR diagnostic configuration, $\overline{\text { ZERO }}$ becomes the Serial Data Output SDO. This change is only on the output pin; internally, the zero detect function is unchanged. |

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am29PL141
    D C
        Blank - Standard processing
        B - 96 Hour Burn-in
    Temperature (See Operating Range)
        C - Commercial (0}\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+7\mp@subsup{0}{}{\circ}\textrm{C}
        M - Military (-55 % to +125 % C)
```

Package

- 28-pin CERDIP
$X$ - Dice
Device Type
Fuse Programmable Controller



## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## DETAILED 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 Register (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 (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 (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 OE is programmed as a LOW. The lower eight control bits (P[7 : 0]) are always enabled. The microword and general microinstruction format are shown in Figure 4.


BDR02330

Figure 3. Am29PL141 Block Diagram.
*Note: These pins available only in SSR mode.
**Note: These pins available only in normal mode.

The general microinstruction format is shown below:

## Am29PL141 General Microinstruction Format



DFR00730
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.

## TEST[2:0]

| 000 | $\mathrm{~T}[0]$ |
| :--- | :--- |
| 001 | $\mathrm{~T}[1]$ |
| 010 | $\mathrm{~T}[2]$ |
| 011 | $\mathrm{~T}[3]$ |
| 100 | $\mathrm{~T}[4]$ |
| 101 | $\mathrm{~T}[5]$ |
| 110 | CC |
| 111 | EQ |

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

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

## MICROADDRESS CONTROL LOGIC

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

```
PC MUX - The microprogram counter multiplexer
\(P\) CNTR - Microprogram counter (PC) and incrementer
    \((\mathrm{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 ( $P C+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. 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. $\mathrm{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 SUBREG 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 not used in typical operation-each other. This allows the CREG to be an additional stack location when not used for counting, and the SREG to be a nested count location when not used as a stack location. Thus, the SREG and CREG can operate in three 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 (T[5: $0])$ masked by the DATA Field (P[21 : 16]). (This is represented by $\mathrm{T}^{*} \mathrm{M}$.)
2. It provides a branch address from the DATA Field in the pipeline register ( $\mathrm{P}[21$ : 16]) or from the TEST inputs
(T[5 : 0]) masked by the DATA Field (P[21 : 16]). (This is represented by $\mathrm{T}^{\star} \mathrm{M}$.)
3. It compares the TEST inputs
(T[5: 0]) masked by the DATA Field ( $\mathrm{P}[21: 16]$ ), called $T^{*} 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 field bits that correspond to marked test bits must be ZERO.

The EQ flag can be tested by the condition code selection logic. Multiple tests of any group of $T$ inputs 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 conditon inputs are the device inputs (CC and T[5:0]) and the EQ flag. The TEST field $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 conditon. 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.

The SSR diagnostics configuration activates a 32-bit-wide, Dtype 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 register 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.

TABLE 1.

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

*S7, S 6 are undefined. $\mathrm{S}_{15}-\mathrm{S}_{8}$ load from the source driving pins $\mathrm{P}[15]$ - $\mathrm{P}[8]$. If $\mathrm{P}[31]$ in the microword is a ONE, $\mathrm{S}_{15}$ - $\mathrm{S}_{8}$ are loaded from the pipeline register. If $\mathrm{P}[31]$ in the microword is a ZERO, $\mathrm{S}_{15}-\mathrm{S}_{8}$ are loaded from an external source.

## FUNCTION TABLE DEFINITIONS

## INPUTS

```
H= HIGH X = Don't Care
L = LOW }\quad\dagger=\mathrm{ LOW-to-HIGH transition
    \downarrow = \text { High-to-Low transition}
```

TABLE 2.

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

## PROGRAMMING AND VERIFICATION

The Am29PL141 FPC is programmed and verified using a simple algorithm that is almost identical to that used for AMD's Programmable Array Logic family. The internal programmable array of the Am29PL141 is organized as a 64 word by 32 bit (column) PROM. The fuse to be programmed is selected by its address (1 of 64), the byte at that address (1 of 4), and the bit in the byte ( 1 of 8 ). Control of programming and verifying is accomplished by applying a simple sequence of voltages on two control pins (CLK and CC).

The fuse address is selected using a full decode of the T[5: 0 ] inputs, where $T[5]$ is the MSB and $T[0]$ the LSB. The one of four byte addressing is done on the $\mathrm{P}[7]$ (MSB) and $\mathrm{P}[6]$ (LSB) outputs. The bit selection is done one output at a time by applying the programming voltage $\left(V_{O P}\right)$ to the output pin. The output pins that accept $V_{\text {OP }}$ are $\mathrm{P}[15$ : 8]. A graphical representation of the fuse array organization for programming, with fuse numbering compatible to the JEDEC standard programmable logic transfer format, is shown in Figure A.

The complete program and verify cycle timing is shown in Figure B. A programming sequence is initiated by raising the CLK pin to $\mathrm{V}_{\mathrm{HH}}$. This places the device in the program mode and disables the output pins so that they may be used as fuse addressing inputs. The next step is to address the fuse to be blown as previously stated. Note that bit selection, with VOP, should follow address and byte selection. Raising the CC pin to $\mathrm{V}_{\mathrm{HH}}$ initiates programming and lowering $\mathrm{V}_{\mathrm{OP}}$ terminates programming. Lowering the CLK pin to a TTL LOW level places the device in the fuse verification mode by enabling the programming outputs, $\mathrm{P}[15: 8]$. Following a clock pulse the fuse may be verified on the same output as bit selection was
performed. This scheme allows fuses to be verified in parallel as a byte if desired. The verification mode is terminated by lowering the CC pin back to a normal TTL level.

## SSR DIAGNOSTICS CONFIGURATION PROGRAMMING

One additional fuse (\#2048) is used to alter the configuration of the Am29PL141 to include on-chip SSR Diagnostics. This fuse is addressed by applying $V_{H H}$ to the RESET and $T[5]$, followed by $\mathrm{V}_{\mathrm{OP}}$ on pin $\mathrm{P}[15]$. To verify the diagnostic fuse, $\mathrm{P}[7]$ and $\mathrm{P}[6]$ must select byte \#3, i.e., $\mathrm{P}[7]$ must be low and $\mathrm{P}[6]$ must be high.

## PROGRAMMING YIELD

AMD programmable logic devices have been designed to insure extremely high programming yields ( $>98 \%$ ). To help insure that a part was correctly programmed, once the programming sequence is completed, the entire fuse array should be reverified at both low and high $V_{C C}\left(V_{C C L}\right.$ and $\mathrm{V}_{\mathrm{CCH}}$ ). Reverification can be accomplished in a verification only mode (CC at $\mathrm{V}_{\mathrm{HH}}$ ) by reading the outputs in parallel. This verification cycle checks that the array fuses have been blown correctly and can be sensed under varying conditions by the outputs.
AMD programmable logic devices 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 that is out of calibration, or improper usage of said equipment.


PFR00970
JEDEC FUSE NUMBER $=32($ FUSE ADDRESS $)+8(3-$ BYTE $)+(7-$ BIT $)$
Figure A. Programming Configuration.

| BYTE SELECT |  |  |
| :---: | :---: | :---: |
| BYTE | P[7] | P[6] |
| 0 | $H$ | L |
| 1 | $H$ | $H$ |
| 2 | L | L |
| 3 | L | H |


| BIT SELECT |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BIT | P[15] | P[14] | P [13] | P [12] | P [11] | P[10] | P[9] | P[8] |
| 0 | L | L | L | L | L | L | L | H |
| 1 | L | L | L | L | L | L | H | L |
| 2 | L | L | L | L | L | H | L | L |
| 3 | L | L | L | L | H | L | L | L |
| 4 | L | L | L | H | L | L | L | L |
| 5 | L | L | H | L | L | L | L | L |
| 6 | L | H | L | L | L | L | L | L |
| 7 | H | L | L | L | L | L | L | L |


| COLUMN DECODE |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :---: |
| 0 | C 0 | C 8 | C 16 | C 24 |  |
| 1 | C 1 | C 9 | C 17 | C 25 |  |
| 2 | C 2 | C 10 | C 18 | C 26 |  |
| 3 | C 3 | C 11 | C 19 | C 27 |  |
| 4 | C 4 | C 12 | C 20 | C 28 |  |
| 5 | C 5 | C 13 | C 21 | C 29 |  |
| 6 | C 6 | C 14 | C 22 | C 30 |  |
| 7 | C 7 | C 15 | C 23 | C 31 |  |


| FUSE ADDRESS DECODE |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FUSE ADDRESS | T[5] | T[4] | T[3] | T[2] | T[1] | T[0] |
| 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 | L |
| 21 | L | H | L | 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 | L | 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 |
| 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 | L |
| 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 |
| 44 | H | L | H | H | L | L |
| 45 | H | L | H | H | L | H |
| 46 | H | $L$ | H | H | H | L |
| 47 | H | L | H | H | H | H |
| 48 | H | H | L | L | L | L |
| 49 | H | H | L | L | L | H |
| 50 | H | H | L | L | H | L |
| 51 | H | H | L | L | H | H |
| 52 | H | H | L | H | L | L |
| 53 | H | H | L | H | L | H |
| 54 | H | H | L | H | H | L |
| 55 | H | H | L | H | H | H |
| 56 | H | H | H | L | L | L |
| 57 | H | H | H | L | L | H |
| 58 | H | H | H | L | H | L |
| 59 | H | H | H | L | H | H |
| 60 | H | H | H | H | L | L |
| 61 | H | H | H | H | L | H |
| 62 | H | H | H | H | H | L |
| 63 | H | H | H | H | H | H |



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $\ldots . . . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 28 to Pin 14) Continuous ............. -0.5 V to +7.0 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
DC Output Current, Into Outputs During
Programming (Max Duration of 1 sec )
..............200mA
DC Input Voltage ................................. 0.5 V to +5.5 V
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) DevicesTemperature .$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage

$\qquad$
+4.75 V to +5.25 V
Military (M) Devices
Temperature ..... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$Supply Voltage

+4.5 V to +5.5 V
$\qquad$ Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\mathrm{OH}}$ | Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & \mathrm{P}[15: 0], \mathrm{I}_{\mathrm{OH}}=- \\ & \mathrm{ZERO}, \mathrm{l}_{\mathrm{OH}}=- \\ & \mathrm{SDO}, \mathrm{I}_{\mathrm{OH}}=- \end{aligned}$ | COM'L | 2.4 |  | Volts |
|  |  |  | $\begin{aligned} & \mathrm{P}[15: 0], \mathrm{I}_{\mathrm{OH}}=- \\ & \mathrm{ZERO}, \mathrm{IOH}_{=}=- \\ & \mathrm{SDO}, \mathrm{I}_{\mathrm{OH}}=- \end{aligned}$ | MIL |  |  |  |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & \mathrm{P}[15.0], \mathrm{lOL}= \\ & \mathrm{ZERO}, \mathrm{IOL}_{\mathrm{O}}= \\ & \mathrm{SDO}, \mathrm{l}_{\mathrm{OL}}= \end{aligned}$ | COM'L |  | 0.50 | Volts |
|  |  |  | $\begin{aligned} & \mathrm{P}[15.0], \mathrm{l} \mathrm{OL}= \\ & \mathrm{ZERO}, \mathrm{IOL}^{2}= \\ & \mathrm{SDO}, \mathrm{l}_{\mathrm{OL}}= \end{aligned}$ | MIL |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \text { (Note 1) } \end{aligned}$ | Input HIGH Level | Guaranteed Input Logical HIGH Voltage for All Inputs |  |  | 2.0 |  | Volts |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \text { (Note 1) } \end{aligned}$ | Input LOW Level | Guaranteed Input Logical LOW Voltage for All Inputs |  |  |  | 0.8 | Volts |
| IL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=0.40 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| 1 H | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  |  | 25 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=M A X, V_{1 N}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ (Note2) |  |  |  |  | mA |
| ICC | Power Supply Current | All inputs $=\mathrm{GND} \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  |  | mA |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| IOZH | Output Leakage Current (Note 3) | $\begin{aligned} & V_{C C}=M A X, \quad V_{I L}=0.8 \mathrm{~V} \\ & V_{I H}=2.0 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| lozL |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -100 |  |
| $\mathrm{CiN}_{\text {I }}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 4) |  |  |  |  | pF |
| COUT | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{V@f}=1 \mathrm{MHz}$ (Note 4) |  |  |  |  |  |

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. $V_{\text {OUT }}=0.5 \mathrm{~V}$ has been chosen to avoid test problems caused by tester ground degradation.
3. $I / O$ pin leakage is the worst case of lozx or llx (where $X=H$ or L).
4. Those parameters are not $100 \%$ tested, but are periodically sampled.

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2914 | Vectored Priority Interrupt Controller |
| Am29100 | Controller Family Products |



## Am29500 Array Processing and Digital Signal Processing Index

| The Am29500 Family | A High-Performance Architecture for Digital Signal/Array Processing $\qquad$ |
| :---: | :---: |
| Am29501 | Multi-Port Pipelined Processor (Byte-Slice ${ }^{\text {TM }}$ ) ........................7-3 |
| Am29509/L509 | $12 \times 12$ Multiplier Accumulator.........................................7-15 |
| Am29510/L510 | $16 \times 16$ Multiplier Accumulator ...................................... 7 .26 |
| Am29516/17 |  |
| Am29520/Am29521 | Multilevel Pipeline Registers.......................................... 7-54 |
| Am29526/Am29527 |  |
| Am29528/Am29529 | High Speed Sine, Cosine Generators................................. 7-64 |
| Am29540 | Programmable FFT Address Sequencer............................. 7-69 |

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry.

For specific testing details contact your local AMD sales representative.
The company assumes no responsibility for the use of any circuits described herein.

# The Am29500 Family 

## A High-Performance Architecture For Digital Signal/Array Processing

As new system designs continue to press for maximum performance, high-speed array processing is becoming an increasingly attractive alternative. Parallel processing and pipelined architectures implemented in the fastest technologies are requisites for maximum performance array and signal processing applications.

The Am29500 Family is designed specifically for maximum performance and flexibility. Key product features include:

- Microprogrammable for maximum versatility
- Pipelined organization for efficient use of resources
- IMOX ${ }^{\text {TM }}$ process and ECL internal-structures for maximum speed
- TTL I/O for ease of interface

The Am29500 family components are targeted for the efficient execution of Digital Signal Processing (DSP) and Array Processing algorithms, including Infinite Impulse Response (IIR) and Finite Impulse Response (FIR) digital filters, Fast Fourier Transform (FFT) processors, graphics processors, etc.

The Am29500 family components include:

- Am29501 Multi-Port Pipelined Processor

A specialized eight-bit wide parallel processor which executes multiple simultaneous data operations. Its Register/ALU structure provides the key functional element for a high-performance signal processing system.

- Am29516/29517 High Speed $16 \times 16$-Bit Parallel Multipliers
Both are $16 \times 16$-bit Parallel Multipliers. The Am29516 is pin and functionally compatible with the MPY-16HJ, but with an added multiplexer to output the LSP at the MSP port. The Am29517 is the same function, but with clock enables for microprogrammed applications. Low power and speed enhanced versions are also available.
- Am29520/29521 Multilevel Pipeline Registers Both devices contain four 8 -bit registers for dual twostage or single four-stage data or address pipelining. Combined load-and-shift (Am29520) or separate load-and-shift (Am29521) control options are available.
- Am29526/29527/29528/29529 High-Speed Sine/ Cosine Function Generators
The sine and cosine functions are necessary for Fast Fourier Transforms (FFT). The Am29526/527 generate the most significant and least significant byte of the 16 bit sine function and the Am29528/529 generate the most significant and least significant byte of the 16-bit cosine function. The sine and cosine functions are generated to provide a range of $\theta$ for a half cycle, $0 \leqslant \theta \leqslant \pi$, in increments of $\pi / 2048$.
- Am29540 FFT Address Sequencer

This algorithm-specific VLSI chip generates data and coefficient addresses for the Fast Fourier Transform. It supports a wide variety of FFT algorithms in either radix2 or radix-4

HIGH PERFORMANCE SIGNAL PROCESSOR


- Am29509 and Am29510 Multiplier-Accumulators

These devices are $12 \times 12$ and $16 \times 16$ multipliers with builtin accumulators. They are often used in constructing digital filters. The Am29509 is pin- and function-compatible with the TDC1009 and the Am29510 is pin- and functioncompatible with the TDC1010.

- Am29325 Floating Point Processor

Support both IEEE and DEC 32-bit floating point formats, the Am29325 will perform a full parallel 32-bit floating point multiply in a single clock cycle. This device can replace more than a full circuit board of logic. 32-bit floating point is useful in filters for reducing errors and noise, and can be used to conveniently extend the number range in array processors.

A high-performance signal processor may be constructed as shown in the diagram. The processor is built entirely with Am29500 digital signal processing and Am2900 devices. Such a processor is attached as a slave to the main system bus to perform the multitude of arithmetic operations which prevail in DSP algorithms.

## Am29500 ARRAY PROCESSOR



BD002651

## DISTINCTIVE CHARACTERISTICS

- Expandable Byte-Slice ${ }^{T M}$ Register-ALU
- Sign extend input and output
- Carry and $\bar{P} / \bar{G}$ expansion with force/inhibit/normal carry modes
- Eight instruction ALU
- Four arithmetic operations
- Four logic operations
- Ten internal data paths
- Highly parallel architectures
- Multiple simultaneous data manipulations
- Pipelining register file has six 8 -bit registers
- Multilevel pipelining
- Multiple register-to-register moves
- Completely microprogrammable
- No instruction encoding
- All operation combinations available
- Three I/O ports for maximum system interconnect flexibility


## GENERAL DESCRIPTION

The Am29501 is an expandable Byte-Slice ${ }^{T M}$ register-ALU designed to bring maximum speed to array processor and digital signal processor systems. It provides a flexible processor building block for implementing highly pipelined, highly parallel architectures where speed is achieved by a combination of optimized integrated circuit technology (IMOX ${ }^{\text {TM }}$ process and internal ECL circuitry) and customized system architecture. I/O port flexibility and multiple concurrent data moves make it possible to construct processors capable of very high throughput. Parallel processors are especially efficient for array/vector operations or signal processing algorithms requiring complex number arithmetic (e.g. FFT, convolution, correlation, etc.).

The Am29501's Pipeline Register File provides data storage and pipelining flexibility. Any combination of register instructions, ALU instructions, and I/O instructions can be microprogrammed to occur in the same cycle. This allows overlap of external multiplication, ALU operations, and memory I/O.

Three I/O ports support a wide variety of parallel, pipelined architectures by providing separate I/O ports for the multiplier and the memory data bus. Either of two bidirectional I/O ports, DIO and MIO, can interface to the data bus or multiplier Y-input port, and a separate MI port connects to the multiplier output port.

| RELATED PRODUCTS |  |
| :--- | :--- |
| $\qquad$Part No. Description <br> Am2902A Carry look-ahead generator <br> Am29516/17 $16 \times 16$-bit high speed <br> multipliers <br> Am25S558 $8 \times 8$-bit multiplier |  |

## CONNECTION DIAGRAM

## Top View

## D-64-3



PIN DESCRIPTION

| *Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| 50 | $\mathrm{CiN}^{\text {IN }}$ | 1 | Carry-in input to the internal 8-bit ALU. |
| 51 | COUT | 0 | Carry-out output from the internal 8-bit ALU. |
| 48 | CP | 1 | Clock input for the internal pipeline register file. Data selected by $l_{7}-I_{1}$, meeting the set-up and hold time requirements of the respective register, is clocked into the register on the clock LOW-to-HIGH transition. |
| $\begin{aligned} & 9,11,13, \\ & 15,18,20, \\ & 22,24 \end{aligned}$ | $\mathrm{DIO}_{0}-\mathrm{DIO}_{7}$ | 1/0 | Bidirectional data 1/O port (see Note). |
| 53, 52 | $\overline{\mathbf{G}}, \overline{\bar{P}}$ | 0 | The carry generate and propagate outputs of the internal ALU. These signals are used with the Am2902A for carrylookahead. |
| $\begin{aligned} & 26-44 \\ & 54-57 \\ & 59-64 \end{aligned}$ | $10-128$ | I | Instruction inputs designed to be driven under microprogram control. All instruction inputs control multiplexers or drivers or the ALU directly. There is no instruction encoding. See Control Input Function Tables for operating modes. |
| 1-8 | $\mathrm{Ml}_{0}-\mathrm{Ml}_{7}$ | 1 | Data Input port <br> (Multiplier Input - see Note). |
| $\begin{aligned} & 10,12,14, \\ & 17,19,21, \\ & 23,25 \end{aligned}$ | $\mathrm{MlO}_{0}-\mathrm{MlO}_{7}$ | 1/0 | Bidirectional data $1 / 0$ port (Multiplier I/O - see Note). |
| 47 | OVR | 0 | Overflow <br> This pin is logically the Exclusive-OR of the carry-in and carry-out of the MSB of the ALU. At the most significant end of the word, this pin indicates that the result of an arithmetic two's complement operation has overflowed into the sign-bit. |
| 45 | SEOUT | 0 | The most significant bit of the S-operand. This is used in multiple precision arithmetic operations for sign extension of two's complement numbers. |
| 58 | SEIN | 1 | A single-bit input which generates an 8-bit sign extension R-operand for multiple precision two's complement arithmetic operations. |
| 46 | ZERO | 0 | This is an open collector output which goes HIGH if the data on the ALU outputs are all LOW. |

Note: This is a general purpose data port. The names are derived from the typical usage in a typical Am29500 system but are not restricted to this interconnection scheme.
*DIP Configuration

CONTROL INPUT FUNCTION TABLES

| 1. Data I/O Port (DIO) Output Select |  |  |  |
| :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathbf{3}}$ | $\mathrm{I}_{\mathbf{2}}$ | $\mathrm{I}_{0}$ | Source |
| L | L | L | $A_{2}$ |
| L | H | L | $A_{3}$ |
| H | L | L | $B_{2}$ |
| $H$ | $H$ | L | $B_{3}$ |
| X | X | $H$ | Output Disabled |


| 2. Multiplier 1/O Port (MIO) Output Select |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{6}$ | $\mathrm{I}_{5}$ | 14 | 11 | Source |
| L | L | L | L | $\mathrm{A}_{1}$ |
| L | L | H | L | $A_{2}$ |
| L | H | L | L | $\mathrm{A}_{3}$ |
| L | H | H | L | $B_{1}$ |
| H | L | L | L | $\mathrm{B}_{2}$ |
| H | L | H | L | B3 |
| H | H | L | L | ALU |
| H | H | H | L | DI |
| X | X | X | H | Output Disabled |


| 3. Register $A_{1}$ Data Source Select |  |  |
| :---: | :---: | :---: |
| $I_{\mathbf{8}}$ | $I_{7}$ | Source |
| $L$ | $L$ | MSP (MI) |
| $L$ | $H$ | DI (DIO) |
| $H$ | $L$ | $B_{3}$ |
| $H$ | $H$ | $A_{1}$ (Hold) |


| 4. Register $A_{2}$ Data Source Select |  |  |  |
| :---: | :---: | :---: | :---: |
| $I_{10}$ | $I_{9}$ | Source |  |
| L | L | LSP (MIO) |  |
| L | $H$ | ALU |  |
| $H$ | L | $A_{1}$ |  |
| $H$ | $H$ | $A_{2}$ (Hold) |  |



## DETAILED DESCRIPTION

Figure 1 contains a block diagram of the Am29501. It shows four major sections - an eight-bit cascadable ALU, a register file consisting of six eight-bit registers, three I/O ports, and a microcode control section.

## DETAILED Am29501 BLOCK DIAGRAM



DFR00710
Figure 1.

## ALU

The ALU performs arithmetic on an eight-bit Byte-Slice ${ }^{\mathrm{TM}}$ with full internal carry lookahead and carry input and output for cascading. The carry can ripple between byte-slices by connecting the COUT of one slice to $\mathrm{C}_{\mathrm{IN}}$ of the next byte-slice. Carry generate $(\bar{G})$ and propagate ( $\overline{\mathrm{P}}$ ) outputs are also provided for faster operation when the ALU is used in conjunction with a carry lookahead generator such as the Am2902A.

There are three arithmetic modes - cascade, carry inhibit and forced carry. The cascade mode produces an output carry based on the results of the operation and is the normal mode. The carry inhibit mode produces no carry output and is used to decouple cascaded ALUs. A 16 -bit ALU consisting of two Am29501s can operate as two 8 -bit ALUs simultaneously by programming the carry inhibit mode. This mode could also be used with a second 16 -bit ALU for double precision where the more significant slice is programmed in the carry inhibit mode for single precision and in the cascade mode for double precision. The less significant slices would be programmed in normal mode for either case. The forced carry mode is the
converse and always produces a carry. All three modes treat the input carry in the same way. The Am29501 uses the input carry as a true borrow during subtraction as opposed to most two's complement ALUs which use borrow. The usual requirement is that input borrow be programmed HIGH (inactive) when doing a subtraction. Since the Am29501 has a true borrow, the input carry is programmed to be LOW for both addition and subtraction. This is consistent with the carry inhibit mode discussed previously.

In addition to arithmetic operations the ALU also does bitwise logic operations - OR, AND, exclusive OR, and invert. Carries are not applicable for these operations and are inactive. Codes to program the ALU function are contained in Control Input Function Table 9.

Each operand of the ALU has eight possible sources. Operand $R$ can be any register in the register file or one of the I/O ports MI or MIO as shown in Table 10. Operand S can be any register, zero or a sign extension input ( $\mathrm{SE}_{\mathrm{IN}}$ ) from another ALU (Table 11). The ALU result can be steered to registers A2, A3, B2, and B3 of the register file or the MIO I/O port

## REGISTER FILE

The register file provides for fully independent use of the registers. Each register has a four-input mux which can be programmed so that the register holds its previous contents or is loaded from the ALU and I/O port or the "preceding" register. If all registers are programmed for the preceding register, a ring is formed and data circulates through all the registers. This facilitates constructing a pipelined data flow. Various combinations of I/O ports and the ALU make up the remaining inputs to each register. The sources for each register are shown in the Control Input Function Tables 3-8.

## I/O PORTS

The Am29501 has two bidirectional ports (DIO and MIO) and one input port (MI). As an input the DIO port can be loaded into registers A1 and B1 and directed to the MIO output port. Output from the DIO comes from registers A2, A3, B2 or B3 using the codes from Control Input Function Table 1. This separation of input and output registers connected to the DIO port is in keeping with the pipelined organization of the part when the DIO port is used for data flow in and out of the processor.

Input through the MIO port can be directed to registers A2 and B2 in the register file and to the ALU. Output can come from any of the six registers, the DIO input port or from the ALU.

This structure allows the user to direct operands to an auxiliary processor (such as a multiplier or barrel shifter) from any point in the pipeline. The MIO port could be connected to a processor with bidirectional data bus. The auxiliary processor would receive data and return its results to registers A2 and B2 through the MIO port.
The MI port provides another entry point for inserting data in the processing pipeline. An auxiliary processor with flowthrough architecture could receive data from the MIO port and return data through the MI port which can be directed to registers A1, A3, B1 and B3 and to the ALU.
A potential use of the ports is connecting the bidirectional bus of an Am29116 microprocessor to the MIO port. An Am29516 would have its inputs connected to the same MIO port and its output to the MI port. This architecture could calculate magnitudes by computing the sum of the squares with the Am29516 and Am29501 and the square root with the Am29116.

## CONTROL

The Am29501 is controlled by 29 microcode bits which select operations with no encoding. This provides the maximum flexibility for the independent control of parallel operations. Sources may be directed to multiple destinations simultaneously wherever data paths are provided.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature -65 to $+150^{\circ} \mathrm{C}$
Temperature Under Bias-TC ........................ -55 to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous -0.5 to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ .0 .5 V to $+V_{\mathrm{CC}} \max$ DC Input Voltage $\qquad$ ......... 0.5 to +5.5 V
DC Output Current, Into Outputs ........................... 30mA DC Input Current ..................................-30 to +5.0 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 device reliability.

## OPERATING RANGES

| Commercial (C) Devices |  |
| :---: | :---: |
| Temperature |  |
| DIPs ............................... $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |
| Chip Carriers......................... $\mathrm{T}_{\mathrm{C}}=0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |  |
| Supply Voltage .......................... +4.75 V to +5.25 V |  |
| Military (M) Devices |  |
| Temperature ............................ $-55^{\circ} \mathrm{C}$ to $+125^{\circ}$ |  |
| Supply Voltage ............................ + 4.5 V to +5.5V |  |
| Operating ranges define those limits over which the functionality of the device is guaranteed. |  |

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | 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}=-2.6 \mathrm{~mA}\left(\mathrm{COM}^{\prime} \mathrm{L}\right)$ | 2.4 |  |  | Volts |
| 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}$ | COM'L | $\mathrm{IOL}^{\prime}=24 \mathrm{~mA} \mathrm{DIO}, \mathrm{MIO}$ |  |  | 0.5 | Volts |
|  |  |  |  | $1 \mathrm{OL}=8 \mathrm{~mA}$ Others |  | - | 0.5 |  |
|  |  |  | MIL | $1 \mathrm{LL}=16 \mathrm{~mA} \mathrm{DIO}, \mathrm{MIO}$ | - | + |  |  |
|  |  |  |  | $\mathrm{IOL}^{\prime}=8 \mathrm{~mA}$ Others | \% |  | 0.5 |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=M I N, I_{\text {IN }}=-18 \mathrm{~mA}$ |  | , |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $V_{C C}=M A X, V_{1 N}=0.5 V$ |  | ( |  |  | -0.4 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.7 V$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=$ MAX, $V_{\text {IN }}=5.5 \mathrm{~V}$. |  |  |  |  | 0.1 | mA |
| IOZH | Off State (High Impedance) Output Current | $v_{C C}=M A X$ |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -55 | $\mu \mathrm{A}$ |
| lozl |  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 100 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  | -30 |  | -100 | mA |
| ICC | Power Supply Current | COM'L and MIL |  | $T_{A}=25^{\circ} \mathrm{C}$ |  | 300 |  | mA |
|  |  | COM'L Only $V_{C C}=\mathrm{MAX}$ |  | $\Gamma_{A}=0$ to $+70^{\circ} \mathrm{C}$ (Note 4) |  |  | 400 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ (Note 4) |  |  | 375 |  |
|  |  | MIL Only$V_{C C}=M A X$ |  | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ |  |  |  |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{C}}=+125^{\circ} \mathrm{C}$ |  |  |  |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Chip Carriers: $\mathrm{T}_{\mathrm{C}}=85^{\circ} \mathrm{C}$.


SWITCHING CHARACTERISTICS, COMMERCIAL
Minimum Set-up/Hold Times and Maximum Propagation Delays

| From Input | To Output |  |  |  |  |  |  |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Set-up, $\mathbf{t}_{\mathbf{s}} /$ Hold, $\mathrm{t}_{\mathrm{h}}$ |  | Propagation Delay Times, tPD |  |  |  |  |  |  |  |  |  |
|  | Register Input | Reg via ALU | $\begin{aligned} & \text { MIO } \\ & \text { Port } \end{aligned}$ | MIO via ALU | $\begin{aligned} & \text { DIO } \\ & \text { Port } \end{aligned}$ | Cout | $\overline{\mathbf{P}}$ | $\overline{\mathbf{G}}$ | z | Overflow | SEout |  |
| CLK |  |  | 23 | 35 | 24 | 31 | 31 | 31 | 39 | 34 | 26 | ns |
| DIO | 10/5 |  | 17 |  |  |  |  |  |  |  |  | ns |
| MIO | 10/5 | 20/0 |  |  |  | 29 | 29 | 29 | 34 | 29 | 24 | ns |
| MI | 10/5 | 20/0 |  | 32 |  | 30 | 29 | 29 | 34 | 29 | 24 | ns |
| $\mathrm{C}_{\mathrm{IN}}$ |  | 10/5 |  | 25 |  | 15 |  |  | 26 | 19 |  | ns |
| SEIN |  | 20/0 |  | 29 |  | 27 | 27 | 22 | 32 | 27 |  | ns |
| $\mathrm{I}_{2-3}$ (DIO) |  |  |  |  | 21 |  |  |  |  | + |  | ns |
| $\mathrm{I}_{4-6}$ (MIO) |  |  | 22 |  |  |  |  |  |  |  |  | ns |
| 17-18(REG) | 10/5 |  |  |  |  |  | , |  | - |  |  | ns |
| 19-22(ALU OP) |  | 20/0 | 32 |  |  | 27 | 27 | 27 | 32 | 29 |  | ns |
| $\mathrm{I}_{23 \text {-28(ALU SEL) }}$ |  | 20/0 | - | , |  | 29 | 29 | 29 | 35 | 32 | 22 | ns |

## SWITCHING CHARACTERISTICS, MILITARY

Minimum Set-up/Hold Times and Maximum Propagation Delays


Note: Please refer to Guidelines for Testing Am2900 Family Devices in section 13 of this data book.

Am29501 Minimum Clock Pulse Widths

| Parameter | Description |  | TYPICAL | COMMERCIAL | MILITARY | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| tpW | Clock Pulse Width | High |  | 15 |  | ns |
|  |  |  | 15 |  | ns |  |

## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS
C. OPEN-COLLECTOR OUTPUTS



TC001420

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for $t_{P Z H}$ test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tPZL test.
4. $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ for output disable tests.

SET-UP, HOLD, AND RELEASE TIMES


WFR02970

PROPAGATION DELAY


WFR02980

Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense.
2. Cross hatched area is don't care condition.


ICR00520
$\mathrm{C}_{\mathrm{O}} \cong 5.0 \mathrm{pF}$, all outputs
Note: Actual current flow direction shown.

## Am29509/L509

$12 \times 12$ Multiplier Accumulator

## ADVANCED INFORMATION

- Uses two's complement or unsigned inputs and outputs
- Round control
- 27 -bit product accumulation result
- 24-bit product
- 3-bit extended product
- Output register preload
- Three-state output control
- $\mathrm{IMOX}^{\mathrm{TM}}$ processing
- ECL internal circuitry for speed
- TTL I/O


## GENERAL DESCRIPTION

The Am29509 is a high-speed $12 \times 12$-bit multiplier/accumulator (MAC). The $X$ and $Y$ input registers accept 12-bit inputs in two's complement or unsigned magnitude format. A third register stores the Two's Complement (TC), Round (RND), Accumulate (ACC), and Subtraction SUB/ADD control bits. This register is clocked whenever the $X$ or $Y$ input registers are clocked.
The 27-bit accumulator/output register contains the full 24bit multiplier output which is sign extended or zero-filled
based on the TC control bit. The accumulator can also be preloaded from an external source through the bidirectional P-port. The operation of the accumulator is controlled by the signals ACC, SUB/ $\overline{A D D}$, and PREL (Preload). Each of the input registers and output register has independent clocks.

The Am29L509 is a low-power version of the Am29509. The Am29L509 is expected to dissipate $50 \%$ less power than the high-speed Am29509.

## BLOCK DIAGRAM



Leadless Chip Carrier


CDR04450


CDR04460

Note: Pin 1 is marked for orientation

## METALLIZATION AND PAD LAYOUT



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am29509/L509


- Screening Option Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
$D=64-$ Pin Top-Brazed with Heat Sink 64-Pin Top-Brazed without Heat Sink*
L = Leadless Chip Carrier
P = Molded DIP*
Device Type $12 \times 12$ Multiplier
Accumulator
*For low-power version.
Note 1. 160-hour burn-in -
Heat sink parts: $\mathrm{T}_{A}=125^{\circ} \mathrm{C}$
Non-heat sink parts: $\mathrm{T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$

| Valid Combinations |  |
| :--- | :--- |
| Am29509 | DC $^{2} \mathrm{DCB}, \mathrm{LC}, \mathrm{LMB}$ |
| Am29L509 | PC $^{*}, \mathrm{PCB}^{*}$ |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| *Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 8 | RND | 1 | Round When RND is High, a bit with a weight of $\mathrm{P}_{11}$ is added to the multiplier product. RND is loaded on the rising edge of CLKX or CLKY. |
| 42 | TC | 1 | Two's Complement When High, the $X$ and $Y$ inputs are defined as two's complement data, or as unsigned data when Low. The TC control is loaded on the rising edge of CLKX or CLKY. |
| 24 | PREL | 1 | Preload <br> When High, data is preloaded into the specific output register when its respective Load Enable is High. When Low, the accumulator register is available at the P-port when the Output Enables are Low. |
| 41 | LEx/OEX | 1 | Load Enable Extended/Output Enable Extended <br> Active High Load Enable for the XTP port during preloading. Active Low three-state control for the XTP port during normal operation (see Preload Function). (TSX)** |
| 25 | $\mathrm{LE}_{M} / \overline{\mathrm{OE}} \mathrm{M}_{M}$ | 1 | Load Enable Most/Output Enable Most <br> Active High Load Enable for the MSP port during preloading. Active Low three-state control for the MSP port during normal operation (see Preload Function). (TSM)** |
| 9 | LEL/ठEL | 1 | Load Enable Least/Output Enable Least <br> Active High Load Enable for the LSP port during preloading. Active Low three-state control for the LSP port during normal operation (see Preload Function). (TSL)** |
| 57, 56 | CLKX, CLKY | 1 | CLOCKS Load $X$ and $Y$ data respectively and TC, RND, ACC and SUB/ $\overline{A D D}$ on the rising edge. |
| 23 | $\mathrm{CLK}_{\mathrm{P}}$ | 1 | CLOCK <br> Loads data into the XTP, MSP and LSP registers on the rising edge. |
| $\begin{aligned} & 1-5, \\ & 58-64 \end{aligned}$ | $x_{11}-x_{0}$ | 1 | Multiplier Data Input <br> Data is loaded into the X register on the rising edge of CLKX. |
| $\begin{aligned} & 43-48, \\ & 50-55 \end{aligned}$ | $Y_{11}-Y_{0}$ | 1 | Multiplier Data Input <br> Data is loaded into the $Y$ register on the rising edge of CLKY. |
| 38-40 | $\mathrm{P}_{26} \mathrm{P}_{24}$ | 1/0 | Bidirectional Port Product output for Extended Product (XTP) and input to preload XTP register. |
| 26-37 | $\mathrm{P}_{23} \mathrm{P}_{12}$ | 1/0 | Bidirectional Port <br> Product output for the Most Significant Product (MSP) and input to preload MSP register. |
| $\begin{aligned} & 10-15, \\ & 17-22 \\ & \hline \end{aligned}$ | $\mathrm{P}_{11}-\mathrm{P}_{0}$ | 1/0 | Bidirectional Port Product output for the Least Significant Product (LSP) and input to preload the LSP register. |
| 6 | ACC | 1 | Accumulate <br> When High, the multiplier product is accumulated in the accumulator. When Low, the multiplier product is written into the accumulator (see Accumulator Function Table). The ACC control is loaded on the rising edge of CLKX or CLKY. |
| 7 | SUB/ADD | 1 | Subtraction/Addition <br> When High, the accumulator contents are subtracted from the multiplier product and the result written back into the accumulator. When Low, the multiplier product is added into the accumulator (see Accumulator Function Table). The SUB/ADD control is loaded on the rising edge of CLKX or CLKY. |

*DIP Configuration
**TRW TDC1009 PIN DESIGNATION

PRELOAD FUNCTION

| PREL | $\begin{aligned} & \text { LEX/ } \\ & \mathbf{L E}_{X} \\ & \hline E_{1} \end{aligned}$ | $\begin{aligned} & \mathrm{LE}_{\mathrm{M}} / \\ & \mathrm{OE}_{\mathrm{M}} \end{aligned}$ | $\frac{L E_{L}^{\prime}}{O E_{L}^{\prime}}$ | Output Register |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | XTP | MSP | LSP |
| 0 | 0 | 0 | 0 | Q | Q | Q |
| 0 | 0 | 0 | 1 | Q | Q | z |
| 0 | 0 | 1 | 0 | Q | z | Q |
| 0 | 0 | 1 | 1 | Q | z | z |
| 0 | 1 | 0 | 0 | z | Q | Q |
| 0 | 1 | 0 | 1 | z | Q | z |
| 0 | 1 | 1 | 0 | z | z | Q |
| 0 | 1 | 1 | 1 | Z | z | z |
| 1 | 0 | 0 | 0 | z | z | Z |
| 1 | 0 | 0 | 1 | z | z | PL |
| 1 | 0 | 1 | 0 | z | PL | Z |
| 1 | 0 | 1 | 1 | z | PL | PL |
| 1 | 1 | 0 | 0 | PL | z | 2 |
| 1. | 1 | 0 | 1 | PL | Z | PL |
| 1 | 1 | 1 | 0 | PL | PL | Z |
| 1 | 1 | 1 | 1 | PL | PL | PL |

$\mathrm{Z}=$ output buffers at High impedance (disabled).
$Q=$ output buffers at Low impedance. Contents of output register available through output ports.
$\mathrm{PL}=$ output disabled. Preload data supplied to the output pins will be loaded into the output register at the rising edge of CLKp.

## ACCUMULATOR FUNCTION TABLE

| PREL | ACC | $\frac{\text { SUB }}{\overline{A D D}}$ | P | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| L | L | X | Q | Load |
| L | $H$ | L | Q | Add |
| L | $H$ | $H$ | Q | Subtract |
| $H$ | X | X | PL | Preload |

## DETAILED DESCRIPTION

The Am29509 is a high-speed $12 \times 12$-bit multiplier/accumulator (MAC). It comprises a 12-bit parallel multiplier followed by a 27-bit accumulator. Two 12-bit input registers are provided for the $X$ and $Y$ operands. A third register stores two control bits, TC and RND. TC selects either a two's complement or an unsigned magnitude format for both data inputs. The RND control, when High, causes a bit to be added to the multiplier product with the weight of $P_{11}$. This causes the most significant 12-bits of the product to be rounded to the value nearest to the full 24-bit product. Using the RND control once during an accumulation causes the most significant 15-bits of the accumulator to be rounded to the value nearest the full 27 bit accumulation. The TC/RND register is clocked whenever the $X$ or $Y$ input registers are clocked.

The 24-bit multiplier output is zero-filled or sign-extended as appropriate to provide a 27-bit input to the accumulator. The accumulator has four functions: the product may be loaded into the accumulator, the product may be added into the
accumulator value, the previous accumulator value may be subtracted from the product and the result stored in the accumulator or the accumulator may be preloaded from an external source. The operation of the accumulator is controlled by the signals ACC, SUB/ $\overline{\mathrm{ADD}}$ and PREL. ACC and SUB/ $\overline{A D D}$ are stored in a register clocked whenever the $X$ or Y registers are clocked. ACC in conjunction with SUB/ADD selects one of the first three accumulator functions (see Accumulator Function Table). For output and preloading purposes the accumulator is considered in three sections: Extended Product (XTP, $\mathrm{P}_{26}-\mathrm{P}_{24}$ ) controlled by LEx/OEX, Most Significant Product (MSP, $\mathrm{P}_{23}-\mathrm{P}_{12}$ ) controlled by $\mathrm{LE}_{\mathrm{M}} /$ $\overline{O E}_{M}$ and Least Significant Product (LSP, $\mathrm{P}_{11}-\mathrm{P}_{0}$ ) controlled by $L E_{L} / \overline{O E}$. When PREL is Low these controls are activeLow Output Enables for the three-state output buffers. When PREL is High the output buffers automatically become high impedance, and the controls operate as active High Load Enables to the three sections of the accumulator to permit preloading of data applied to the bidirectional P port. The Pport has 27-bits.

## Unsigned Fractional Input


$Y_{\text {IN }}$

| 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ |

## Unsigned Integer Input

| 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |


| 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

Two's Complement Fractional Output

$$
\begin{aligned}
& \text { (Sign) }
\end{aligned}
$$

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ -65 to $+150^{\circ} \mathrm{C}$
Temperature Under Bias-TC ................... -55 to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ DC Voltage Applied to Outputs For High Output State $\qquad$ 0.5 to +7.0 V

DC Input Voltage. $\qquad$ ........ 0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max

DC Output Current, Into Outputs $\qquad$ -0.5 to +5.5 V

DC Input Current $\qquad$
$\qquad$
$\qquad$ .......... 30 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 device reliability.

## OPERATING RANGES

| Commercial (C) Devices |  |
| :---: | :---: |
| Temperature |  |
| DIPs | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |
| Chip Carriers. | $\mathrm{T}_{\mathrm{C}}=0$ to $+85^{\circ} \mathrm{C}$ |
| Supply Voltage | 4.75 V to 5.25 V |

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ . 4.5 V to 5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified Am29509/L509

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{l}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | 2.4 | 2.7 |  | Volts |
| $\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{lOL}=4.0 \mathrm{~mA}$ |  |  | . 3 | . 5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed Input Logical HIGH Voltage for All Inputs |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed Input Logical LOW Voltage for All inputs |  |  |  | - | . 8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  | + |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.4 | mA |
| $\mathrm{I}_{\mathrm{H}}$ | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1 | mA |
| IOZH | Off State (High Impedance) Output Current | $V_{C C}=M A X$ | Product | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| lozl |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -25 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ | Product | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | -20 |  | -85 | mA |
| Icc | Power Supply Current | COM'L and MIL <br> COM'L Devices $V_{C C}=$ Max | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | STD Devices |  |  |  | mA |
|  |  |  |  | L Devices |  |  |  |  |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ | STD Devices |  |  |  |  |
|  |  |  | (Note 4) | L Devices |  |  |  |  |
|  |  |  |  | STD Devices |  |  |  |  |
|  |  |  | (Note 4) | L Devices |  |  |  |  |
|  |  | MIL Devices $V_{C C}=$ Max |  | STD Devices |  |  |  |  |
|  |  |  | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ | L Devices |  |  |  |  |
|  |  |  | $\mathrm{T}^{\mathrm{C}}=+125^{\circ} \mathrm{C}$ | STD Devices |  |  |  |  |
|  |  |  |  | L Devices |  |  |  |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Chip Carriers: $T_{C}=85^{\circ} \mathrm{C}$.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description |  | Test Conditions | Typ | COMMERCIAL |  | MILITARY <br> 29509 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  | Min |  | Max | Min | Max |  |
| tMA | Multiply Accumulate Time |  |  |  |  |  |  |  |  | ns |
| ts | $\begin{aligned} & X_{i}, Y_{i}, \text { RND, TC, ACC, SUB/ADD } \\ & \text { Set-up Time } \end{aligned}$ |  |  |  |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | $\begin{aligned} & X_{i}, Y_{i}, \text { RND, TC, ACC, SUB/矿 } \\ & \text { Hold Time } \end{aligned}$ |  |  |  |  |  |  |  | ns |
| ts | PREL Set-up Time |  |  |  |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | PREL Hold Time |  |  |  |  |  |  |  | ns |
| tpWH | Clock Pulse Width High |  |  |  |  |  |  |  | ns |
| tpWL | Clock Pulse Width Low |  | . |  |  |  |  |  | ns |
| tpDP | Output Clock to $P$ |  |  |  |  |  |  |  | ns |
| tPHZ | $\begin{aligned} & \mathrm{LE}_{X} / \overline{\mathrm{OE}} \mathrm{E}_{\mathrm{X}}, \mathrm{LE}_{\mathrm{M}} / \overline{\mathrm{OE}}{ }_{\mathrm{M}} \\ & -\mathrm{LE}_{\mathrm{L}} / \overline{\mathrm{OE}} \mathrm{~L} \\ & \mathrm{P} \text { Disable Time } \\ & \hline \end{aligned}$ | High to Z |  |  |  |  |  |  | ns |
| tplz |  | Low to Z |  |  |  |  |  |  | ns |
| tPZH | $\begin{aligned} & \mathrm{LE}_{\mathrm{X}} / \overline{\mathrm{OE}} \\ & \text { LE, } \mathrm{LE}_{\mathrm{M}} / \overline{\mathrm{OE}}{ }_{\mathrm{M}}, \\ & \mathrm{LE} / \overline{\mathrm{OE}} \mathrm{~L} \\ & \mathrm{P} \text { Enable Time } \end{aligned}$ | $Z$ to High |  |  |  |  |  |  | ns |
| tpZL |  | Z to Low |  |  |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{HCL}}$ | Relative Hold Time |  |  |  |  |  |  |  | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified




WFR02970

Notes: 1. Diagram shown for HIGH data only.
Output transition may be opposite sense.
2. Cross hatched area is don't care condition.


## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29526/527 | High speed Sine function generator |
| Am29528/529 | High speed Cosine function generator |
| Am29540 | Programmable FFT address sequencer |
| Am29520/21 | Multilevel pipeline registers |

## DISTINCTIVE CHARACTERISTICS

- Uses two's complement or unsigned inputs and
- Round control
- Output register preload
- 35-bit product accumulator result
- 32-bit product
- 3-bit extended product
- IMOX ${ }^{\text {TM }}$ processing
- ECL internal circuitry for speed
- TTL I/O, Single 5V Supply
- FAST
- High speed version multiply accumulate time 80ns
- Low power version multiply accumulate time 110 ns


## GENERAL DESCRIPTION

The Am29510 is a high-speed $16 \times 16$-bit multiplier/accumulator (MAC). The $X$ and $Y$ input registers accept 16 -bit inputs in either two's complement or unsigned magnitude format. A third register stores the Two's Complement (TC), Round (RND), Accumulator (ACC), and Subtraction/Addition (SUB/ADD) control bits. This register is clocked whenever the X or Y input registers are clocked.
The 35-bit accumulator/output register contains the full 32 bit multiplier output which is sign extended or zero-filled based on the TC control bit. The accumulator can also be
preloaded from an external source through the bidirectional P port. The operation of the accumulator is controlled by the signals ACC, (Accumulator), SUB/ $\overline{\mathrm{ADD}}$ (Subtraction/ Addition), and PREL (Preload). Each of the input registers and the output register has independent clocks.

The Am29L510 is a low-power version of the Am29510. The Am29L510 consumes only one-half the power of its standard power counterpart while maintaining nearly twothirds the speed.

BLOCK DIAGRAM


BDR02280


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

## Am29510/L510



Blank - Standard Processing B - Burn-in (Note 1)
Temperature (See Operating Ranges)
C - Commercial ( 0 to $+70^{\circ} \mathrm{C}$ )
M - Military ( -55 to $+125^{\circ} \mathrm{C}$ )
Package Code
$\mathrm{L}=68$-Pin Leadless Chip Carrier
$D=64-$ Pin Top-Brazed with Heat Sink
or 64-Pin Top-Brazed without Heat Sink $\mathrm{P}=64$-Pin Molded DIP*

Device Type
Multiplier Accumulator
Note 1. 160-hour burn-in -
Heat sink parts: $T_{A}=125^{\circ} \mathrm{C}$
Non-heat sink parts: $T_{A}=85^{\circ} \mathrm{C}$


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## DETAILED DESCRIPTION

The Am29510 is a high-speed $16 \times 16$-bit multiplier/accumulator (MAC). It comprises a 16-bit parallel multiplier followed by a 35-bit accumulator. Two 16-bit input registers are provided for the $X$ and $Y$ operands. A third register stores two control bits, TC and RND. TC selects either a two's complement or an unsigned magnitude format for both data inputs. The RND control, when High, causes a bit to be added to the multiplier product with the weight of $\mathrm{P}_{15}$. This causes the most significant 16 -bits of the product to be rounded to the value nearest to the full 32-bit product. Using the RND control once during an accumulation causes the most significant 19-bits of the accumulator to be rounded to the value nearest the full 35bit accumulation. The TC/RND register is clocked whenever the $X$ or $Y$ input registers are clocked.

The 32-bit multiplier output is zero-filled or sign-extended as appropriate to provide a 35-bit input to the accumulator. The accumulator has four functions: the product may be loaded into the accumulator, the product may be added into the
accumulator value, the previous accumulator value may be subtracted from the product and the result stored in the accumulator or the accumulator may be preloaded from an external source. The operation of the accumulator is controlled by the signals ACC, SUB/ $\overline{A D D}$ and PREL. ACC and SUB/ $\overline{A D D}$ are stored in a register clocked whenever the $X$ or $Y$ registers are clocked. ACC in conjunction with SUB/ $\overline{A D D}$ selects one of the first three accumulator functions (see Accumulator Function Table). For output and preloading purposes the accumulator is considered in three sections: Extended Product (XTP, $\mathrm{P}_{34}-\mathrm{P}_{32}$ ) controlled by LEx/ $\overline{\mathrm{OE}}_{\mathrm{X}}$, Most Significant Product (MSP, $\mathrm{P}_{31}-\mathrm{P}_{16}$ ) controlled by LEM/ $\overline{\mathrm{OE}}_{\mathrm{M}}$ and Least Significant Product (LSP, $\mathrm{P}_{15}-\mathrm{P}_{0}$ ) controlled by $L E_{L} / \overline{O E}_{L}$. When PREL is Low these controls are activeLow Output Enables for three-state output buffers. When PREL is High the output buffers automatically become high impedance, and the controls operate as active-High Load Enables to the three sections of the accumulator to permit preloading of data applied to the bidirectional $P$ port. The $P$ port has 35 bits, the least significant 16 of which share pins with the Y input.

## Am29510/L510 INPUT FORMATS

## Fractional Two's Complement Input



Integer Two's Complement Input


## Unsigned Fractional Input



## Unsigned Integer Input

| 15 | $X_{\text {IN }}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{15}$ | $2^{14}$ | $2^{13}$ | 12 | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ |
| $2^{0}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature -65 to $+150^{\circ} \mathrm{C}$

Supply Voltage to Ground Potential
Continuous
Applied to Outputs For
High Output State $\qquad$ .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ -0.5 to +5.5 V
DC Output Current, Into Outputs $\qquad$ 5.5 V

DC Input Current $\qquad$ -30 to +5.0 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 device reliability.

## OPERATING RANGES

| Commercial (C) Devices |  |
| :---: | :---: |
| Temperature |  |
| DIPs | $\mathrm{T}_{\mathrm{A}}=0$ to $+70^{\circ} \mathrm{C}$ |
| Chip Carriers | $\mathrm{T}_{\mathrm{C}}=0$ to $+85^{\circ} \mathrm{C}$ |
| Supply Voltage ..................................4.75V to 5.25 V |  |
| Military (M) Devices |  |
| Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots . \mathrm{T}^{\text {C }}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| Supply Voltage ...................................4.5V to 5.5 V |  |
| Operating ranges define thos ality of the device is gua | which the function- |

DC CHARACTERISTICS over operating range unless otherwise specified

## Am29510

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ | $\mathrm{IOH}^{\prime}=$ |  | 2.4 | 2.7 |  | Volts |
| $\mathrm{V}_{\text {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}=4$ |  |  | 3 | . 5 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW level | Guaranteed input logical LOW voltage for all inputs |  |  | \% |  | . 8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1 \times}=0.4 \mathrm{~V}$, |  |  |  |  | -0.4 | mA |
| IIH | Input HIGH Current | $V_{C C}=M A X, V_{I N}=2.4 \mathrm{~V}$ |  |  |  |  | 75 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=M A X, V_{\mathbb{N}}=5.5 \mathrm{~V}$ |  |  |  |  | 1 | mA |
| IOZH | Off State (High Impedance) Output Current | $V_{C C}=M A X$ | Product | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| lozl |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -25 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX | Product | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | -3 |  | -30 | mA |
| Icc | Power Supply Current | COMLL and MIL |  | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | 750 |  | mA |
|  |  | COM'L Only $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ |  | $\begin{aligned} & \mathrm{T}_{A}=0 \text { to }+70^{\circ} \mathrm{C} \\ & \text { (Note 4) } \end{aligned}$ |  |  | 900 |  |
|  |  |  |  | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C} \\ & \text { (Note 4) } \end{aligned}$ |  |  | 725 |  |
|  |  | MIL Only V $\mathrm{CCC}^{\text {= Max }}$ |  | TCC $=-55$ to $+125^{\circ} \mathrm{C}$ |  |  | 1000 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{CC}}=+125^{\circ} \mathrm{C}$ |  |  | 750 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Chip Carriers: $\mathrm{T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$.

DC CHARACTERISTICS over operating range unless otherwise specified Am29L510


Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Chip Carriers, $\mathrm{T}_{\mathrm{C}}=85^{\circ} \mathrm{C}$.

| Parameters | Description |  | Test Conditions | Typ <br> (Note 1) | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | Min |  | Max | Min | Max |  |
| 'tMA | Multiply Accumulate Time |  |  |  | 50 |  | 80 |  | 90 | ns |
| ts | $\begin{aligned} & X_{i}, Y_{i}, \text { RND, TC, ACC, SUB/ADD } \\ & \text { Set-up Time } \end{aligned}$ |  |  |  | $\bigcirc 12$ | 25 |  | 30 | - | ns |
| $t_{\text {H }}$ | $\begin{aligned} & X_{i}, Y_{i}, \text { RND, TC, ACC, SUB/ } \overline{\text { ADD }} \\ & \text { Hold Time } \end{aligned}$ |  |  | 0 | 5 |  | 5 |  | ns |
| ts | PREL Setup Time |  |  | 10 | 25 |  | 30 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | PREL Hold Time |  |  | 0 | 0 |  | 2 |  | ns |
| tpWH | Clock Pulse Width High |  |  | 10 | 20 |  | 25 |  | ns |
| tpWL | Clock Pulse Width Low |  |  | 10 | 20 |  | 25 |  | ns |
| tPDP | Output Clock to P |  |  | 25 |  | 40 |  | 40 | ns |
| tPDY | Output Clock to $Y$ |  |  | 25 |  | 40 |  | 40 | ns |
| tPHZ | $\begin{aligned} & \mathrm{LEX}_{X} / \overline{\mathrm{O}}_{\mathrm{X}}, \mathrm{LE}_{M} / \overline{\mathrm{OE}}_{\mathrm{M}} \\ & \text { to } \mathrm{P}, \mathrm{LE}_{L} / \mathrm{OE}_{\mathrm{L}} \\ & \text { to } \mathrm{Y} \text { Disable Time } \end{aligned}$ | High to Z |  | 21 |  | 35 |  | 40 | ns |
| tplz |  | Low to Z |  | 20 |  | 35 | - | 40 | ns |
| tPZH | $\begin{aligned} & \mathrm{LE}_{X} / \overline{\mathrm{OE}} \mathrm{E}_{\mathrm{X}}, \mathrm{LE}_{M} / \overline{\mathrm{OE}}_{M} \\ & \text { to } \mathrm{P}, \mathrm{LE}, \overline{\mathrm{LE}}_{\mathrm{L}} \\ & \text { to } \mathrm{Y} \text { Enable Time } \end{aligned}$ | $Z$ to High |  | 28 |  | 40 | - | - 40 | ns |
| tPZL |  | $Z$ to Low |  | 24 |  | 40 |  | 40 | ns |
| thCL | Relative Hold Time |  |  |  | 0 | - | 0 |  | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | Typ (Note 1) | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $29 \mathrm{L510}$ |  | $29 \mathrm{L510}$ |  |  |
|  |  |  | Min |  | Max | Min | Max |  |
| $\mathrm{t}_{\text {MA }}$ | Multiply Accumulate Time |  |  |  | 70 |  | 110 |  | 120 | ns |
| ts | $\begin{aligned} & X_{i,}, Y_{i}, \text { RND, TC, AC } \\ & \text { Set-up Time } \end{aligned}$ | $\text { SUB/ } \overline{\text { ADD }}$ |  |  | 20 | 40 |  | 45 |  | ns |
| $\mathrm{th}^{\text {H}}$ | $\begin{aligned} & X_{i}, Y_{i}, \text { RND, TC, ACC, SUB } / \overline{A D D} \\ & \text { Hold Time } \end{aligned}$ |  | -3 |  | 0 |  | 0 |  | ns |
| ts | PREL Set-up Time |  | 15 |  | 27 |  | 35 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | PREL Hold Time |  | -5 |  | 0 |  | 0 |  | ns |
| tpWh | Clock Pulse Width High |  | 15 |  | 25 |  | 30 |  | ns |
| tPWL | Clock Pulse Width Low |  | 15 |  | 25 |  | 30 |  | ns |
| tPDP | Output Clock to P |  | 35 |  |  | 45 |  | 50 | ns |
| tpDY | Output Clock to $Y$ |  | 35 |  |  | 45 |  | 50 | ns |
| tPHZ | $\begin{aligned} & \mathrm{LEXX}_{\mathrm{X}} / \overline{\mathrm{EE}}_{\mathrm{X}}, \mathrm{LE}_{\mathrm{M}} / \overline{\mathrm{OE}}_{\mathrm{M}} \\ & \text { to } \mathrm{P}, \mathrm{LE}_{\mathrm{L}} / \overline{\mathrm{OE}} \\ & \text { to } \mathrm{Y} \text { Disabe Time } \\ & \hline \end{aligned}$ | High to Z | 24 |  |  | 35 |  | 40 | ns |
| tPLZ |  | Low to Z | 25 |  |  | 35 |  | 40 | ns |
| tPZH | $\mathrm{LE}_{X} / \overline{\mathrm{O}} \mathrm{E}_{\mathrm{X}}, \mathrm{LE}_{\mathrm{M}} / \overline{\mathrm{OE}}{ }_{M}$ to $P, L E_{L} / \overline{O E} L$ to $Y$ Enable Time | Z to High | 38 |  |  | 45 |  | 50 | ns |
| tPZL |  | Z to Low | 32 |  |  | 40 |  | 45 | ns |
| $\mathrm{t}_{\mathrm{HCL}}$ | Relative Hold Time |  |  |  | 0 |  | 0 |  | ns |

Note: 1. Typical limits are $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.



## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



ICR00490

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29526/527 | High speed Sine function <br> generator |
| Am29528/529 | High Speed Cosine function <br> generator |
| Am29540 | Programmable FFT address <br> sequencer |
| Am29520/21 | Multilevel pipeline registers |

# Am29516/17 Family 

- High speed $16 \times 16$ multiplier
- Two's complement, unsigned or mixed operands
- Full product multiplexed at output
- Improved speed: 38ns clocked multiply (A devices) Reduced power dissipation: 2W (L devices)


## DISTINCTIVE CHARACTERISTICS

- Am29516 pin and functionally compatible with TRW MPY-16HJ - Am29517 optimized for microprogramming, single clock with register enables
- TTL I/O-single +5 V supply - 64-pin package


## GENERAL DESCRIPTION

The Am29516 and Am29517 are high speed parallel $16 \times$ 16-bit multipliers utilizing internal ECL logic to generate a 32-bit product. 17-bit input registers are provided for the $X$ and $Y$ operands and their associated mode controls $X_{M}$ and $Y_{M}$. These mode controls are used to specify the operands as two's complement or unsigned numbers.

At the output of the multiplier array, a format adjust control (FA), allows the user to select either a full 32-bit product or a left-shifted 31-bit product suitable for two's complement only.

Two 16-bit output registers are provided to hold the most and least significant halves of the product (MSP and LSP) as defined by FA. For asynchronous output, these registers may be made transparent by taking the feedthrough control (FT) high. A round control (RND) allows the rounding of the MSP; this control is registered, and is entered whenever either input register is clocked.
The two halves of the product may be routed to a 16-bit 3state output port $(P)$ via a multiplexer, and in addition, the

LSP is connected to the Y -input port through a separate three-state buffer.

The Am29516 X, Y, MSP and LSP registers have independent clocks (CLKX, CLKY, CLKM, CLKL). The output multiplexer control (MSPSEL) uses a pin which is a supply ground in the TRW MPY 16HJ. When this control is LOW the function is that of the MPY16HJ, thus allowing full compatibility.
The Am29517 differs in that it has a single clock input (CLK) and three register enables (ENX, ENY, ENP) for the two input registers and the entire product, respectively. This facilitates the use of the part in microprogrammed systems. In both parts data is entered into the registers on the positive edge of the clock.

The Am29516A and Am29517A are higher speed versions of the Am29516 and Am29517, respectively, offering greater than $40 \%$ speed improvement while the Am29L516 and Am29L517 low-power versions consume only one-half the power of their standard power counterparts.

BLOCK DIAGRAM

Am29516/29516A/29L516


BD002840

Am29517/29517A/29L517


BD002850

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29501 | Multi-port Pipelined Processor |
| Am29526/27 | Sine Function Generator |
| Am29528/29 | Cosine Function Generator |
| Am29520/21 | Pipeline Register |
| Am29540 | Address Generator |

D-64-3


CDR04380

L-68-3


CDR04410

METALLIZATION AND PAD LAYOUT
Am29516A/29L516/29516


STANDARD DEVICE DIE SIZE: $250 \times 222$ MILS
'A' DEVICE DIE SIZE: $178 \times 190$ MILS
'L' DEVICE DIE SIZE: $250 \times 222$ MILS

D-64-3


CDR04390
L-68-3


CDR04400

## METALLIZATION AND PAD LAYOUT <br> Am29517A/29L517/29517



STANDARD DEVICE DIE SIZE: $250 \times 222$ MILS
'A' DEVICE DIE SIZE: $178 \times 190$ MILS
'L' DEVICE DIE SIZE: $250 \times 222$ MILS


CDR04370

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

*TD-64-1 (64-pin CERDIP) without heat sink for Low-Power versions

Note 1. 160-hour burn-in -
Heat sink parts: $\mathrm{T}_{\mathrm{A}}=125^{\circ} \mathrm{C}$
Non-heat sink parts: $\mathrm{T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$


## OUTPUT FORMATS

(All Devices)
Fractional 2's Complement (Shifted)* Output
$F A=0$
MSP
LSP

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $-2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ |

(Sign)
Fractional 2's Complement Output
$F A=1$
MSP
LSP
 (Sign)

## Integer Two's Complement Output

$F A=1$
MSP
LSP
 (Sign)

Unsigned Fractional Output
$F A=1$
MSP

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ | $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ | $2^{-16}$ |

LSP

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-17}$ | $2^{-18}$ | $2^{-19}$ | $2^{-20}$ | $2^{-21}$ | $2^{-22}$ | $2^{-23}$ | $2^{-24}$ | $2^{-25}$ | $2^{-26}$ | $2^{-27}$ | $2^{-28}$ | $2^{-29}$ | $2^{-30}$ | $2^{-31}$ | $2^{-32}$ |

## Unsigned Integer Output

$F A=1$
MSP
LSP

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

*In this format an overflow occurs in the attemped multiplication of the two's complement number $1.000 \ldots(-1)$ with itself, yielding a product of $1.000 \ldots$ or -1 .

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ -65 to $+150^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$ ..........-0.5 to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ .0 .5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ .0 .5 to +5.5 V
DC Output Current, Into Outputs ............................ 30 mA
DC Input Current .................................. 30 to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature

$$
\text { DIPs } \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . T_{A}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
$$

$$
\text { Chip Carriers.............................. } \mathrm{T}_{\mathrm{C}}=0^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}
$$

Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified Am29516/29517

| Parameters | Description | Test Conditions |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}=-0.4 \mathrm{~mA}$ | 2.4 | 2.7 |  | Volts |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MIN} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  | $\mathrm{lOL}=4.0 \mathrm{~mA}$ |  | . 3 | . 5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | . 8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{I}^{\prime}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.4 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  |  |  |  | 75 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \times}=5.5 \mathrm{~V}$ |  |  |  |  | 1 | mA |
| lozH | Off State (High Impedance) Output Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Product | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| lozl |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -25 |  |
| ISC | Output Short Circuit Current (Note 2) | $V_{C C}=\mathrm{MAX}$ | Y, Product | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | -3 |  | -30 | mA |
| Icc | Power Supply Current (Note 3) |  | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |  |  | 600 |  | mA |
|  |  | COM'L Devices $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | $\mathrm{T}_{A}=0$ to + | ote 4) |  |  | 800 |  |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C}$ |  |  |  | 750 |  |
|  |  | MIL Devices$V_{C C}=M A X$ | $\mathrm{T}_{A}=-55$ to |  |  |  | 900 |  |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=+125^{\circ}$ |  |  |  | 800 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{C C}=5.0 \mathrm{~V},+25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
3. $\overline{O E P}$ and $\overline{O E L}$ LOW with all product (MSP and LSP) bits LOW.
4. Chip Carriers: $\mathrm{T}_{\mathrm{C}}=85^{\circ} \mathrm{C}$.

DC CHARACTERISTICS over operating range unless otherwise specified Am29516A/29L516/Am29517A/29L517

| Parameters | Description | Test Conditions |  |  | Min | $\begin{array}{\|c} \text { Typ } \\ \text { (Note 1) } \end{array}$ | 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} \\ & \hline \end{aligned}$ |  | $\mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | 2.4 | 2.7 |  | Volts |
| $\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{OL}=4.0 \mathrm{~mA}$ |  | . 3 | . 5 | Volts |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  | . 8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.4 | mA |
| ${ }_{1 / 2}$ | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=2.4 \mathrm{~V}$ |  |  |  |  | 75 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  | 1 | mA |
| lozh | Off State (High Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ | Product | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| lozl |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -25 |  |
| Isc | Output Short Circuit Current (Note 2) | $V_{C C}=M A X$ | Y, Product | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | -3 |  | -30 | mA |
| Icc | Power Supply Current (Note 3) | COM'L Devices$V_{C C}=M A X$ | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | A Devices |  | 600 |  | mA |
|  |  |  |  | L Devices |  | 300 |  |  |
|  |  |  | $\begin{aligned} & T_{A}=0 \text { to }+70^{\circ} \mathrm{C} \\ & \text { (Note 4) } \end{aligned}$ | A Devices |  |  | 800 |  |
|  |  |  |  | L Devices |  |  | 400 |  |
|  |  |  | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=+70^{\circ} \mathrm{C} \\ & \text { (Note 4) } \end{aligned}$ | A Devices |  |  | 750 |  |
|  |  |  |  | L Devices |  |  | 350 |  |
|  |  | MIL Devices$V_{C C}=M A X$ | $\mathrm{T}_{\mathrm{C}}=-55$ to $+125^{\circ} \mathrm{C}$ | A Devices |  |  | 900 |  |
|  |  |  |  | L Devices |  |  | 440 |  |
|  |  |  | $\mathrm{T}_{\mathrm{CC}}=+125^{\circ} \mathrm{C}$ | A Devices |  |  | 800 |  |
|  |  |  |  | L Devices |  |  | 350 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
3. OEP and OEL LOW with all product (MSP and LSP) bits LOW.
4. Chip Carriers: $\mathrm{T}_{\mathrm{C}}=85^{\circ} \mathrm{C}$.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified (Note 1) Am29516/29517

| Parameters | Description | Test Conditions | Typ | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max | Min | Max |  |
| $\mathrm{t}_{\text {MUC }}$ | Unclocked Multiply Time |  | 50 |  | 85 |  | 95 | ns |
| $\mathrm{t}_{\mathrm{MC}}$ | Clocked Multiply Time |  | 40 |  | 65 |  | 75 | ns |
| ts | $X_{i}, Y_{i}$, RND Set-up Time |  | 10 | 20 |  | 25 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | $\mathrm{X}_{\mathrm{i}}, \mathrm{Y}_{\mathrm{i}}$, RND Hold Time |  | 0 | 3 |  | 3 |  | ns |
| tpWH | Clock Pulse Width High | Load 1 | 10 | 15 |  | 15 |  | ns |
| tpWL | Clock Pulse Width Low |  | 10 | 15 |  | 15 |  | ns |
| tPDSEL | $\overline{\text { MSPSEL }}$ to Product Out |  | 20 |  | 30 |  | 35 | ns |
| tPDP | Output Clock to P |  | 20 |  | 30 |  | 35 | ns |
| tpoy | Output Clock to Y |  | 20 |  | 30 |  | 35 | ns |
| tpHz | $\overline{\mathrm{OEP}}$ Disable Time | Load 2 | 12 |  | 23 |  | 28 | ns |
| tpLZ |  |  | 15 |  | 23 |  | 28 | ns |
| tpZH | $\overline{\mathrm{OEP}}$ Enable Time |  | 25 |  | 32 |  | 35 | ns |
| tPZL |  |  | 25 |  | 32 |  | 35 | ns |
| tpHz | OEL Disable Time |  | 12 |  | 23 |  | 28 | ns |
| tpLz |  |  | 15 |  | 23 |  | 28 | ns |
| tpzi | $\overline{\text { OEL Enable Time }}$ |  | 25 |  | 32 |  | 35 | ns |
| tpZL |  |  | 25 |  | 32 |  | 35 | ns |
| ts | Clock Enable Set-up Time (Am29517 Only) | Load 1 | 5 | 10 |  | 15 |  | ns |
| ${ }_{\text {th }}$ | Clock Enable Hold Time (Am29517 Only) |  | 0 | 3 |  | 3 |  | ns |
| thCL | Clock Low Hold Time CLKXY Relative to CLKML (See Note 2) (Am29516 Only) |  | 0 | 0 |  | 0 |  | ns |

Notes: 1. Switching Characteristics are measured and guaranteed for $T_{A}$ as specified with $200 \mathrm{Lf} / \mathrm{min}$ flowing across the device.
2. To ensure that the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.

| SWITCHING CHARACTERISTICS over operating range unless otherwise specified (Note 1) Am29L516/29L517 |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters | Description |  |  | Typ | COMMERCIAL |  | MILITARY* |  | Units |
|  |  |  | Conditions |  | Min | Max | Min | Max |  |
| tmuc | Unclocked Multiply Time |  | Load 1 | 90 |  | 120 |  | 135 | ns |
| $t_{\text {MC }}$ | Clocked Multiply Time |  |  | 70 |  | 90 |  | 100 | ns |
| ts | $X_{i}, Y_{i}$, RND Set-up Time |  |  |  | 25 |  | 25 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | $X_{i}, Y_{i}$, Hold Time |  |  |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | RND Hold Time |  |  |  | 3 |  | 3 |  | ns |
| tpWh | Clock Pulse Width High |  |  |  | 20 |  | 20 |  | ns |
| tpWL | Clock Puise Width Low |  |  |  | 20 |  | 20 |  | ns |
| tpdsel | $\overline{\text { MSPSEL }}$ to Product Out |  |  | 25 |  | 35 |  | 40 | ns |
| tPDP | Output Clock to P |  |  | 25 |  | 35 |  | 40 | ns |
| tPDY | Output Clock to Y |  |  | 25 |  | 35 |  | 40 | ns |
| $t_{\text {PHZ }}$ | OEP Disable Time | High to Z | Load 2 | 20 |  | 30 |  | 35 | ns |
| tpLZ |  | Low to Z |  | 20 |  | 30 |  | 35 | ns |
| $\mathrm{t}_{\text {PZH }}$ | OEP Enable Time | $z$ to High |  | 25 |  | 35 |  | 40 | ns |
| tPZL |  | Z to Low |  | 25 |  | 35 |  | 40 | ns |
| tPHZ | $\overline{O E L}$ Disable Time | High to Z |  | 20 |  | 30 |  | 35 | ns |
| tplz |  | Low to Z |  | 20 |  | 30 |  | 35 | ns |
| tpZH | OEL Enable Time | Z to High |  | 25 |  | 35 |  | 40 | ns |
| $\mathrm{t}_{\text {PZL }}$ |  | Z to Low |  | 25 |  | 35 |  | 40 | ns |
| ts | Clock Enable Set-up Time (Am29L517 Only) |  | Load 1 | 10 | 15 |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock Enable Hold Time(Am29L517 Only) |  |  |  | 3 |  | 5 |  | ns |
| ${ }_{\text {thCL }}$ | Clock Low Hold Tim Relative to CLKML (Am29L516 Only) | CLKXY <br> See Note 2) $\qquad$ |  |  | 0 |  | 0 |  | ns |

Notes: 1. Switching Characteristics are measured and guaranteed for $T_{A}$ as specified with $200 \mathrm{Lf} / \mathrm{min}$ flowing across the device.
2. To ensure that the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.
*PRELIMINARY

## SWITCHING CHARACTERISTICS over operating range unless otherwise specified (Note 1) Am29516A/517A

|  | Description | Test Conditions | Typ | COMMERCIAL |  | , MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters |  |  |  | Min | Max | Min | Max |  |
| $t_{\text {MUC }}$ | Unclocked Multiply Time | Load 1 | 45 |  | 58 |  | 65 | ns |
| ${ }_{\text {IMC }}$ | Clocked Multiply Time |  | 30 |  | 38 |  | 42 | ns |
| ts | $X_{i}, Y_{i}$, Set-up Time |  | 4 | 7 |  | 8 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | $X_{i}, Y_{i}$, Hold Time |  | 1 | 3 |  | 3 |  | ns |
| ts | RND Set-up Time |  | 4 | 7 |  | 8 |  | ns |
| $t_{H}$ | RND Hold Time |  | 1 | 3 | 2 | 3 | \% | ns |
| tpWH | Clock Pulse Width High |  | 7 | 7 |  | 8 |  | ns |
| tPWL | Clock Pulse Width Low |  | 7 | 13 |  | 3 |  | ns |
| tpDSEL | MSPSEL to Product Out |  | 13 |  | 18 |  | 21 | ns |
| tpDP | Output Clock to P |  | 15 | 4 | 20 |  | 23 | ns |
| tpDY | Output Clock to Y |  | 15. | , 3 | 20 |  | 23 | ns |
| tPHZ | OEP Disable Time |  | 13 | - | 15 |  | 17 | ns |
| tplz |  |  | 12 |  | 15 |  | 17 | ns |
| tPZH | OEP Enable Time |  | 20 |  | 23 |  | 25 | ns |
| tpZL |  |  | 15 |  | 23 |  | 25 | ns |
| $\mathrm{tPHz}^{\text {Pr }}$ | OEL Disable Time |  | 13 |  | 15 |  | 17 | ns |
| tplz |  |  | 12 |  | 15 |  | 17 | ns |
| tpzi | OEL Enable Time $z$ to High <br> $z$ to Low  |  | 20 |  | 23 |  | 25 | ns |
| tpZL |  |  | 15 |  | 23 |  | 25 | ns |
| ts | Clock Enable Set-up Time (Am29517A Only) | Load 1 |  | 10 |  | 15 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock Enable Hold Time (Am29517A Only) |  |  | 3 |  | 3 |  | ns |
| ${ }_{\text {thCl }}$ | Clock Low Hold Time CLKXY Relative to CLKML (See Note 2) (Am29516A Only) |  | -1 |  |  |  |  | ns |

Notes: 1. Switching Characteristics are measured and guaranteed for $T_{A}$ as specified with $200 \mathrm{Lf} / \mathrm{min}$ flowing across the device.
2. To ensure that the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.

## Notes on Testing

Incoming test procedures on this device should be carefully planned, taking into account the high complexity and power levels of the part. The following notes may be useful:

1. Insure the part is adequately decoupled at the test head. Large changes in $V_{C C}$ current as the device switches may cause erroneous function failures due to $\mathrm{V}_{\mathrm{CC}}$ changes.
2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency.
3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in $5-8 \mathrm{~ns}$. Inductance in the ground
cable may allow the ground pin at the device to rise by 100 s of millivolts momentarily.
4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $\mathrm{V}_{\mathrm{IL}}$ or $V_{I H}$ until the noise has settled. AMD recommends using $\mathrm{V}_{\mathrm{IL}} \leqslant 0.0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{IH}} \geqslant 3.0 \mathrm{~V}$ for AC tests.
5. To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests.
6. To assist in testing, AMD offers complete documentation on our test procedures and, in most cases, can provide Fairchild Sentry programs under license.


Notes: 1. Diagram shown for HIGH data only. Output tran-
sition may be opposite sense.
2. Cross hatched area is don't care condition.




## DISTINCTIVE CHARACTERISTICS

- Four 8-bit high speed registers
- Dual two-level or single four-level push-only stack operation
- All registers available at multiplexed output
- Hold, transfer and load instructions
- Provides temporary address or data storage
- 24-pin 0.3" package


## GENERAL DESCRIPTION

The Am29520 and Am29521 each contain four 8-bit positive edge-triggered registers. These may be operated as a dual 2 -level pipeline or as a single 4-level pipeline. A single 8-bit input is provided and any of the four registers is available at the 8 -bit, 3 -state output.

The Am29520 and Am29521 differ only in the way data is loaded into and between the registers in dual 2-level
operation. This difference is illustrated in Figure 1. In the Am29520 when data is entered into the first level (1-2 or $1-1$ ) the existing data in the first level is moved to the second level. In the Am29521 these instructions simply cause the data in the first level to be overwritten. Transfer of data to the second level is achieved using the 4 -level shift instruction $(l=0)$. This transfer also causes the first level to change. In either part $I=3$ is a HLD.

BLOCK DIAGRAM


BDR02270
*Multilevel Pipeline Register



Figure 1.

## METALLIZATION AND PAD LAYOUT CHIP TOPOGRAPHY Am29520/21



DIE SIZE: $0.117^{\prime \prime} \times 0.131^{\prime \prime}$
ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Valid Combinations |  |
| :--- | :--- |
| Am29520 | DC, DCB, DM, |
| Am29521 | DMB |

Temperature (See Operating Range)
C - Commercial ( 0 to $+70^{\circ} \mathrm{C}$ )
M - Military ( -55 to $+125^{\circ} \mathrm{C}$ )
Package
D-24-pin SLIM
Device Type
Multilevel Pipeline Registers

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| *Pin No. | Name | 1/0 | Description |  |
| 3-10 | $\mathrm{D}_{0}-\mathrm{D}_{7}$ |  | Register input port. |  |
| 11 | CLK |  | Clock input. Enter data into re | on LOW-to-HIGH transitions. |
| 1, 2 |  |  | Instruction inputs. See Figure 1 | Instruction Control Tables. |
| 23, 22 | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ |  | Multiplexer select. Inputs either | er $A_{1}, A_{2}, B_{1}$ or $B_{2}$ data to be available at the output port. |
| 13 | $\overline{\text { OE }}$ |  | Output enable for 3-state out |  |
| 14-21 | $Y_{0}-Y_{7}$ | 0 | Register output port. |  |
| *DIP Configuration <br> APPLICATIONS <br> The IMOX ${ }^{\text {TM }}$ Am29520 and Am29521 multilevel pipeline registers are specifically designed as a temporary address storing register for array processing and digital signal processing applications using the Am29500 Family. <br> In AP/DSP applications a single data address may be used a multiple number of times. The multilevel pipeline register allows saving addresses within its registers for use at a later time. <br> Below are a number of applications where the use of a multilevel pipeline register can be implemented. <br> CLOCK CONTROLLER, BYTE-WIDE DELAY LINE/SHIFT REGISTER <br> The Am29520/21 can be utilized as a byte-wide shift register capable of delaying a byte of data from one to four clock cycles. The number of delay cycles is controlled by the $\mathrm{S}_{0}, \mathrm{~S}_{1}$ <br> control inputs and can be changed by the user without interrupting the data flow. <br> ANALOG/DIGITAL BUFFER <br> In the example shown in Figure 2 the Am29520/21 acts as a 4-byte buffer between an A/D converter and a controller (or microprocessor). Four digitized samples are sequentially stored in the Am29520/21 from the A/D converter. This is accomplished by applying a READ control input to the clock input of the Am29520/21 as well as to the READ input of the A/D. Since $I=0$, the data output from the A/D will be stored in the Am29520/21 as shown in Figure 3. <br> While the fifth sample is being acquired by the $A / D$, the controller will read all registers of the Am29520/21 by manipulating $\mathrm{S}_{0}, \mathrm{~S}_{1}$. Note that the three-state output (controlled by OE) can be tied directly to a microprocessor bus and that the registers of the Am29520/21 can be easily memory mapped. |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |

Figure 2. A/D Buffer


Figure 3. A/D Buffer Timing

$\mathbf{S}_{0}, \mathbf{S}_{\mathbf{1}}$ INPUT


AFR01710
The A/D will acquire four more samples before the Am29520/21 registers need to be read.
Note that the Am29520/21 can be simultaneously written and read. A two byte ping-pong memory is realizable by switching between 1 modes 1 and 2. While the $A / D$ is writing registers $B_{1}$ and $B_{2}$, the microprocessor can be reading registers $A_{1}$ and $A_{2}$.

Also, note that the Am29520/21 is easily cascadable in width for applications involving 12-bit and 16-bit A/D converters.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature -65 to $+150^{\circ} \mathrm{C}$
Temperature Under Bias-TC -55 to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potentia Continuous $\qquad$ -0.5 to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ .-0.5 to +5.5 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current .............................. 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
+4.75 V to +5.25 V

Military (M) Devices
Temperature
$\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $. \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots+4 . \mathrm{F}^{2} \ldots$ to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second
4. All inputs LOW
SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters |  | Description | Test Conditions | Min | Typ | Max | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min |  |  |  |  | Max | Min | Max |  |
| tPD | tpLH |  | Clock to Data Output | $\begin{aligned} \mathrm{R}_{\mathrm{L}} & =280 \Omega \\ \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \end{aligned}$ |  | 12 | 18 |  | 21 |  | 24 |  |
|  | tPHL |  |  |  | 12 | 20 |  | 22 |  | 24. | ns |
| tpdsel | tplH | $S_{0}, S_{1}$ to Data Output |  |  | 12 | 18 |  | 20 |  | 22 | ns |
|  | tpHL |  |  |  | 12 | 18 |  | 20 |  | 22 |  |
| ts |  | Input Data to Clock | 10 |  |  |  | 10 |  | 10 |  | ns |
| ${ }_{\text {t }}$ |  |  | 3 |  |  |  | 3 |  | 3 |  |  |
| ts |  | Instruction (Register Enable) to Clock | 10 |  |  |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ |  |  | 3 |  |  |  | 3 |  | 3 |  |  |
| tphz |  | OE. to Output | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 5 | 11 |  | 13 |  | 14 | ns |
| tPLZ | , | OE to Output | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 6 | 13 |  | 15 |  | 16 | ns |
| tpZH |  | OE to Output | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=280 \Omega \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \end{aligned}$ |  | 12 | 18 |  | 20 |  | 22 | ns |
| tpZL |  | $\overline{\text { OE }}$ to Output |  |  | 13 | 20 |  | 21 |  | 22 | ns |
| tpWH |  | Clock Pulse Width HIGH |  | 10 |  |  | 10 |  | 10 |  | ns |
| tpWL |  | Clock Pulse Width LOW |  | 10 |  |  | 10 |  | 10 |  | ns |

[^14]
## SWITCHING TEST CIRCUIT

## SWITCHING TEST CIRCUITS FOR DELAY MEASUREMENTS


${ }^{*} \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ for all tpD, $\mathrm{t}_{\mathrm{ZH}}$ and $\mathrm{t}_{\mathrm{ZL}}$
$C_{L}=5 p F$ for $t_{H Z}$ and $t_{L Z}$

TEST WAVEFORMS

| Test | Output Waveform - Measurement Level |  |
| :---: | :---: | :---: |
| All tpDS |  | $S_{1}$ Closed <br> $\mathrm{S}_{2}$ Closed |
| $t_{\text {PHZ }}$ |  | $S_{1}$ Closed <br> $\mathrm{S}_{2}$ Closed |
| $t_{\text {PLZ }}$ | $v_{\mathrm{OL}} 0.5 \mathrm{~V} \perp \mathrm{~T}$ | $S_{1}$ Closed <br> $\mathrm{S}_{2}$ Closed |
| ${ }_{\text {tPZH }}$ |  | $S_{1}$ Open <br> $\mathrm{S}_{2}$ Closed |
| ${ }^{\text {tPZL }}$ |  | $S_{1}$ Closed <br> $S_{2}$ Open |

WFR02920


WFR02930

Am29520/21
THREE-STATE TIMING


WFR02940


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29540 | FFT Address Sequencer |
| Am29116 | 16 -bit Bipolar Microprocessor |
| Am2925 | System Clock Generator and Driver |
| Am29517 | $16 \times 16$-bit High Speed Multiplier |
| Am29510 | $16 \times 16$-bit Multiplier Accumulator |
| Am6108 | 8 -bit Microprocessor Compatible <br> A/D Converter |
| Am9128-70 | $2 \mathrm{KK} \times 8$ Static RAM |
| Am21L47-55 | $4 \mathrm{~K} \times 1$ Static RAM |

# Am29526 • Am29527 Am29528 • Am29529 

High Speed Sine, Cosine Generators

| distinctive characteristics <br> - Provides values for sine/cosine functions in $\pi / 2048$ increments <br> - Outputs are 16 -bit two's complement fractions <br> - Fast generation time of 50 ns max Com'l <br> - S/LS compatible <br> - Three-state outputs <br> - IMOX $^{T M}$ processing |  |
| :---: | :---: |
| RELATED PRODUCTS |  |
| Part No. | Description |
| Am29516/17 | $16 \times 16$-Bit High Speed Mutipliers |
| Am29510 | $16 \times 16$ - Bit Muttiply Accumulator. |

CONNECTION DIAGRAMS - Top Views
DIP


Chip-Pak ${ }^{\text {TM }}$
ABL-006


## FUNCTIONAL DESCRIPTION

The Am29526/27 and Am29528/29 provide high speed generation of sine and cosine functions over the range $0 \leqslant \theta<\pi$ in increments of $\pi / 2048$. $\theta$ is determined by an 11-bit input word. Each device provides an 8-bit output and two are used to give the full 16 -bit value. The Am29526 and Am29527 generate the MS and LS bytes respectively for the sine function. Similarly, the Am29528 and Am29529 generate the cosine functions.
The outputs are fractional two's complement numbers with the radix point located immediately to the right of the sign bit (in between the bits weighted $-2^{\circ}$ and $2^{-1}$ ). As this format does not allow for the representation of +1 the functions generated are $-\sin \theta$ and $-\cos \theta$. In this way the output values are restricted to the range $-1 \leqslant f(\theta)<+\uparrow$ which is representable. The outputs are three-state with one active Low enable and two active High enable.

While providing general purpose sine and cosine function capability, the Am29526/27/28/29 satisfy the requirements of the Am29540 FFT Address Sequencer.


## Am29526/27/28/29

ELECTRICAL CHARACTERISTICS
The following conditions apply unless otherwise specified:
COM'L $\quad T_{A}=0$ to $+70^{\circ} \mathrm{C}$
$V_{C C}=5.0 \mathrm{~V} \pm 5 \% \quad(\mathrm{MIN}=4.75 \mathrm{~V}$
$\mathrm{MAX}=5.25 \mathrm{~V}$ )
MIL $\quad T_{C}=-55$ to $+125^{\circ} \mathrm{C} \quad \mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \% \quad(\mathrm{MIN}=4.50 \mathrm{~V} \quad \mathrm{MAX}=5.50 \mathrm{~V})$

## DC CHARACTERISTICS OVER OPERATING RANGE



Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
2. Not more than one output should be shorted at a time. Duration of the short circuit should not be more than one second.
3. These parameters are not $100 \%$ tested, but are periodically sampled.

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

| Storage Temperature | -65 to $+\mathbf{1 5 0 ^ { \circ } \mathrm { C }}$ |
| :--- | ---: |
| Temperature (Ambient) under Bias | -55 to $+\mathbf{1 2 5 ^ { \circ } \mathrm { C }}$ |
| Supply Voltage to Ground Potential Continuous | -0.5 to $+\mathbf{7 . 0 \mathrm { V }}$ |
| DC Voltage Applied to Outputs | $-\mathbf{0 . 5 \mathrm { V } \text { to } + \mathrm { V } _ { \mathrm { CC } } \mathbf { ~ m a x }}$ |
| DC Input Voltage | -0.5 to $+\mathbf{5 . 5 \mathrm { V }}$ |
| DC Input Current | $-\mathbf{3 0}$ to $+\mathbf{5 m A}$ |

## DEFINITION OF FUNCTIONAL TERMS

$\mathrm{A}_{10}-\mathrm{A}_{0}$
Data Input Values
Input, $\theta$, corresponding to $\theta=0$ (000) to 2047 $\pi$ / 2048 (3FF). $\mathrm{A}_{10}$ is MSB.
$\bar{E}_{1}, E_{2}, E_{3}$ Output Enables
When $\bar{E}_{1}$ is Low and $E_{2}$ and $E_{3}$ are High, the
outputs $F_{0}-F_{7}$ are enabled. Otherwise the outputs are in the high impedance state or off.
Data Output Values
The outputs corresponding to $-\sin \theta$ or $-\cos \theta$. $F_{7}$ is MSB.

Am29526/27/28/29
SWITCHING CHARACTERISTICS
OVER OPERATING RANGE

| Parameters |  |  |  | COM'L | MIL | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{gathered} \mathrm{T}_{A}=+25^{\circ} \mathrm{C} \\ \mathrm{~V}_{\mathrm{CC}}=5 \mathbf{V} \end{gathered}$ | $\begin{aligned} & T_{A}=0 \text { to }+70^{\circ} \mathrm{C} \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ | $\begin{gathered} \mathrm{TC}=-55 \text { to }+125^{\circ} \mathrm{C} \\ \mathrm{VCC}=5 \mathrm{~V} \pm 10 \% \end{gathered}$ |  |  |
|  | Description |  | Typ | Max | Max |  |  |
| tpli | Sin/Cos Generation Time $A_{i}$ to $F_{i}$ |  | 30 | 50 | 65 | ns | $\begin{gathered} R_{L}=600 \Omega \\ C_{L}=30 \mathrm{pF} \\ \text { (Notes } 1 \text { and 2) } \end{gathered}$ |
| $\mathrm{t}_{\text {PHL }}$ |  |  | 30 | 50 | 65 | ns |  |
| $\mathrm{t}_{\text {PHZ }}$ | $\begin{aligned} & \bar{E}_{1}, \mathrm{E}_{2}, \mathrm{E}_{3} \\ & \text { Disable Time } \end{aligned}$ | High to Z | 10 | 25 | 30 | ns |  |
| tplz |  | Low to Z | 10 | 25 | 30 | ns |  |
| tPZH | $\begin{aligned} & \overline{\mathrm{E}}_{1}, \mathrm{E}_{2}, \mathrm{E}_{3} \\ & \text { Enable Time } \end{aligned}$ | Z to High | 10 | 25 | 30 | ns |  |
| tpzl |  | Z to Low | 10 | 25 | 30 | ns |  |

Notes: 1. $t_{P L H}$ and $t_{P H L}$ are tested with switch $S_{1}$ closed and $C_{L}=30 \mathrm{pF}$.
2. For three-state outputs, the disables time is tested with $C_{L}=30 \mathrm{pF}$ to the 1.5 V level; $S_{1}$ is open for $Z$ to High test and closed for $Z$ to $L o w$ test. The enable time is tested with $C_{L}=5 p F$. High to $Z$ tests are made to an output voltage to $V_{O H}-0.5 \mathrm{~V}$ with $S_{\dagger}$ open; Low to $Z$ tests are made to the $\mathrm{V}_{\mathrm{OL}}-0.5 \mathrm{~V}$ level with $\mathrm{S}_{1}$ closed.

## SWITCHING WAVEFORMS



## AC TEST LOAD



TABLE 1. $-\operatorname{COS}(\theta)$ TABLE

| Decimal <br> Input | Actual <br> Hexadecimal <br> Input | Angle <br> in Radians | Decimal Value <br> of $-\boldsymbol{\operatorname { C o s } ( \boldsymbol { \theta } )}$ | Hex Value <br> of $-\boldsymbol{\operatorname { C o s } ( \boldsymbol { \theta } )}$ | Am29526 <br> MS Device | Am29527 <br> LS Device |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | -1.000000 | 1000 | 10 | 00 |
| 512 | 200 | $\pi / 4$ | -0.707107 | A57E | A5 | 7 E |
| 1024 | 400 | $\pi / 2$ | 0.000000 | 0000 | 00 | 00 |
| 1536 | 600 | $3 \pi / 4$ | +0.707107 | $5 A 82$ | $5 A$ | 82 |
| 2047 | $7 F F$ | $2047 \pi / 2048$ | +0.999999 | 7 FFF | 7 F | FF |

TABLE 2. - $\operatorname{SIN}(\theta)$ TABLE

| Decimal <br> Input | Actual <br> Hexadecimal <br> Input | Angle <br> in Radians | Decimal Value <br> of $-\operatorname{Sin}(\boldsymbol{\theta})$ | Hex Value <br> of $-\boldsymbol{\operatorname { S i n } ( \boldsymbol { \theta } )}$ | Am29528 <br> MS Device | Am29529 <br> LS Device |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 000 | 0 | 0 | 0000 | 00 | 00 |
| 512 | 200 | $\pi / 4$ | -0.707107 | A57E | A5 | 7 E |
| 1024 | 400 | $\pi / 2$ | -1.00000 | 8000 | 80 | 00 |
| 1536 | 600 | $3 \pi / 4$ | -0.707107 | A57E | A5 | 7 E |
| 2047 | 7FF | $2047 \pi / 2048$ | -0.001534 | FFCE | FF | CE |

Figure 1. The Minus Sine Function

-

Figure 2. The Minus Cosine Function


## ORDERING INFORMATION

Order the part number according to the table below to obtain the desired package, temperature range and screening level.

| Order Number | Package Type <br> (Note 1) | Operating Range <br> (Note 3) | Screening Level (Note 2) |
| :---: | :---: | :---: | :---: |
| AM29526PC | P-24-1AA | C | C-1 |
| AM29527PC | P-24-1AA | C | C-1 |
| AM29528PC | P-24-1AA | C | C-1 |
| AM29529PC | P-24-1AA | C | C-1 |
| AM29526PC-B | P-24-1AA | C | B-1 |
| AM29527PC-B | P-24-1AA | C | B-1 |
| AM29528PC-B | P-24-1AA | C | B-1 |
| AM29529PC-B | P-24-1AA | C | B-1 |
| AM29526DC | D-24-1AA | C | C-1 |
| AM29527DC | D-24-1AA | C | C-1 |
| AM29528DC | D-24-1AA | C | C-1 |
| AM29529DC | D-24-1AA | C | C-1 |
| AM29526DC-B | D-24-1AA | C | B-1 |
| AM29527DC-B | D-24-1AA | C | B-1 |
| AM29528DC-B | D-24-1AA | C | B-1 |
| AM29529DC-B | D-24-1AA | C | B-1 |
| AM29526DM | D-24-1AA | M | C-3 |
| AM29527DM | D-24-1AA | M | C-3 |
| AM29528DM | D-24-1AA | M | C-3 |
| AM29529DM | D-24-1AA | M | C-3 |
| AM29526DM-B | D-24-1AA | M | B-3 |
| AM29527DM-B | D-24-1AA | M | B-3 |
| AM29528DM-B | D-24-1AA | M | B-3 |
| AM29529DM-B | D-24-1AA | M | B-3 |
| AM29526LC | L-32-2 | C | C-1 |
| AM29527LC | L-32-2 | C | C-1 |
| AM29528LC | L-32-2 | C | C-1 |
| AM29529LC | L-32-2 | C | C-1 |
| AM29526LM | L-32-2 | M | C-3 |
| AM29527LM | L-32-2 | M | C-3 |
| AM29528LM | L-32-2 | M | C-3 |
| AM29529LM | L-32-2 | M | C-3 |
| AM29526LM-B | L-32-2 | M | B-3 |
| AM29527LM-B | L-32-2 | M | B-3 |
| AM29528LM-B | L-32-2 | M | B-3 |
| AM29529LM-B | L-32-2 | M | B-3 |

Notes: 1. $\mathrm{P}=$ Molded DIP, $\mathrm{D}=$ Hermetic DIP, $\mathrm{L}=$ Chip-Pak. Number following letter is number of leads. See
Appendix B for detailed outline. Where Appendix B contains several dash numbers, any of the variations of the package may be used unless otherwise specified.
2. Levels C-1 and C-3 conform to MIL-STD-883, Class C. Level B-3 conforms to MIL-STD-883, Class B
3. $\mathrm{C}=0$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.75$ to $5.25 \mathrm{~V}, \mathrm{M}=-55$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.50$ to 5.50 V .

# Am29540 

Programmable FFT Address Sequencer

## DISTINCTIVE CHARACTERISTICS

－Generates data and coefficient addresses
－Programmable transform length 2 to 65,536 points
－Radix－2 or Radix－4
－In－place or non－in－place transformation
－Decimation in frequency（DIF）or decimation in time （DIT）FFT algorithms supported
－40－pin DIP package， 5 volt single supply

## GENERAL DESCRIPTION

The Am29540 Fast Fourier Transform Address Sequencer generates all the data（RAM）and coefficient（ROM）ad－ dresses necessary to perform the repetitive butterfly opera－ tions of the FFT．Decimation in time and decimation in frequency algorithms are supported（control DIT／DIF）in radix－2 or radix－4（RADIX 4／$\overline{2}$ ）．A radix－2 real valued input （RVI）transform is also supported．For radix－2 operation the transform length is programmable in powers of 2 from 2 to 65,536 points．In radix－4 the range is 4 to 65,536 in powers of 4 ．

Address sequences can be selected to be compatible with data which may or may not have been pre－scrambled（＇bit－ reversed＇）．If the data has been pre－scrambled the control $\overline{\text { PSD }}$ must be LOW to select the correct sequence．If the data is not pre－scrambled（ $\overline{\mathrm{PSD}} \mathrm{HIGH}$ ）and an in－place transform is performed，the output data will necessarily be in bit－reversed order．If this is not desirable，alternate addresses are available for a non－in－place，non－bit－revers－ ing algorithm．

The butterfly counter operates on the positive clock edge and responds to four instructions．COUNT causes the counter to increment to the next butterfly．RESET causes the counter to initialize for the specified transform length． RESET／LOAD causes the counter to initialize and a data address offset to be loaded into the part via the bi－ directional 3－state ADDRESS port．This offset is effectively OR－ed onto the higher significant bits of the address which are unused for the selected transform length．A HOLD instruction is also provided．Three status lines are provided．
 write memories for non－in－place transforms and determines the butterfly structure in the RVI transform．The flag has the function KNZ／$\overline{K Z}$ when RVI data addresses are selected （ $A S=12$ to 15）．Iteration complete（IT COMP）flags the bottom of a＂column＇of butterflies and is used in conjunc－ tion with block floating point schemes．FFT COMP identifies the last butterfly of the transform．


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29501 | Multi-port pipelined processor <br> (Byte-slice ${ }^{\text {}}$ (M) |
| Am29516/17 | $16 \times 16$ parallel multiplier |
| Am29520/21 | Multilevel pipeline register |
| Am29526/ <br> $27 / 28 / 29$ | High speed sine/cosine <br> generators |
| Am29825 | High performance 8-bit <br> register |



## PIN DESCRIPTION

| *Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 31-34 | $\begin{aligned} & \mathrm{TL}_{3}, \mathrm{TL}_{2} \\ & \mathrm{TL}_{1}, \mathrm{TL}_{0} \\ & \hline \end{aligned}$ | 1 | Transform length control determines the number of points to be transformed. (See Figure 1.) |
| 36, 35 | TSEL, TSTRB | I | Transform length latch enables. These active LOW inputs are ANDed to control the latch. The latch is transparent when both TSEL and TSTRB are LOW. |
| 29, 28 | $\mathrm{I}_{0}, \mathrm{I}_{1}$ | 1 | Counter Instruction inputs determine one of four available butterfly counter instructions: Hold, Reset, Reset/Load and Count. (See Figure 2.) |
| 27 | CP | 1 | Butterfly counter clock (positive edge active). |
| 22 | Radix 4/ $\overline{2}$ | 1 | The Radix control determines whether addresses will be generated for Radix-4 (HIGH) for Radix-2 (LOW) transforms. |
| 23 | $\overline{\text { PSD }}$ | 1 | The Pre-Scrambled Data, $\overline{\text { PSD }}$, input is used to select an appropriate transform for input data which has previously been digit reversed. Refer to individual transform flow charts for other cases. |
| 24 | DIT/DIF | 1 | Control input for selection of the Decimation in Frequency algorithm (LOW) or Decimation In Time algorithm (HIGH). |
| 26, 25 | $\overline{\text { SEL, }}$ STRB | I | Transform type (Radix 4/ $\overline{2}, \mathrm{PSD}, \mathrm{DIF} / \overline{\mathrm{T}}$ ) latch enables. These active LOW inputs are ANDed to control the latch. The latch is transparent when both SEL and STRB are LOW. |
| 1, 38-40 | $\begin{aligned} & \mathrm{AS}_{3}, \mathrm{AS}_{2}, \\ & \mathrm{AS}_{1}, \mathrm{AS}_{0} \\ & \hline \end{aligned}$ | 1 | Address Select control determines address selection. (See Figure 3.) |
| 19 | $\overline{\text { OE }}$ | 1 | Three-state output enable. The 3 -state output is controlled solely by $\overline{\mathrm{OE}}$. The output does not automatically become high impedance during the Reset/Load instruction. |
| 2-9, 11-18 | $\mathrm{A}_{15}-\mathrm{A}_{0}$ <br> Address Output <br> (offset input) | 1/0 | Bidirectional 16-bit port to output selected addresses or to input an address offset. |
| 37 | $\begin{aligned} & \text { ODD/EVEN, } \\ & \text { (KNZ/KZ) } \end{aligned}$ | 0 | For address select 0 to 11 the ODD/EVEN output controls the alternation of separate read and write memories for non-in-place transforms. For Address select 12 to $15 \mathrm{KNZ} / \overline{\mathrm{KZ}}=$ (LOW) indicates that the rotational constant to be used in the RVI transform is $\mathrm{W}^{0}$ and that an alternative butterfly must be implemented. |
| 20 | FFT COMP | 0 | FFT Complete $=$ HIGH identifies the last butterfly (or end) of the transform. (See Figure 4.) |
| 21 | IT COMP | 0 | Iteration Complete $=$ HIGH flags the bottom of a 'column' of butterflies. (See Figure 4.) |

## DETAILED DESCRIPTION

The Am29540 can be pictured as consisting of sixteen 16-bit counters that output on a bidirectional three-state address port, $A_{15}-A_{0}$. These sixteen counters generate the data and coefficient addresses required to support the various FFT algorithms.

Decimation-In-Time (DIT) and Decimation-In-Frequency (DIF) algorithms are supported in Radix-2 and Radix-4. Two inputs, DIT/ $\overline{\mathrm{DIF}}$ and Radix $4 / \overline{2}$, control these two parameters without encoding. A third microcode bit, $\overline{\mathrm{PSD}}$, enables input data to be bit reversed. PSD must be LOW for all transforms with prescrambled (bit reversed) input data. For all in-place transforms with normally-ordered input data, $\overline{\text { PSD }}$ must be HIGH. For all non-in-place DIT transforms, $\overline{\text { PSD }}$ must be LOW, and for all non-in-place DIF transforms, $\overline{\text { PSD }}$ must be HIGH. These three microcode bits can be latched. $\overline{\text { STRB }}$ and $\overline{\text { SEL }}$ are the latch enables. They are ANDed so that the latch is transparent when both are LOW.

The transform length is latched via the $\mathrm{TL}_{3}-\mathrm{TL}_{0}$ inputs. TSTRB and TSEL are the latch enables. They are ANDed so that the latch is transparent when both are LOW. For Radix-4 operations, the transform length is programmable in powers of 4, from 4 to 65,536 points. In Radix-2, the range is 2 to 65,536 points in powers of 2. A Radix-2 Real Valued Input (RVI) algorithm is also supported for transform lengths from 2 to 65,536, in powers of 2 . Codes to program the transform length are contained in Figure 1.

Two microcode bits, $I_{1}-l_{0}$, control the operation of the Am29540. The four possible instructions are:

1. HOLD. All counters hold their last values. This instruction is used at any time the counter values must remain constant and could be used during initialization of the part.
2. RESET. All counters are reset to the start of the transform. All unused address lines are set to zero. Control bits DIT/ $\overline{\mathrm{DIF}}$, Radix $4 / \overline{2}$ and $\overline{\mathrm{PSD}}$ are unaffected.
3. RESET/LOAD. All counters are reset to the start of the transform. All unused address lines are set to the current value of the address port. This allows loading of an offset address via the bidirectional address port. This offset is effectively ORed onto the higher significant bits of the address which are unused for the transform length. Only data address counters are affected. Coefficient address counters are not affected.
4. COUNT. All counters are incremented to their next valid address.

## Codes for all four instructions are contained in Figure 2.

Four address select controls, $\mathrm{AS}_{3}-\mathrm{AS}_{0}$, choose which of the sixteen counter outputs are available at the address port. Typically, these bits would come from the microcode. Data addresses are right-justified, $\mathrm{A}_{15}$ being the MSB. Coefficient addresses are left-justified: $A_{15}$ is the MSB for Radix-4 operations; $\mathrm{A}_{14}$ is the MSB for Radix-2 operations. Codes for $A S_{3}-A S_{0}$ are contained in Figure 3.
Two output flags, ITCOMP and FFTCOMP, indicate counter status. When the bottom of a column of butterflies is reached, Iteration Complete (ITCOMP) goes HIGH. When the last butterfly (or end) of the transform is reached, FFT Complete (FFTCOMP) also goes HIGH. These two flags would typically be condition code inputs to the microprogram sequencer.
A third flag is used to indicate end of column for non-in-place transforms or one of two butterfly types for RVI transforms. For column indication, the flag is called ODD/EVEN and can be used to switch memory banks. The flag will be a HIGH for the last column of butterflies. In the RVI transform the flag is called KNZ/KZ. The equations for the butterfly when the rotational constant is $W^{0}$ are different from when the rotational constant is not $W^{0}$. When KNZ/ $\overline{K Z}$ is LOW, it indicates that the rotational constant to be used is $\mathrm{W}^{0}$ and that the alternative butterfly equations must be executed. Typically there are two microcode segments. The KNZ/ $\overline{K Z}$ flag would be a condition code input to the sequencer to select one of the two segments.

|  |  |  |  | Transform Length |  |  |  |
| :---: | :---: | :---: | :---: | ---: | ---: | ---: | :---: |
| $\mathbf{T L}_{\mathbf{3}}$ |  |  | TL $_{\mathbf{2}}$ | TL $_{\mathbf{1}}$ |  | TL $_{\mathbf{0}}$ |  |
| L | L | L | Radix-2 | Radix-4 | RVI |  |  |
| L | L | L | H | 2 | 4 | 4 |  |
| L | L | H | L | 8 | 4 | 8 |  |
| L | L | H | H | 16 | 16 | 16 |  |
| L | H | L | L | 32 | 64 | 16 |  |
| L | H | L | H | 64 | 64 | 64 |  |
| L | H | H | L | 128 | 256 | 128 |  |
| L | H | H | H | 256 | 256 | 256 |  |
| H | L | L | L | 512 | 1024 | 1024 |  |
| H | L | L | H | 1024 | 1024 | 2048 |  |
| H | L | H | L | 2048 | 4096 | 4096 |  |
| H | L | H | H | 4096 | 4096 | 8192 |  |
| H | H | L | L | 8192 | 16384 | 16384 |  |
| H | H | L | H | 16384 | 16384 | 32768 |  |
| H | H | H | L | 32768 | 65536 | 65536 |  |
| H | H | H | H | 65536 | 65536 | Not Used |  |

Figure 1. Transform Length Control

| $I_{1}$ | $I_{0}$ | Counter Function |
| :---: | :--- | :--- |
| L | L | Hold |
| L | H | Reset. Reset counter to start of transform <br> with unused address outputs set to 0. |
| H | L | Reset/Load. Reset counter to start of transform <br> with unused address outputs set to the current <br> value of the address bus. |
| H | H | Count. Increment butterfly counter. |

Figure 2. Counter Instruction Control

| FFT Type | AS $_{\mathbf{3}}$ | AS $_{\mathbf{2}}$ |
| :---: | :---: | :---: |
| Complex Input | L | X |
|  | H | L |

Figure 2a. Offset Address Control

| AS $=$ | AS $_{\mathbf{3}}$ | $\mathbf{A S}_{\mathbf{2}}$ | $\mathbf{A S}_{\mathbf{1}}$ | $\mathbf{A S}_{\mathbf{0}}$ | Description | Usage |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- |
| 0 | L | L | L | L | Data Address 1 | Radix 2/4 |
| 1 | L | L | L | H | Data Address 2 | Radix 2/4 |
| 2 | L | L | H | L | Data Address 3 | Radix 4 |
| 3 | L | L | H | H | Data Address 4 | Radix 4 |
| 4 | L | H | L | L | Alt. Data Address 1 | Radix 2/4 |
| 5 | L | H | L | H | Alt. Data Address 2 | Radix 2/4 |
| 6 | L | H | H | L | Alt. Data Address 3 | Radix 4 |
| 7 | L | H | H | H | Alt. Data Address 4 | Radix 4 |
| 8 | H | L | L | L | Const Address 1 | Radix 2/4, Shading |
| 9 | H | L | L | H | Const Address 2 | Radix 4 |
| 10 | H | L | H | L | Const Address 3 | Radix 4 |
| 11 | H | L | H | H | Const Address 1 | Shading |
| 12 | H | H | L | L | RVI Data Address 1 | RVI |
| 13 | H | H | L | H | RVI Data Address 2 | RVI |
| 14 | H | H | H | L | RVI Data Address 3 | RVI |
| 15 | H | H | H | H | RVI Data Address 4 | RVI |

Figure 3. Address Select Control

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ -65 to $+150^{\circ} \mathrm{C}$
Temperature Under Bias-TC $\ldots \ldots . . . . . . . . . . . .-55$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous ..........................................-0.5 to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage -0.5 to +5.5 V
DC Output Current, Into Outputs ............................. 30mA
DC Input Current
. -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
DIPs $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Chip Carriers................................ $\mathrm{T}_{\mathrm{C}}=0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $\mathrm{T}_{\mathrm{C}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output shouid be shorted at a time. Duration of the short circuit test should not exceed one second.
4. OE LOW and all inputs LOW.
5. It is limited to 5.5 V because $A_{0}$ to $A_{15}$ inputs also connect to output transistors.
6. Chip Carriers: $\mathrm{T}_{\mathrm{C}}=0$ to $85^{\circ} \mathrm{C}$.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified ( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ )


SWITCHING CHARACTERISTICS over operating range unless otherwise specified


## SWITCHING TEST CIRCUIT

A. THREE-STATE OUTPUTS
B. NORMAL OUTPUTS


$$
\mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{1 \mathrm{~K}}} \quad \mathrm{R}_{2}=\frac{2.4 \mathrm{~V}}{\mathrm{lOH}} \quad \mathrm{R}_{1}=\frac{5.0-\mathrm{V}_{\mathrm{BE}}-\mathrm{V}_{\mathrm{OL}}}{\frac{\mathrm{lOL}+\mathrm{V}_{\mathrm{OL}}}{\mathrm{R}_{2}}}
$$

Notes: 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.
2. $S_{1}, S_{2}, S_{3}$ are closed during function tests and all AC tests except output enable tests.
3. $S_{1}$ and $S_{3}$ are closed while $S_{2}$ is open for tpZH test.
$S_{1}$ and $S_{2}$ are closed while $S_{3}$ is open for tpZL test.
4. $C_{L}=5.0 \mathrm{pF}$ for output disable tests.

| Test | Output Waveform - Measurement Level |
| :---: | :---: |
| All ${ }_{\text {tPD }}$ |  |
| ${ }_{\text {tPHZ }}$ |  |
| $t_{\text {PLZ }}$ | $\mathrm{v}_{\mathrm{OL}}^{0.5 \mathrm{~V} \perp \mathrm{~T}}$ |
| ${ }^{\text {t }}$ PZH |  |
| ${ }^{\text {tPRL }}$ |  |



WFR02850

## SET－UP AND HOLD TIME



WFR02970

Notes：1．Diagram shown for HIGH data only．Output transition may be opposite sense．
2．Cross hatched area is don＇t care condition．



## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS





TRANSFORM CHARACTERISTICS

- 16-Point $(\mathrm{N}=16)$
- RADIX-2
- DIF
- Normally ordered input data (Bit-reversed output data order)
- In-place
- Complex valued input data


## FORWARD TRANSFORM INVERSE TRANSFORM

| $A^{\prime}=A+B$ | $A^{\prime}=A+B$ |
| :--- | :--- |
| $B^{\prime}=(A-B) W^{k}$ | $B^{\prime}=(A-B) W^{-k}$ |

$W=e^{-j \pi}$


| DIT/信F | $\overline{\text { PSD }}$ | RADIX 4/部 |
| :---: | :---: | :---: |
| L | H | L |


| Address of | A | B | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AS $=$ | 0 | 1 | 0 | 1 | 8 |

TRANSFORM CHARACTERISTICS

| - 16-Point $(\mathrm{N}=16)$ |  |
| :--- | :--- |
| - RADIX-2 |  |
| - DIF |  |
| - Normally ordered output data |  |
| (Bit-reversed input data order) |  |
| - In-place |  |
| - Complex valued input data |  |
|  |  |
| FORWARD TRANSFORM |  |
|  | INVERSE TRAN |
| $A^{\prime}=A+B$ | $A^{\prime}=A+B$ |
| $B^{\prime}=(A-B) W^{k}$ | $B^{\prime}=(A-B) W^{-k}$ |

TYPICAL BUTTERFLY


TRANSFORM CHARACTERISTICS

- 16-Point $(\mathrm{N}=16)$
- RADIX-2
- DIF
- Normally ordered input and output data (Non-bit-reversing)
- Non-in-place
- Complex valued input data

FORWARD TRANSFORM INVERSE TRANSFORM

$$
\begin{array}{ll}
A^{\prime}=A+B & A^{\prime}=A+B \\
B^{\prime}=(A-B) W^{k} & B^{\prime}=(A-B) W^{-k}
\end{array}
$$



$$
W=e^{-j \pi}
$$

DFR00640


DFRO0650

| DIT/信IF | $\overline{\text { PSD }}$ | RADIX 4//्र |
| :---: | :---: | :---: |
| $L$ | $H$ | $L$ |


| Address of | A | B | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A S}=$ | 0 | 1 | 4 | 5 | 8 |

TRANSFORM CHARACTERISTICS

- 16-Point ( $\mathrm{N}=16$ )
- RADIX-2
- DIT
- Normally ordered input data (Bit-reversed output data order)
- In-place
- Complex valued input data

FORWARD TRANSFORM INVERSE TRANSFORM
$A^{\prime}=A+B W^{k}$
$B^{\prime}=A-B W^{k}$
$A^{\prime}=A+B W^{-k}$
$B^{\prime}=A-B W^{-k}$

TYPICAL BUTTERFLY


DFR00590

$$
W=e^{-j \pi}
$$



DFR00620

| DIT/们F | $\overline{\text { PSD }}$ | RADIX 4/产 |
| :---: | :---: | :---: |
| $H$ | $H$ | $L$ |


| Address of | A | B | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AS $=$ | 0 | 1 | 0 | 1 | 8 |

TRANSFORM CHARACTERISTICS
－16－Point $(\mathrm{N}=16)$
－RADIX－2
－DIT
－Normally ordered output data （Bit－reversed input data order）
－In－place
－Complex valued input data
FORWARD TRANSFORM INVERSE TRANSFORM

$$
\begin{array}{ll}
A^{\prime}=A+B W^{k} & A^{\prime}=A+B W^{-k} \\
B^{\prime}=A-B W^{k} & B^{\prime}=A-B W^{-k}
\end{array}
$$

$W=e^{-j \pi}$



DFR00590

DFR00470

| DIT／信F | PSD | RADIX 4／部 |
| :---: | :---: | :---: |
| $H$ | $L$ | $L$ |


| Address of | A | B | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AS $=$ | 0 | 1 | 0 | 1 | 8 |

TRANSFORM CHARACTERISTICS

- 16-Point $(\mathrm{N}=16)$
- RADIX-2
- DIT
- Normally ordered input and output data (Non-bit-reversing)
- Non-in-place
- Complex valued input data

FORWARD TRANSFORM INVERSE TRANSFORM

$$
\begin{array}{ll}
A^{\prime}=A+B W^{k} & A^{\prime}=A+B W^{k} \\
B^{\prime}=A-B W^{k} & B^{\prime}=A-B W^{-k}
\end{array}
$$

TYPICAL BUTTERFLY


DFR00590


| DIT/DIF | $\overline{\text { PSD }}$ | RADIX 4/ $\overline{\mathbf{2}}$ |
| :---: | :---: | :---: |
| H | L | L |


| Address of | A | B | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AS $=$ | 4 | 5 | 0 | 1 | 8 |

TRANSFORM CHARACTERISTICS
TYPICAL BUTTERFLY

- 16-Point $(\mathrm{N}=16)$
- RADIX-4
- DIF
- Normally ordered input data (Digit-reversed output data order)
- In-place
- Complex valued input data


## FORWARD TRANSFORM

| $A^{\prime}=A+B+C+D$ | $A^{\prime}=A+B+C+D$ |
| :--- | :--- |
| $B^{\prime}=(A-j B-C+j D) W^{k}$ | $B^{\prime}=(A+j B-C-j D) W^{k}$ |
| $C^{\prime}=(A-B+C-D) W^{2 k}$ | $C^{\prime}=(A-B+C-D) W^{2 k}$ |
| $D^{\prime}=(A+j B-C-j D) W^{3 k}$ | $D^{\prime}=(A-j B-C+j D) W^{-3 k}$ |

INVERSE TRANSFORM


DFR00510


| DIT/DIF | $\overline{\text { PSD }}$ | RADIX 4/ $\overline{\mathbf{2}}$ |
| :---: | :---: | :---: |
| L | H | H |


| Address of | A | B | C | D | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{C}^{\prime}$ | $\mathrm{D}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ | $\mathrm{W}^{2 \mathrm{k}}$ | $\mathrm{W}^{3 \mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A S}=$ | 0 | 1 | 2 | 3 | 0 | 1 | 2 | 3 | 8 | 9 | 10 |

TRANSFORM CHARACTERISTICS

- 16-Point $(N=16)$
- RADIX-4
- DIF
- Normally ordered output data (Digit-reversed input data order)
- In-place
- Complex valued input data


## FORWARD TRANSFORM <br> $A^{\prime}=A+B+C+D$ <br> $B^{\prime}=(A-j B-C+j D) W^{k}$ <br> $C^{\prime}=(A-B+C-D) W^{2 k}$ <br> $D^{\prime}=(A+j B-C-j D) W^{3 k}$

INVERSE TRANSFORM
$A^{\prime}=A+B+C+D$
$B^{\prime}=(A+j B-C-j D) W^{-k}$
$C^{\prime}=(A-B+C-D) W^{-2 k}$
$D^{\prime}=(A-j B-C+j D) W^{-3 k}$

TYPICAL BUTTERFLY


DFR00510

$$
\mathrm{W}=\mathrm{e}^{-\mathrm{j} \pi}
$$



DFR00500

| DIT/矿 | $\overline{\text { PSD }}$ | RADIX 4/2 |
| :---: | :---: | :---: |
| L | L | H |


| Address of | A | B | C | D | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{C}^{\prime}$ | $\mathrm{D}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ | $\mathrm{W}^{2 \mathrm{k}}$ | $\mathrm{W}^{3 \mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A S}=$ | 0 | 1 | 2 | 3 | 0 | 1 | 2 | 3 | 8 | 9 | 10 |

TRANSFORM CHARACTERISTICS
16－Point $(N=16)$
－RADI -4
－DIF
－Normally ordered input and output data
（Non－digit reversing）
－Non－in－place
－Complex valued input data
FORWARD TRANSFORM

| $A^{\prime}=A+B+C+D$ |  |
| :--- | :--- |
| $B^{\prime}=(A-j B-C+j D) W^{k}$ | $A^{\prime}=A+B+C+D$ |
| $C^{\prime}=(A-B+C-D) W^{2 k}$ | $B^{\prime}=(A+j B-C-j D) W^{k}$ |
| $D^{\prime}=(A+j B-C-j D) W^{3 k}$ | $C^{\prime}=(A-B+C-D) W^{-2 k}$ |



DFR00580

| DIT／信F | PSD | RADIX 4／호 |
| :---: | :---: | :---: |
| L | $H$ | $H$ |


| Address of | A | B | C | D | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{C}^{\prime}$ | $\mathrm{D}^{\prime}$ | $\mathrm{W}^{k}$ | $\mathrm{~W}^{2 k}$ | $\mathrm{~W}^{3 \mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{AS}=$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |

TRANSFORM CHARACTERISTICS

- 16-Point $(\mathrm{N}=16)$
- RADIX-4
- DIT
- Normally ordered input data (Digit-reversed output data order)
- In-place
- Complex valued input data


DFR00530
INVERSE TRANSFORM

$$
\begin{aligned}
& A^{\prime}=A+B W^{-k}+C W^{-2 k}+D W^{-3 k} \\
& B^{\prime}=A+j B W^{-k}-C W^{-2 k}-j D W^{-3 k} \\
& C^{\prime}=A-B W^{-k}+C W^{-2 k}-D W^{-3 k} \\
& D^{\prime}=A-j B W^{-k}-C W^{2 k}+j D W^{-3 k}
\end{aligned}
$$

$$
\mathrm{W}=\mathrm{e}^{-\mathrm{j} \pi}
$$



DFR00540

| DIT/信F | PSD | RADIX 4/产 |
| :---: | :---: | :---: |
| $H$ | $H$ | $H$ |


| Address of | A | B | C | D | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{C}^{\prime}$ | $\mathrm{D}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ | $\mathrm{W}^{2 \mathrm{k}}$ | $\mathrm{W}^{3 \mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A S}=$ | 0 | 1 | 2 | 3 | 0 | 1 | 2 | 3 | 8 | 9 | 10 |

TRANSFORM CHARACTERISTICS

- 16-Point $(\mathrm{N}=16)$
- RADIX-4
- DIT
- Normally ordered output data (Digit-reversed input data order)
- In-place
- Complex valued input data

FORWARD TRANSFORM
$A^{\prime}=A+B W^{k}+C W^{2 k}+D W^{3 k}$
$B^{\prime}=A-j B W^{k}-C W^{2 k}+j D W^{3 k}$
$C^{\prime}=A-B W^{k}+C W^{2 k}-D W^{3 k}$
$D^{\prime}=A+j B W^{k}-C W^{2 k}-j D W^{3 k}$

TYPICAL BUTTERFLY


DFR00530
INVERSE TRANSFORM

$$
\begin{aligned}
& A^{\prime}=A+B W^{-k}+C W^{-2 k}+D W^{3 k} \\
& B^{\prime}=A+j B W^{-k}-C W^{-2 k}-j D W^{3 k} \\
& C^{\prime}=A-B W^{-k}+C W^{-2 k}-D W^{-3 k} \\
& D^{\prime}=A-j B W^{-k}-C W^{-2 k}+j D W^{-3 k}
\end{aligned}
$$

$$
\mathrm{W}=\mathrm{e}^{-\mathrm{j} \pi}
$$



DFR00550

| DIT/矿 | $\overline{\text { PSD }}$ | RADIX 4/产 |
| :---: | :---: | :---: |
| $H$ | $L$ | $H$ |


| Address of | A | B | C | D | $\mathrm{A}^{\prime}$ | $\mathrm{B}^{\prime}$ | $\mathrm{C}^{\prime}$ | $\mathrm{D}^{\prime}$ | $\mathrm{W}^{\mathrm{k}}$ | $\mathrm{W}^{2 \mathrm{k}}$ | $\mathrm{W}^{3 \mathrm{k}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{A S}=$ | 0 | 1 | 2 | 3 | 0 | 1 | 2 | 3 | 8 | 9 | 10 |

- 16-Point $(\mathrm{N}=16)$
- RADIX-4
- DIT
- Normally ordered input and output data (Non-digit reversing)
- Non-in-place
- Complex valued input data

TYPICAL BUTTERFLY


DFR00530
INVERSE TRANSFORM

$$
\begin{aligned}
& A^{\prime}=A+B W^{-k}+C W^{-2 k}+D W^{-3 k} \\
& B^{\prime}=A+j B W^{-k}-C W^{-2 k}-j D W^{-3 k} \\
& C^{\prime}=A-B W^{-k}+C W^{2 k}-D W^{-2 k} \\
& D^{\prime}=A-j B W^{-k}-C W^{-2 k}+j D W^{-3 k}
\end{aligned}
$$

$$
\begin{aligned}
& A^{\prime}=A+B W^{k}+C W^{2 k}+D W^{3 k} \\
& B^{\prime}=A-j B W^{k}-C W^{2 k}+j D W^{3 k} \\
& C^{\prime}=A-B W^{k}+C W^{2 k}-D W^{3 k} \\
& D^{\prime}=A+j B W^{k}-C W^{2 k}-j D W^{3 k}
\end{aligned}
$$

$W_{N}=e j^{2 \pi} N$


- DIF
- In-place
- Real valued output data
- Inverse Transform
TYPICAL BUTTERFLIES
$A^{\prime}=\operatorname{Re}[A+j B+C-j D]$
$B^{\prime}=\operatorname{lm}[A+j B+C-j D]$
$C^{\prime}=\operatorname{Re}[(A+j B-C+j D) W R]$
$D^{\prime}=\operatorname{lm}[(A+j B-C+j D) W R]$


## $\mathrm{KNZ} / \overline{\mathrm{KZ}}=\mathrm{LOW}$ ( $k=0$ )



DFR00600

$$
\begin{aligned}
& \\
& \left.V R_{1}\right] \\
& W R]
\end{aligned}
$$

$\qquad$

$$
\begin{aligned}
& A^{\prime}=\operatorname{Re}[A+j B+C-j D] \\
& B^{\prime}=\operatorname{Re}\left[(A+j B-C+j D) W^{k}\right] \\
& C^{\prime}=\operatorname{Im}[A+j B+C-j D] \\
& D^{\prime}=\operatorname{Im}\left[(A+j B-C+j D) W^{k}\right] \\
& W_{N}=e j^{2 \pi} N
\end{aligned}
$$

TRANSFORM CHARACTERISTICS

- 16-Point ( $\mathrm{N}=16$ )
- RADIX-2
- DIT
- Normally ordered input data (Unique output data order)
- In-place
- Real Valued Input (RVI) data
- Forward Transform


## TYPICAL BUTTERFLIES

$$
\begin{gathered}
\mathrm{KNZ} / \overline{\mathrm{KZ}}=\mathrm{LOW} \\
(\mathrm{k}=0)
\end{gathered}
$$



DFR00600
$\mathrm{KNZ} / \overline{\mathrm{KZ}}=\mathrm{HIGH}$ ( $k \neq 0$ )


DFR00610
$A^{\prime}=\operatorname{Re}\left[A+j C+(B+j D) W K^{K}\right]$
$\left.B^{\prime}=\ln \left[A+j C+(B+j D) W^{k}\right]\right]$
$C^{\prime}=\operatorname{Re}\left[A+j C-(B-j D) W^{k}\right]$
$D^{\prime}=\operatorname{lm}\left[-A-j C+(B+j D) W^{k}\right]$
$W_{N}=e \frac{-j 2 \pi}{N}$


| DIT/矿 | PSD | RADIX 4/产 |
| :---: | :---: | :---: |
| $H$ | $H$ | $L$ |



## Am29800 High Performance Bus Interface and Logic Index

High Performance Bus Interface Family
David A. Laws and Peter Alfke ..... 8-1
Am29806/Am29809 6-Bit Chip Select Decoder/9-Bit Equal-to-Comparator ..... 8-4
Am29818 SSR ${ }^{\text {TM }}$ Diagnostics/WCS Pipeline Register ..... 8-13
Am29821-26 High Performance Bus Interface Registers ..... 8-23
Am29827/Am29828 High Performance Buffers ..... 8-32
Am29833-34/Am29853-54 Parity Bus Transceivers ..... 8-38
Am29841-46 High Performance Bus Interface Latches ..... 8-48
Am29861-64 High Performance Bus Transceivers ..... 8-57

# High Performance Bus Interface Family 

David A. Laws and Peter Alfke<br>Advanced Micro Devices, Inc., Sunnyvale, CA

## Standardizes Around Slim 24-Pin Package

Most IC designers tend to focus their attention on ever more complex VLSI solutions to improve the package count, cost, and reliability of microprocessor based systems. In many cases, however, greater impact could be achieved with much less effort by designing a more efficient bus interface. The last major innovation in this area was the advent of the popular 20-pin octal interface, which occurred not so coincidentally with the boom in 8-bit microprocessor sales.

## The Octal Explosion

The 20-pin package was ideal for 8-bit interface elements as it allowed for eight input lines, eight output lines, two control inputs, power supply, and ground. Octal configurations of registers, latches and transceivers appeared in Schottky, low-power Schottky, and CMOS technologies from every major integrated circuit supplier, and as technology improved, a proliferation of polarity, pin rotation, high current drive, and low power options became available to meet every conceivable 8 -bit need.

However, as the designers' world became more complex, it became apparent that modular sizes larger than 8 bits were needed. For example, systems that use a parity check scheme need 9 bits for each byte, and if a clock line is added, a 10-bit part is needed. The 10-bit part also fits nicely with the 20-bit addressing schemes used with many 16-bit microprocessors.
A 9- or 10-bit function previously required the one octal and one 4-bit part, which left the designer with two packages and potential problems. Clearly, the answer was a new approach.

## The 24-Pin Solution

Two factors contributed to the 24-pin solution. First was the development of a more compact 24-pin package. Until recently the only package available for this pin count was a $600-\mathrm{mil}$ wide DIP. Now a slimline, 24 -pin $300-\mathrm{mil}$ wide package, called Thin-DIP by AMD, is entering production at a number of package manufacturers. Second, advanced Schottky technologies made it possible to pack increased functional complexity onto chips small enough to fit into the narrow cavities of these new packages. AMD calls its version of this process $I M O X{ }^{\top M}$, an acronym which means ion-implanted and oxide-isolated.
The fabrication and packaging problems overcome, AMD proceeded to define a complete family of functions from the ground up. While the previous 20-pin octal interface devices had been a great improvement over their predecessors, the piecemeal approach to their conception had led to a bewildering array of inconsistent configurations. So before starting design on any one device, AMD applications engineers looked at all the essential interface functions required by a system. The result is the new Am29800 series.

The Am29800 Family includes registers, latches, buffers, and transceivers; most functions are supplied in 8- or 9-
and 10 -bit wide configurations. De facto standards have determined that most systems are noninverting internally, while most bus configurations are inverting. To meet all these needs, both inverting and noninverting versions of the Am29800 devices are available to the designer.

Now that two-layer metal interconnect is an established manufacturing process, it is possible to give careful consideration to the physical location of input and output pins. All inputs on the new Am29800 Family have been placed on one side of the package with corresponding outputs on the other, so data can flow in a direct physical path from the microprocessor CPU through the interface unit and onto the bus. This permits a much cleaner board layout. In addition, power supply, ground, and control function pins are always in the same position.

AMD also decided to standardize pinouts between logic functions. For example, all 10-bit elements, i.e., latches, registers, or transceivers, have the same input and output pin assignment, as do all 9 - and 8-bit devices.

## Electrical Performance

For many years, TTL devices, such as the 'S240 series, employed PNP inputs to achieve very low input current characteristics. Unfortunately, while the DC input current is indeed low, the dynamic performance of the device is severely downgraded because of the large capacitance associated with the PNPs. The Am29800 devices were designed with low capacitance loading at the inputs and outputs.

Most IC data sheets specify AC performance at 15 pF test conditions only. While this is adequate for general purpose logic applications, a realistic bus structure will typically see much higher loading, and all Am29800 series devices are designed to provide optimum performance under more realistic system conditions. Specified sink currents of 48 mA over the commercial temperature operating range (0 to $70^{\circ} \mathrm{C}$ ) and 32 mA over the military temperature range ( -55 to $+125^{\circ} \mathrm{C}$ ) ensure adequate capacitance drive and fanout for bus systems. And since drivers must charge load capacitance in both falling and rising directions, source current is also fully characterized at both 2.0 and 2.4 V .

Critical AC specifications such as propagation delays and disable times for the three-state outputs are specified for 300 pF load conditions both at $25^{\circ} \mathrm{C}$ and over the full operating temperature range and power supply tolerance; specific delays depend on the function being considered. Typical values for a D-type register at 50pF are 6 to 7 ns , comparable to those achieved with AS or FAST devices under the same conditions and an improvement over higher power Schottky products. At 350 pF , loading delays increase to the 12 to 14 ns range. Simple buffers and inverters exhibit typical values of 4 ns .

## Registers

The Am29821-26 Bus Interface Registers are specifically designed to provide extra width for wide address or data paths and buses carrying parity.

The Am29821 is a 10-bit wide version of the popular '374 8-bit register. It has ten inputs, ten outputs, common buffered clock enable and three status Output Enable lines. The inverting version, Am29822, is comparable with the '534 8-bit device.

The 9-bit registers, Am29823 and Am 29824, give up one bit to gain two additional control lines which are used for Clock Enable (EN), and Clear (CLR). This combines '273, '374 and ' 377 functions in one single package. The extra pins available on the 8-bit parts, Am29825 and Am29826, provide gate output enable capability, which eliminates the need for external gate packages when used in DMA or Multibus* control applications. The Am29825 can also be used to implement high source/sink drive on the data port for the AmZ8000** or 8086 16-bit CPUs. The registers can be controlled from WR and CS, can be cleared and can be disabled for DMA operations. The two 24-pin parts replace four of the earlier octal devices plus one gate package, and system performance is improved up to three or four times because of the reduced number of gate delays and shorter wiring traces.

## Other Functions

Other functions in the Am29800 Family include latches, buffers and transceivers, comparators, and special parity transceivers.

The Am29841 through Am29846 latches follow the pattern as the registers. The 10-bit device is similar in function to the popular 'S373 octal latch; control lines available are latch enable (LE) and three-state output enable (OE). The noninverting device is analogous to the '533 element. The 9-bit latches add preset (PRE) and clear (CLR) and the 8-bit options have added gated output enable controls.

Buffers and inverters, Am29827 and Am29828, are 10-bit wide high performance versions of the ' 240 and ' 244 devices, while the transceivers emulate the '245 and 8304B octal elements. For improved operation in a noisy bus environment, all data inputs have 200 mV minimum input hysteresis.

## The Metastable Problem

One problem faced by designers is the interfacing of asynchronous digital signals. Although most difficulties can be overcome somewhat easily, there is also a more fundamental problem that defies a perfect solution. The following is a general overview of the metastable problem.
Latches and flip-flops are normally considered bistable devices, since they have two unconditionally stable operating points, either HIGH or LOW. There is, however, a third operating point when the cross-coupled arrangement is exactly balanced. This operating point is stable only if there is no noise in the system and the system is perfectly balanced. The condition is called metastable (meta = Greek for 'between''). A metastable condition will last only long enough for the circuit to fall into one of the two stable operating points. This time can be many microseconds, even milliseconds, for devices as fast as a 74S74 flip-flop. In other words, if a flip-flop has reached the balanced, metastable condition, it may remain in this state for an undetermined time, perhaps 1000 times longer than its normal response speed.

## When Does This Cause A Problem?

In almost every digital system certain asynchronous events (key-strokes, incoming data, interrupts), must be synchronized to the computer clock. The textbook solution is a fast, clocked flip-flop, like the 74S74, in which the asynchronous signal is applied to the D input and clocked with the system clock. This results in a perfectly synchronized output (usually).

Let's analyze the timing more carefully: the data sheet specified a setup time requirement (for this device, $\mathrm{t}_{\mathrm{s}}=3 \mathrm{~ns}$ ). This means that any signal that arrives at least 3ns before the clock edge will achieve the intended result, i.e., an H will set, an $L$ will reset the flip-flop. Great for synchronous systems. But what happens when the asynchronous input violates this setup time requirement and changes less than $3 n s$ before the clock edge? Well, most of the time, nothing. The actual moment where the flip-flop samples the D input is somewhere in the guaranteed range, i.e., somewhere less than $3 n s$ before the clock. So the flip-flop makes the decision. It either senses the change on the asynchronous input and therefore changes its Q output, or it ignores the change and doesn't change the $Q$ output. So the only thing lost is one clock cycle. Unfortunately, that's not always true.
"Going metastable" here means that the synchronizer output is within a mid-level or oscillation range for an unpredictable time. Most occurrences will last less than 50 ns , but may occasionally last much longer - perhaps many microseconds. This certainly can upset the timing chain.
A metastable latch or flip-flop has an unpredictable delay and will therefore change its output at a time that differs from the value obtained from the worst case timing analysis. In a slow system this usually doesn't matter, but in a fast system it can lead to a "crash."

## In Conclusion:

The Am29800 Family registers provide an additional bonus; they recover extremely fast from a metastable condition.

The metastable condition occurs in all flip-flops any time the active clock edge interrogates the input at exactly the same time the input changes state. When this happens, the cross coupled latch at the output can reach a balanced, symmetrical condition which it will hold for some microseconds or even milliseconds before returning to its proper state. Previously, the designer of an asynchronous system had only one remedy for the metastable problem. Two or even three synchronizer flip-flops could be cascaded. This reduced probability of a metastable output but increased throughput delay.
The Am29800 registers, while not totally immune to this problem, are "metastable hardened"' by means of a unique circuit design that reduces both the probability and the delay of any metastable condition under test. Artificially induced, a metastable condition failed to produce any output oscillations and increased the clock-to-input delay by a mere 6 ns . This is an improvement of many orders of magnitude over previously available designs.

## It is Now Necessary to Look Beyond the Data Sheet

If the $D$ input changes exactly at the same moment that the flip-flop makes its decision, it might transfer exactly the amount of energy to kick the output latch into the metastable balanced condition, from which it will recover after an unpredictable delay (measured in nanoseconds, microseconds or even milliseconds).
In other words: any latch, flip-flop, or register has a 'moment of truth" somewhere inside the guaranteed range of setup time where it actually makes up its mind, and if the input changes at that very moment, the output is no longer synchronous. This "moment of truth" is a very short window. For TTL flip-flops it is of the order of 10ps; for MOS devices it is more like 50ps to 100ps. For purposes of this discussion this timing window will be called " t ."

How often does this happen?

[^15]Here are two extreme examples. In each case there is a need to synchronize asynchronous inputs that have no phase or frequency relationship with the computer clock.

- Date signal derived from a disk, roughly 6 MHz with enough frequency modulation and jitter to make it totally asynchronous to the 10 MHz computer clock. How often will the TTL synchronizer go metastable?

The answer is: every time the Data Signal falls into the "window." The probability of hitting the window is $t$ divided by the clock period, or even simpler: clock frequency times $t$
$M=$ Metastable Rate $=f_{D} \cdot f_{C} \cdot t$
$f_{D}=$ Device Frequency $=6 \mathrm{MHz} \cdot 10 \mathrm{MHz} \cdot 10 \mathrm{ps}=600 \mathrm{~Hz}$
$f_{C}=$ Clock Frequency
The synchronizer goes metastable 600 times per second.

- Keyboard entry: one keystroke per second synchronized with a 100 KHz clock.
$M=$ Metastable Rate $=1 \mathrm{~Hz} \cdot 10^{5} \mathrm{~Hz} \cdot 10 \mathrm{ps}=10^{-6} \mathrm{~Hz}$
The synchronizer goes metastable with a statistical probability of once per $10^{6} \mathrm{sec}$, i.e., once every six weeks (assuming 5 eight-hour days/week).


## 29800 Design Guidelines

The 29800 Family offers short delay and setup times, high drive capability (fan-out), and low input capacitance-attractive features for modern high performance TTL systems.

As in any high speed bus interface ('S240 series, FAST or Advanced Schottky), high edge rates and high drive capability mean that a certain amount of care must be exercised in the design of both signal paths and the grounding system. Since every data path is really a transmission line, the relationships between loading, termination, noise margins and ringing must be given more than cursory consideration.

Similarly, the grounding network may require either heavier busing or a grid approach depending on the number of drivers in a given area. 48 mA per bit, plus the AC impact of charging bus lines can cause large ground currents. Distributed supply decoupling is required to provide local charging current for bus drive.

Here are some general suggestions to minimize the potential for system induced grounding and noise problems. These suggestions, in conjunction with the designer's own practical experience handling similar problems with high performance S, AS or FAST logic families, will result in an optimum Am29800 design.

## - Minimize Crosstalk

## Provide Tight Ground

- Use topside links to create a ground 'grid''
- In multi-layer boards, use a ground plane
- In flat cables, make every other wire a ground
- Minimize spacing between signal lines and ground
- Maximize spacing between signal lines

For backplane or wire-wrap systems, use a twisted pair for sensitive functions-clock, asynchronous set/clear lines.

Use of 4 layer boards is recommended.

## - Increase Decoupling

Distribute System Capacitance

- Provide one bypass cap close to each buffer package
- Provide one bypass cap for every two logic packages


## Use High Frequency Capacitors

- Take care in the selection of decoupling capacitor materials. Good choices include high frequency tantalum and ceramic types.
- Do not use low frequency capacitors or aluminum electrolytics
- Be Sure All Lines Are Terminated


## Am29806/Am29809

## 6-Bit Chip Select Decoder 9-Bit Equal-to-Comparator

## DISTINCTIVE CHARACTERISTICS

- High-speed, expandable, 9-bit 'equal-to' comparator (Am29809)
- High-speed comparator with chip select decoder (Am29806)
- Multibus ${ }^{\text {TM }}$ compatible, open-collector acknowledge output
- Internal pull-up resistors on all B inputs
- Acknowledge timing control input
- Fully TTL-compatible inputs and outputs


## GENERAL DESCRIPTION

## Am29809 9-Bit Comparator

The Am29809 is a 9 -bit 'equal-to"' comparator. Its combinatorial, active LOW output, EOUT, responds to the combination of a LOW input on the enable input $\bar{G}$ and a match between input words A and B.

## Am29806 Chip Select Decoder

The Am29806 combines a 6-bit 'equal-to" comparator with a 2- to 4 -line decoder to select one-of-four active LOW chip select outputs. The selected output becomes active in response to the select inputs $\mathrm{S}_{0}, \mathrm{~S}_{1}$ and is enabled by an active LOW input on the enable input $\bar{G}$ and a match between comparator inputs A and B . The active LOW output, Any Enable ( $\overline{\mathrm{ANYE}}$ ), responds to a valid comparison
of $A$ and $B$ and is intended for use as an output enable control for data path buffers associated with the selected peripheral or board.

Both devices have open collector, active LOW acknowledge outputs with a conditional timing input $\bar{C}$ that may be driven by a timing circuit or wait state generator. The acknowledge output responds to a valid comparison, $\overline{\mathrm{G}}=$ LOW and $\overline{\mathrm{C}}=$ LOW.
Both devices have internal pull-up resistors on the comparator B-inputs for easy connection to SPST switches to ground selected input lines. The comparator function is described by:
$\bar{E}_{\text {OUT }}=\left(\overline{\left.A_{0} \odot B_{0}\right)\left(A_{1} \cdot B_{1}\right)\left(A_{2} \cdot B_{2}\right) \ldots\left(A_{i} \odot B_{i}\right) G}\right.$

## BLOCK DIAGRAM



BD001010



| PIN DESCRIPTION |  |  |  |
| :--- | :--- | :---: | :--- |
| Pin No. | Name | I/O | Description |
|  | $A_{i}, B_{i}$ | I | Comparator data inputs. Each $A_{i}$ is compared with each $B_{i}$ on a bit basis. The comparator output is <br> valid when all $A_{i}$ bits match all $B_{i}$ bits. |
| 11 | $\overline{\text { ACK }}$ | O | Active LOW open collector acknowledge output. This output acknowledges memory of I/O transfers <br> when $A$ and $B$ match and $\overline{\mathrm{C}}$ and $\overline{\mathrm{G}}$ are LOW. |
| 13 | $\overline{\overline{A N N E}}$ <br> (Am29806) | O | Active LOW output. Any Enable ( $\overline{\mathrm{ANYE}}$ ) is LOW when $\overline{\mathrm{G}}=$ LOW and there is a match between A and <br> B. |
| 10 | $\overline{\mathrm{C}}$ | I | Active LOW input. This input is used to control when $\overline{A C K}$ is active. It will normally be connected to <br> GND when no wait states or timing delays need to be inserted. It may be connected to a wait state <br> generator or timer. |
| 13 | $\overline{E_{O U T}}$ <br> (Am29809) | O | Active LOW output. The comparator output is active for $\bar{G}=$ LOW and a match between $A$ and $B$. <br> 1 |


| Am29806 Only |  |  |  |
| :--- | :--- | :---: | :--- | :--- |
| 9,8 | $S_{1}, S_{0}$ | 1 | Decoder select inputs. These inputs are decoded to produce a 1-of-4 selection of the $\bar{E}_{i}$ outputs. |
| $17-14$ | $\bar{E}_{0}, \bar{E}_{1}$, | $O$ | Active LOW outputs. 1-of-4 outputs is active as selected by $S_{1}$ and $S_{0}$. |

## FUNCTION TABLES

COMPARATOR FUNCTION TABLE

| $\overline{\mathbf{G}}$ | $\mathbf{A} \quad$ B | $\overline{E_{\text {OUT }}}$ or $\overline{\text { ANYE }}$ |  |
| :---: | :---: | :---: | :---: |
| $H$ | $X \quad X$ | $H$ |  |
| L | X | $\mathrm{A}=\mathrm{B}$ | L |
|  | $A \neq B$ | $H$ |  |

ACKNOWLEDGE FUNCTION TABLE

| $\overline{\text { ANYE }}$ or $\overline{\text { EOUT }}$ | $\overline{\mathbf{C}}$ | $\overline{\text { ACK }}$ |
| :---: | :---: | :---: |
| $H$ | X | $\mathrm{H}^{*}$ |
| X | H | $\mathrm{H}^{*}$ |
| L | L | L |

* Assumes pull-up resistor.

DECODER FUNCTION TABLE (Am29806)

| $\overline{\text { ANYE }}$ | $\mathbf{S}_{\mathbf{1}}$ | $\mathbf{S}_{\mathbf{0}}$ | $\overline{\mathbf{E}_{\mathbf{0}}}$ | $\overline{\mathbf{E}_{\mathbf{1}}}$ | $\overline{\mathbf{E}_{\mathbf{2}}}$ | $\overline{\mathbf{E}_{\mathbf{3}}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $H$ | X | X | H | $H$ | $H$ | $H$ |
|  | L | L | L | $H$ | $H$ | $H$ |
| L | L | $H$ | $H$ | L | $H$ | $H$ |
|  | $H$ | L | $H$ | $H$ | L | $H$ |
|  | $H$ | $H$ | $H$ | $H$ | $H$ | L |

TYPICAL APPLICATION MICROPROCESSOR ENABLE CONTROLLED，SELECTABLE，ADDRESS DECODER


AF000330

MAX ENABLE（HIGH－to－LOW）DELAY OVER 15 BITS
（Commercial Range）

| tPHL | $\mathrm{A}_{\mathrm{i}}$ or $\mathrm{B}_{\mathrm{i}}$ to EOUT | 13 |
| :---: | :---: | :---: |
| tphL | $\overline{\mathrm{G}}$ to $\overline{\mathrm{ANYE}}$ | 11 |
|  | Total | 24 |

Am29806 Decodes and Enables 1 of 4 Banks of Memory


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground .-0.5 V to +7.0 V
DC Voltage Applied to Outputs
for High Output State -0.5 V to $\mathrm{V}_{\mathrm{CC}}$ max
DC Input Voltage ..-0.5 V to +7.0 V
DC Output Current, into Outputs ............... 30mA DC Input Current -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.5 V to +5.5 V Military (M) Devices

Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ $55{ }^{\circ}$ to $+125 \mathrm{C}^{\circ}$ Operating ranges detine those limits over which ality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage (Note 2) | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | $\mathrm{IOH}=-3.0 \mathrm{~mA}$ | 2.4 |  |  | Volts |
| 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}$ |  | $\overline{\mathrm{ACK}} \mathrm{lOL}=32 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  |  | All Others $\mathrm{IOL}=.24 \mathrm{~mA}$ |  |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed Input Logical HIGH Voltage for All Inputs |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed Input Logical LOW Voltage for All Inputs |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  | . |  | -1.2 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.5 \mathrm{~V}$ |  | $\mathrm{A}_{\mathrm{i}}$ |  |  | -0.6 | mA |
|  |  |  |  | $\mathrm{B}_{\mathrm{i}}$ |  |  | -1.0 |  |
|  |  |  |  | All Others |  |  | -0.6 |  |
| IIH | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  | $A_{i}$ |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{B}_{\mathrm{i}}$ (Note 4) |  |  | -250 |  |
|  |  |  |  | All Others |  |  | 20 |  |
| 11 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1} \mathrm{~F}=5.5 \mathrm{~V}$ |  | $A_{i}$ |  |  | 0.1 | mA |
|  |  |  |  | $\mathrm{B}_{\mathrm{i}}$ |  |  | 0.1 |  |
|  |  |  |  | All Others |  |  | 0.1 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=\mathrm{MAX}$ |  |  | -60 |  | -150 | mA |
| ICC | Power Supply Current | $V_{C C}=$ MAX |  | 0 to $70^{\circ} \mathrm{C}$ |  | 35 | 50 | mA |
|  |  |  |  | $+70^{\circ} \mathrm{C}$ |  |  | 45 |  |
|  |  |  |  | -55 to $+125^{\circ} \mathrm{C}$ |  | 35 | 50 |  |
|  |  |  |  | $+125^{\circ} \mathrm{C}$ |  |  | 40 |  |

Notes: 1. Typical limits are $T_{A}=25^{\circ} \mathrm{C} V_{C C}=5.0 \mathrm{~V}$
2. Except one-collector acknowledge output.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Due to internal pull-up resistor: $27 \mathrm{k} \Omega$ nominal.


SWITCHING CHARACTERISTICS（ $T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ ）

| Parameters | Description | Test Conditions（See Figure 2） | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tple | $\mathrm{A}_{i}$ or $\mathrm{B}_{\mathrm{i}}$ to $\overline{E_{\text {OUT }}}$ | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & R_{L}=1 \mathrm{k} \Omega \end{aligned}$ |  | 8 | 11 | ns |
| tPHL |  |  |  | 8 | 11 |  |
| tPLH | $\overline{\mathbf{G}}$ to $\overline{\text { EOUT }}$ |  |  | 7 | 10 | ns |
| tPHL |  |  |  | 7 | 10 |  |
| tply（Note 1） | $A_{i}$ or $B_{i}$ to $\overline{A C K}$ | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=375 \Omega \end{aligned}$ |  | 9 | 12 | ns |
| tPHL |  |  |  | 8 | 12 |  |
| tply（Note 1） | $\overline{\mathrm{C}}$ to $\overline{\mathrm{ACK}}$ |  |  | 9 | 12 | ns |
| $t_{\text {PHL }}$ |  |  |  | 7 | 11 |  |
| tply（Note 1） | $\overline{\mathrm{G}}$ to $\overline{\mathrm{ACK}}$ |  | ， | 7 | 12 | ns |
| tpHL |  |  |  | 7 | 11 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

|  | Description | Test Conditions （See Figure 2） | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters |  |  | Min | Max | Min | Max |  |
| tplH | $A_{i}$ or $B_{i}$ to $\overline{E O U T}$ | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & R_{L}=1 \mathrm{k} \Omega \end{aligned}$ |  |  |  |  |  |
| ${ }^{\text {tPHL }}$ |  |  |  | 13 |  | 14 | ns |
| tplH | G to EOUT |  |  |  |  |  |  |
| tPHL |  |  |  | 11 |  | 12 | ns |
| tplH（Note 1） | $A_{i}$ or $B_{i}$ to $\overline{A C K}$ | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =375 \Omega \end{aligned}$ |  |  |  |  |  |
| tPHL |  |  |  | 14 |  | 15 | ns |
| tplH（Note 1） | $\overline{\mathrm{C}}$ to $\overline{\mathrm{ACK}}$ |  |  | 13 |  | 14 | ns |
| tPHL |  |  |  | 13 |  | 14 | ns |
| $t_{\text {PLH }}$（Note 1） | $\overline{\mathrm{G}}$ to $\overline{\mathrm{ACK}}$ |  |  | 13 |  | 14 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 13 |  | 14 | ns |

Note 1．This propagation time is dependent on the RC time constant of the external load applied．
INPUT／OUTPUT CURRENT INTERFACE CONDITIONS


## Am29818

## DISTINCTIVE CHARACTERISTICS

- High-speed noninverting 8-bit parallel register for any data path or pipelining application
- WCS (Writable Control Store) pipeline register
- Load WCS from serial register
- Read WCS via serial scan
- Alternate sourced as SN54/74S818
- High-speed 8-bit "shadow register" with serial shift mode for Serial Shadow Register (SSR) Diagnostics - Controllability: serial scan in new machine state
- Observability: serial scan out diagnostics routine results


## GENERAL DESCRIPTION

The Am29818 is a high-speed, general-purpose pipeline register with an on-board shadow register for performing Serial Shadow Register (SSR) Diagnostics and/or Writable Control Store loading.

The D-to-Y path provides an 8-bit parallel data path pipeline register for normal system operation. The shadow register can load parallel data to or from the pipeline register and can output data through the D input port (as in WCS loading).

The 8-bit shadow register has multiplexer inputs that select parallel inputs from the Y -port or adjacent bits in the
shadow register to operate as a right-shift-only shift register. This register can then participate in a serial loop throughout the system where normal data, address, status and control registers are replaced with Am29818 Diagnostic Pipeline Registers. The loop can be used to scan in a complete test routine starting point (data, address, etc.). Then after a specified number of clock cycles, the data clocked out can be compared to the expected results. WCS loading can be accomplished using the same technique. An instruction word can be serially shifted into the shadow register and written into the WCS RAM by enabling the D output.

BLOCK DIAGRAM


BD001020


AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am29818
```



```
Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-24-pin SLIMDIP (D-24-SLIM)
L-28-pin Leadless Chip Carrier (L-28-1)
X - Dice
Device type
SSR \({ }^{\text {TM }}\) Diagnostics/WCS Pipeline Register
```

| Valid Combinations |  |
| :--- | :--- |
| Am29818 | DC, DCB, DM, |
|  | DMB |
|  | LC, LCB, LM, |
|  | LMB |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## AN INTRODUCTION TO SERIAL SHADOW REGISTER (SSR) DIAGNOSTICS

## DIAGNOSTICS

A diagnostics capability provides the necessary functionality as well as a systematic method for detecting and pin-pointing hardware-related failures in a system. This capability must be able to both observe intermediate test points and control intermediate signals - address, data, control and status - to exercise all portions of the system under test. These two capabilities - observability and controllability - provide the ability to establish a desired set of input conditions and state register values, sample the necessary outputs, and determine whether the system is functioning correctly.

## TESTING COMBINATIONAL AND SEQUENTIAL NETWORKS

The problem of testing a combinational logic network is well understood (Figure 1). Sets of input signals (test vectors) are applied to the network and the network outputs are compared to the set of computed outputs (result vectors). In some cases sets of test vectors and result vectors can be generated in a computer-aided environment, minimizing engineering effort. Additionally, fault coverage analysis can be automated to provide a measure of how efficient a set of test vectors is at pin-pointing hardware failures. For example, a popular measure of fault coverage computes the percentage of stuck-atones (nodes with outputs always HIGH) and stuck-at-zeros (nodes with outputs always LOW) a given set at test vectors will discover.

Figure 1.


## DF000070

A sequential network (Figure 2) is much more difficult to test systematically. The outputs of a sequential network depend not only on the present inputs but also on the internal state of the network. Initializing the internal state register to the value necessary to test a given set of inputs is difficult at best, and not easily automated. Additionally, observing the internal state of a sequential network can be very difficult and time consuming if the state information is not directly available. For example, consider the problem of determining the value of an internal 16 -bit counter if only a carry-out signal is available. The counter must be clocked until it reaches the carry-out state and the starting value computed. Up to 65,535 clock cycles may be necessary! An easier method must exist. Serial Shadow Register diagnostics provides this method.

Figure 2.


## SERIAL SHADOW REGISTER DIAGNOSTICS

Serial Shadow Register diagnostics provides sufficient observability and controllability to turn any sequential network into a combinational network. This is accomplished by providing the means to both initialize (control) and sample (observe) the state elements of a sequential network. Figure 3 shows the method by which serial shadow register diagnostics accomplishes these two functions.

Figure 3.


DF000040
Serial Shadow Register diagnostics utilizes an extra multiplexer on the input of each state register and a duplicate or shadow of each state flip/flop in an additional register. The shadow register can be loaded serially via the serial data input (thus the name Serial Shadow Register diagnostics) for controllability. Once the desired state information is loaded into the serial register it can be transferred into the internal state register by selecting the multiplexer and clocking the state register with PLCK. This allows any internal state to be set to a desired state in a simple, quick, and systematic manner.

Internal state information can be sampled by loading the serial register from the state register outputs. This state information can then be shifted out via the serial data output to provide observability. Notice that the serial data inputs and outputs can be cascaded to make long chains of state information available on a minimum number of connections.

In effect, Serial Shadow Register diagnostics breaks the normal feedback path of the sequential network and establishes a logical path with which inputs can be defined and outputs sampled (Figure 4). This means that those techniques which have been developed to test combinational networks can be applied to any sequential network in which Serial Shadow Register diagnostics is utilized.

Figure 4.


## A TYPICAL COMPUTER ARCHITECTURE WITH SSR DIAGNOSTICS

When normal pipeline registers are replaced by SSR diagnostics pipeline registers system debug and diagnostics are easily implemented. State information which was inaccessible is now both observable and controllable. Figure 5 shows a typical computer system using the Am29818.
Serial paths have been added to all the important state registers (macro instruction, data, status, address, and micro instruction registers). This extra path will make it easier to diagnose system failures by breaking the feed-back paths and turning sequential state machines into combinatorial logic
blocks. For example, the status outputs of the ALU may be checked by loading the micro instruction register with the necessary micro instruction. The desired ALU function is then executed and the status outputs captured in the status register. The status bits can then be serially shifted out and checked for validity.

A single diagnostic loop was shown in Figure 5 for simplicity, but several loops can be employed in more complicated systems to reduce scan time. Additionally, the Am29818s can be used to sample intermediate test points not associated with normal state information. These additional test points can further ease diagnostics, testability and debug.

Figure 5. Typical System Configuration


SSR DIAGNOSTICS/WCS PIPELINE REGISTERS
REPLACE NORMAL REGISTERS WITH DIAGNOSTICS LOOP

## USE OF THE Am29818 PIPELINE REGISTER IN WRITABLE CONTROL STORE (WCS) DESIGNS

The Am29818 SSR diagnostics/WCS Pipeline Register was designed specifically to support writable control store designs. In the past, designers of WCS based systems needed to use an excessive amount of support circuitry to implement a WCS. As shown in Figure 7, additional input and output buffers are necessary to provide paths from the parallel input data bus to the memory, and from the instruction register to the output data bus. The input port is necessary to write data to the control store, initializing the micromemory. The output port provides the access to the instruction register, indirectly allowing the RAM to be read. Additionally, access to the instruction register is useful during system debugging and system diagnostics.

The Am29818 supports all of the above operations (and more) without any support circuitry. Figure 6 shows a typical WCS design with the Am29818. Access to memory is now possible over the serial diagnostics port. The instruction register contents may be read by serially shifting the information out on the diagnostics port. Additionally, the instruction register may be written from the serial port via the shadow register. This simplifies system debug and diagnostics operations considerably.

## CONCLUSION

Serial Shadow Register diagnostics provides the observability and controllability necessary to take any sequential network and turn it into a combinational network. This provides a method for pin-pointing digital system hardware failures in a systematic and well-understood fashion.

Figure 6. Am29818 Based WCS Application.


DF000100

Figure 7. WCS Application without Am29818s.




Note 1. $C_{L}=50 \mathrm{pF}$ includes scope probe, wiring and stray capacitances without device in test fixture.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

*AC performance over the operating range is guaranteed by testing defined in Group A, Subgroup 9.



Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense.
2. Cross hatched area is don't care condition.


Note: 1. Pulse Generator for All Pulses: Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{O}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.

## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


$D_{0}-D_{7}, Y_{0}-Y_{7}$


SDO
IC000050

## Am29821-26

High Performance Bus Interface Registers

## DISTINCTIVE CHARACTERISTICS

- High-speed parallel registers with positive edge-triggered D-type flip-flops
- Noninverting CP-Y tpD $=7.5$ ns typ
- Inverting CP-Y tPD $=7.5 \mathrm{~ns}$ typ
- Buffered common Clock Enable (EN) and asynchronous Clear input ( $\overline{\mathrm{CLR}}$ )
- Three-state outputs glitch free during power-up and down. Outputs have Schottky clamp to ground
- 48mA Commercial Iol, 32mA MIL lol
- Low input/output capacitance
- 6pF inputs (typical)
-8 pF outputs (typical)
- Metastable "Hardened" Registers


## GENERAL DESCRIPTION

The Am29820 Series bus interface registers are designed to eliminate the extra packages required to buffer existing registers and provide extra data width for wider address/ data paths or buses carrying parity. The Am29821 and Am29822 are buffered, 10-bit wide versions of the popular '374/'534 functions. The Am29823 and Am29824 are 9-bit wide buffered registers with Clock Enable (EN) and Clear (CLR) - ideal for parity bus interfacing in high performance microprogrammed systems. The Am29825 and Am29826 are 8 -bit buffered registers with all the ' $823 / 4$ controls plus
multiple enables ( $\overline{\mathrm{OE}}_{1}, \overline{\mathrm{OE}}_{2}, \overline{\mathrm{OE}}_{3}$ ) to allow multiuser control of the interface, e.g., $\overline{C S}, \overline{D M A}$, and RD/ $\overline{\mathrm{WR}}$. They are ideal for use as an output port requiring high $\mathrm{lOL}_{\mathrm{O}} / \mathrm{l}_{\mathrm{OH}}$.

All of the AM29800 high performance interface family are designed for high capacitance load drive capability while providing low capacitance bus loading at both inputs and outputs. All inputs are Schottky diode inputs, and all outputs are designed for low capacitance bus loading in the high impedance state.

## BLOCK DIAGRAM




## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am29821-26
Device type
High Performance
Bus Interface Registers
Package

X- Dice

| Valid Combinations |  |
| :--- | :--- |
| Am29821 | DC, DCB, DM, |
| Am29822 | DMB |
| Am29823 | LC, LCB, LM, |
| Am29824 | LMB |
| Am29825 | XC, XM |
| Am29826 | XC, |

D-24-pin SLIM DIP (D-24-SLIM)
L-28-pin Leadless Chip Carrier (L-28-1)

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


LOGIC SYMBOL

## CONNECTION DIAGRAM

Top View
Am29823/Am29824 9-BIT REGISTERS


METALLIZATION AND PAD LAYOUT 9-Bit Registers Am29823*


## CONNECTION DIAGRAM

 Top ViewAm29825/Am29826 8-BIT REGISTERS


LOGIC SYMBOL


## METALLIZATION AND PAD LAYOUT 8-Bit Registers Am29825*



| PIN DESCRIPTION |  |  |  |
| :--- | :--- | :---: | :--- |
| Pin No. | Name | I/O | Description |
|  | $\mathrm{D}_{\mathrm{i}}$ | I | The D flip-flop data inputs. |
| 11 | $\overline{\mathrm{LL}}$ | I | For both inverting and noninverting registers, when the clear input is LOW and $\overline{O E}$ is LOW, the $Q_{i}$ <br> outputs are LOW. When the clear input is HIGH, data can be entered into the register. |
| 13 | CP | I | Clock Pulse for the Register; enters data into the register on the LOW-to-HIGH transition. |
|  | $Y_{i}, \overline{Y_{i}}$ | O | The register three-state outputs. |
| 14 | $\overline{E N}$ | I | Clock Enable. When the clock enable is LOW, data on the $D_{i}$ input is transferred to the $Q_{i}$ output on the <br> LOW-to-HIGH clock transition. When the clock enable is HIGH, the $Q_{i}$ outputs do not change state, <br> regardless of the data or clock input transitions. (Note 5.) |
|  | $\overline{O E}$ | I | Output Control. When the $\overline{O E}$ input is HIGH, the $Y_{i}$ outputs are in the high impedance state. When the <br> $\overline{O E}$ input is LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

Note 5: The Am29823 thru Am29826 registers achieve short throughput delay and setup time and reduced power consumption by means of a clock gating and latching circuit. This circuit is sensitive to very short (<3ns) HIGH-to-LOW-to-HIGH going spikes on EN while CP is HIGH. The designer should be aware of this and avoid the use of decoders or other potentially glitching devices in the $\overline{E N}$ logic.

## FUNCTION TABLES

Am29821/29823/29825

| Inputs |  |  |  |  | Internal Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O E}$ | CLR | EN | $\mathrm{D}_{\mathbf{i}}$ | CP | $a_{i}$ | $Y_{i}$. |  |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | L | $\uparrow$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & z \\ & z \end{aligned}$ | Hi-Z |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\stackrel{L}{\mathrm{~L}}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | X X | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | L | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{~L} \end{aligned}$ | Clear |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\underset{N C}{z}$ | Hold |
| H H L L | H H H H | L L L L | L H L $H$ | $\dagger$ $\dagger$ $\dagger$ $\dagger$ | L H L $H$ | Z Z L $H$ | Load |

$$
\begin{array}{lll}
\mathrm{H}=\text { HiGH } & \mathrm{NC}=\text { No Change } \\
\mathrm{L} & =\text { LOW } & \uparrow=\text { LOW-to-HIGH Transition } \\
\mathrm{X} & =\text { Don't Care } & \mathrm{Z}=\text { High Impedance }
\end{array}
$$

Am29822/29824/29826

| Inputs |  |  |  |  | Internal Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { OE }}$ | CLR | EN | $\mathrm{D}_{\mathrm{i}}$ | CP | $\mathrm{a}_{\mathbf{i}}$ | $\overline{Y_{i}}$ |  |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\uparrow$ | $\begin{gathered} \mathrm{H} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & z \\ & z \end{aligned}$ | Hi-Z |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{array}{\|l\|} \hline x \\ x \end{array}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{~L} \end{aligned}$ | Clear |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{array}{\|l} \hline x \\ x \end{array}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{gathered} \mathrm{z} \\ \mathrm{NC} \end{gathered}$ | Hold |
| H H L L | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L L L L | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \uparrow \\ & \uparrow \\ & \uparrow \\ & \uparrow \end{aligned}$ | H L $H$ $L$ | Z Z H L | Load |

$$
\begin{aligned}
\mathrm{H} & =\mathrm{HIGH} \\
\mathrm{~L} & =\text { LOW } \\
\mathrm{X} & =\text { Don't Care }
\end{aligned}
$$

NC = No Change
$\uparrow=$ LOW-to-HIGH Transition
Z $=$ High Impedance

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied............................... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ......................................-0.5V to +7.0V
DC Voltage Applied to Outputs for High Output State $\qquad$ 0.5 V to $\mathrm{V}_{\mathrm{CC}}$ max

DC Input Voltage ..-0.5 V to +5.5 V
DC Output Current, into Outputs ............. 100 mA
DC Input Current $\qquad$ -30 mA to +5.0 mA 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 device reliability.

## OPERATING RANGES

## Commercial (C) Devices

Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage
$\qquad$ +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}=-15 \mathrm{~mA}$ | 2.4 | 3.3 |  | Volts |
|  |  |  | $\mathrm{IOH}^{\prime}=-24 \mathrm{~mA}$ | 2.0 | 3.1 |  |  |
| 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{MIL}, \mathrm{IOL}=32 \mathrm{~mA}$ |  | 0.31 | 0.5 | Volts |
|  |  |  | COM'L, $1 \mathrm{loL}=48 \mathrm{~mA}$ |  | 0.38 | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=M I N, I_{1 N}=-18 \mathrm{~mA}$ |  |  | -0.7 | -1.2 | Volts |
| ILL | Input LOW Current | $V_{C C}=M A X, V_{\text {IN }}=0.4 \mathrm{~V}$ | Data, CLR |  | -0.3 | -1.0 | mA |
|  |  |  | $\overline{\text { OE, EN, }}$ CP |  | -1.2 | -2.0 |  |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Ioz | Output Off-State (High Impedance) <br> Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  | -75 | -160 | -250 | mA |
| Icc | Supply Current (Note 4) | $\begin{aligned} & V_{C C}=M A X \\ & \text { Outputs Open } \\ & E N=L O W \end{aligned}$ | Over Temperature Range |  |  | 140 | mA |
|  |  |  | $+70^{\circ} \mathrm{C}$ |  |  | 130 |  |
|  |  |  | $+125^{\circ} \mathrm{C}$ |  |  | 120 |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under recommended Operating Range.
2. All typical values are $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
3. Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.
4. Clock input, CP, is HIGH after clocking in data to produce outputs $=$ LOW.

## SWITCHING TEST CIRCUIT



SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions (Note 4) | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Propagation Delay Clock to $\mathrm{Y}_{\mathrm{i}}$ ( $\overline{O E}=\mathrm{LOW}$ ) | $C_{L}=50 \mathrm{pF}$ | 3.5 |  | 8.5 | ns |
| tPHL |  |  | 3.5 |  | 10.5 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  |  | 14 | ns |
| tpHL |  |  |  |  | 18 | ns |
| ts | Data to CP Setup Time | $C_{L}=50 \mathrm{pF}$ | 2.0 | 0 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Data to $\overline{C P}$ Hold Time |  | 2.0 | 0.5 |  | ns |
| ts | Enable (EN $Z$ ) to CP Setup Time |  | 3.0 | 1.5 |  | ns |
| ts | Enable (EN_5) to CP Setup Time |  | 3.0 | 1.5 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Enable (EN) Hold Time |  | 0 | -1.5 |  | ns |
| $t_{\text {PHL }}$ | Propagation Delay, Clear to $Y_{i}$ |  |  | 12.9 | 15.0 | ns |
| ts | Clear Recovery ( $\overline{C L R}$ _ ${ }^{\text {) }}$ ) Time |  | 5.0 | 1.1 |  | ns |
| tpWH | Clock Pulse Width | $C_{L}=50 \mathrm{pF}$ | 5.0 | 3.5 |  | ns |
| tPWL |  |  | 5.0 | 3.0 |  | ns |
| tpWL | Clear (CLR = LOW) Pulse Width |  | 5.0 | 4.0 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable Time $\overline{O E}$ L to $Y_{i}$ | $C_{L}=300 \mathrm{pF}$ |  |  | 17 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 21 | ns |
| t ZH |  | $C_{L}=50 \mathrm{pF}$ |  | 11.5 | 12 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 11.0 | 12 | ns |
| $\mathrm{thz}^{\text {L }}$ | Output Disable Time $\overline{O E} \Gamma$ to $Y_{i}$ | $C_{L}=50 \mathrm{pF}$ |  |  | 9 | ns |
| tLZ |  |  |  |  | 9 | ns |
| thz |  | $C_{L}=5 p F$ |  | 5.2 | 8 | ns |
| thz |  |  |  | 5.5 | 8 | ns |

Note: 4. See test circuit and waveforms.


Note: 4. See test circuit and waveforms.

## SWITCHING WAVEFORMS

SET UP, HOLD, AND RELEASE TIMES


Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense.
2. Cross hatched area is don't care condition.
enable and disable times Enable Disable


Notes: 1. Diagram shown for input Control Enable-LOW and Input Control Disable-HIGH.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.

Note: Pulse Generator for All Pulses: Rate $\leqslant 10 \mathrm{MHz} ; Z_{o}=50 \Omega ; t_{r} \leqslant 2.5 n s ; t_{f} \leqslant 2.5 n s$.


Note: Pulse Generator for All Pulses: Rate $\leqslant 10 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{o}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.
INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


IC000080

## Am29827/Am29828

High Performance Buffers

## DISTINCTIVE CHARACTERISTICS

- High-speed buffers and inverters
- Noninverting tpD $=5.0 \mathrm{~ns}$ typ
- Inverting tpD $=4.5$ ns typ
- 200 mV minimum input hysteresis on input data ports
- Three-state outputs glitch-free during power-up and -down. Outputs have Schottky clamp to ground
- 48 mA commercial lol, 32mA military lol
- High capacitance load capability
- Low capacitance inputs and outputs


## GENERAL DESCRIPTION

The Am29827 and Am29828 10-bit bus buffers provide high performance bus interface buffering for wide data/ address paths or buses carrying parity. The 10 -bit buffers have NOR-ed output enables for maximum control flexibility. All buffer data inputs have 200 mV minimum input hysteresis to provide improved noise rejection.

All of the Am29800 high performance interface family are designed for high capacitance load drive capability while providing low capacitance bus loading at both inputs and outputs. All inputs are Schottky diode inputs, and all outputs are designed for low capacitance bus loading in the high impedance state.

BLOCK DIAGRAM

Am29827/Am29828 10-BIT BUFFERS



Am29827
Am29828


Device type
High Performance Buffers
Package X－Dice

emperature（See Operating Range）
C －Commercial（ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ） M－Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ ）

D－24－pin SLIM DIP（D－24－SLIM） L－28－pin Leadless Chip Carrier（L－28－1）
$L^{B}$ Screening Option
Blank－Standard processing B－Burn－in

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish．

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\overline{O E}_{\mathrm{i}}$ | I | When both are LOW the outputs are enabled. When either one or both are HIGH the outputs are HI-Z. |
|  | $\mathrm{D}_{\mathrm{i}}$ | I | 10-bit data input. |
|  | $\mathrm{Y}_{\mathrm{i}}$ | O | 10-bit data output. |

FUNCTION TABLES

| Am29827 (Noninverting) |  |  |  |
| :---: | :---: | :---: | :---: |
| Inputs |  | Outputs |  |
| $\overline{\mathbf{O E}}$ | $\mathrm{D}_{\mathrm{i}}$ | $Y_{i}$ | Function |
| L | H | H | Transparent |
| L | L | L | Transparent |
| H | X | Z | HI-Z |

## Am29828 (Inverting)

| Inputs |  | Outputs |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
|  | $\mathbf{D}_{\mathbf{i}}$ | $\overline{\mathbf{Y}_{\mathbf{i}}}$ | Function |
| L | $H$ | L | Transparent |
| L | L | H | Transparent |
| $H$ | $X$ | $Z$ | $\mathrm{HI}-\mathrm{Z}$ |

## ABSOLUTE MAXIMUM RATINGS

## Storage Temperature

with
Power Applied $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous -0.5 V to +7.0 V
DC Voltage Applied to Outputs for High Output State
-1.5 V to $\mathrm{V}_{\mathrm{Cc}}$ max
DC Input Voltage .0 .5 V to +5.5 V
Output Current, into Outputs .. 100 mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}}=-15 \mathrm{~mA}$ | 2.4 |  |  | V |
|  |  |  | $1 \mathrm{OH}=-24 \mathrm{~mA}$ | 2.0 |  |  |  |
| 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{MIL}, \mathrm{IOL}^{\prime}=32 \mathrm{~mA}$ |  |  | 0.5 | V |
|  |  |  | COM'L, $\mathrm{lOL}^{\prime}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | V |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | V |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}^{\text {a }}$ - 18 mA |  |  |  | -1.2 | V |
| $\mathrm{V}_{\text {HYST }}$ | Input Hysteresis | Output under test connected to Switching Test Circuit |  | 200 |  |  | mV |
| ILL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  |  |  | -1.0 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{1} \mathrm{~N}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| lozh | Output Off-State <br> Output Current (HI-Z) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| Iozl | Output Off-State Output Current (HI-Z) | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  | -75 |  | -250 | mA |
| Icc | Supply Current | $V_{C C}=M A X$ Outputs Open | Over Temperature Range |  |  | 80 | mA |
|  |  |  | $+70^{\circ} \mathrm{C}$ |  |  | 75 |  |
|  |  |  | $+125^{\circ} \mathrm{C}$ |  |  | 70 |  |

Note: 1 Typical Units are $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

## SWITCHING TEST CIRCUIT



Note: Pulse Generator for All Pulses: Rate $\leqslant 10 \mathrm{MHz}$;
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Data ( $\mathrm{D}_{\mathrm{i}}$ ) to Output ( $\mathrm{Y}_{\mathrm{i}}$ ) Am29827 (Noninverting) | $C_{L}=50 \mathrm{pF}$ |  | 4.8 | 6.0 | ns |
| tpHL |  |  |  | 5.2 | 6.2 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  | 8.0 | 11 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 10.8 | 13.2 | ns |
| tple | Data $\left(D_{i}\right)$ to Output $\left(Y_{i}\right)$ Am29828 (Inverting) | $C_{L}=50 \mathrm{pF}$ |  | 4.0 | 5.2 | ns |
| tPHL |  |  |  | 4.9 | 5.9 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  | 7.3 | 10 | ns |
| tPHL |  |  |  | 10.5 | 12.9 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable Time $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ | $C_{L}=50 \mathrm{pF}$ |  | 6.5 | 12 | ns |
| $\mathrm{t}_{\mathrm{LL}}$ |  |  |  | 9.5 | 12 | ns |
| $\mathrm{t}_{\mathrm{zH}}$ |  | $C_{L}=300 \mathrm{pF}$ |  | 11 | 17 | ns |
| t ZL |  |  |  | 18 | 21 | ns |
| $\mathrm{t}_{\mathrm{H}} \mathrm{z}$ | Output Disable Time $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ | $C_{L}=5 \mathrm{pF}$ |  | 3.5 | 8.0 | ns |
| tLZ |  |  |  | 3.5 | 8.0 | ns |
| $t_{\text {thz }}$ |  | $C_{L}=50 \mathrm{pF}$ |  | 11.2 | 16 | ns |
| $t_{L Z}$ |  |  |  | 4.5 | 11 | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Data ( $\mathrm{D}_{\mathrm{i}}$ ) to Output $\left(\mathrm{Y}_{\mathrm{i}}\right)$ Am29827 (Noninverting) | $C_{L}=50 \mathrm{pF}$ | , | 8 |  | 10 | ns |
| tPHL |  |  |  | 8 |  | 10 | ns |
| tpliH |  | $C_{L}=300 \mathrm{pF}$ |  | 15 |  | 17 | ns |
| tPHL |  |  |  | 15 |  | 17 | ns |
| tplH | Data $\left(D_{i}\right)$ to Output $\left(Y_{i}\right)$ Am29828 (Inverting) | $C_{L}=50 \mathrm{pF}$ |  | 7.0 |  | 9.0 | ns |
| tPHL |  |  |  | 7.5 |  | 9.5 | ns |
| tPLH |  | $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ |  | 14 |  | 16 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 14 |  | 16 | ns |
| tzi | Output Enable Time $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ | $C_{L}=50 \mathrm{pF}$ |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\mathrm{L}}$ |  |  |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  | $C_{L}=300 \mathrm{pF}$ |  | 20 |  | 22 | ns |
| t LL |  |  |  | 23 |  | 25 | ns |
| $t_{H z}$ | Output Disable Time $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ | $C_{L}=5 p F$ |  | 9 |  | 10 | ns |
| tLZ |  |  |  | 9 |  | 10 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  | $C_{L}=50 \mathrm{pF}$ |  | 17 |  | 19 | ns |
| tLz |  |  |  | 12 |  | 12 | ns |



Notes: 1. Diagram shown for Input Control Enable-LOW and Input Control Disable-HIGH.
2. $\mathrm{S}_{1}$ and $\mathrm{S}_{2}$ of Load Circuit are closed except where shown.

## Am29833-34/Am29853-54

Parity Bus Transceivers

## PRELIMINARY

## DISTINCTIVE CHARACTERISTICS

- High-speed bidirectional bus transceiver for processor organized devices
- Error flag with open-collector output
- Generates odd parity for all-zero protection
- Buffered direction three-state control
- Output short-circuit protected to $\mathrm{V}_{\mathrm{CC}}$ limits
- 200 mV minimum input hysteresis on input data ports
- High-capacitance drive capability 48 mA commercial lol 32 mA military IOL


## GENERAL DESCRIPTION

The Am29833/34/53/54 are high-performance bus transceivers designed for two-way communications. They each contain an 8-bit data path from the R (port) to the T (port), a 9-bit data path from the $T$ (port) to the R (port), and a 9-bit parity checker/generator. Two options are available. The Am29833/34 register option, and the Am29853/54 latch option. With the register option, the error flag can be clocked and stored in a register and read at the opencollector ERR output. The clear (CLR) input is used to clear the error flag register. With the latch option, the error can be either passed, stored, sampled or cleared at the error flag output by using the $\overline{E N}$ and $\overline{C L R}$ controls.

The output enables $\overline{O E T}$ and $\overline{O E R}$ are used to force the port outputs to the high-impedance state so that the device can drive bus lines directly. In addition, the $\overline{\mathrm{OER}}$ and $\overline{\mathrm{OET}}$ can be used to force a parity error by enabling both lines simultaneously. This transmission of inverted parity gives the designer more system diagnostic capability. The Am29833 and Am29853 are noninverting, while the Am29834 and Am29854 present inverting data at the outputs. The devices are specified at 48 mA output sink current over the commercial range and 32 mA over the military range.

## BLOCK DIAGRAM

Am29833
(Device Shown Noninverting)


BD001040
*Noninverting buffer for Am29833; inverting buffer for Am29834.
*Note that the inverting device converts the positive logic " $R$ " bus levels to negative logic levels on the " T " bus.

*Noninverting buffer for Am29853; inverting buffer for Am29854.
*Note that the inverting device converts the positive logic " $R$ " bus levels to negative logic levels on the " $T$ " bus.


[^16]Am29853 NONINVERTING OPTION

| Inputs |  |  |  |  |  | Outputs |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OET | OER | CLR | CLK | R ( E of $\mathrm{H}^{\prime} \mathrm{s}$ ) | Ti Incl Parity ( $\Sigma$ of $\mathrm{H}^{\prime} \mathrm{s}$ ) | $\mathbf{R i}_{1}$ | TI | Parity | ERR ${ }^{1}$ |  |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \text { - } \\ & \text { - } \end{aligned}$ | - - | H (Odd) <br> H (Even) <br> L (Odd) <br> $L$ (Even) | NA NA NA NA | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ |  | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | NA <br> NA <br> NA <br> NA | Transmit data from R Port to T Port with parity, receiving path is disabled |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | H (Odd) <br> H (Even) <br> L (Odd) <br> L (Even) | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | NA <br> NA <br> NA <br> NA | $\begin{aligned} & H \\ & H \\ & H \\ & L \end{aligned}$ | Receive data from T. Port to R Port with parity test resulting in flag, transmitting path is disabled |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \end{aligned}$ | NA <br> NA <br> NA <br> NA | H (Odd) <br> H (Even) <br> L (Odd) <br> H (Even) | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | NA <br> NA <br> NA <br> NA | NA <br> NA <br> NA <br> NA | $H$ L H L | Receive data from T Port to R Port, pass the error test resulting to error flag, transmitting path is disabled |
| H | L | H | H | NA | - | - | NA | NA | $E R R_{n-1}$ | Store the state of error flag register |
| - | - | L | H | - | - | - | NA | NA | H | Clear the state of error flag register |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ |  | $\begin{aligned} & \hline \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{gathered} \overline{-} \\ \text { L (Odd) } \\ H \text { (Even) } \end{gathered}$ | - | $\begin{aligned} & \hline z \\ & z \\ & z \\ & z \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline z \\ & z \\ & i \\ & z \end{aligned}$ | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{Z} \\ & \mathbf{z} \\ & \mathbf{z} \\ & \hline \end{aligned}$ |  | Both transmitting and receiving paths are disabled. Parity logic defaults to transmit mode |
| $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ |  |  | H (Odd) <br> H (Even) <br> L (Odd) <br> L (Even) | NA <br> NA <br> NA <br> NA | $\begin{aligned} & \hline \text { NA } \\ & N A \\ & N A \\ & N A \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \hline H \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | NA <br> NA <br> NA <br> NA | Forced-error checking |

Am29854 INVERTING OPTION*

| Inputs |  |  |  |  |  | Outputs |  |  |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OET | OER | CLR | CLK | $\mathrm{R}_{\mathrm{l}}\left(\Sigma\right.$ of $\mathrm{H}^{\prime} \mathrm{s}$ ) | Til Incl Parity ( $\Sigma$ of $\mathrm{H}^{\prime} \mathrm{s}$ ) | $\mathrm{R}_{1}$ | Ti | Parity | ERR ${ }^{1}$ |  |
| $L$ $L$ $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \text { - } \\ & \text { - } \end{aligned}$ | - - | H (Odd) <br> H (Even) <br> L (Odd) <br> $L$ (Even) | NA <br> NA <br> NA <br> NA | NA <br> NA <br> NA <br> NA |  | $H$ L H L | NA <br> NA <br> NA <br> NA | Transmit data from R Port to T Port with parity, receiving path is disabled |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | H (Odd) <br> H (Even) <br> L (Odd) <br> $L$ (Even) | $\begin{aligned} & L \\ & L \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | Receive data from T Port to R Port with parity test resulting in flag, transmitting path is disabled |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $L$ $L$ $L$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | NA <br> NA <br> NA <br> NA | H (Odd) <br> H (Even) <br> $L$ (Odd) <br> L (Even) | $\begin{aligned} & L \\ & L \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | NA <br> NA <br> NA <br> NA | $\begin{aligned} & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{~L} \end{aligned}$ | Receive data from T Port to R Port, pass the error test resulting to error flag, transmitting path is disabled |
| H | L | H | H | NA | - | - | NA | NA | $E R R_{\text {n-1 }}$ | Store the state of error flag register |
| - | - | L | H | - | - | - | NA | NA | H | Clear the state of error flag register |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $H$ $\mathbf{L}$ - - | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | L (Odd) <br> L (Even) | $\begin{aligned} & \text { - } \\ & \text { - } \end{aligned}$ | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{z} \\ & \mathrm{z} \\ & \mathrm{z} \end{aligned}$ | $\begin{aligned} & \hline z \\ & z \\ & z \\ & z \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{z} \\ & \mathrm{z} \\ & \mathrm{z} \\ & \mathrm{z} \end{aligned}$ | $\begin{gathered} \hline \mathrm{NC} \\ \mathrm{H} \\ \mathrm{~L} \\ \mathrm{H} \\ \hline \end{gathered}$ | Both transmitting and receiving paths are disabled. Parity logic defaults to transmit mode |
| $\begin{aligned} & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & \text { - } \\ & \text { - } \end{aligned}$ | H (Odd) <br> H (Even) <br> $L$ (Odd) <br> L (Even) | NA <br> NA <br> NA <br> NA | $\begin{aligned} & \hline \text { NA } \\ & \text { NA } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | NA <br> NA <br> NA <br> NA | Forced-error checking |
| H L Z NC <br> *N <br> 1. | High <br> Low <br> High <br> No ch <br> that fo <br> put sta | pedan nge <br> the ne assu | ative HIG | gic levels on output pre-st | NA $=$ Not applicable <br> $R_{n-1}=$ Pre-state of ERR <br> $=$ Don't care or irre <br> B Port, an " H " represent | nt <br> logic | whil | Odd Even i an "L"' | $\begin{aligned} & =\text { Odd } n \\ & =\text { Even } \\ & =0,1,2 \end{aligned}$ <br> epresent | number of logic one's number of logic one's , 3, 4, 5, 6, 7 <br> s a logic "1." |



Note: 1 Typical units are $T A=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.

## SWITCHING TEST CIRCUIT

CIRCUIT NO. 1


CIRCUIT NO. 2


Note: Test Circuit No. 1 is used with Propagation delay
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )


[^17]**Note: Not applicable to Am29853/54.


SWITCHING WAVEFORMS (LATCH OPTION, Am29853/54)

b. $\mathrm{T}_{\mathrm{i}}$, PARITY, $\overline{\mathrm{EN}}, \overline{\mathrm{CLR}}$ to $\overline{\mathrm{ERR}}$
*Calculation must be done from last arriving signal.

## Am29841-46

High Performance Bus Interface Latches

## DISTINCTIVE CHARACTERISTICS

- High-speed parallel latches
- Noninverting transparent tpD $=5.25 \mathrm{~ns}$ typ
- Inverting transparent tpD $=6.0 \mathrm{~ns}$ typ
- Buffered common latch enable, clear and preset input
- Three-state outputs glitch-free during power-up and down. Outputs have Schottky clamp to ground
- 48mA Commercial IOL 32mA MIL IOL
- Low input/output capacitance
- 6pF inputs (typical)
- 8pF outputs (typical)
- lOH specified 2.0 V and 2.4 V


## GENERAL DESCRIPTION

The Am29840 Series bus interface latches are designed to eliminate the extra packages required to buffer existing latches and provide extra data width for wider address/data paths or buses carrying parity. The Am29841 and Am29842 are buffered, 10 -bit wide versions of the popular ' 373 function. The Am29843 and Am29844 are 9-bit wide buffered latches with Preset (PRE) and Clear (CLR) - ideal for parity bus interfacing in high performance systems. The Am29845 and Am29846 are 8-bit buffered latches with all the ' $843 / 4$ controls plus multiple enables $\left(\overline{\mathrm{OE}}_{1}, \overline{\mathrm{OE}} 2, \overline{\mathrm{OE}} 3\right.$ )
to allow multiuser control of the interface, e.g., $\overline{\mathrm{CS}}, \mathrm{DMA}$, and $\mathrm{RD} / \overline{\mathrm{WR}}$. They are ideal for use as an output port requiring high $\mathrm{IOL} / \mathrm{OH}$.

All of the Am29800 high performance interface family products are designed for high capacitance load drive capability while providing low capacitance bus loading at both inputs and outputs. All inputs are Schottky diode inputs, and all outputs are designed for low capacitance bus loading in the high impedance state.

## BLOCK DIAGRAM

Am29843


PRODUCT SELECTOR GUIDE

|  | Device |  |  |
| :--- | :---: | :---: | :---: |
|  | 10-Bit | 9-Bit | 8-Bit |
| Noninverting | Am29841 | Am29843 | Am29845 |
| Inverting | Am29842 | Am29844 | Am29846 |

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type High Performance Bus Interface Latches

| Valid Combinations |  |
| :--- | :--- |
| Am29841 | DC, DCB, DM, |
| Am29842 | DMB |
| Am29843 | LC, LCB, LM, |
| Am29844 | LMB |
| Am29845 | XC, XM |
| Am29846 |  |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


| Pin No． | Name | 1／0 | Description |
| :---: | :---: | :---: | :---: |
| Am29841／43／45（Noninverting） |  |  |  |
| 11 | CLR | 1 | When CLR is LOW，the outputs are LOW if $\overline{\mathrm{OE}}$ is LOW．When $\overline{\text { CLR }}$ is HIGH，data can be entered into the latch． |
|  | $\mathrm{D}_{1}$ | 1 | The latch data inputs． |
| 13 | LE | 1 | The latch enable input．The latches are transparent when LE is HIGH．Input data is latched on the HIGH－to－LOW transition． |
|  | $Y_{i}$ | 0 | The 3－state latch outputs． |
| 1 | $\overline{O E}$ | 1 | The output enable control．When $\overline{O E}$ is LOW，the outputs are enabled．When OE is HIGH，the outputs $Y_{i}$ are in the high－impedance（off）state． |
| 14 | $\overline{\text { PRE }}$ | 1 | Preset line．When $\overline{\text { PRE }}$ is LOW，the outputs are HIGH if $\overline{\text { OE }}$ is LOW．Preset overrides $\overline{C L R}$ ． |
| Am29842／44／46（Inverting） |  |  |  |
| 11 | $\overline{\text { CLR }}$ | 1 | When CLR is LOW，the outputs are LOW if $\overline{O E}$ is LOW．When CLR is HIGH，data can be entered into the latch． |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The latch inverting data inputs． |
| 13 | LE | 1 | The latch enable input．The latches are transparent when LE is HIGH．Input data is latched on the HIGH－to－LOW transition． |
|  | $Y_{i}$ | 0 | The 3－state latch outputs． |
| 1 | $\overline{O E}$ | 1 | The output enable control．When OE is LOW，the outputs are enabled．When OE is HIGH，the outputs $Y_{i}$ are in the high－impedance（off）state． |
| 14 | $\overline{\text { PRE }}$ | 1 | Preset line．When $\overline{\text { PRE }}$ is LOW，the outputs are HIGH if $\overline{\mathrm{OE}}$ is LOW．Preset overrides CLR． |

FUNCTION TABLES

29841／43／45（Noninverting）

| Inputs |  |  |  |  | Internal Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CLR }}$ | $\overline{\text { PRE }}$ | $\overline{\mathbf{O E}}$ | LE | $\mathrm{D}_{1}$ | $Q_{i}$ | $Y_{1}$ |  |
| H | H | H | X | X | X | Z | Hi－Z |
| H | H | H | H | L | L | Z | Hi－Z |
| H | H | H | H | H | H | Z | Hi－Z |
| H | H | H | L | X | NC | Z | Latched （ Hi －Z） |
| H | H | L | H | L | L | L | Transparent |
| H | H | L | H | H | H | H | Transparent |
| H | H | L | L | x | NC | NC | Latched |
| H | L | L | x | x | H | H | Preset |
| L | H | L | X | x | L | L | Clear |
| L | L | L | x | x | H | H | Preset |
| L | H | H | L | X | L | Z | Latched （Hi－Z） |
| H | L | H | L | X | H | Z | Latched <br> （Hi－Z） |

29842／44／46（Inverting）

| Inputs |  |  |  |  | Internal Outputs |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{C L R}$ | PRE | $\overline{\text { OE }}$ | LE | $\mathrm{D}_{1}$ | $Q_{1}$ | $Y_{1}$ |  |
| H | H | H | x | X | X | Z | Hi－Z |
| H | H | H | H | H | L | Z | $\mathrm{Hi}-\mathrm{Z}$ |
| H | H | H | H | L | H | Z | Hi－Z |
| H | H | H | L | X | NC | Z | Latched （Hi－Z） |
| H | H | L | H | H | L | L | Transparent |
| H | H | L | H | L | H | H | Transparent |
| H | H | L | L | x | NC | NC | Latched |
| H | L | L | $x$ | x | H | H | Preset |
| L | H | L | X | x | L | L | Clear |
| L | L | L | X | X | H | H | Preset |
| L | H | H | L | X | L | Z | Latched <br> （Hi－Z） |
| H | L | H ${ }^{\text {²}}$ | L | X | H | Z | Latched <br> （Hi－Z） |

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied.............................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous -0.5 V to +7.0 V
DC Voltage Applied to Outputs for High Output State $\qquad$ -0.5 V to $\mathrm{V}_{\mathrm{Cc}}$ max
DC input voltage -0.5 V to +5.5 V
DC Output Current, into Outputs $\qquad$ 100 mA
DC input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ........................... +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} . \end{aligned}$ | $1 \mathrm{OH}=-15 \mathrm{~mA}$ | 2.4 | 3.3 |  | Volts |
|  |  |  | $\mathrm{IOH}^{\prime}=-24 \mathrm{~mA}$ | 2.0 | 3.1 |  |  |
| 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{MIL}, \mathrm{IOL}=32 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{IOL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  | -1.0. | mA |
| 1 IH | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| loz | Output Off-State (High Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |
| ISC | Output Short Circuit Current ${ }^{3}$ | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  | -75 |  | -250 | mA |
| Icc | Supply Current | $V_{C C}=M A X$ <br> Outputs Open | Over Temperature Range |  |  | 120 | mA |
|  |  |  | +70 |  |  | 110 |  |
|  |  |  | $+125^{\circ} \mathrm{C}$ |  |  | 100 |  |

Notes: 1. All typical values are $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$
2. For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
3. Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.

## SWITCHING TEST CIRCUIT



SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description |  | Test Conditions (Note 4) | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $\begin{aligned} & \text { tpLH } \\ & \text { (Am29841, 3, 5) } \\ & \hline \end{aligned}$ | Data $\left(D_{i}\right)$ to Output $Y_{i}(L E=H I G H)$ |  |  | $C_{L}=50 \mathrm{pF}$ | 3.5 | 9.5 | 3.5 | 11 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  | 3.5 |  | 9.5 | 3.5 | 11 | ns |
| tPLH |  |  | $C_{L}=300 \mathrm{pF}$ |  | 12.5 |  | 14 | ns |
| $t_{\text {PHL }}$ |  |  |  | 13 |  | 15 | ns |  |
| $\mathrm{t}_{\mathbf{S}}$ | Data to LE Setup Time |  |  | $C_{L}=50 \mathrm{pF}$ | 2.5 |  | 2.5 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Data to LE Hold Time |  | 2.5 |  |  | 3 |  | ns |
| $\begin{aligned} & \text { TPLH } \\ & \text { (Am29842, 4, 6) } \end{aligned}$ | Data $\left(D_{i}\right)$ to Output ( $\left.\overline{Y_{i}}\right)(\mathrm{LE}=\mathrm{HIGH})$ |  | $C_{L}=50 \mathrm{pF}$ | 3.5 | 10 |  | 12 | ns |
| tPHL |  |  | 3.5 | 10 |  | 12 | ns |  |
| tPLH |  |  | $C_{L}=300 \mathrm{pF}$ |  | 12.5 |  | 14 | ns |
| tPHL |  |  |  | 13 |  | 15 | ns |  |
| tPLH | Data to LE Setup Time |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 2.5 |  | 2.5 |  | ns |
| $\mathrm{t}_{\text {PHL }}$ | Data to LE Hold Time |  | 2.5 |  |  | 3 |  | ns |
| tple | Latch Enable (LE) to $\mathrm{Y}_{\mathrm{i}}$ |  | $C_{L}=50 \mathrm{pF}$ |  | 12 |  | 16 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 12 |  | 16 | ns |  |
| tple |  |  | $C_{L}=300 \mathrm{pF}$ |  | 16 |  | 20 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 16 |  | 20 | ns |  |
|  |  |  |  | $C_{L}=50 \mathrm{pF}$ |  |  |  |  | ns |
|  |  |  |  |  |  |  |  | ns |
| $t_{\text {PLH }}$ | Propagation Delay, Preset to $\mathrm{Y}_{\mathrm{i}}$ |  |  |  | 12 |  | 14 | ns |
| ts | Preset Recovery (PRE 5) Time |  |  |  | 14 |  | 17 | ns |
| tPHL | Propagation Delay, Clear to $\mathrm{Y}_{\mathrm{i}}$ |  |  |  | 21 |  | 23 | ns |
| ts | Clear Recovery (CLR $\Gamma^{\text {c }}$ ) Time |  |  |  | 14 |  | 17 | ns |
| tpWH | LE Pulse Width | HIGH | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 6 |  | 6 |  | ns |
| tpWL | Preset Pulse Width | LOW |  | 8 |  | 9 |  | ns |
| tpWL | Clear Pulse Width | LOW |  | 8 |  | 9 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable Time $\overline{O E}$ L to $Y_{i}$ |  | $C_{L}=300 \mathrm{pF}$ |  | 20 |  | 22 | ns |
| t ZL |  |  |  | 23 |  | 25 | ns |  |
| t ZH |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 14 |  | 15 | ns |
| t ZL |  |  |  | 14 |  | 15 | ns |  |
| $t_{H z}$ | Output Disable Time $\overline{O E} \sqrt{ } \mathrm{~F}_{\text {to }} Y_{i}$ |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 15 |  | 15 | ns |
| tLZ |  |  |  |  | 12 |  | 12 | ns |
| $t_{\text {t }} \mathrm{z}$ |  |  | $C_{L}=5 p F$ |  | 9 | , | 10 | ns |
| tız |  |  |  | 9 |  | 10 | ns |  |
| Note: 4. See test circuit and waveforms. |  |  |  |  |  |  |  |  |  |



## SWITCHING WAVEFORMS

SET UP, HOLD, AND RELEASE TIMES


Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense.
2. Cross hatched area is don't care condition.

ENABLE AND DISABLE TIMES Enable Disable


WF001410
Notes: 1. Diagram shown for Input Control Enable-LOW and Input Control Disable-HIGH.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.


Note: Pulse Generator for All Pulses: Rate $\leqslant 10 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{O}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.
INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


IC000070

## Am29861-64

High Performance Bus Transceivers

## DISTINCTIVE CHARACTERISTICS

- High-speed symmetrical bidirectional transceivers
- Noninverting tpD $=5.0 \mathrm{~ns} \mathrm{typ}$
- Inverting tpD $=4.5 \mathrm{~ns}$ typ
- 200 mV minimum input hysteresis on input data ports
- Three-state outputs glitch-free during power-up and down. Outputs have Schottky clamp to ground
- 48mA commercial lol, 32mA military IOL
- Low input/output capacitance
- loH specified 2.0 V and 2.4 V


## GENERAL DESCRIPTION

The Am29860 Series bus transceivers provide high performance bus interface buffering for wide data/address paths or buses carrying parity. The Am29863/64 9-bit transceivers have NOR-ed output enables for maximum control flexibility. All transceiver data inputs have 200 mV minimum input hysteresis to provide improved noise rejection.

All of the Am29800 high performance interface family are designed for high capacitance load drive capability while providing low capacitance bus loading at both inputs and outputs. All inputs are Schottky diode inputs, and all outputs are designed for low capacitance bus loading in the high impedance state.

BLOCK DIAGRAM

## Am29861/Am29862 10-BIT TRANSCEIVERS



## CONNECTION DIAGRAM <br> Top View <br> Am29861/Am29862 10-BIT TRANSCEIVERS



CD001150

## LOGIC SYMBOL



Am29861 (NONINVERTING)
LS000370

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am29861 - 64
Device type
High Performance Bus Transceiver
Package

X - Dice


| Valid Combinations |  |
| :--- | :--- |
| Am29861 | DC, DCB, DM, |
| Am29862 | DMB |
| Am29863 | LC, LCB, LM, |
| Am29864 | LMB |

D-24-pin SLIM DIP (D-24-SLIM)
L-28-pin Leadless Chip Carrier (L-28-1)
Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
L_Screening Option
Blank - Standard processing B - Burn-in
LMB
XC, XM

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

LOGIC SYMBOL

Am29863 (NONINVERTING)

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| Am29861/Am29862 |  |  |  |
| 1 | OER | 1 | When LOW in conjunction with ОET HIGH activates the RECEIVE mode. |
| 13 | OET | 1 | When LOW in conjunction with $\overline{\text { OER }}$ HIGH activates the TRANSMIT mode. |
|  | $\mathrm{R}_{\mathrm{i}}$ | 1/0 | 10-bit RECEIVE input/output. |
|  | $\mathrm{T}_{\mathrm{i}}$ | $1 / 0$ | 10-bit TRANSMIT input/output. |
| Am29863/Am29864 |  |  |  |
|  | $\overline{\mathrm{OER}} \mathrm{i}^{\text {i }}$ | 1 | When both are LOW in conjunction with any $\overline{\text { OET }}_{\mathrm{i}}$ HIGH indicates the RECEIVE mode. |
|  | $\mathrm{OET}_{i}$ | 1 | When both are LOW in conjunction with any $\overline{\text { OER }} \mathrm{F}_{\mathrm{i}}$ HIGH indicates the TRANSMIT mode. |
|  | $\mathrm{R}_{\mathrm{i}}$ | 1/0 | 9-bit RECEIVE input/output. |
|  | $\mathrm{T}_{\mathrm{i}}$ | 1/0 | 9 -bit TRANSMIT input/output. |

## FUNCTION TABLES



| ABSOLUTE MAXIMUM RATINGS | OPERATING RANGES |
| :---: | :---: |
| Storage Temperature ...................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | Commercial (C) Devices |
| Ambient Temperature with | Temperature ................................ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Power Applied........................... $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Supply Voltage .......................... +4.75 V to +5.25 V |
| Supply Voltage to Ground Potential <br> Continuous $\qquad$ -0.5 V to +7.0 V | Military (M) Devices <br> Temperature ................................ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| DC Voltage Applied to Output for High Output State .....................-1.5V to VCC max | Supply Voltage $\qquad$ +4.5 V to +5.5 V |
| DC Input voltage ..................................-0.5V to +5.5 V DC Output Current, Into Outputs <br> 100 mA | Operating ranges define those limits over which the functionality of the device is guaranteed. |
| DC Input Current ..........................-30mA to +5.0 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 device reliability. |  |

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameter | Description | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}=-15 \mathrm{~mA}$ | 2.4 |  |  | V |
|  |  |  | $\mathrm{IOH}=-24 \mathrm{~mA}$ | 2.0 |  |  |  |
| 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{MIL}, \mathrm{IOL}^{=32 \mathrm{~mA}}$ |  |  | 0.5 | V |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{IOL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | V |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| $\mathrm{V}_{\text {HYST }}$ | Input Hysteresis | Tested output is connected to AC load test circuit |  | 200 |  |  | mV |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1} \mathrm{~F}=0.4 \mathrm{~V}$ |  |  |  | -1.0. | mA |
| IIH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| lozh | Output Off-State Output Current (HI-Z) | $V_{C C}=M A X, V_{0}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| lozl | Output Off-State <br> Output Current ( $\mathrm{HI}-\mathrm{Z}$ ) | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  |  | -1.0 | mA |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  | -75 |  | -250 | mA |
| ICC | Supply Current | $V_{C C}=M A X$ Outputs Open | Over Temperature Range |  |  | 160 | mA |
|  |  |  | $+70^{\circ} \mathrm{C}$ |  |  | 150 |  |
|  |  |  | $+125^{\circ} \mathrm{C}$ |  |  | 140 |  |

## SWITCHING TEST CIRCUIT



Note: Pulse Generator for All Púlses: Rate $\leqslant 10 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{o}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Propagation Delay from $R_{i}$ to $T_{i}$ or $T_{i}$ to $R_{i}$ Am29861/Am29863 (Noninverting) | $C_{L}=50 \mathrm{pF}$ |  | 4.8 | 6.0 | ns |
| tpHL |  |  |  | 5.2 | 6.2 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  | 8 | 11 | ns |
| tPHL |  |  |  | 11 | 14 | ns |
| tplH | Propagation Delay from $R_{i}$ to $\bar{T}_{i}$ or $\bar{T}_{i}$ to $R_{i}$ Am29862/Am29864 (Inverting) | $C_{L}=50 \mathrm{pF}$ |  | 4.0 | 5.2 | ns |
| tPHL |  |  |  | 4.9 | 5.9 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  | 7.3 | 10 | ns |
| tPHL |  |  |  | 10.5 | 12.9 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable Time $\overline{O E T}$ to $T_{i}$ and OER to $R_{i}$ | $C_{L}=50 \mathrm{pF}$ |  | 6.5 | 12 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 9.5 | 12 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  | $C_{L}=300 \mathrm{pF}$ |  | 11 | 17 | ns |
| tzL |  |  |  | 17 | 21 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Disable Time OET to $T_{i}$ and OER to $\mathrm{R}_{\mathrm{i}}$ | $C_{L}=5 p F$ |  | 3.5 | 8.0 | ns |
| tLZ |  |  |  | 3.5 | 8.0 | ns |
| $t_{H Z}$ |  | $C_{L}=50 \mathrm{pF}$ |  | 11.2 | 16 | ns |
| tLz |  |  |  | 4.5 | 9.0 | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tple | Propagation Delay from $R_{i}$ to $T_{i}$ or $T_{i}$ to $R_{i}$ Am29861/Am29863 (Noninverting) | $C_{L}=50 \mathrm{pF}$ |  | 8 |  | 10 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 8 |  | 10 | ns |
| tPLH |  | $C_{L}=300 \mathrm{pF}$ |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 15 |  | 17 | ns |
| tple | Propagation Delay from $R_{i}$ to $T_{i}$ or $\bar{T}_{i}$ to $R_{i}$ Am29862/Am29864 (Inverting) | $C_{L}=50 \mathrm{pF}$ |  | 7.0 |  | 9.0 | ns |
| tPHL |  |  |  | 7.5 |  | 9.5 | ns |
| tplH |  | $C_{L}=300 \mathrm{pF}$ |  | 14 |  | 16 | ns |
| tPHL |  |  |  | 14 |  | 16 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Enable Time $\overline{O E T}$ to $T_{i}$ or $\overline{O E R}$ to $R_{i}$ | $C_{L}=50 \mathrm{pF}$ |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  | $C_{L}=300 \mathrm{pF}$ |  | 20 |  | 22 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 23 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Disable Time $\overline{O E T}$ to $T_{i}$ or $\overline{O E R}$ to $R_{i}$ | $C_{L}=5 p F$ |  | 9 |  | 10 | ns |
| tLz |  |  |  | 9 |  | 10 | ns |
| $t_{\text {t }} \mathrm{z}$ |  | $C_{L}=50 \mathrm{pF}$ |  | 17 |  | 19 | ns |
| tLZ |  |  |  | 12 |  | 12 | ns |




## Am25S and Am25LS Logic Family Index

Am25S05<br>Am25LS07/Am25LS08<br>Am25S07/Am25S08<br>Am25LS09<br>Am25S09<br>Am25S10<br>Am25LS14A<br>Am25LS15<br>Am25S18<br>Am25LS22<br>Am25LS23<br>Am25LS2513<br>Am25LS381/Am54LS381<br>Am74LS381/Am25LS2517<br>Am25LS2518<br>Am25LS2519<br>Am25LS2520<br>Am25LS2521<br>Am25LS2535<br>Am25LS2536<br>Am25LS2537<br>Am25LS2538

Four-Bit by Two-Bit Two's Complement Multiplier ...................9-1
Hex/Quad Parallel D Registers with Register Enable ..............9-8
Hex/Quad Parallel D Register with Register Enable..............9-13
Quad Two-Input, High-Speed Register.................................9-20
Quad Two-Input, High-Speed Register.................................9-26
Four-Bit Shifter with Three-State Outputs.............................9-32
8-Bit Serial/Parallel Two's Complement Multiplier .................9-38
Quad Serial Adder/Subtractor ...........................................9-45
Quad D Register with Standard and Three-State Outputs .....9-51
8-Bit Serial/Parallel Register with Sign Extend.....................9-57
8-Bit Shift/Storage Register with Synchronous Clear .............9-64
Three-State Priority Encoder .............................................9-69
Arithmetic Logic Unit/Function Generator Low-Power
Schottky Integrated Circuits .........................................-977
Quad D Register with Standard and Three-State Outputs .....9-89
Quad Register with Two Independently Controlled
Three-State Outputs ...................................................9-95
Octal D-Type Flip-Flop with Clear, Clock Enable and
Three-State Control..................................................9-101
Eight-Bit Equal-to Comparator ........................................ 9-108
Eight-Input Multiplexer with Control Register...................... 9-113
Eight-Bit Decoder with Control Storage ............................ 9-120
One-of-Ten Decoder with Three-State Outputs and
Polarity Control ........................................................9-125
One-of-Eight Decoder with Three-State Outputs and
Polarity Control .......................................................9-131
Dual One-of-Four Decoder with Three-State Outputs and
Polarity Control ......................................................... 9-138
Chip Select Address Decoder with Acknowledge................ 9-144
Eight-Bit by Eight-Bit Combinatorial Multiplier ..................... 9-150
Four-Bit Up/Down Counters with Three-State Outputs ........ 9-157

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The performance characteristics listed in this data book are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry. For specific testing details contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

# Am25S05 

Four-Bit by Two-Bit Two's Complement Multiplier

## DISTINCTIVE CHARACTERISTICS

- Provides 2's complement multiplication at high speed without correction.
- Can be used in a combinatorial array or in a time sequenced mode.
- Multiplies two 12-bit signed numbers in typically 115 ns .
- Multiplies in active HIGH (positive logic) or active LOW (negative logic) representations.
- Reduced input loading as compared to Am2505.


## GENERAL DESCRIPTION

The Am25S05 is a high-speed digits! multiplier that can multiply numbers represented in the 2 's complement notation and produce a 2's complement product without correction. The device consists of a $4 \times 2$ multiplier that can be connected to form iterative arrays able to multiply numbers either directly, or in a time sequenced arrangement. The device assumes that the most significant digit in a word carries a negative weight, and can therefore be used in arrays where the multiplicand and multiplier have different word lengths. The multiplier uses the quaternary algorithm and performs the function $S=X Y+K$ where $K$ is the input field used to add partial products generated in the array. At the beginning of the array the K inputs are available to add a signed constant to the least significant part of the product. Multiplication of an $m$ bit number by an $n$ bit
number in an array results in a product having $m+n$ bits so that all possible combinauons of product are accounted for. If a conventional 2's complement product is required the most significant bit can be ignored, and overflow conditions can be detected by comparing the last two product digits.

A number of connection schemes are possible. Figure 1 shows the connection scheme that results in the fastest multiply. If higher speed is required an array can be split into several parts, and the parts added with high-speed look-ahead carry adders.

Provision is made in the design for multiplication in the active high (positive logic) or active low (negative logic) representations simply by reinterpreting the active level of the input operands, the product, and a polarity control $\overline{\mathrm{P}}$.

## BLOCK DIAGRAM



RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS14A | 8 -Bit Serial/Parallel Multiplier |
| Am25LS557/8 | 8 -Bit by 8-Bit Multiplier |
| Am29516/7 | 16-Bit by 16 -Bit Multiplier |

Top View
$v_{C C v}, v_{0} v_{1} \overline{\bar{p}} k_{0} k_{1} k_{2} \quad k_{3} s_{5} s_{4} c_{n} \cdot 4$


Note: Pin 1 is marked for orientation

## LOGIC SYMBOL

METALLIZATION AND PAD LAYOUT


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25S05



- Screening Option

Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
Package
D-24-pin CERDIP
F-24-pin flatpak
$\mathrm{P}-24$-pin plastic DIP X - Dice

Device type
4-Bit by 2-Bit Multiplier


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## SWITCHING TIME TEST TABLE

| Input | Outputs | Inputs at OV (remaining inputs at 4.5V) |
| :--- | :---: | :---: |
| $C_{n}$ | $C_{n+4}, S_{0123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $X$ |
| $k_{0}$ | $C_{n}+4, S_{0123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $X$ |
| $k_{1}$ | $C_{n+4}, S_{123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $X$ |
| $k_{2}$ | $C_{n+4}, S_{23}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $X$ |
| $k_{3}$ | $S_{3}$ | $P, Y_{-1}, Y_{1}$, All $X$ |
| $k_{3}$ | $S_{45}$ | $P, Y_{-1}, Y_{1}$, All $X, C_{n}$ |
| $x_{-1}$ | $C_{n+4}, S_{0123}, S_{45}$ | $P, Y_{1}$, All $k$ |
| $x_{0}$ | $C_{n+4}, S_{0123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $k$ |
| $x_{1}$ | $C_{n+4}, S_{123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $k$ |
| $x_{2}$ | $C_{n+4}, S_{123}, S_{45}$ | $P, Y_{-1}, Y_{1}$, All $k$ |
| $x_{3}$ | $S_{3}$ | $P, Y_{-1}, Y_{1}$, All $k$ |
| $x_{3}$ | $S_{45}$ | $P, Y_{-1}, Y_{1}$, All $k, C_{n}$ |
| $x_{4}$ | $S_{45}$ | $P, Y_{1}$, All $k, C_{n}$ |
| $y_{-1}$ | $C_{n+4}, S_{0123}, S_{45}$ | $P, X_{1}, X_{2}, X_{3}, X_{4}$, All $k$ |
| $y_{0}$ | $C_{n+4}, S_{0123}, S_{45}$ | $X_{0}, X_{1}, X_{2}, X_{3}, X_{4}$, All $k$ |
| $y_{1}$ | $C_{n+4}, S_{0123}, S_{45}$ |  |

## DEFINITION OF TERMS

SUBSCRIPT TERMS:
H HIGH, applying to a HIGH logic level or when used with $V_{C C}$ to indicate high $V_{C C}$ value.
I Input.
L LOW, applying to LOW logic level or when used with $V_{C C}$ to indicate low $V_{C C}$ value.
0 Output.
FUNCTIONAL TERMS:
$\mathbf{C}_{\boldsymbol{n}}$ The carry input to the high-speed adder. $\mathrm{C}_{\mathrm{n}}+4$ The carry output from the high-speed adder. $\mathbf{K}_{\mathbf{i}}$ The constant field used for accumulating partial products. $i=0,1,2,3$. At the beginning of the array the $K$ field can be used to add a 2's complement number to the least significant half of the double length product. $\overline{\mathbf{P}}$ The polarity control input. This input must be at a lowlogic level for numbers in the active high logic representation, and held high for numbers in the active low logic representation.
$\mathbf{S}_{\mathbf{i}}$ The product outputs. $\mathbf{i}=0,1,2,3,4,5$.
$\mathbf{x}_{\mathbf{i}}$ The multiplicand inputs. $\mathrm{i}=-1,0,1,2,3,4$. At the first column of the array $x_{-1}$ must be held at logic ' 0 ',
and at the last column of the array $\mathrm{x}_{4}$ is connected to $\times 3$.
$\mathbf{Y}_{\mathrm{i}}$ The multiplier inputs. $\mathrm{i}=-1,0,1$.
At the first row of the array $Y_{-1}$ must be held at logic ' 0 '.

## OPERATIONAL TERMS:

IIL Forward input load current.
$\mathrm{IOH}^{\text {OHt }}$ Output HIGH current, forced out of output in $\mathrm{VOH}_{\mathrm{OH}}$ test.
loL Output LOW current, forced into the output in $\mathrm{V}_{\mathrm{OL}}$ test.
Icc The current drawn by the device from VCC power supply with input and output terminals open.
$I_{\text {IH }}$ Reverse input load current.
Negative Current Current flowing out of the device. Positive Current Current flowing into the device.
$\mathbf{V}_{\mathbf{I H}}$ Minimum logic HIGH input voltage.
$V_{\text {IL }}$ Maximum logic LOW input voltage.
$V_{\text {IN }}$ Input voltage applied in IL, I IH tests.
$\mathrm{V}_{\text {OH }}$ Minimum logic HIGH output voltage with output HIGH current $\mathrm{I}_{\mathrm{OH}}$ flowing out of output.
VOL Maximum logic LOW output voltage with output LOW current loL flowing into output.

MSI INTERFACING RULES

| Interfacing <br> Digital Family | Equivalent <br> Input Unit Load |  |
| :--- | :---: | :---: |
|  | HIGH | LOW |
| Advanced Micro Devices 54/7400 <br> Series | 1.25 | 1.25 |
| Advanced Micro Devices 9300/2500 <br> Series | 1.25 | 1.25 |
| FSC Series 9300 | 1.25 | 1.25 |
| TI Series 54/7400 | 1.25 | 1.25 |
| Signetics Series 8200 | 2.5 | 2.5 |
| National Series DM 75/85 | 1.25 | 1.25 |
| DTL Series 930 | 15 | 1.25 |

## OPERATION TABLE

| $\mathbf{Y}$ Multiplier |  |  | Operation <br> $\mathbf{X}$ Multiplicand |
| :---: | :---: | :---: | :---: |
| $\mathrm{Y}_{\mathbf{- 1}}$ | $\mathrm{Y}_{\mathbf{0}}$ | $\mathbf{Y}_{\mathbf{1}}$ |  |
| 0 | 0 | 0 | $\mathrm{~K}+\mathrm{X}$ |
| 1 | 0 | 0 | $\mathrm{~K}+\mathrm{X}$ |
| 0 | 1 | 0 | $\mathrm{~K}+2 \mathrm{X}$ |
| 1 | 1 | 0 | $\mathrm{~K}-2 \mathrm{X}$ |
| 0 | 0 | 1 | $\mathrm{~K}-\mathrm{X}$ |
| 1 | 0 | 1 | $\mathrm{~K}-\mathrm{X}$ |
| 0 | 1 | 1 | $\mathrm{~K}-0$ |
| 1 | 1 | 1 |  |

Active Low Inputs and Outputs
'1' = Low, '0' = High, $\mathrm{P}=$ High
Active High Inputs and Outputs ' 1 ' = High, ' 0 ' = Low, $\bar{P}=$ Low

Am25S05 LOADING RULES IN UNIT LOADS

| Input/Output | Pin Nos. | Input Unit Load |  | Fan-out |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Input HIGH | Input LOW | Output HIGH | Output LOW |
| $\mathrm{X}_{4}$ | 1 | 0.2 | 0.2 | - | - |
| $\mathrm{C}_{\mathrm{n}}$ | 2 | 0.2 | 0.2 | - | - |
| $\mathrm{X}_{3}$ | 3 | 0.2 | 0.2 | - | - |
| $\mathrm{x}_{2}$ | 4 | 0.4 | 0.4 | - | - |
| $\mathrm{x}_{1}$ | 5 | 0.4 | 0.4 | - | - |
| $\mathrm{x}_{0}$ | 6 | 0.4 | 0.4 | - | - |
| X-1 | 7 | 0.2 | 0.2 | - | - |
| $\mathrm{S}_{0}$ | 8 | - | - | 20 | 10 |
| $\mathrm{S}_{1}$ | 9 | - | - | 20 | 10 |
| $\mathrm{S}_{2}$ | 10 | - | - | 20 | 10 |
| $\mathrm{S}_{3}$ | 11 | - | - | 20 | 10 |
| GND | 12 | - | - | - | - |
| $\mathrm{C}_{\mathrm{n}+4}$ | 13 | - | - | 20 | 10 |
| $\mathrm{S}_{4}$ | 14 | - | - | 20 | 10 |
| $\mathrm{S}_{5}$ | -15 | - | - | 20 | 10 |
| $k_{3}$ | 16 | 2 | 2 | - | - |
| $\mathrm{k}_{2}$ | 17 | 2 | 2 | - | - |
| $\mathrm{k}_{1}$ | 18 | 2 | 2 | - | - |
| $\mathrm{k}_{0}$ | 19 | 2 | 2 | - | - |
| $\overline{\mathrm{P}}$ | 20 | 1 | 1 | - | - |
| $\mathrm{y}_{1}$ | 21 | 0.6 | 0.6 | - | - |
| yo | 22 | 0.6 | 0.6 | - | - |
| y-1 | 23 | 0.6 | 0.6 | - | - |
| $\mathrm{V}_{\mathrm{CC}}$ | 24 | - | - | - | - |

A Schottky, TTL Unit Load is defined as $50 \mu \mathrm{~A}$ at 2.7 V at the HIGH Logic Level and -2.0 mA at 0.5 V at the LOW Logic Level.

## USER NOTES

1. Arithmetic in the multiplier is performed in the 2 's complement notation, which requires a carry in at the first stage. This is accomplished by connecting the $Y_{i}$ multiplier bit to the appropriate carry input terminal $i=1,3,5$...
2. The multiplier can perform multiplication in either the active high (positive logic) or active low (negative logic) representations by reinterpreting the active logic level and by grounding or leaving the polarity control pin $\overline{\mathrm{P}}$ open circuit respectively.
3. Multiplication can be performed in number representations other than 2's complement by either correcting the 2's complement product or adding in a correction at the beginning of the multiplication at the $K$ inputs. 2 's complement numbers are represented as: $X_{2}=x-x_{s} 2^{n-1}$.

| Number Representation | Correction |
| :---: | :---: |
| 2's complement | None |
| 1's complement | Add $x_{s} Y_{2}+y_{S} x_{2}+x_{s} Y_{s}$ at $K$ inputs |
| Unsigned | Extended multiplier and multiplicand one bit |
| (Magnitude) | at the least significant end. Form $x_{0} y_{0}+y_{0} x+x_{0} y$ with conditional adder and add to array shifted two places up at $k$ inputs. Force $\mathrm{k}_{\mathrm{s}}, \mathrm{y}_{\mathrm{s}}, \mathrm{x}_{\mathbf{s}}=0$. |
| Sign magnitude | $\begin{array}{ll} x_{s}=0, & y_{s}=0 \\ x_{s}=1, & y_{s}=0 \\ \text { Norm }_{s}\left[(X Y)_{2}+2^{n-1} y\right] \\ x_{s}=0, & y_{s}=1 \\ x_{s}=1, & y_{s}=1 \end{array} \text { Form }\left[\left(X Y 2^{n-1}\left(x+2^{n-1} y\right]-2^{2 n-2} .\right.\right.$ |

4. For the highest speed array with the multipliers arranged in a parallelogram structure carries between certain multipliers are exchanged with the $y$ carry-ins needed for 2's complement subtract. The delays in the array are then equalized as best possible as shown in Figure 1.
5. For higher speed multiplication the array can be split into several parts that can be added together with high-speed adders.
6. Rounding off to a single length product can be achieved by adding a ' 1 ' to the array at the most significant positive k input of the array, ignoring the most significant product digit, and using the remainder of the most significant part of the product.
7. Truncation of a product without round off enables some of the multipliers in the array to be removed.

CONNECTION SCHEMES


2
paballelogram
CARRIES FROM
LOWER ORER
MULTPLLERS SKIP
TO ALTERNATE ROWS
TO ALTERNATE ROW
WHERE POSSIELE


3
SPLIT INTO
TWO PARTS WHICH
ARE ADDED WITH HIG ASPEED
CARRY LOOKAHEAD ADNE:

HAGH SPEED SCHOTTKY HIGH.SPEED SCHOTTKY
CARRY LOOKAHEAD ADOER

AF000820
Figure 1

TYPICAL MULTIPLICATION TIMES

| Array |  |  |  |
| :---: | :---: | :---: | :---: |
| Size |  |  |  |
| Bits | Total <br> Multiplication <br> Time (ns) | Package Count |  |
|  | Am25S05 | Am54S/74S181 |  |
| $4 \times 4$ | 35 | 2 |  |
| $8 \times 8$ | 75 | 8 |  |
| $12 \times 12$ | 115 | 18 |  |
| $12 \times 12$ | 82 | 18 | 5 |
| $16 \times 16$ | 155 | 32 |  |
| $16 \times 16$ | 111 | 32 | 7 |
| $16 \times 16$ | 98 | 32 | 16 |
| $20 \times 20$ | 195 | 50 |  |
| $20 \times 20$ | 130 | 50 | 9 |
| $24 \times 24$ | 235 | 72 |  |
| $24 \times 24$ | 149 | 72 | 11 |
| $24 \times 24$ | 125 | 72 | 24 |
| $28 \times 28$ | 275 | 98 |  |
| $28 \times 28$ | 168 | 98 | 13 |
| $32 \times 32$ | 315 | 128 |  |
| $32 \times 32$ | 187 | 128 | 15 |
| $32 \times 32$ | 152 | 128 | 32 |


AF001170
Figure 2

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature(Ambient) Under Bias ........ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 24 to Pin 12) Continuous ............. -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$
$\qquad$ $\ldots . .-0.5 \mathrm{~V}$ to +5.5 V
DC Output Current, Into Outputs ...........................30mA
DC Input Current............................. 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $\ldots \ldots \ldots \ldots \ldots \ldots . . \ldots \ldots . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N ., V_{O H}=-1.0 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | XM | 2.5 | 3.3 |  | Volts |
|  |  |  | XC | 2.7 | 3.3 |  |  |
| Vol | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O L}=20 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  | 0.3 | 0.5 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| ILL (Note 2) | Unit Load Input LOW Current | $V_{C C}=M A X ., V_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  | -2.0 | mA |
| IH (Note 2) | Unit Load Input HIGH Current | $V_{C C}=M A X ., V_{I N}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}^{\text {., }} \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| IsC | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=$ MAX., $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{C C}=\mathrm{MAX} ., \mathrm{Y}_{1}=.0 \mathrm{~V}$ |  |  | 120 | 175 | mA |

Note 1. Typical Limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
Note 2. Actual input currents are obtained by multiplying unit load current by the input load factor (See loading rules).

SWITCHING CHARACTERISTICS $\left(V_{C C}=5 V, T_{A}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega\right.$ )

| Parameters | From (Input) | To (Output) | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | $\mathrm{C}_{n}$ | $C_{n+4}$ | See Test Table | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 8 \\ & 9 \end{aligned}$ | $\begin{aligned} & 12 \\ & 14 \end{aligned}$ | ns |
| $\begin{aligned} & \mathrm{tPLH} \\ & \mathrm{t}_{\mathrm{pHLL}} \end{aligned}$ | $\mathrm{C}_{n}$ | $\mathrm{S}_{0,1,2,3}$ |  | $\begin{aligned} & 6 \\ & 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & 12 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 18 \\ & 15 \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tPHL } \\ & \hline \end{aligned}$ | $\mathrm{C}_{n}$ | $\mathrm{S}_{4,5}$ |  | $\begin{aligned} & 7 \\ & 6 \\ & \hline \end{aligned}$ | $\begin{aligned} & 15 \\ & 13 \end{aligned}$ | $\begin{aligned} & 22 \\ & 20 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any k | $C_{n+4}$ |  | $\begin{aligned} & 3 \\ & 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & 6.5 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 12 \\ & 15 \end{aligned}$ | ns |
| $\begin{aligned} & \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any k | $\mathrm{S}_{0,1,2,3}$ |  | $\begin{aligned} & 6 \\ & 4 \end{aligned}$ | $\begin{gathered} 13.5 \\ 9.5 \\ \hline \end{gathered}$ | $\begin{aligned} & 20 \\ & 14 \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tPHL } \\ & \hline \end{aligned}$ | Any k | $\mathrm{S}_{4,5}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 15.5 \\ & 12.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & 23 \\ & 19 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any x | $C_{n+4}$ |  | $\begin{aligned} & \hline 8 \\ & 9 \end{aligned}$ | $\begin{aligned} & 17 \\ & 18 \end{aligned}$ | $\begin{aligned} & 26 \\ & 27 \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tPLH } \\ & t_{\text {PHLL }} \\ & \hline \end{aligned}$ | Any x | $\mathrm{S}_{0,1,2,3}$ |  | $\begin{aligned} & 10 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 21 \\ & 21 \\ & \hline \end{aligned}$ | $\begin{aligned} & 32 \\ & 32 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any x | $\mathrm{S}_{4,5}$ |  | $\begin{aligned} & 6 \\ & 5 \end{aligned}$ | $\begin{aligned} & 23.5 \\ & 21.5 \end{aligned}$ | $\begin{aligned} & 35 \\ & 32 \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any y | $C_{n+4}$ |  | $\begin{aligned} & 11 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{array}{r} 23 \\ 20 \\ \hline \end{array}$ | $\begin{aligned} & 34 \\ & 30 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any y | $\mathrm{S}_{0,1,2,3}$ |  | $\begin{aligned} & 11 \\ & 11 \end{aligned}$ | $\begin{aligned} & 23 \\ & 23 \\ & \hline \end{aligned}$ | $\begin{aligned} & 34 \\ & 34 \\ & \hline \end{aligned}$ | ns |
| $\begin{aligned} & \hline \text { tpLH } \\ & \text { tpHL } \\ & \hline \end{aligned}$ | Any y | $S_{4,5}$ |  | $\begin{aligned} & \hline 12 \\ & 12 \\ & \hline \end{aligned}$ | $\begin{aligned} & 25 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & 37 \\ & 37 \\ & \hline \end{aligned}$ | ns |

## Am25LS07/Am25LS08

Hex/Quad Parallel D Registers with Register Enable

## DISTINCTIVE CHARACTERISTICS

- 4-bit and 6-bit parallel registers
- Common Clock and Common Enable
- Positive edge triggered D flip flops
- Second sourced by TI as 54LS/74LS378 and 379
- Am25LS D.C. parameters including: $\mathrm{V}_{\mathrm{OL}}=0.45 \mathrm{~V}$ at $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$
Fan-out over military range $=22$
$440 \mu \mathrm{~A}$ source current


## GENERAL DESCRIPTION

The Am25LS07 is a 6-bit Low Power Schottky register with a buffered common register enable. The Am25LS08 is a 4bit register with a buffered common register enable. The devices are similar to the Am54LS/74LS174 and Am54LS/ 74LS175 but feature the common register enable rather than common clear.

Both registers will find application in digital systems where information is associated with a logic gating signal. When the enable is LOW, data on the D inputs is stored in the register on the positive going edge of the clock pulse. When the enable is $\mathrm{HIGH}^{-1}$, the register will not change state regardless of the clock or data input transitions.

## BLOCK DIAGRAM

Am25LS07


BD001450

Am25LS08


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2918 | Quad D Register |
| Am2919 | Quad D Register |



ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


Device type Hex/Quad Parallel D Registers



FUNCTION TABLE

| Inputs |  |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{E}}$ | $\mathbf{D}_{\mathbf{i}}$ | $\mathbf{C P}$ | $\mathbf{Q}_{\mathbf{i}}$ | $\overline{\mathbf{Q}}_{\mathbf{i}}$ |
| $H$ | $X$ | $X$ | NC | NC |
| L | $X$ | $H$ | NC | NC |
| L | $X$ | $L$ | NC | NC |
| L | L | $\uparrow$ | $L$ | $H$ |
| L | $H$ | $\uparrow$ | $H$ | $L$ |

$H=$ HIGH NC $=$ No Change $\uparrow=$ LOW-to-HIGH Transition $\mathrm{L}=$ LOW $\mathrm{X}=$ Don't Care $\overline{\mathrm{Q}_{1}}$ on Am25LS08 Only

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . . . . . . . . . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous............... 0.5 V to +7.0 V
DC Voltage Applied to Outputs For
HIGH Output State...................... 0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage................................ 0.5 V to +7.0 V
DC Output Current, Into Outputs .......................... 30mA
DC Input Current ............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O H}=-440 \mu \mathrm{~A} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | COM'L | 2.7 | 3.4 |  | Volts |
|  |  |  | MIL | 2.5 | 3.4 |  |  |
| 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}$ | $1 \mathrm{OL}=4 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{OL}=8 \mathrm{~mA}$ |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs | COM'L |  |  | 0.8 | Volts |
|  |  |  | MIL |  |  | 0.7 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=$ MIN., ${ }_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | Volts |
| IL | Input LOW Current | $V_{C C}=M A X ., V_{1 N}=0.4 V$ | Clock, $\overline{\mathrm{E}}$ |  |  | -0.36 | mA |
|  |  |  | Others |  |  | -0.24 |  |
| 1 H | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{1 \mathrm{~N}}=2.7 \mathrm{~V}$ | Clock, E |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | Others |  |  | 14 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{1 \mathrm{~N}}=7.0 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$. |  | -15 |  | -85 | mA |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ MAX. ( Note 4) | LS07 |  | 16 | 22 | mA |
|  |  |  | LS08 |  | 11 | 18 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Outputs open; enable grounded; data inputs at 4.5 V , measured after a momentary ground, then 4.5 V applied to the clock input.


Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMN | RCIAL | MIL | ARY | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS. |  | Am25LS |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Clock to Output | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 30 |  | 35 | ns |
| tPHL | Clock to Output |  |  | 30 |  | 35 | ns |
| $\mathrm{t}_{\mathrm{pw}}$ | Clock Pulse Width |  | 26 |  | 30 |  | ns |
| $t_{s}$ | Data |  | 30 |  | 35 |  | ns |
| $\mathrm{t}_{\text {s }}$ | Enable |  | 43 |  | 50 |  | ns |
| $t_{n}$ | Data |  | 11 |  | 12 |  | ns |
| $t_{n}$ | Enable |  | 11 |  | 12 |  | ns |
| $f_{\text {max }}$ (Note 1) | Maximum Clock Frequency |  | 30 |  | 25 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

## Am25S07/Am25S08

Hex/Quad Parallel D Registers with Register Enable

## DISTINCTIVE CHARACTERISTICS

- 4-bit and 6-bit high-speed parallel registers
- Positive edge triggered D flip-flops
- Common clock and common enable


## GENERAL DESCRIPTION

The Am25S07 is a 6-bit, high-speed Schottky register with a buffered common register enable. The Am25S08 is a 4-bit register with a buffered common register enable. The devices are similar to the Am54S/74S174 and Am54S/ 74 S 175 but feature the common register enable rather than common clear.

Both registers will find application in digital systems where information is associated with a logic gating signal. When the enable is LOW, data on the D inputs is stored in the register on the positive going edge of the clock pulse. When the enable is HIGH , the register will not change state regardless of the clock or data input transitions.

## BLOCK DIAGRAM

Am25S07.


Am25S08


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS07/08 | Low Power Versions |
| Am2918 | Quad D Register |
| Am2919 | Quad Register |
| Am29821-26 | 8, 9, 10-Bit Register |

CONNECTION DIAGRAM
Top View
Am25S07


Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

 Device number, speed option (if applicable), package type, operating range and screening option (if desired).| Am25S07/08 |  |
| :---: | :---: |
| Device type Hex/Quad | egisters |

METALLIZATION AND PAD LAYOUT Am25S07


DIE SIZE: $0.070^{\prime \prime} \times 0.083^{\prime \prime}$

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following:

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am25S07/08 | DC, DM |
|  | FM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

CONNECTION DIAGRAM Top View

## Am25S08



Note: Pin 1 is marked for orientation

LOGIC SYMBOL Am25S08


LS000600

METALLIZATION AND PAD LAYOUT Am25S08


DIE SIZE: $0.067^{\prime \prime} \times 0.073^{\prime \prime}$

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\mathrm{D}_{\mathrm{i}}$ | I | The D flip-flop data inputs. |
| 1 | $\bar{E}$ | 1 | Enable. When the enable is LOW, data on the $D_{i}$ inputs is transferred to the $Q_{i}$ outputs on the LOW- <br> to-HIGH clock transition. When the enable is HIGH, the $Q_{i}$ outputs do not change regardless of the <br> data or clock input transitions. |
| 9 | CP | I | Clock Pulse for the register. Enters data on the LOW-to-HIGH transition. |
|  | $Q_{i}$ | 0 | The TRUE register outputs. |
|  | $\bar{Q}_{i}$ | 0 | The complement register outputs. |

FUNCTION TABLE

| Inputs |  |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{E}}$ | $\mathbf{D}_{\mathbf{I}}$ | $\mathbf{C P}$ | $\mathbf{Q}_{\mathbf{i}}$ | $\overline{\mathbf{Q}}_{\mathbf{i}}$ |
| H | $X$ | $X$ | NC | NC |
| L | $X$ | H | $\cdot$ NC | NC |
| L | $X$ | L | NC | NC |
| L | L | $\uparrow$ | L | H |
| L | H | T | H | L |

$$
\begin{array}{ll}
H=\text { HIGH } & \uparrow=\text { LOW-to-HIGH Transition } \\
L=\text { LOW } & \text { NC = No Change } \\
X=\text { Don't Care } & \bar{Q}_{i} \text { on Am25S08 Only }
\end{array}
$$



Selective Register Loading of Data on Synchronous Clock.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous............... -0.5 V to +7.0 V DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}}$ max DC Input Voltage $\qquad$ -0.5 V to +5.5 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current $\qquad$ -30 mA to +5.0 mA

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

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 device reliability.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O H}=-1 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | XC | 2.7 | 3.4 |  | Volts |
|  |  |  | XM | 2.5 | 3.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O L}=20 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level * | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage _ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{liN}^{\prime}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| $\begin{aligned} & \text { ILNote 3) } \\ & \text { (Not } \end{aligned}$ | Unit Load Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{1 \times}=0.5 \mathrm{~V}$ |  |  |  | -2 | mA |
| $\begin{aligned} & \hline \mathrm{liH} \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input HIGH Current | $V_{C C}=M A X ., V_{I N}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current (Note 4) | $V_{C C}=$ MAX . |  | -40 |  | $-100$ | mA |
| ICC | Power Supply Current (Note 5) | $V_{C C}=M A X$. | S07 |  | 90 | 144 |  |
|  |  |  | S08 |  | 60 | 96 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type. 3. Actual input currents $=$ Unit Load Current $\times$ Input Load Factor (See Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
5. Outputs open; enable grounded; data inputs at 4.5 V , measured after a momentary ground, then 4.5 V applied to the clock input.

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Clock to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega$ | 4 | 8 | 12 | ns |
| $\mathrm{t}_{\text {PHL }}$ | Clock to Output |  | 4 | 11.5 | 17 | ns |
| $\mathrm{t}_{\mathrm{pw}}$ | Clock Pulse Width |  | 7 |  |  | ns |
| $\mathrm{t}_{\text {s }}$ | Data |  | 5.5 |  |  | ns |
| $t_{s}$ | Enable |  | 9 |  |  | ns |
| $t_{h}$ | Data |  | 3 |  |  | ns |
| $t_{n}$ | Enable |  | 3 |  |  | ns |

Am25S07 LOADING RULES （In STTL Unit Loads）

|  |  |  | Fan－out |  |
| :--- | :---: | :---: | :---: | :---: |
| Input／Output | Pin <br> Nos． | Input <br> Unit Load | Output <br> HIGH | Output <br> LOW |
| $\bar{E}$ | 1 | 1 | - | - |
| $Q_{0}$ | 2 | - | 20 | 10 |
| $D_{0}$ | 3 | 1 | - | - |
| $D_{1}$ | 4 | 1 | - | - |
| $Q_{1}$ | 5 | - | 20 | 10 |
| $D_{2}$ | 6 | 1 | - | - |
| $Q_{2}$ | 7 | - | 20 | 10 |
| $G N D$ | 8 | - | - | - |
| $C P$ | 9 | 1 | - | - |
| $Q_{3}$ | 10 | - | 20 | 10 |
| $D_{3}$ | 11 | 1 | - | - |
| $Q_{4}$ | 12 | - | 20 | 10 |
| $D_{4}$ | 13 | 1 | - | - |
| $D_{5}$ | 14 | 1 | - | - |
| $Q_{5}$ | 15 | - | 20 | 10 |
| $V_{C C}$ | 16 | - | - | - |

A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ measured at 2．7V HIGH and -2.0 mA measured at 0.5 V LOW．

Am25S08 LOADING RULES （In STTL Unit Loads）

|  |  |  | Fan－out |  |
| :--- | :---: | :---: | :---: | :---: |
| Input／Output | Pin <br> Nos． | Input <br> Unit Load | Output <br> HIGH | Output <br> LOW |
| $\bar{E}$ | 1 | 1 | - | - |
| $Q_{0}$ | 2 | - | 20 | 10 |
| $\bar{Q}_{0}$ | 3 | - | 20 | 10 |
| $D_{0}$ | 4 | 1 | - | - |
| $D_{1}$ | 5 | 1 | - | - |
| $\bar{Q}_{1}$ | 6 | - | 20 | 10 |
| $Q_{1}$ | 7 | - | 20 | 10 |
| $G_{N D}$ | 8 | - | - | - |
| $C P$ | 9 | 1 | - | - |
| $Q_{2}$ | 10 | - | 20 | 10 |
| $\bar{Q}_{2}$ | 11 | - | 20 | 10 |
| $D_{2}$ | 12 | 1 | - | - |
| $D_{3}$ | 13 | 1 | - | - |
| $\bar{Q}_{3}$ | 14 | - | 20 | 10 |
| $Q_{3}$ | 15 | - | 20 | 10 |
| $V_{C C}$ | 16 | - | - | - |

## SCHOTTKY INPUT／OUTPUT CURRENT INTERFACE CONDITIONS



Note：Actual current flow direction shown．

## DISTINCTIVE CHARACTERISTICS

- 4-bit register accepts data from one-of-two 4-bit input fields
- Edge triggered clock action

Second sourced by T.I. as 54LS/74LS399

- Am25LS D.C. parameters including:
$-\mathrm{V}_{\mathrm{OL}}=0.45 \mathrm{~V}$ at $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$
- Fan-out over military range $=22$
- $440 \mu \mathrm{~A}$ source current


## GENERAL DESCRIPTION

The Am25LS09 is a dual port four-bit register using advanced Low Power Schottky technology to reduce the effect of transistor storage time. The register consists of four D flip-flops with a buffered common clock, and a twoinput multiplexer at the input of each flip-flop. A common select line, S, controls the four multiplexers. Data on the
four inputs selected by the $S$ line is stored in the four flipflops at the clock LOW-to-HIGH transition. When the S input is LOW, the $D_{i A}$ input data will be stored in the register. When the $S$ input is HIGH, the $D_{i B}$ input data will be stored in the register.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S09 | High Speed Register |
| Am25S07/08 | 6/4-Bit Registers |
| Am25LS07/08 | 6/4-Bit Low Power Registers |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS09
            D L
                            Blank - Standard processing
                            B - Burn-in
                Temperature (See Operating Range)
                M - Military ( }-5\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ to }+12\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ )
            Package
            D-16-pin CERDIP
            F-16-pin flatpak
            P-16-pin plastic DIP
            X-Dice
```

Device type
Quad Two-Input, High-Speed Register

| Valid Combinations |  |
| :--- | :--- |
| Am25LS09 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 3,6,11, \\ & 14 \end{aligned}$ | $D_{0 A}$, <br> $D_{1 A}$, <br> $\mathrm{D}_{2 \mathrm{~A}}$, <br> $D_{3 A}$ | 1 | The " A " word into the two-input multiplexer of the D flip-flops. |
| $\begin{aligned} & 4,5,12 \\ & 13 \end{aligned}$ | $\mathrm{D}_{\mathrm{OB}}$, <br> $D_{1 B}$, <br> $\mathrm{D}_{2 \mathrm{~B}}$, <br> $\mathrm{D}_{3 \mathrm{~B}}$ | 1 | The "'B' word into the two-input multiplexer of the D flip-flops. |
|  | $\begin{aligned} & Q_{0}, Q_{1}, \\ & Q_{2}, Q_{3} \end{aligned}$ | 0 | The outputs of the four D-type flip-flops of the register. |
| 1 | S | 1 | Select. When the select is LOW, the A word is applied to the D inputs of the flip-flops. When the select is HIGH the B word is applied to the D inputs of the flip-flops. |
| 9 | CP | 1 | Clock Pulse. Clock pulse for the register. Enters data on the LOW-to-HIGH transition of the clock line. |

FUNCTION TABLE

| SELECT <br> $\mathbf{S}$ | CLOCK <br> $\mathbf{C P}$ | DATA <br> $\mathbf{D}_{\mathbf{I}}$ | INPUTS <br> $\mathbf{D}_{\mathbf{i B}}$ | OUTPUT <br> $\mathbf{Q}_{\mathbf{i}}$ |
| :---: | :---: | :---: | :---: | :---: |
| L | $\uparrow$ | L | X | L |
| L | $\uparrow$ | H | X | H |
| $H$ | $\uparrow$ | X | L | L |
| $H$ | $\uparrow$ | X | H | H |

$$
\begin{array}{ll}
H=\text { HIGH Voltage Level } & L=\text { LOW Voltage Level } \\
X=\text { Don't Care } & i=0,1,2, \text { or } 3 \\
\dagger=\text { LOW-to-HIGH Transition } &
\end{array}
$$

## APPLICATIONS



AF001210
Am25LS09 used in $258 \times 4$ memory system with load/recirculate control, and $1 \times 4$ static test capability for the system. MOS interface is one load at each end. This circuit is especially useful in digital filtering where special algorithms require a static single step operation for testing purposes.


[^18]
## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 6 to Pin 8) Continuous ................-0.5V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $\mathrm{V}_{\mathrm{Cc}}$ max
DC Input Voltage $\qquad$ -0.5 V to +7.0 V
DC Output Current, Into Outputs .......................... 30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature . $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O H}=-440 \mu \mathrm{~A} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | COM'L | 2.7 | 3.4 |  | Volts |
|  |  |  | MIL | 2.5 | 3.4 |  |  |
| $\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{OL}=4 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=8 \mathrm{~mA}$ |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
|  | Input LOW Level | Guaranteed input logical LOW voltage for all inputs | MIL |  |  | 0.7 | Volts |
| $V_{\text {IL }}$ |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ | Clock, S |  |  | -0.36 | mA |
|  |  |  | Others |  |  | -0.24 |  |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $V_{C C}=M A X ., V_{I N}=2.7 \mathrm{~V}$ | Clock, S |  | , | 20 | $\mu \mathrm{A}$ |
|  |  |  | Others |  |  | 14 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX . |  | -15 |  | -85 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$. (Note 4) |  |  | 11 | 18 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Measured with Select and Clock inputs at 4.5 V ; all data inputs at OV ; all outputs open.

## SWITCHING CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Clock to Q HIGH | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 13 | 20 | ns |
| $\mathrm{t}_{\mathrm{pHL}}$ | Clock to Q LOW |  |  | 13 | 20 | ns |
| $t_{\text {pw }}$ | Clock Pulse Width |  | 17 |  | - | ns |
| $t_{s}$ | Data Set-up Time |  | 20 |  |  | ns |
| $t_{s}$ | Select Input Set-up Time |  | 30 |  |  | ns |
| $t_{h}$ | Data Hold Time |  | 5 |  |  | ns |
| $t_{h}$ | Select Input Hold Time |  | 0 |  |  | ns |
| $\mathrm{f}_{\max }$ (Note 1) | Maximum Clock Frequency |  | 40 | 65 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{f}$, $t_{f}$, pulse width or duty cycle.
SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMM | RCIAL | MIL | ARY | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS |  | Am25LS |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Clock to Q HIGH | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 30 |  | 35 | ns |
| tPHL | Clock to Q LOW |  |  | 30 |  | 35 | ns |
| $\mathrm{t}_{\mathrm{pw}}$ | Clock Pulse Width |  | 26 |  | 30 |  | ns |
| $\mathrm{t}_{\text {s }}$ | Data Set-up Time |  | 30 |  | 35 |  | ns |
| $\mathrm{t}_{\text {s }}$ | Select Input Set-up Time |  | 43 |  | 50 |  | ns |
| $t_{n}$ | Data Hold Time |  | 11 |  | 12 |  | ns |
| $t_{h}$ | Select Input Hold Time |  | 4 |  | 5 |  | ns |
| $\mathrm{f}_{\max }$ (Note 1) | Maximum Clock Frequency |  | 30 |  | 25 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.
Am25LS - Am54LS/74LS LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25S09

Quad Two-Input, High-Speed Register

## DISTINCTIVE CHARACTERISTICS

- Four-bit register accepts data from one of two 4-bit input fields.
- Edge-triggered clock action
- High-speed Schottky technology.
- Electrically tested and optically inspected dice for the assemblers of hybrid products.


## GENERAL DESCRIPTION

The Am25S09 is a dual port high-speed, four-bit register using advanced Schottky technology to reduce the effect of transistor storage time. The register consists of four D flipflops with a buffered common clock, and a two-input multiplexer at the input of each flip-flop. A common select line, S, controls the four multiplexers. Data on the four
inputs selected by the $S$ line is stored in the four flip-flops at the clock LOW-to-HIGH transition. When the $S$ input is LOW, the $\mathrm{D}_{\mathrm{iA}}$ input data will be stored in the register. When the S input is HIGH , the $\mathrm{D}_{\mathrm{iB}}$ input data will be stored in the register.

## BLOCK DIAGRAM



## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS09 | Low Power Version |
| Am25S07/08 | 6/4-Bit Register |
| Am25LS07/08 | 6/4-Bit Low Power Register |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25S09


Package
D-16-pin CERDIP
F-16-pin flatpak P -16-pin plastic DIP $X$ - Dice

Device type
Quad Two-Input, High-Speed Register


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.



Am25S09 used in $258 \times 4$ memory system with load/recirculate control, and $1 \times 4$ static test capability for the system. MOS interface is one load at each end. This circuit is especially useful in digital filtering where special algorithms require a static single step operation for testing purposes.


AF000770
Am25S09 used to store a word from either data bus A or data bus B.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature
$\ldots \ldots \ldots \ldots \ldots \ldots \ldots .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous................ 0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$

DC Output Current, Into Outputs ............................30mA
DC Input Current .............................. 30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .

$$
.0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
$$

Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ | COM'L | 2.7 | 3.4 |  | Volts |
|  |  |  | MIL | 2.5 | 3.4 |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ |  |  | 0.3 | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH Voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{liN}^{\prime}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| $\begin{aligned} & 1 / \mathrm{L} \\ & \text { (Note 3) } \end{aligned}$ | Input Load Input LOW Current | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{1 N}=0.5 \mathrm{~V}$ |  |  |  | -2 | mA |
| $\begin{aligned} & 1 \mathrm{l}_{1} \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| ISC | Output Short Circuit Current (Note 4) | $V_{C C}=M A X$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ (Note 5) |  |  | 75 | 120 | mA |

Notes:

1. Typical limits are at $\mathrm{V}_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
. Actual input currents = Unit Load Current x Input Load Factor (See Loading Rules).
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Measured with Select and Clock inputs at 4.5 V ; all data inputs at OV ; all outputs open.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | Clock to Q HIGH | $\begin{gathered} V_{C C}=5.0 \mathrm{~V}, C_{L}=15 \mathrm{pF} \\ R_{L}=280 \Omega \end{gathered}$ |  | 8 | 12 | ns |
| tpHL | Clock to Q LOW |  |  | 11.5 | 17 | ns |
| $\mathrm{t}_{\mathrm{pw}}$ | Clock Pulse Width |  | 7 |  |  | ns |
| $t_{s}$ | Data Set-up Time |  | 5.5 |  |  | ns |
| $t_{s}$ | Select Input Set-up Time |  | 10 |  |  | ns |
| $t_{\text {h }}$ | Data Hold Time |  | 3 |  |  | ns |
| $t_{n}$ | Select Input Hold Time |  | 3 |  |  | ns |

LOADING RULES (In Unit Loads)

|  |  |  | Fan-out |  |
| :--- | :---: | :---: | :---: | :---: |
| Input/Output | Pin <br> Nos. | Input <br> Unit Load | Output <br> HIGH | Output <br> LOW |
| S |  | 1 | - | - |
| $\mathrm{Q}_{0}$ | 2 | - | 20 | 10 |
| $\mathrm{D}_{0 \mathrm{~A}}$ | 3 | 1 | - | - |
| $\mathrm{D}_{0 \mathrm{~B}}$ | 4 | 1 | - | - |
| $\mathrm{D}_{1 \mathrm{~B}}$ | 5 | 1 | - | - |
| $\mathrm{D}_{1 \mathrm{~A}}$ | 6 | 1 | - | - |
| $\mathrm{Q}_{1}$ | 7 | - | 20 | 10 |
| GND | 8 | - | - | - |
| $C_{P}$ | 9 | 1 | - | - |
| $\mathrm{Q}_{2}$ | 10 | - | 20 | 10 |
| $\mathrm{D}_{2 \mathrm{~A}}$ | 11 | 1 | - | - |
| $\mathrm{Q}_{2 \mathrm{~B}}$ | 1 | 1 | - | - |
| $\mathrm{D}_{3 \mathrm{~B}}$ | 13 | 1 | - | - |
| $\mathrm{D}_{3 \mathrm{~A}}$ | 14 | 1 | - | - |
| $\mathrm{Q}_{3}$ | 15 | - | 20 | 10 |
| $\mathrm{~V}_{\mathrm{CC}}$ | 16 | - | - | - |

A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ measured at 2.7V HIGH and -2.0 mA measured at 0.5 V LOW.

## SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000150
Note: Actual current flow direction shown

## Am25S10

Four-Bit Shifter with Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Shifts 4-bits of data to $0,1,2$ or 3 places under control of two select linies.
- Three-state outputs for bus organized systems.
- 6.5 ns typical data propagation delay
- Alternate source is $54 \mathrm{~S} / 74 \mathrm{~S} 350$


## GENERAL DESCRIPTION

The Am25S10 is a combinatorial logic circuit that accepts a four-bit data word and shifts the word $0,1,2$ or 3 places. The number of places to be shifted is determined by a twobit select field $S_{0}$ and $S_{1}$. An active-LOW enable controls the three-state outputs. This feature allows expansion of shifting over a larger number of places with one delay.

By suitable interconnection, the Am25S10 can be used to shift any number of bits any number of places up or down. Shifting can be logical, with logic zeroes pulled in at either or both ends of the shifting field; arithmetic, where the sign bit is repeated during a shift down; or end around, where the data word forms a continuous loop.

## BLOCK DIAGRAM



RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2901 | Bit Slice ALU |
| Am2903 | Superslice |
| Am29501 | Multiport Pipeline Processor |



| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\mathrm{I}_{\mathrm{i}}$ | I | The seven data inputs of the shifter. |
| 13 | $\overline{\mathrm{OE}}$ |  | Enable. When the enable is HIGH, the four outputs are in the high impedance state. When the enable <br> is LOW, the selected $\mathrm{I}_{\mathrm{i}}$ inputs are present at the outputs. |
| 10,9 | $\mathrm{~S}_{0}, \mathrm{~S}_{1}$ | I | Select inputs. Controls the number of places the inputs are shifted. |
| 11,12, <br> 14,15 | $\mathrm{Y}_{\mathrm{i}}$ | O | The four outputs of the shifter. |

LOADING RULES (In Unit Loads)

| Input/Output | Pin Nos. | Input <br> Unit Load (Note 1) | Fan-out |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Output HIGH |  | Output LOW |
|  |  |  | XM | XC |  |
| 1-3 | 1 | 1 | - | - | - |
| 1-2 | 2 | 1.5 | - | - | - |
| I-1 | 3 | 1.5 | - | - | - |
| 10 | 4 | 1.5 | - | - | - |
| $\mathrm{I}_{1}$ | 5 | 1.5 | - | - | - |
| $\mathrm{I}_{2}$ | 6 | 1.5 | - | - | - |
| 13 | 7 | 1 | - | - | - |
| GND | 8 | - | - | - | - |
| $\mathrm{S}_{1}$ | 9 | 1 | - | - | - |
| $\mathrm{S}_{0}$ | 10 | 1 | - | - | - |
| $Y_{3}$ | 11 | - | 40 | 130 | 10 |
| $Y_{2}$ | 12 | - | 40 | 130 | 10 |
| $\overline{\text { OE }}$ | 13 | 1 | - | - | - |
| $Y_{1}$ | 14 | - | 40 | 130 | 10 |
| $Y_{0}$ | 15 | - | 40 | 130 | 10 |
| $V_{\text {cc }}$ | 16 | - | - | - | - |

A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ at 2.7 V at the HIGH and -2.0 mA at 0.5 V at the LOW.

Note 1. The fan-in on $\mathrm{I}_{-2}, \mathrm{I}_{-1}, \mathrm{I}_{0}, \mathrm{I}_{1}$ and $\mathrm{I}_{2}$ will not exceed 1.5 Unit Loads when measured at $\mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$. As $\mathrm{V}_{\mathrm{IL}}$ is decreased to a OV, the input current IIL MAX. increases to $-4,-6,-8,-6$ and -4 mA respectively due to the decrease in current sharing with the internal select buffer outputs.

## LOGIC EQUATIONS

$$
\begin{aligned}
& Y_{0}=\bar{S}_{0} \bar{S}_{1} l_{0}+S_{0} \bar{S}_{1} l_{-1}+\bar{S}_{0} S_{1} l_{-2}+S_{0} S_{1} l_{-3} \\
& Y_{1}=\bar{S}_{0} \bar{S}_{1} l_{1}+S_{0} \bar{S}_{1} l_{0}+\bar{S}_{0} S_{1} l_{-1}+S_{0} S_{1} l_{-2} \\
& Y_{2}=\bar{S}_{0} \bar{S}_{1} l_{2}+S_{0} \bar{S}_{1} l_{1}+\bar{S}_{0} S_{1} l_{0}+S_{0} S_{1} l_{-1} \\
& Y_{3}=\bar{S}_{0} \bar{S}_{1} l_{3}+S_{0} \bar{S}_{1} l_{2}+\bar{S}_{0} S_{1} I_{1}+S_{0} S_{1} l_{0}
\end{aligned}
$$

TRUTH TABLE

| $\overline{O E}$ | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ | 13 | 12 | $\mathrm{I}_{1}$ | 10 | l-1 | 1.2 |  | $\mathrm{Y}_{3}$ | $\mathrm{Y}_{2}$ | $\mathrm{V}_{1}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | X | x | X | X | X |  | Z | Z | Z |  |
| L | L | L | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | X | X | X | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | 0 |
| L | L | H | X | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | D-1 | X | X | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | D-1 | -1 |
| L | H | L | X | X | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | D-1 | D. 2 | X | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | D-1 | D-2 | -2 |
| L | H | H | X | X | X | $\mathrm{D}_{0}$ | D. 1 | D-2 | D. 3 | $\mathrm{D}_{0}$ | D-1 | D-2 | D-3 | -3 |

X = Don't Care
$\mathrm{L}=$ LOW $\quad \mathbf{Z}=$ High Impedance State
$D_{n}$ at input $I_{n}$ may be either HIGH or LOW and output $Y_{m}$ will follow the selected $D_{n}$ input level.


## ABSOLUTE MAXIMUM RATINGS



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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | 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{XM} \mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{XC} \mathrm{IOH}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O L}=20 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=$ MIN., $I_{\mathbb{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| $\begin{aligned} & \text { ILL } \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input LOW Current | $V_{C C}=M A X ., V_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  | -2.0 | mA |
| $\begin{aligned} & \mathrm{I}_{1 \mathrm{H}} \\ & \text { (Note 3) } \end{aligned}$ | Unit Load Input HIGH Current | $V_{C C}=M A X ., V_{\mathbb{I N}}=2.7 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| lo | Off State (High Impedance) Output Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |
| 1 | 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 (Note 4) | $\mathrm{V}_{\text {CC }}=$ MAX., $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$., All outputs open, All inputs = GND |  |  | 60 | 85 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type.
3. Actual input currents $=$ Unit Load Current $\times$ Input Load Factor (See Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

PERFORMANCE CURVES SWITCHING CHARACTERISTICS


OP001390

Select to Output (Typical)


OP001400

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Data Input to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega$ |  | 5 | 7.5 |  |
| tPHL |  |  |  | 8 | 12 | ns |
| tplH | Select to Output |  |  | 11 | 17 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 13 | 20 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Control $\overline{O E}$ to Output |  |  |  | 19.5 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 21 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Control $\overline{O E}$ to Output | $V_{C C}=5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega$ |  | 5 | 8 | ns |
| thz |  |  |  | 10 | 15 |  |



IC000370
Note: Actual current flow direction shown.

## Am25LS14A

## 8-Bit Serial/Parallel Two's Complement Multiplier

## DISTINCTIVE CHARACTERISTICS

- Two's complement multiplication without correction
- Magnitude only multiplication
- Cascadable for any number of bits
- 8-bit parallel multiplicand data input
- 50 MHz minimum clock frequency
- Second sourced by T.I. as the SN54LS/74LS384
- IMOX $^{\text {TM }}$ process with ECL internal


## GENERAL DESCRIPTION

The Am25LS14A is an 8-bit by 1 -bit sequential logic element that performs digital multiplication of two numbers represented in two's complement form to produce a two's complement product without correction. The device accepts an 8-bit multiplicand ( X input) and stores this data in eight internal latches. The $X$ latches are controlled via the clear input. When the clear input is LOW, all internal flipflops are cleared and the $X$ latches are opened to accept new multiplicand data. When the clear input is HIGH, the latches are closed and are insensitive to $X$ input changes.

The multiplier word data is passed by the $Y$ input in a serial bit stream - least significant bit first. The product is clocked out the $S$ output least significant bit first.

The multiplication of an m-bit multiplicand by an $n$-bit multiplier results in an $m+n$ bit product. The Am25LS14A must be clocked for $m+n$ clock cycles to produce this two's complement product. Likewise, the $n$-bit multiplier ( $Y$ input) sign bit data must be extended for the remaining m bits to complete the multiplication cycle.

The device also contains a $K$ input so that devices can be cascaded for longer length $X$ words. The sum (S) output of one device is connected to the $K$ input of the succeeding device when cascading. Likewise, a mode input ( $M$ ) is used to indicate which device contains the most significant bit. The mode input is wired HIGH or LOW depending on the position of the 8 -bit slice in the total X word length.

BLOCK DIAGRAM



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| Am25LS14A | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |


| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & x_{0}, x_{1}, \\ & x_{2}, \\ & x_{3}, \\ & x_{4}, \\ & x_{6}, \\ & x_{6}, \\ & x_{7} \end{aligned}$ | 1 | The eight data inputs for the multiplicand ( $X$ ) data. |
| 15 | Y | 1 | The serial input for the multiplier ( Y ) data-least significant bit first. |
| 6 | S | 0 | The serial output for the product of $\mathrm{X} \bullet \mathrm{Y}$-least significant bit first. |
| 7 | CP | 1 | Clock. The buffered common clock input for the serial/parallel multiplier. All functions occur on the LOW-to-HIGH transition of the clock. |
| 1 | CLR | 1 | Clear. The buffered common clear for all flip-flops within the device. When the clear is LOW all flip-flops are cleared. Also the buffered X-input latch enable. When the clear input is LOW, the $X$ latches will accept new X-input data. |
| 10 | K | 1 | The sum expansion input to the serial/parallel multiplier. Allows for cascading devices. |
| 9 | M | 1 | The mode control input for the most significant bit of the multiplier. It is used in conjunction with cascading to determine the most significant bit. |

FUNCTION TABLE

| INPUTS |  |  |  |  |  | INTERNAL | OUTPUT | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLR | CP | K | M | $\mathrm{X}_{1}$ | Y | $Y_{-1}$ | S |  |
| - | - | L | L | - | - | - | - | Most Significant Multiplier Device |
| - | - | CS | H | - | - | - | - | Devices Cascaded in Multiplier String |
| L | - | - | - | OP | - | L | L | Load New Multiplicand and Clear Internal Sum and Carry Registers |
| H | - | - | - | - | - | - | - | Device Enabled |
| H | $\uparrow$ | - | - | - | L | L | AR | Shift Sum Register |
| H | $\uparrow$ | - | - | - | L | H | AR | Add Multiplicand to Sum Register and Shift |
| H | $\uparrow$ | - | - | - | H | L | AR | Subtract Multiplicand from Sum Register and Shift |
| H | $\uparrow$ | - | - | - | H | H | AR | Shift Sum Register |

$\mathrm{H}=\mathrm{HIGH}$
L = LOW
$\uparrow=$ LOW-to-HIGH transition
CS = Connected to $S$ output of higher order device
$O P=X_{i}$ latches open for new data ( $i=0,7$ )
$A R=$ Output as required

## DEFINITION OF STANDARD TERMS

H HIGH, applying to a HIGH voltage level.
L LOW, applying to a LOW voltage level.
I Input.
O Output.
Negative Current Current flowing out of the device.
Positive Current Current flowing into the device.
IIL LOW-level input current with a specified LOW-level voltage applied.
$\mathbf{I}_{\mathbf{H}}$ HIGH-level input current with a specified HIGH-level voltage applied.

IOL LOW-level output current.
IOH HIGH-level output current.
IsC Output short-circuit source current.
ICC The supply current drawn by the device from the
$V_{C C}$ power supply.
$V_{\text {IL }}$ Logic LOW input voltage.
$V_{\text {IH }}$ Logic HIGH input voltage.
VOL LOW-level output voltage with IOL applied.
VOH HIGH-level output voltage with $\mathrm{I}_{\mathrm{OH}}$ applied.



AF001130
8-Bit by 8 -Bit Multiplier, Bus Organized, with 8-Bit Truncated Product

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential

Continuous ......................................-0.5V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ C Input Voltage
$\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$

DC Output
DC Input Current ............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N ., I_{O H}=-1.0 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  | COM'L | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N . \\ & V_{I N}=V_{I H} \text { or } V_{I L} \\ & \hline \end{aligned}$ | $\mathrm{lOL}=8.0 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  |  | 0.45 |  |
| $\mathrm{V}_{1}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=$ MIN., $\operatorname{liN}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{C C}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ | X, M |  |  | -0.48 | mA |
|  |  |  | K, CLP |  |  | -1.2 |  |
|  |  |  | CP |  |  | -1.6 |  |
|  |  |  | Y |  |  | -3.2 |  |
| $\mathrm{I}_{\mathrm{H}}$ | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX} ., \mathrm{V}_{1 \mathrm{~N}}=2.7 \mathrm{~V}$ | X, M |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | K, CLR |  |  | 30 |  |
|  |  |  | CP |  |  | 40 |  |
|  |  |  | Y |  |  | 80 |  |
| 1 | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current (Note 3) | $\mathrm{V}_{C C}=$ MAX . |  | -15 |  | -85 | mA |
| ICC | Power Supply Current | $V_{C C}=$ MAX |  |  | 45 | 65 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type.
3. Duration of the short circuit test should not exceed one second.

## SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Clock to Output | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 8 | 14 | ns |
| $t_{\text {PHL }}$ |  |  |  | 10 | 18 |  |
| tphL | Clear to Output |  |  | 9 | 17 | ns |
| $t_{s}$ | Y to Clock |  | 15 |  |  | ns |
| $t_{\text {h }}$ |  |  | 0 |  |  |  |
| $t_{s}$ | K to Clock |  | 15 |  |  | ns |
| th |  |  | 0 |  |  |  |
| $t_{s}$ | $\mathrm{X}_{\mathrm{i}}$ to Clear |  | 13 |  |  | ns |
| $t_{n}$ |  |  | 0 |  |  |  |
| $t_{p w}$ | Clock (HIGH) |  | 10 |  |  | ns |
|  | Clock (LOW) |  | 10 |  |  |  |
| $t_{\text {pw }}$ | Clear Pulse Width |  | 10 |  |  | ns |
| $t_{s}$ | Clear Recovery Time (Inactive State) |  | 5 |  |  | ns |
| $f_{\text {max }}$ (Note 1) | Maximum Clock Frequency |  | 50 | 60 |  | MHz |

Note 1: Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}, t_{f}$, pulse width or duty cycle.

## SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | Am25LS COMMERCIAL |  | Am25LS MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Clock to Output | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 18 |  | 20 |  |
| tPHL |  |  |  | 22 |  | 25 | ns |
| tpHL | Clear to Output |  |  | 22 |  | 25 | ns |
| $\mathrm{t}_{\text {s }}$ | Y to Clock |  | 22 |  | 25 |  | ns |
| th |  |  | 0 |  | ${ }^{\circ} \mathrm{O}$ |  |  |
| $\mathrm{t}_{\mathrm{s}}$ | K to Clock |  | 20 |  | 22 |  | ns |
| $t_{n}$ |  |  | 0 |  | 0 |  |  |
| $t_{s}$ | $\mathrm{X}_{i}$ to Clear |  | 20 |  | 22 |  | ns |
| $t_{n}$ |  |  | 0 |  | 0 |  |  |
| $t_{\text {pw }}$ | Clock (HIGH) |  | 10 |  | 10 |  | ns |
|  | Clock (LOW) |  | 10 |  | 10 |  |  |
| $\mathrm{t}_{\mathrm{pw}}$ | Clear Pulse Width |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\mathbf{s}}$ | Clear Recovery Time (Inactive State) |  | 5 |  | 5 |  | ns |
| $\mathrm{f}_{\text {max }}$ (Note 1) | Maximum Clock Frequency |  | 50 |  | 50 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## LOW CURRENT SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



IC000210
Note: Refer to Electrical Characteristics for measure currents.

## INPUT/OUTPUT INTERFACE CONDITIONS



IC000200
Note: Actual current flow direction shown.

## Am25LS15

Quad Serial Adder/Subtractor

## DISTINCTIVE CHARACTERISTICS

- Four independent adder/subtractors
- Use with two's complement arithmetic
- Magnitude only addition/subtraction
- Second sourced by T.I. as Am54LS/74LS385


## GENERAL DESCRIPTION

The Am25LS15 is a serial two's complement adder/ subtractor designed for use in association with the Am25LS14 serial/parallel two's complement multiplier. This device can also be used for magnitude only or one's complement addition or subtraction.

Four independent adder/subtractors are provided with common clock and clear inputs. The add function is A plus $B$ and the subtract function is $A$ minus $B$. The clear function sets the internal carry function to logic zero in the add
mode and to logic one in subtract mode. This least significant carry is self propagating in the subtract mode as long as zeroes are applied to the A and B inputs at the LSB's. All internal flip-flops change state on the LOW-toHIGH clock transition.

The Am25L.S15 is particularly useful for recursive or nonrecursive digital filtering or butterfly networks in Fast Fourier Transforms.

BLOCK DIAGRAM
(One of Four Similar Functions)



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS15
```



```
Device type Quad Serial Adder/Subtractor
```

| Valid Combinations |  |
| :--- | :--- |
| Am25LS15 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish

$\mathrm{X}=$ Don't Care
$\mathrm{H}=\mathrm{HIGH}$
L = LOW
$\dagger=$ LOW-to-HIGH Transition

## APPLICATIONS

The normal butterfly network associated with the CooleyTukey Fast Fourier Transform (FFT) algorithm is shown below. Here we assume A, B, C, D and W are all complex numbers such that:
$A=A_{R}+j A_{1}$
$B=B_{R}+j B_{1}$
$W=W_{R}+j W_{1}$
The outputs $C$ and $D$ are also complex numbers and are evaluated as:
$C=C_{R}+j C_{1}=\left(A_{R}+B_{R} W_{R}-B_{1} W_{1}\right)+j\left(A_{1}+B_{R} W_{1}+B_{1} W_{R}\right)$
$D=C_{R}+j D_{1}=\left(A_{R}-B_{R} W_{R}+B_{1} W_{1}\right)+i\left(A_{1}-B_{R} W_{1}-B_{1} W_{R}\right)$

The four multiplications can be implemented using four Am25LS14 serial-parallel multipliers (the appropriate number of bits must, of course, be used). The additions and the subtractions are implemented using the Am25LS15 quad serial adder/subtractors. This diagram depicts only the basic data flow; binary weighting of the numbers, rounding, truncation, etc. must be handled as required by the individual design parameters.

FAST FOURIER TRANSFORM (FFT) BUTTERFLY


An FFT butterfly connection for complex arithmetic inputs and outputs.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous
-0.5 V to +7.0 V
DC Voltage Applied to Outputs For HIGH Output State -0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max DC Input Voltage ................................. 0.5 V to +7.0 V
DC Output Current, Into Outputs .......................... 30 mA
DC Input Current ............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military ( $M$ ) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{I}_{\mathrm{OH}}=-440 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ | MIL | 2.5 |  |  | Volts |
|  |  |  | COM'L | 2.7 |  |  |  |
| $\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{OL}=4.0 \mathrm{~mA}$ |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{lOL}=8.0 \mathrm{~mA}$ |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs | MIL |  |  | 0.7 | Volts |
|  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | Volts |
| ILI | Input LOW Current | $\mathrm{V}_{\text {CC }}=M A X ., \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  | -0.36 | mA |
| $\mathrm{IH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX . |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$. |  |  | 48 | 75 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All inputs HIGH, measured after a LOW-to-HIGH clock transmission.

Functional Diagram for FFT Butterfly Connection



Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on the $t_{r}, t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | COMMERCIAL <br> Am25LS |  | $\frac{\text { MILITARY }}{\text { Am25LS }}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tpLH | Clock to Output |  |  | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 33 |  | 38 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  |  | 33 |  | 38 |  |  |
| tPHL | Clear to Output |  |  |  | 43 |  | 50 | ns |  |
| $\mathrm{t}_{\text {s }}$ | A, B, S |  | 17 |  |  | 20 |  | ns |  |
| $t_{\text {h }}$ |  |  | 4 |  |  | 5 |  |  |  |
| $\mathrm{t}_{5}$ | Clear Recovery |  | 37 |  |  | 42 |  | ns |  |
| th | Clear Hold Time |  | 4 |  |  | 5 |  | ns |  |
| $t_{\text {pw }}$ | Clock | HIGH | 26 |  |  | 30 |  | ns |  |
|  |  | LOW | 26 |  |  | 30 |  |  |  |
| $t_{\text {pw }}$ | Clear LOW |  | 30 |  |  | 35 |  | ns |  |
| $f_{\text {max }}$ (Note 1) | Maximum Clock Frequency |  | 23 |  |  | 20 |  | MHz |  |

[^19]Am25LS •Am54LS/74LS
LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25S18

## Quad D Register with Standard and Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Advanced Schottky technology
- Four D-type flip-flops
- Four standard totem-pole outputs

Four three-state outputs

- 75 MHz clock frequency


## GENERAL DESCRIPTION

The Am25S18 consists of four D-type flip-flops with a buffered common clock. Information meeting the set-up and hold requirements on the D inputs is transferred to the Q outputs on the LOW-to-HIGH transition of the clock.
The same data as on the $Q$ outputs is enabled at the threestate $Y$ outputs when the "output control' ( $\overline{\mathrm{OE}}$ ) input is LOW. When the $\overline{\mathrm{OE}}$ input is HIGH, the $Y$ outputs are in the high-impedance state.
The Am25S18 is a 4-bit, high speed Schottky register intended for use in real-time signal processing systems
where the standard outputs are used in a recursive algorithm and the three state outputs provide access to a data bus to dump the results after a number of iterations.

The device can also be used as an address register or status register in computers or computer peripherals.

Likewise, the Am25S18 is also useful in certain display applications where the standard outputs can be decoded to drive LED's (or equivalent) and the three-state outputs are bus organized for occasional interrogation of the data as displayed.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S07 | Register |
| Am25S08 | Register |
| Am25S09 | Register |
| Am25S374 | Register |
| Am29821-26 | Register |

## CONNECTION DIAGRAM

 Top View

Note: Pin 1 is marked for orientation
LOGIC SYMBOL


METALLIZATION AND PAD LAYOUT


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25S18

$\stackrel{\text { B }}{1}$ Screening Option
Blank - Standard processing
B - Burn-in
Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-16-pin CERDIP
F-16-pin flatpak
$\mathrm{P}-16$-pin plastic DIP
X-Dice
Device type
Quad D Register with Standard and Three-State Outputs


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


A Schottky TTL Unit Load is defined as $50 \mu \mathrm{~A}$ measured at 2.7V HIGH and -2.0 mA measured at 0.5 V LOW.
*Fan-out on each $Q_{i}$ and $Y_{i}$ output pair should not exceed 15 unit loads ( 30 mA ) for $i=0,1,2,3$.


The Am25S18 Used As Display Register With Bus Interrogate Capability.


The Am25S18 As A Variable Length (1, 2, 3 or 4 Word) Shift Register.

## ABSOLUTE MAXIMUM RATINGS



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 device reliability.

## OPERATING RANGES

Commercial (C) Devices

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N . \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $Q \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
|  |  |  | $Y$ | $X M, I_{O H}=-2 m A$ |  | 2.4 | 3.4 |  |  |
|  |  |  |  | $\mathrm{XC}, \mathrm{IOH}=$ | 6.5 mA | 2.4 | 3.2 |  |  |
| Vol | Output LOW Voltage (Note 6) | $\begin{aligned} & V_{C C}=M I N ., I_{O L}=20 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  |  |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=$ MIN., $\mathrm{I}^{\prime} \mathrm{N}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.2 | Volts |
| $\begin{aligned} & \text { I/L } \\ & \text { (Note 3) } \end{aligned}$ | Input LOW Current | $V_{C C}=M A X ., V_{I N}=0.5 \mathrm{~V}$ |  |  |  |  |  | -2.0 | mA |
| $\begin{aligned} & \hline 1 \mathrm{H} \\ & \text { (Note 3) } \end{aligned}$ | Input HIGH Current | $V_{C C}=M A X ., V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 1.0 | mA |
| lo | Y Output Off-State Leakage Current | $V_{C C}=M A X$. |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ | " |  | 50 | $\mu \mathrm{A}$ |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |
| Isc | Output Short Circuit Current (Note 4) | $V_{C C}=$ MAX |  |  |  | -40 |  | -100 | mA |
| ICC | Power Supply Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$. (Note 5) |  |  |  |  | 80 | 130 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type.
3. Actual input currents $=$ Unit Load Current $x$ Input Load Factor (See Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
6. Measured on Q outputs with Y outputs open. Measured on Y outputs with Q outputs open

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega\right)$

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplH | Clock to Q Output |  | $C_{L}=15 \mathrm{pF}$ |  | 6.0 | 9.0 | ns |
| tPHL |  |  |  | 8.5 | 13 | ns |
| $t_{\text {pw }}$ | Clock Pulse Width | HIGH |  | 7.0 |  |  | ns |
|  |  | LOW |  | 9.0 |  |  |  |
| $t_{s}$ | Data |  |  | 5.0 |  |  | ns |
| th | Data |  |  | 3.0 |  |  | ns |
| tplH | $\begin{aligned} & \text { Clock to Y Output } \\ & \text { (OE LOW) } \end{aligned}$ |  |  |  | 6.0 | 9.0 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 8.5 | 13 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | Output Control to Output |  |  | $C_{L}=15 \mathrm{pF}$$C_{L}=5.0 \mathrm{pF}$ |  | 12.5 | 19 | ns |
| t ZL |  |  |  |  | 12 | 18 |  |  |
| ${ }_{\text {thz }}$ |  |  |  |  | 4.0 | 6.0 |  |  |
| $t \mathrm{tz}$ |  |  |  |  | 7.0 | 10.5 |  |  |
| $\mathrm{f}_{\text {max }}$ | Maximum Clock Frequency |  |  | $C_{L}=15 \mathrm{pF}$ | 75 | 100 |  | MHz |

SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


IC000170
Note: Actual current flow direction shown.

## Am25LS22

8－Bit Serial／Parallel Register with Sign Extend

## DISTINCTIVE CHARACTERISTICS

－Three－state outputs with multiplexed input
－Multiplexed serial data input
－Sign extend function
－Second sourced by T．I．as Am54LS／74LS322

## GENERAL DESCRIPTION

The Am25LS22 is an eight－bit serial／parallel register built using advanced Low－Power Schottky processing．The de－ vice features an eight－bit parallel multiplexed input／output port to provide improved bit density in a 20－pin package． Data may also be loaded into the device in a serial manner from either input $D_{A}$ or $D_{B}$ ．A serial output，$Q_{0}$ is also provided．

The Am25LS22 is specifically designed for operation with the Am25LS14 serial／parallel two＇s complement multiplier and provides the sign extended function required for this device．

When the Register Enable（ $\overline{\mathrm{RE}}$ ）input is HIGH，the register will retain its current contents．Synchronous parallel loading
is accomplished by applying a LOW to $\overline{\mathrm{RE}}$ and applying a LOW to the Serial／Parallel（S／P）input．This places the three－state outputs in the high－impedance state indepen－ dent of $\overline{O E}$ and allows data that is applied on the input／ output lines $\left(D Y_{i}\right)$ to be clocked into the register．When the S／P input is HIGH，the device will shift right．The Sign Extend（ $\overline{\mathrm{SE}}$ ）input is used to repeat the sign in the $Q_{7}$ flip－ flop．This occurs whenever $\overline{S E}$ is LOW when the SHIFT mode is selected．When $\overline{\mathrm{SE}}$ is high，the serial two－input multiplexer is enabled．Thus，either $D_{A}$ or $D_{B}$ can be selected to load data serially．The register changes state on the LOW－to－HIGH transition of the clock．A clear input （CLR）is used to asynchronously reset all flip－flops when a LOW is applied．

## BLOCK DIAGRAM



## RELATED PRODUCTS

| Part No． | Description |
| :--- | :--- |
| Am25LS23 | 8－Bit Shift／Storage Register |

## CONNECTION DIAGRAM <br> Top View



Note: Pin 1 is marked for orientation

## METALLIZATION AND PAD LAYOUT



DIE SIZE 0.096" $\times{ }^{\prime \prime} \mathbf{0 . 1 1 2 "}$
ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS22
            D / & L
                            Blank - Standard processing
                    B - Burn-in
                            Temperature (See Operating Range)
                            C - Commercial ( }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+7\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ )
            M - Military ( }-5\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ to }+12\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ )
            Package
                            D-20-pin CERDIP
                    F-20-pin flatpak
                        P-20-pin plastic DIP
                        X-Dice
        Device type
        8-Bit Serial/Parallel Register
        with Sign Extend
```

| Valid Combinations |  |
| :--- | :--- |
| Am25LS22 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin No. | Name | $1 / 0$ | Description |
|  | DYi | 1/0 | The multiplexed parallel input/output port to the device. Data may be parallel loaded into the register or data can be read in parallel from the register on these pins. These outputs can be forced to the high-impedance state, $i=0$ through 7. |
| 12 | $Q_{0}$ | 0 | The continuous output from the $Q_{0}$ flip-flop of the register. This output is used for serial shifting. |
| 1 | $\overline{R E}$ | 1 | Register Enable. When $\overline{R E}$ is LOW, the register functions are enabled. When $\overline{R E}$ is HIGH, the register functions (parallel load, shift right and sign extend) are inhibited. |
| 2 | S/P | 1 | Serial/Parallel. When S/P is LOW, the register can be synchronously parallel loaded. This input forces the register output buffers to the high-impedance state independent of the $\overline{O E}$ input. When $S / P$ is HIGH, the register contents are shifted right on the clock LOW-to-HIGH transition. |
| 18 | $\overline{\text { SE }}$ | 1 | Sign Extend. When the $\overline{S E}$ input is LOW, the contents of the $Q_{7}$ flip-flop will be repeated in the $Q_{7}$ flip-flop as the register is shifted right. When $\overline{S E}$ is $H I G H$, the two-input multiplexer ( $\mathrm{D}_{\mathrm{A}}$ and $\mathrm{D}_{\mathrm{B}}$ ) is enabled to enter data during the serial shift right. The $\mathrm{Q}_{7}$ flip-flop ( $\mathrm{DY}_{7}$ ) is normally considered the MSB of the register for arithmetic definitions. |
| 3, 17 | $\mathrm{D}_{\mathrm{A}}, \mathrm{D}_{\mathrm{B}}$ | 1 | The serial inputs to the device. |
| 19 | S | 1 | Multiplexer Select. When S is LOW, the DA serial input is selected. When S is HIGH, the D $\mathrm{D}_{\mathrm{B}}$ serial input is selected. |
| 9 | CLR | 1 | Clear. The asynchronous clear to the register. When the clear is LOW, the outputs of the flip-flops are set LOW independent of all other inputs. When the clear is HIGH, the register will perform the selected function. |
| 11 | CP | 1 | Clock. The clock pulse for the register. Register operations occur on the LOW-to-HIGH transition of the clock pulse. |
| 8 | $\overline{O E}$ | 1 | Output Control. When the $\overline{\mathrm{OE}}$ input is HIGH, the eight $D Y_{i}$ outputs are in the high-impedance state. When $\overline{\mathrm{OE}}$ is LOW, data in the eight flip-flops will be present at the register parallel outputs unless S/P is LOW. |

## FUNCTION TABLE


*When the OE input is HIGH, all input/output terminals are at the high-impedance state; sequential operation or clearing of the register is not affected. $D_{7}, D_{6} \ldots D_{0}=$ the level of the steady-state input at the respective $D Y_{n}$ terminal is loaded into the flip-flop while the flip-flop outputs (except $Q_{0}$ ) are isolated from the $D Y_{n}$ terminal.
$D_{A}, D_{B}=$ the level of the steady-state inputs to the serial multiplexer input.
$Y_{7 n}, Y_{6 n} \ldots Y_{0 n}=$ the level of the respective $Q_{n}$ flip-flop prior to the last Clock LOW-to-HIGH transition.


Two Am25LS22 8-bit registers can be used to perform the sign extend associated with two's complement 8-bit bytes for arithmetic operations in a 16 -bit machine. If the upper byte value is to be used, it is shifted to the lower bit positions and its sign is extended. If the lower byte value is to be used, it is held in place while the sign is extended downward from the MSB position of the upper byte.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $.65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $\ldots-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous
...........
DC Voltage Applied to Outputs For
HIGH Output State......................... 0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage ( $\overline{\mathrm{OE}}, \mathrm{S} / \mathrm{P}, \mathrm{RE}$,
CP, CLR)
-0.5 V to +7.0 V
DC Input Voltage (Others) ...................... -0.5 V to +5.5 V
DC Output Current, Into Outputs .......................... 30mA
DC Input Current .............................-30mA to +5.0mA
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $\ldots . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
$\ldots+4.5 \mathrm{~V}$ to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN, or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$


Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | COMMERCIAL <br> Am25LS |  | $\frac{\text { MILITARY }}{\text { Am25LS }}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Clock to DYi |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 35 |  | 41 | ns |
| tPHL |  |  |  |  | 38 |  | 44 |  |  |
| tpHL | Clear to DY ${ }_{\text {i }}$ |  |  |  | 43 |  | 50 | ns |  |
| tplH | Clock to $Q_{0}$ |  |  |  | 35 |  | 41 | ns |  |
| tPHL |  |  |  |  | 38 |  | 44 |  |  |
| tpHL | Clear to $Q_{0}$ |  |  |  | 43 |  | 50 | ns |  |
| t ZH | OE to $D Y_{i}$ |  |  |  | 32 |  | 36 | ns |  |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 38 |  | 44 |  |  |
| ${ }_{\text {thz }}$ |  |  | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 28 |  | 31 |  |  |
| tiz |  |  |  | 34 |  | 39 |  |  |
| $\mathrm{t}_{\mathrm{Z}} \mathrm{H}$ | SER/PAR to DY ${ }_{i}$ |  |  | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 38 |  | 44 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 46 |  | 53 |  |  |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 34 |  | 39 |  |  |
| $t_{\text {LZ }}$ |  |  |  | 42 |  | 48 |  |  |
| $\mathrm{t}_{\mathrm{s}}$ | RE to Clock |  |  | $\cdots$ | 30 |  | 35 |  |  |
| $\mathrm{t}_{\text {s }}$ | SE to Clock |  | 17 |  |  | 20 |  |  |  |
| $t_{s}$ | S to Clock $D_{A}$ and $D_{B}$ to Clock |  | $\begin{gathered} C_{L}=50 \mathrm{pF} \\ R_{L}=2.0 \mathrm{~K} \Omega \end{gathered}$ | 24 |  | 27 |  | ns |  |
| $\mathrm{t}_{\text {s }}$ |  |  | 24 |  | 27 |  |  |  |
| $t_{\text {s }}$ | DY ${ }_{\text {i }}$ (Load) to Clock |  |  | 24 |  | 27 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Clear Recovery to Clock |  |  | 15 |  | 17 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | S/P to Clock Any Input |  |  | 24 |  | 27 |  | ns |  |
| $t_{n}$ |  |  | 4 |  | 5 |  |  |  |
| $t_{n}$ | Clear Hold |  |  | 4 |  | 5 |  | ns |  |
| ${ }^{\text {tpw }}$ | Clock | HIGH |  | 15 |  | 17 |  | ns |  |
|  |  | LOW |  | 15 |  | 17 |  |  |  |
| $\mathrm{t}_{\mathrm{pw}}$ | Clear |  |  | 30 |  | 35 |  | ns |  |
| $\mathrm{f}_{\text {max }}$ (Note 1) | Maximum Clock Frequency |  |  |  | 26 |  | 23 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

## Am25LS23

## DISTINCTIVE CHARACTERISTICS

- Synchronous clear
- Three-state outputs
- Common input/output pins
- Cascadable shifting
- Second sourced by T.I. as 54LS/74LS323


## GENERAL DESCRIPTION

The Am25LS23 is an 8-bit universal shift/storage register with 3-state outputs. The function is similar to the Am25LS299 with the exception of a synchronous clear function. Parallel load inputs and register outputs are multiplexed to allow the use of a 20-pin package. Separate
continuous outputs are also provided for flip-flops $Q_{0}$ and Q7.

Four modes of operation are possible - Hold (store), Shiftleft, Shift-right and Load Data. The Am25LS23 has a typical shift frequency of 50 MHz . The Am25LS23 is packaged in a standard $20-$ pin package.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS23
|
```



## L Screening Option

```
Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
-Package
D-20-pin CERDIP
F-20-pin flatpak
\(\mathrm{P}-20\)-pin plastic DIP
X - Dice
Device type
8-Bit Shift Storage Register With Synchronous Clear
```

| Valid Combinations |  |
| :--- | :--- |
| Am25LS23 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 11 | $\mathrm{S}_{\mathrm{R}}$ | 1 | Shift right data input to $\mathrm{Q}_{7}$. |
| 18 | $\mathrm{S}_{\mathrm{L}}$ | 1 | Shift left data input to $Q_{0}$. |
| 9 | Clear | 1 | Active LOW synchronous input forcing the $Q_{0}$ through $Q_{7}$ register to see LOW conditions, visable only if outputs are enabled. |
| 12 | Clock | 1 | A LOW-to-HIGH transition will result in the register changing state to next state as described by mode and input data condition. |
| 1, 19 | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ | 1 | Mode selection control lines used to control input (output during load) conditions. |
| 2, 3 | $\overline{\mathrm{G}}_{1}, \overline{\mathrm{G}}_{2}$ | 1 | Active LOW input to control three-state output in active LOW AND configuration. |
| 8, 17 | $Q_{0}, Q_{7}$ | 0 | The only two direct outputs; used to cascade shift operations. |
| $\begin{aligned} & 7,13,6,14 \\ & 5,15,4,16 \end{aligned}$ | $\mathrm{DY}_{0}-\mathrm{DY}_{7}$ | 1/0 | Input/Output line dependent on mode and output control. Input only with mode select LOAD. Output in all other modes but subject to output select $\left(\bar{G}_{1}, \bar{G}_{2}\right)$. |

## TRUTH TABLE

| FUNCTION |  | INPUTS |  |  |  |  |  |  | OUTPUTS |  | INPUTS/OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{S}_{\mathbf{R}}$ | $S_{L}$ | CLEAR | CLOCK | $\mathrm{S}_{0} \quad \mathrm{~S}_{1}$ | $\overline{\mathbf{G}}_{1}$ | $\bar{G}_{2}$ | $\mathbf{Q}_{0}$ | $Q_{7}$ | DY0 | DY 1 | DY 2 | DY 3 | $\mathrm{DY}_{4}$ | DY 5 | DY 6 | DY 7 |
| Clear |  | X | X | L | $\uparrow$ | (Note 1) | L | L | L | L | L | L | L | L | L | L | L | L |
| Output Control |  | X | x | X | X | $\mathrm{X} \quad \mathrm{X}$ | H | L | NC | NC | Z | Z | Z | Z | Z | Z | Z | Z |
|  |  | X | $x$ | X | X | $x \quad x$ | L | H | NC | NC | Z | Z | Z | Z | Z | Z | Z | Z |
|  |  | X | X | X | X | $\mathrm{X} \quad \mathrm{X}$ | H | H | NC | NC | Z | Z | Z | z | Z | Z | z | Z |
| $\begin{aligned} & M \\ & O \\ & D \\ & \mathrm{D} \end{aligned}$ | Hold Load (Note 2) | X X L | X X x |  |  |  |  |  | $\mathrm{NC}$ |  | $\mathrm{NC}$ | $\underset{B}{N C}$ | $\begin{gathered} \mathrm{NC} \\ \mathrm{C} \end{gathered}$ | $\begin{gathered} \hline \text { NC } \\ \mathrm{D} \end{gathered}$ | $\begin{gathered} \mathrm{NC} \\ \mathrm{E} \end{gathered}$ | $\begin{gathered} \hline \mathrm{NC} \\ \mathrm{~F} \end{gathered}$ | $\begin{gathered} \mathrm{NC} \\ \mathrm{G} \end{gathered}$ | NC |
|  | Load (Note 2) Shift Right | X L L | x x x | H H | $\begin{aligned} & \uparrow \\ & \uparrow \end{aligned}$ | $\begin{array}{ll} H \\ H & H \\ L \end{array}$ | L | $L$ | A | $\stackrel{H}{D Y_{6}}$ | A | $\begin{gathered} \mathrm{B} \\ \mathrm{DY}_{0} \end{gathered}$ | $\underset{\mathrm{CY}}{\mathrm{C}}$ | $\begin{gathered} \mathrm{D} \\ \mathrm{DY} \end{gathered}$ | $\underset{\mathrm{E}}{\mathrm{E}}$ | $\stackrel{\stackrel{F}{\mathrm{DY}_{4}}}{ }$ | $\underset{\mathrm{DY}}{\mathrm{G}}$ | $\mathrm{H}_{\substack{\mathrm{H} \\ \hline}}^{\text {dr }}$ |
|  | Shift Right | H | X | H | + | H L | L | L | H | DY6 | H | DY0 | DY 1 | $\mathrm{DY}_{2}$ | $\mathrm{DY}_{3}$ | $\mathrm{DY}_{4}$ | $\mathrm{DY}_{5}$ | $\mathrm{DY}_{6}$ |
|  | Shift Left | X | L | H | $\dagger$ | L H | L | $L$ | DY 1 | L | DY1 | DY2 | $\mathrm{DY}_{3}$ | $\mathrm{DY}_{4}$ | DY5 | DY6 | DY7 | L |
|  | Shift Left | X | H | H | $\dagger$ | $\mathrm{L} \quad \mathrm{H}$ | L | L | DY ${ }_{1}$ | H | DY ${ }_{1}$ | $\mathrm{DY}_{2}$ | $\mathrm{Dr}_{3}$ | $\mathrm{Dr}_{4}$ | DY 5 | DY6 | $\mathrm{DY}_{7}$ | H |

$\begin{array}{lllll}\text { L }=\text { LOW } & Z=\text { High Impedance } & \dagger=\text { Transition LOW-to-HIGH } & \text { NC }=\text { No Change } & \text { Notes: } 1 \text {. Either LOW to observe outputs. } \\ H=\text { HIGH } & X=\text { Don't Care } & \text { 2. In this mode DY }{ }_{1} \text { are inputs. }\end{array}$


AF001110

16-Bit Cascaded Parallel Load/Unload Shift Right/Left Register.

## ABSOLUTE MAXIMUM RATINGS


(Ambien) Tomperaure Under Bias $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Continuous $\qquad$  HIGH Output State $\qquad$ DC Input Voltage $\mathrm{S}_{0}, \mathrm{~S}_{1}, \overline{\mathrm{G}}_{1}, \overline{\mathrm{G}}_{2}$,
.....-0.5V to +7.0 V
DC Output Current, Into Outputs ........................... 30mA
DC Input Current ............................-30mA to +5.0 mA

RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute reliability.

## OPERATING RANGES

Commercial (C) Devices

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  |  | 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_{O L} \end{aligned}$ | $Q_{0}, Q_{7}$ | $\mathrm{IOH}^{\prime}=-440 \mu \mathrm{~A}$ |  | MIL | 2.5 |  |  | Volts |
|  |  |  |  |  |  | COM'L | 2.7 |  |  |  |
|  |  |  | $D Y_{0}-\mathrm{DY}_{7}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  |  | 2.4 |  |  |  |
|  |  |  |  | COM'L, ${ }^{\text {IOH }}=-2.6 \mathrm{~mA}$ |  |  | 2.4 |  |  |  |
| V 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{lOL}=4.0$ | . 0 mA |  | 0.25 | 0.4 | Volts |
|  |  |  |  |  | $\mathrm{l} \mathrm{OL}=8$. | . 0 mA |  | 0.35 | 0.45 |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  | $\frac{\text { MIL }}{\text { COM'L }}$ |  |  |  | 0.7 | Volts |
|  |  |  |  |  |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{I}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} ., \mathrm{V}_{\mathbb{N}}=0.4 \mathrm{~V}$ |  |  |  |  | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ |  |  |  | -0.8 | mA |
|  |  |  |  |  | All other |  |  |  | -0.4 |  |  |
| $\mathrm{IH}^{\text {H}}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X ., \quad V_{I N}=2.7 V \\ & (\text { Except DYi) } \end{aligned}$ |  |  | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ |  |  |  | 40 |  |  |
|  |  |  |  |  | All othe |  |  |  | 20 | $\mu \mathrm{A}$ |  |
| 1 | Input HIGH Current | $V_{C C}=M A X .$ <br> (Except DY ${ }^{\text {i }}$ ) | $\mathrm{V}_{1 N}=7 \mathrm{~V}$ | $\mathrm{S}_{0}, \mathrm{~S}_{1}$ |  |  |  |  | 0.2 | mA |  |
|  |  |  |  | $\overline{\mathrm{G}}_{1}, \overline{\mathrm{G}}_{2}, \mathrm{CLR}, \mathrm{C}$ |  |  |  |  | 0.1 |  |  |
|  |  |  | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  |  |  | 0.1 |  |  |
| loz | Off-State (High Impedance) Output Current | $V_{C C}=M A X$. |  |  | $\mathrm{V}_{\mathrm{O}}=0.4$ |  |  |  | -100 | $\mu \mathrm{A}$ |  |
|  |  |  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4$ |  |  |  | 40 |  |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$. |  |  |  |  | -15 |  | -85 | mA |  |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$. (Note 4) |  |  |  |  |  | 38 | 60 | mA |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time.
4. Icc-measured with clock input HIGH and output controls HIGH.
عZSTGてW甘
SWITCHING CHARACTERISTICS ( $T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Clock to $Q_{0}$ or $Q_{7}$ | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{\mathrm{L}}^{\prime} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 18 | 26 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 23 | 28 |  |
| tPLH | Clock to DYi |  |  | 18 | 26 | ns |
| tphL |  |  |  | 21 | 28 |  |
| $\mathrm{t}_{\text {s }}$ | $\mathrm{S}_{1}, \mathrm{~S}_{0}$ Set-up Prior to Clock |  | 12 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}}$ | DY ${ }_{\text {i }}$ or $S_{\text {R }}, \mathrm{S}_{\mathrm{L}}$ Set-up Prior to Clock |  | 12 |  |  | ns |
| tpW | Pulse Width (Clock) |  | 15 |  |  | ns |
| $t_{s}$ | Clear to Clock |  | 15 |  |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $S_{1}, S_{0}, \bar{G}_{1}, \bar{G}_{2}$ to DY |  |  | 18 | 30 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 20 | 30 |  |
| tiz | $\mathrm{S}_{1}, \mathrm{~S}_{0}, \overline{\mathrm{G}}_{1}, \overline{\mathrm{G}}_{2}$, to $D Y_{i}$ | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 22 | 33 | ns |
| $\mathrm{thz}^{\text {l }}$ |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 16 | 23 |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  | 35 | 50 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.
SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

*AC performance over the operating temperature range is guaranteed by testing defined in Group $A$, Subgroup 9.

Note: Actual current flow direction shown.

## Am25LS2513

Three-State Priority Encoder

## DISTINCTIVE CHARACTERISTICS

- Encodes eight lines to three-line binary
- Expandable
- Cascadable
- Three State inverted output version of Am54LS/74LS/ 25LS148
- Gated three-state output
- Advanced Low-Power Schottky processing


## GENERAL DESCRIPTION

The Am25LS2513 Low-Power Schottky Priority Encoder performs priority encoding of 8 inputs to provide a binaryweighted code of the priority order of the 3 tri-state active HIGH outputs $A_{0}, A_{1}, A_{2}$. Three active LOW and two active HIGH inputs in AND-OR configuration allow control of the tri-state outputs. The use of the input enable (EI) combined
with the enable output ( $\overline{\mathrm{EO}}$ ) permits cascading without additional circuitry. Enable input (EI) HIGH will force all outputs LOW subject to the tri-state control. The enable output is LOW when all inputs $\bar{\Gamma}_{0}$ through $\bar{I}_{7}$ are HIGH and the enable input is LOW.

| Part No. | Description |
| :--- | :--- |
| Am2913 | Priority Interrupt Expander |
| Am2914 | Vectored Priority Interrupt Controller |

## CONNECTION DIAGRAM <br> Top View

D-20-1


L-20-1


Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS2513
            D & 
                            Blank - Standard processing
                            B - Burn-in
                            -Temperature (See Operating Range)
                            C - Commercial (0}\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to +70
                            M - Military ( }-5\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ to }+12\mp@subsup{5}{}{\circ}\textrm{C}
                            Package
                    D-20-pin CERDIP
                        F-20-pin flatpak
                        L-20-pin leadless chip carrier
                        P-20-pin plastic DIP
                        X-Dice
    Device type
    3-State Priority Encoder
```

[^20]| PIN DESCRIPTION |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin No | Name | 1/0 | Description |  |  |  |  | $\underset{\sim}{\sim}$ |
| 8, 7, 6 | $\begin{aligned} & \mathrm{AO}, \mathrm{~A} 1, \\ & \mathrm{~A} 2 \end{aligned}$ | $\bigcirc$ | Three-state, active high encoder outputs. |  |  |  |  | $\stackrel{\square}{\omega}$ |
| 5 | EI | 1 | Enable input provided to allow cascaded operation. |  |  |  |  |  |
| 19 | EO | 0 | Enable output provided to enable the next lower order priority chip. |  |  |  |  |  |
| 12, 13 | $\mathrm{G}_{1}, \mathrm{G}_{2}$ | 0 | Active high three-state output controls. |  |  |  |  |  |
| 11, 9, 14 | $\begin{aligned} & \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \\ & \mathrm{G}_{5} \end{aligned}$ | $\bigcirc$ | Active low three-state output controls. |  |  |  |  |  |
| $\begin{aligned} & 18,15,16 \\ & 17,1,2,3 \end{aligned}$ | $\mathrm{I}_{0-7}$ | 1 | Active low encoder inputs. |  |  |  |  |  |
|  |  |  | $\mathrm{I}_{6}$ $\mathrm{I}_{7}$ <br> X X <br> H $H$ <br> $X$ $L$ <br> $L$ $H$ <br> $H$ $H$ <br> $H$ $H$ <br> $H$ $H$ <br> $H$ $H$ <br> $H$ $H$ <br> $H$ $H$ <br> Hel  |  |  | $A_{0}$ $A_{1}$ <br> Enabled  <br> $z$ $Z$ <br> $z$ $z$ <br> $z$ $z$ <br> $z$ $z$ <br> $Z$ $z$ | $A_{2}$ ${ }^{2}$ $Z$ $Z$ $Z$ $Z$ $Z$ |  |

PRIORITY ENCODED RST INTERRUPT INSTRUCTION FOR THE Am9080A


AF001070
APPLICATION

EUTPUT
AF001140
64 Input Priority Encoder Connected for Parallel Enable

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous
DC Voltage Applied to Outputs For
High Output State O .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$
$\qquad$ $+7.0 \mathrm{~V}$
DC Output Current, Into Outputs ........................... 30mA
DC Input Current .............................-30mA to +5.0mA
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 device reliability

## OPERATING RANGES

Commercial (C) Devices
Temperature ................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N . \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $A_{i}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  |  | COM'L, ${ }^{\text {OHH }}=$ | $-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
|  |  |  | $\overline{\mathrm{EO}}, \mathrm{IOH}^{\prime}=-440 \mu \mathrm{~A}$ |  | MIL | 2.5 | 3.4 |  |  |
|  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| $\mathrm{VOL}_{\text {O }}$ | 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{lOL}=4.0 \mathrm{~mA}$ |  |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{l} \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{OL}=12 \mathrm{~mA}\left(\mathrm{~A}_{n}\right.$ Outputs) |  |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| VIL | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} ., \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X . \\ & V_{I N}=0.4 V \\ & \hline \end{aligned}$ | $\overline{\mathrm{E} 1}, \mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}, \overline{\mathrm{I}}_{0}$ |  |  |  |  | -0.4 | mA |
|  |  |  | All others |  |  |  |  | -0.8 |  |
| IH | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X . \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ | E1, $\mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}, \bar{I}_{0}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | All others |  |  |  |  | 40 |  |
| 1 | Input HIGH Current | $\begin{aligned} & V_{C C}=\mathrm{MAX} . \\ & \mathrm{V}_{\mathrm{IN}}=7.0 \mathrm{~V} \\ & \hline \end{aligned}$ | $\overline{\mathrm{E} 1}, \mathrm{G}_{1}, \mathrm{G}_{2}, \overline{\mathrm{G}}_{3}, \overline{\mathrm{G}}_{4}, \overline{\mathrm{G}}_{5}, \mathrm{I}_{0}$ |  |  |  |  | 0.1 | mA |
|  |  |  | All | thers |  |  |  | 0.2 |  |
| 10 | Off-State (High Impedance) Output Current | $V_{C C}=$ MAX |  | 0.4 V |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{0}$ | 2.4 V |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$. |  |  |  |  | 15 | 24 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN. or MAX., use the appropriate value specified under Operating Ranges for the applicable device type
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All inputs and outputs open.

SWITCHING CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tplh | $\bar{T}_{i}$ to $A_{n}$ (In-phase) | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 17 | 25 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 17 | 25 |  |
| tpLH | $\bar{T}_{i}$ to $A_{n}$ (Out-phase) |  |  | 11 | 17 | ns |
| tPHL |  |  |  | 12 | 18 |  |
| tpLH | $\bar{T}_{i}$ to EO |  |  | 7.0 | 11 | ns |
| tPHL |  |  |  | 24 | 36 |  |
| tpLH | El to EO |  |  | 11 | 17 | ns |
| tPHL |  |  |  | 23 | 34 |  |
| tple | El to $A_{n}$ |  |  | 12 | 18 | ns |
| ${ }_{\text {t }}$ |  |  |  | 14 | 21 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $G_{1}$ or $G_{2}$ to $A_{n}$ |  |  | 23 | 40 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 20 | 37 |  |
| $\mathrm{t}_{\mathrm{Z}} \mathrm{H}$ | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 20 | 30 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 18 | 27 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $G_{1}$ or $G_{2}$ to $A_{n}$ | $\begin{aligned} C_{\mathrm{L}} & =5.0 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 17 | 27 | ns |
| tLz |  |  |  | 19 | 28 |  |
| $\mathrm{thz}^{\text {H }}$ | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 16 | 24 | ns |
| thz |  |  |  | 18 | 27 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | Am25LS | ERCIAL | Am25 | TARY | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $\mathrm{t}_{\text {PLH }}$ | $i_{i j}$ to $A_{n}$ (In-phase) | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 31 |  | 37 | ns |
| tPHL |  |  |  | 30 |  | 34 |  |
| tPLH | $I_{i}$ to $A_{n}$ (Out-phase) |  |  | 22 |  | 27 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 22 |  | 25 |  |
| tpLH | $i_{i}$ to EO |  |  | 15 |  | 18 |  |
| ${ }_{\text {tPHL }}$ |  |  |  | 48 |  | 60 | ns |
| tPLH | EI to EO |  |  | 19 |  | 21 | ns |
| tpHL |  |  |  | 46 |  | 57 |  |
| tPLH | El to $A_{n}$ |  |  | 22 |  | 25 | ns |
| tPHL. |  |  |  | 27 |  | 32 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\mathrm{G}_{1}$ or $\mathrm{G}_{2}$ to $A_{n}$ |  |  | 42 |  | 49 | ns |
| t ZL |  |  |  | 43 |  | 49 |  |
| t ZH | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 36 |  | 43 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 35 |  | 43 |  |
| $\mathrm{th}_{\mathrm{H}}$ | $G_{1}$ or $G_{2}$ to $A_{n}$. | $\begin{aligned} C_{L} & =5.0 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 34 |  | 40 |  |
| tLz |  |  |  | 34 |  | 40 | ns |
| $\mathrm{thz}^{\text {L }}$ | $\bar{G}_{3}, \bar{G}_{4}, \bar{G}_{5}$ to $A_{n}$ |  |  | 30 |  | 35 | ns |
| $t_{L Z}$ |  |  |  | 31 |  | 35 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.
Note: $\mathbf{i}=0$ to 7


Note: Actual current flow direction shown.

## Am25LS381/Am54LS381/Am74LS381 Am25LS2517

Arithmetic Logic Unit/Function Generator Low-Power Schottky Integrated Circuits
DISTINCTIVE CHARACTERISTICS

- Three arithmetic functions
- Three logic functions
- Preset and clear functions
- Carry output $\left(C_{n+4}\right)$ and overflow (OVR) outputs on Am25LS2517
- Generate and propagate outputs for full lookahead carry on Am25LS381
- 8 mA sink current over the military temperature range on Am25LS
- 50 mV Improved $\mathrm{V}_{\mathrm{OL}}$ on Am25LS compared to Am54LS/74LS
- $440 \mu \mathrm{~A}$ source current at HIGH output.


## GENERAL DESCRIPTION

The Am25LS381 and Am54LS/74LS381 are arithmetic logic units (ALU)/function generators that perform three arithmetic operations and three logic operations on two 4bit words. The device can also output forced 0000 (clear) or 1111 (preset). These eight operations are selected using three function select inputs $\mathrm{S}_{0}, \mathrm{~S}_{1}$ and $\mathrm{S}_{2}$ as shown in the function table. Full carry lookahead is used over the four-bit field within the device. When devices are cascaded, multilevel full carry lookahead is implemented using a '182 carry lookahead generator and the $\bar{G}$ and $\bar{P}$ outputs on the Am25LS381 or Am54LS/74LS381. The device is packaged in a space-saving (0.3-inch row spacing) 20-pin package. If the $C_{n+4}$ carry output function is required, the Am25LS2517 should be used.

The Am25LS381 is a high-performance version of the Am54LS/74LS381. Improvements include faster A.C. spec-
ifications, higher noise margin and twice the fan-out over the military temperature range.

The Am25LS2517 is an arithmetic logic unit (ALU)/function generator that performs three arithmetic operations and three logic operations on two 4-bit words. The device can also force output 0000 (clear) or 1111 (preset). These eight operations are selected using three function select inputs $\mathrm{S}_{0}, \mathrm{~S}_{1}$ and $\mathrm{S}_{2}$ as shown in the function table. Full carry lookahead is used over the four-bit field within the device. When devices are cascaded, the carry output $\left(C_{n+4}\right)$ is connected to the carry input $\left(\mathrm{C}_{n}\right)$ of the next device. The Am25LS2517 can also detect two's complement overflow. The overflow output (OVR) is defined logically as $\mathrm{C}_{\mathrm{n}}+3^{\oplus}$ $C_{n+4}$.

BLOCK DIAGRAM


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2901 | Bit Slice |
| Am2903 | Bit Slice |
| Am29203 | Super Slice |
| Am29501 | Multiport Pipeline Processor |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25LS381
Am25LS2517


Blank - Standard processing B - Burn-in
Temperature (See Operating Range) C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless Chip-Pak
$\mathrm{P}-20$-pin plastic DIP
X - Dice
Device type
ALU Function Generators

| Valid Combinations |  |
| :--- | :--- |
| Am25LS381 | PC, PCB |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | XC, XM |
| Am25LS2517 | PC, PCB |
|  | DC, DCB, DM, |
|  | DMB |
|  | FM, FMB |
|  | LC, LM, LMB |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| 3, 1, 19, 17 | $A_{0}, A_{1}$, $A_{2}, A_{3}$ | 1 | The A data inputs. |
| 4, 2, 18, 16 | $\begin{array}{ll} \mathrm{B}_{0}, & \mathrm{~B}_{1}, \\ \mathrm{~B}_{2}, & \mathrm{~B}_{3} \\ \hline \end{array}$ | 1 | The B data inputs. |
|  | $\begin{aligned} & s_{0}, s_{1} \\ & s_{2}, s_{3} \end{aligned}$ | 1 | The control inputs used to determine the arithmetic or logic function performed. |
|  | $\begin{aligned} & F_{0}, F_{1}, \\ & F_{2}, F_{3} \end{aligned}$ | 0 | The data outputs of the ALU. |
| 16 | $\mathrm{C}_{\mathrm{n}}$ | 1 | The carry-in input of the ALU. |
|  | $\mathrm{C}_{n+4}$ | 0 | The carry-lookahead output of the four-bit input field. |
| 13 | $\bar{G}$ | 0 | The carry-generate output for use in multi-level lookahead schemes. |
| 14 | $\overline{\mathrm{P}}$ | 0 | The carry-propagate output for use in multi-level lookahead schemes. |
| 13 | OVR |  | Overflow. This pin is logically the Exclusive-OR of the carry-in and carry-out of the MSB of the ALU. At the most significant end of the word, this pin indicates that the result of an arithmetic two's complement operation has overflowed into the sign-bit. |

FUNCTION TABLE

| Selection |  |  | Arithmetic/Logic Operation |
| :---: | :---: | :---: | :---: |
| $\mathbf{S}_{2}$ | $\mathrm{S}_{1}$ | $\mathrm{S}_{0}$ |  |
| L | L | L | Clear |
| L | L | H | B Minus A |
| L | H | L | A Minus B |
| L | H | H | A Plus B |
| H | L | L | $\mathrm{A} \oplus \mathrm{B}$ |
| H | L | H | $A+B$ |
| H | H | L | AB |
| H | H | H | Preset |

$H=$ High Level, L = Low Level
See Truth Table for full description.

## guaranteed loading rules over operating range (In Unit Loads)

A Low-Power Schottky TTL Unit Load is defined as $20 \mu \mathrm{~A}$ measured at 2.7 V HIGH and -0.36 mA measured at 0.4 V LOW.

| Pin Nos. | Input/Output | Am25LS |  |  |  | Am54LS/74LS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Input Load | $\begin{aligned} & \text { Output } \\ & \text { HIGH } \\ & -440 \mu \mathrm{~A} \end{aligned}$ | Output LOW |  | Input Load | $\begin{aligned} & \text { Output } \\ & \text { HIGH } \\ & -440 \mu \mathrm{~A} \end{aligned}$ | Output LOW |  |
|  |  |  |  | MIL | COM'L |  |  | MIL | COM'L |
| 1 | $\mathrm{A}_{1}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 2 | $\mathrm{B}_{1}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 3 | $\mathrm{A}_{0}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 4 | $\mathrm{B}_{0}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 5 | $\mathrm{S}_{0}$ | 1.0 | - | - | - | 1.1 | - | - | - |
| 6 | $\mathrm{S}_{1}$ | 1.0 | - | - | - | 1.1 | - | - | - |
| 7 | $\mathrm{S}_{2}$ | 1.0 | - | - | - | 1.1 | - | - | - |
| 8 | $\mathrm{F}_{0}$ | - | 22 | 22 | 22 | - | 20 | 11 | 22 |
| 9 | $\mathrm{F}_{1}$ | - | 22 | 22 | 22 | - | 20 | 11 | 22 |
| 10 | GND | - | - | - | - | - | - | - | - |
| 11 | $\mathrm{F}_{2}$ | - | 22 | 22 | 22 | - | 20 | 11 | 22 |
| 12 | $\mathrm{F}_{3}$ | - | 22 | 22 | 22 | - | 20 | 11 | 22 |
| 13 | $\overline{\mathrm{G}}$ or OVR* | - | 22 | 44 | 44 | - | 20 | 44 | 44 |
| 14 | $\overline{\mathrm{P}}$ or $\mathrm{C}_{\mathrm{n}}+4$ | - | 22 | 22 | 22 | - | 20 | 11 | 22 |
| 15 | $\mathrm{C}_{n}$ | 3.0** | - | - | - | 4.4 | - | - | - |
| 16 | $\mathrm{B}_{3}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 17 | $\mathrm{A}_{3}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 18 | $\mathrm{B}_{2}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 19 | $\mathrm{A}_{2}$ | 4.0 | - | - | - | 4.4 | - | - | - |
| 20 | $\mathrm{V}_{\mathrm{CC}}$ | - | - | - | - | - | - | - | - |

*OVR Drive is 22 Unit Loads.
**4.0 for Am25LS2517.
Am25LS/54LS/74LS381
TEST TABLE

| Path |  | $\mathbf{S}_{\mathbf{0}} \mathrm{S}_{\mathbf{1}} \mathrm{S}_{\mathbf{2}}$ | $\mathrm{C}_{\mathrm{n}}$ | Same Bit |  | Other Data Bits |  | Output Waveform |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| In | Out |  |  | 4.5V | GND | 4.5 V | GND |  |
| $\mathrm{C}_{\mathrm{n}}$ | Any F | 100 | - | - | - | All A's \& B's | - | out-of-phase |
| $\mathrm{C}_{\mathrm{n}}$ | $F_{i}$ | 1000 | - | $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{A}_{\mathrm{i}}$ | All A's \& B's | - | in-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\overline{\mathrm{G}}$ | 110 | x | $\mathrm{Bi}_{\mathrm{i}}$ | - | All B's | All A's | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\overline{\mathrm{G}}$ | 110 | x | $\mathrm{A}_{\mathrm{i}}$ | - | All B's | All A's | out-of-phase |
| $A_{i}$ | $\bar{p}$ | $\mathrm{x} \times 1$ | x | $\mathrm{Bi}_{\mathrm{i}}$ | - | All A's \& B's | - | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\overline{\text { P }}$ | 110 | x | - | $\mathrm{A}_{\mathrm{i}}$ | All B's | All A's | out-of-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0 0 1 0 | 0 | - | $\mathrm{Bi}_{i}$ | - | A's \& B's | out-of-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0 0 1 0 | 1 | - | $\mathrm{B}_{\mathrm{i}}$ | - | A's \& B's | in-phase |
| $\mathrm{Bi}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0 0 1 0 | 0 | - | $\mathrm{A}_{\mathrm{i}}$ | - | A's \& B's | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0 0 1 0 | 1 | - | $\mathrm{A}_{\mathrm{i}}$ |  | A's \& B's | in-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}+1}$ | 0 0 1 0 | 1 | $\mathrm{Bi}_{\mathrm{i}}$ | - | A's \& B's | - | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}+1}$ | 100 | 1 | $\mathrm{A}_{\mathrm{i}}$ | - | A's \& B's | - | out-of-phase |
| $\mathrm{S}_{0}$ | $\mathrm{F}_{\mathrm{i}}$ | - 00 | 1 | $\mathrm{Bi}_{i}$ | $\mathrm{A}_{\mathrm{i}}$ | All B's | All A's | in-phase |
| $\mathrm{S}_{0}$ | $\overline{\mathrm{G}}$ | - 10 | x |  | - | A's \& B's | - | out-of-phase |
| $\mathrm{S}_{0}$ | $\overline{\mathrm{P}}$ | -10 | x | - | - | All B's | All A's | out-of-phase |
| $\mathrm{S}_{1}$ | $\mathrm{F}_{\mathrm{i}}$ | 0-0 | 1 | $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{B}_{\mathrm{i}}$ | All A's | All B's | in-phase |
| $\mathrm{S}_{1}$ | G | 1-0 | x | - | - | A's \& B's | - | out-of-phase |
| $\mathrm{S}_{1}$ | $\overline{\mathrm{P}}$ | 1-0 | x | - | - | All A's | All B's | out-of-phase |
| $\mathrm{S}_{2}$ | $\mathrm{F}_{\mathrm{i}}$ | 01 - | 1 | $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{B}_{\mathrm{i}}$ | All A's | All B's | out-of-phase |
| $\mathrm{S}_{2}$ | $\overline{\mathrm{G}}$ | 11 - | x | - | - | A's \& B's | - | in-phase |
| $\mathrm{S}_{2}$ | $\overline{\text { P }}$ | 11 | x | - | - | All A's | All B's | in-phase |

X = Don't care


Am25LS2517
TEST TABLE

| Path |  | $\mathrm{S}_{0} \mathrm{~S}_{1} \mathrm{~S}_{2}$ | $\mathrm{C}_{\mathrm{n}}$ | Same Bit |  | Other Data Bits |  | Output Waveform |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| In | Out |  |  | 4.5V | GND | 4.5 V | GND |  |
| $\mathrm{C}_{n}$ | Any F | 100 | - | - | - | A's \& B's | None | out-of-phase |
| $\mathrm{C}_{n}$ | $\mathrm{F}_{\mathrm{i}}$ | 100 | - | $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{A}_{\mathrm{i}}$ | A's \& B's | None | in-phase |
| $A_{i}$ | $\mathrm{F}_{\mathrm{i}}$ | $0 \begin{array}{lll}0 & 1 & 0\end{array}$ | 0 | - | $\mathrm{B}_{\mathrm{i}}$ | None | A's \& B's | out-of-phase |
| $A_{i}$ | $\mathrm{Fi}_{\mathrm{i}}$ | $0 \begin{array}{lll}0 & 1 & 0\end{array}$ | 1 | - | $\mathrm{B}_{\mathrm{i}}$ | None | A's \& B's | in-phase |
| $\mathrm{A}_{\mathrm{i}}$ | OVRF | $0 \begin{array}{lll}0 & 1 & 1\end{array}$ | 1 | $\mathrm{Bi}_{i}$ | - | A's \& B's | None | in-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{C}_{n}+4$ | $0 \begin{array}{lll}0 & 1 & 1\end{array}$ | 1 | $\mathrm{Bi}_{i}$ | - | A's \& B's | None | in-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0 1 1 0 | 0 | - | $\mathrm{A}_{\mathrm{i}}$ | None | A's \& B's | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}}$ | 0010 | 1 | - | $\mathrm{A}_{\mathrm{i}}$ | - | A's \& B's | in-phase |
| $B_{i}$ | OVRF | 0 0 1 1 | 0 | $\mathrm{A}_{\mathrm{i}}$ | - | A's \& B's | None | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{C}_{n}+4$ | $\begin{array}{llll}0 & 1 & 1\end{array}$ | 0 | $\mathrm{A}_{i}$ | - | A's \& B's | None | out-of-phase |
| $\mathrm{A}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}+1}$ | $\begin{array}{lll}0 & 1 & 0\end{array}$ | 1. | $\mathrm{B}_{\mathrm{i}}$ | - | A's \& B's | None | out-of-phase |
| $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{F}_{\mathrm{i}+1}$ | 100 | 1 | $\mathrm{A}_{i}$ | - | A's \& B's | None | out-of-phase |
| $\mathrm{S}_{0}$ | $\mathrm{F}_{\mathrm{i}}$ | - 00 | 1 | $\mathrm{B}_{\mathrm{i}}$ | $\mathrm{A}_{i}$ | All B's | All A's | in-phase |
| $\mathrm{S}_{0}$ | OVRF | $-11$ | 0 | - | - | None | A's \& B's | out-of-phase |
| $\mathrm{S}_{0}$ | $\mathrm{C}_{\mathrm{n}}+4$ | $-11$ | 0 | - | - | None | A's \& B's | out-of-phase |
| $\mathrm{S}_{1}$ | $\mathrm{F}_{\mathrm{i}}$ | $0-0$ | 1 | $A_{i}$ | $B_{i}$ | All A's | All B's | in-phase |
| $\mathrm{S}_{1}$ | OVRF | $0-1$ | X | - | - | None | A's \& B's | in-phase |
| $\mathrm{S}_{1}$ | $\mathrm{C}_{\mathrm{n}+4}$ | $0-1$ | X | - | - | None | A's \& B's | in-phase |
| $\mathrm{S}_{2}$ | $\mathrm{F}_{\mathrm{i}}$ | $0 \begin{array}{lll}0 & 1 & -\end{array}$ | 1 | $A_{i}$ | $B_{i}$ | All A's | All B's | in-phase |
| $\mathrm{S}_{2}$ | OVRF | 0 1 - | 0 | - | - | None | A's \& B's | out-of-phase |
| $\mathrm{S}_{2}$ | $\mathrm{C}_{n}+4$ | $01-$ | 0 | - | - | None | A's \& B's | in-phase |

TRUTH TABLE

TYPICAL SPEED CALCULATIONS

| Path | Output |  |
| :---: | :---: | :---: |
|  | F | $\mathrm{C}_{\mathrm{n}}+4, \mathrm{OVR}$ |
| $A_{i}$ or $B_{i}$ to $\bar{G}$ or $\bar{P}$ | $20 \mathrm{~ns}{ }^{*}$ | $20 \mathrm{~ns}{ }^{*}$ |
| $\overline{\mathrm{G}}_{\mathrm{i}}$ or $\overline{\mathrm{P}}_{\mathrm{i}}$ to $\mathrm{C}_{\mathrm{i}+\mathrm{j}}$ | 8 ns | 8 ns |
| (Am2902) |  |  |
| $\mathrm{C}_{\mathrm{n}}$ to F | 16 ns | ${ }^{-}$ |
| $\mathrm{C}_{n}$ to $\mathrm{C}_{\mathrm{n}+4}$, OVR | - | 15 ns |
| 16-Bit Speed | 44 ns | 43 ns |

${ }^{*}$ Note that $S_{i}$ to $G$ or $P$ may be longer path.
The Am25LS2517 and Am25LS381 in a 16-Bit Carry Lookahead ALU Connection.

## USER NOTES

1. Throughout this data sheet, the active HIGH input and output terminology has been used.
2. Arithmetic operations are performed on a word basis.
3. Logic operations are performed on a bit basis.
4. Arithmetic in 1 's complement notation requires an end around carry.
5. Subtraction in 2's complement notation requires a carry in $\left(\mathrm{C}_{\mathrm{n}}=\mathrm{HIGH}\right)$ for the active HIGH case.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias $\ldots \ldots . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
Continuous $\qquad$
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage (Except Am25LS2517,

DC Output Current, Into Outputs ........................... 30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified
Am25LS381 • Am25LS2517


Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second
4. Test conditions: LS381: $\mathrm{S}_{0}=\mathrm{S}_{1}=\mathrm{S}_{2}=\mathrm{GND}$, all other inputs open.

LS2517: $\mathrm{S}_{0}=\mathrm{C}_{\mathrm{n}}=$ open, all other inputs $=\mathrm{GND}$.

DC CHARACTERISTICS over operating range unless otherwise specified AM54LS/74LS381

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units <br> Volts |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-400 \mu \mathrm{~A} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ |  | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| 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}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | 74LS on | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  | 0.5 |  |
|  |  |  | $\overline{\mathrm{P}}, \mathrm{IOL}=$ | OmA |  |  | 0.5 |  |
|  |  |  | $\overline{\mathrm{G}}$, $\mathrm{IOL}=$ | 6 mA |  |  | 0.65 |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed input voltage for all in | al HIGH |  | 2.0 |  |  | Volts |
|  |  |  |  | MIL |  |  | 0.7 |  |
| $V_{\text {IL }}$ | Input LOW Level | voltage for all |  | COM'L |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{N}}=$ |  |  |  |  | -1.5 | Volts |
|  |  |  |  | Any S |  |  | -0.4 |  |
| ILL | Input LOW Current (Note 5) | $V_{C C}=M A X, V_{1 N}$ |  | Others |  |  | -1.6 | mA |
|  |  |  |  | Any S |  |  | 20 |  |
| 1 H | Input HIGH Current (Note 5) | $V_{C C}=M A X, V_{\text {IN }}$ |  | Others |  |  | 80 | $\mu \mathrm{A}$ |
|  |  |  |  | Any S |  |  | 0.1 |  |
| 1 | Input HIGH Current (Note 5) | $V_{C C}=M A X, V_{\text {IN }}$ |  | Others |  |  | 0.4 | mA |
| IsC | Output Short Circuit Current (Note 3) | $V_{C C}=\mathrm{MAX}$ |  |  | -15 |  | -100 | mA |
| ICC | $\begin{array}{\|l} \hline \begin{array}{l} \text { Power Supply Current } \\ \text { (Note 4) } \end{array} \\ \hline \end{array}$ | $V_{C C}=M A X$ |  |  |  | 25 | 43 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test conditions: LS381: $S_{0}=S_{1}=S_{2}=G N D$, all other inputs open.

LS2517: $\mathrm{S}_{0}=\mathrm{C}_{\mathrm{n}}=$ open, all other inputs $=$ GND.
5. Limits chosen by AMD based on SN545/74S381, T, I, LS data unavailable.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Am25LS |  |  | Am54LS/74LS |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| tPLH | $\mathrm{C}_{n}$ to Fi | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 14 | 21 |  |  | 26 | ns |
| tPHL |  |  |  | 16 | 24 |  |  | 30 |  |
| tple | $A_{i}$ to $B_{i}$ to $F_{i}$ |  |  | 16 | 24 |  |  | 30 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 23 | 35 |  |  | 40 |  |
| tplh | $\mathrm{S}_{\mathrm{i}}$ to $\mathrm{F}_{\mathrm{i}}$ |  |  | 20 | 30 |  |  | 35 | ns |
| tPHL |  |  |  | 25 | 37 |  |  | 40 |  |
| tplH | $A_{i}$ or $B_{i}$ to $\bar{G}$ ('LS381 Only) |  |  | 20 | 30 |  |  | 35 | ns |
| tPHL |  |  |  | 15 | 23 |  |  | 30 |  |
| tPLH | $A_{i}$ or $B_{j}$ to $\bar{P}$ ('LS381 Only) |  |  | 17 | 26 |  |  | 34 |  |
| tPHL |  |  |  | 15 | 23 |  |  | 30 | ns |
| tplH |  |  |  | 32 | 48 |  |  | 55 |  |
| tPHL | $\mathrm{S}_{\mathrm{i}}$ to $\overline{\mathrm{G}}$ or $\overline{\mathrm{P}}$ ('LS381 Only) |  |  | 23 | 35 |  |  | 42 | ns |
| ${ }_{\text {tPLH }}$ |  |  |  | 23 | 34 |  |  | - |  |
| tPHL | $A_{i}$ or $B_{i}$ to OVR ('LS2517 Only) |  |  | 24 | 36 |  |  | - | ns |
| ${ }_{\text {tPLH }}$ |  |  |  | 21 | 32 |  |  | - |  |
| tPHL | $A_{i}$ or $B_{i}$ to $\mathrm{C}_{n+4}$ ('LS2517 Only) |  |  | 24 | 36 |  |  | - | ns |
| tplH |  |  |  | 27 | 41 |  |  | - |  |
| tPHL | $\mathrm{S}_{\mathrm{i}}$ to OVR or $\mathrm{C}_{\mathrm{n}+4}$ ('LS2517 Only) |  |  | 37 | 55 |  |  | - | ns |
| tplH | $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{n+4}$ ('LS2517 Only) |  |  | 14 | 21 |  |  | - | ns |
| $\mathrm{tPHL}^{\text {P }}$ |  |  |  | 15 | 22 |  |  | - |  |
| tplH | $\mathrm{C}_{\mathrm{n}}$ to OVR ('LS2517 Only) |  |  | 15 | 22 |  |  | - | ns |
| tPHL |  |  |  | 15 | 22 |  |  | - |  |


*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am25LS/Am54LS/74LS LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

## Am25LS2518

## Quad D Register with Standard and Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Low-Power Schottky version of the popular Am2918 and Am25S18
- Four standard totem-pole outputs
- Four three-state outputs
- Four D-type flip-flops
- Second sourced by T. I. as the SN54/74LS388


## GENERAL DESCRIPTION

The Am25LS2518 consists of four D-type flip-flops with a buffered common clock. Information meeting the set-up and hold requirements on the $D$ inputs is transferred to the Q outputs on the LOW-to-HIGH transition of the clock.

The same data as on the $Q$ outputs is enabled at the threestate $Y$ outputs when the 'output control' ( $\overline{\mathrm{OE}}$ ) input is LOW. When the $\overline{O E}$ input is HIGH, the $Y$ outputs are in the high-impedance state.

The Am25LS2518 is a 4-bit, high-speed register intended for use in real-time signal processing systems where the
standard outputs are used in a recursive algorithm and the three-state outputs provide access to a data bus to dump the results after a number of iterations.
The device can also be used as an address register or status register in computers or computer peripherals.
Likewise, the Am25LS2518 is also useful in certain display applications where the standard outputs can be decoded to drive LED's (or equivalent) and the three-state outputs are bus organized for occasional interrogation of the data as displayed.


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S18 | Quad D Register |
| Am2918 | Quad D Register |
| Am29LS18 | Quad D Low Power Register |
| Am29LS2519 | Quad D Low Power Register |



ORDERING INFORMATION
AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS2518
    1
    \(\left.\right|^{\text {D }}{ }^{\mathbf{C}}\)
    - Temperature (See Operating Range)
        C - Commercial \(\left(0^{\circ} \mathrm{C}\right.\) to \(\left.+70^{\circ} \mathrm{C}\right)\)
        M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
        - Package
    D-16-pin CERDIP
    F-16-pin flatpak
    L-20-pin leadless chip carrier
    P-16-pin plastic DIP
    X-Dice
    Device type
    Quad D Register
```

| Valid Combinations |  |
| :--- | :--- |
| Am25LS2518 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The four data inputs to the register. |
|  | $\mathrm{Q}_{\mathrm{i}}$ | 0 | The four data outputs of the register with standard totem-pole active pull-up outputs. Data is passed non-inverted. |
|  | Yi | 0 | The four three-state data outputs of the register. When the three-state outputs are enabled, data is passed noninverted. A HIGH on the "'output control" input forces the $Y_{i}$ outputs to the high-impedance state. |
| 9 | CP | 1 | Clock. The buffered common clock for the register. Enters data on the LOW-to-HIGH transition. |
| 7 | $\overline{O E}$ | 1 | Output Control. When the $\overline{O E}$ input is HIGH, the Yi outputs are in the high-impedance state. When the $\overline{O E}$ input is LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

TRUTH TABLE

| INPUTS |  |  | OUTPUTS |  | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O E}$ | $\begin{gathered} \text { CLOCK } \\ \text { CP } \end{gathered}$ | D | Q | Y |  |
| H | L | X | NC | Z | - |
| H | H | x | NC | Z | - |
| H | + | L | L | z | - |
| H | $\dagger$ | H | H | Z | - |
| L | $\dagger$ | L | L | L | - |
| L | $\dagger$ | H | H | H | - |
| L | - | - | L | L | 1 |
| L | - | - | H | H | 1 |

$\mathrm{L}=$ LOW $\quad \mathrm{NC}=$ No change
$H=$ HIGH $\quad \uparrow=$ LOW-to-HIGH transition
$X=$ Don't care $\quad Z=$ High-Impedance
Note: 1. When $\overline{O E}$ is LOW, the $Y$ output will be in the same logic state as the $Q$ output.


The Am25LS2518 as a variable length (1, 2, 3 or 4 word) shift register.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
Continuous
to Ground Potential
DC Voltage Applied to Outputs For
High Output State $\qquad$ .-0.5 V to +7.0 V

DC Input Voltage $\qquad$ 0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max
.... -0.5 V to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage ............................... +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}_{\text {O }}$ | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | Q, ${ }_{\mathrm{IOH}}=-660 \mu \mathrm{~A}$ |  | MIL | 2.5 | 3.4 |  | Voits |
|  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
|  |  |  | $\mathrm{MIL}, \mathrm{IOH}=-1.0 \mathrm{~mA}$ |  |  | 2.4 | 3.4 |  |  |
|  |  |  | COM'L, ${ }^{\mathrm{O}} \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  | 2.4 | 3.4 |  |  |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{\mathbb{I L}} \end{aligned}$ | $\mathrm{l} \mathrm{OL}=4.0 \mathrm{~mA}$ |  |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=8.0 \mathrm{~mA}$ |  |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  |  | 0.7 | Volts |
|  |  |  |  |  | M'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=$ MiN, $\mathrm{I}_{\text {I }}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  |  | -0.36 | mA |
| 1 IH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  |  | 0.1 | mA |
| loz | Off-State (High-Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  |  | 17 | 28 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. ICC is measured with all inputs at 4.5 V and all outputs open.

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | Clock to $\mathrm{Q}_{\mathrm{i}}$ |  | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 18 | 27 |  |
| $\mathrm{tPHL}^{\text {che }}$ |  |  |  | 18 | 27 | ns |
| tply | Clock to $Y_{i}$ ( $\overline{\text { E }}$ LOW) |  |  |  | 18 | 27 |  |
| tpHL |  |  |  | 18 | 27 | ns |
| ${ }_{\text {tow }}$ | Clock Pulse Width | LOW |  | 18 |  |  | ns |
|  |  | HIGH |  | 15 |  |  |  |
| $\mathrm{t}_{\mathrm{s}}$ | Data |  |  | 15 |  |  | ns |
| th | Data |  |  | 5.0 |  |  | ns |
| tz H | $\overline{\mathrm{O}}$ to $\mathrm{Y}_{\mathrm{i}}$ |  |  |  | 7.0 | 11 | ns |
| tzL |  |  |  | 8 | 12 |  |
| ${ }_{\text {thz }}$ | $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ |  |  | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 14 | 21 | ns |
| tz |  |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 12 | 18 |  |  |
| $\mathrm{f}_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  |  | 35 | 50 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | $\frac{\text { COMMERCIAL }}{\text { Am25LS2518 }}$ |  | MILITARYAm25LS2518 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Clock to $\mathrm{Q}_{\mathrm{i}}$ |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 38 |  | 45 |  |
| tPHL |  |  |  |  | 38 |  | 45 | ns |
| tpLH | Clock to $\mathrm{Y}_{\mathrm{i}}$ (OE LOW) |  |  |  | 35 |  | 40 |  |
| tPHL |  |  |  |  | 35 |  | 40 | ns |
| $t_{\text {pw }}$ | Clock Pulse Width | LOW | 20 |  |  | 20 |  | ns |
|  |  | HIGH. | 20 |  |  | 20 |  |  |
| $\mathrm{t}_{\mathbf{s}}$ | Data |  | 15 |  |  | 15 |  | ns |
| $t_{n}$ | Data |  | 5.0 |  |  | 5.0 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  |  | 15 |  | 17 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 16 |  | 17 |  |
| $\mathrm{thz}^{\text {c }}$ | $\overline{O E}$ to $Y_{i}$ |  | $\begin{aligned} & C_{\mathrm{L}}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 27 |  | 30 | ns |
| tLZ |  |  |  | 24 |  | 30 |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | 30 |  | 25 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am25LS2518

LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25LS2519

Quad Register with Two Independently Controlled Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- Two sets of fully buffered three-state outputs
- Four D-type flip-flops
- Polarity control on W outputs
- Buffered common clock enable
- Buffered common asynchronous clear
- Separate buffered common output enable for each set of outputs


## GENERAL DESCRIPTION

The Am25LS2519 consists of four D-type flip-flops with a buffered common clock enable. Information meeting the set-up and hold time requirements on the D inputs is transferred to the flip-flop outputs on the LOW-to-HIGH transition of the clock. Data on the Q outputs of the flipflops is enabled at the three-state outputs when the output control ( $\overline{\mathrm{OE}}$ ) input is LOW. When the appropriate $\overline{\mathrm{OE}}$ input is HIGH, the outputs are in the high impedance state. Two independent sets of outputs - W and Y - are provided such
that the register can simultaneously and independently drive two buses. One set of outputs contains a polarity control such that the outputs can either be inverting or noninverting.

The device also features an active LOW asynchronous clear. When the clear input is LOW, the $Q$ output of the internal flip-flops are forced LOW independent of the other inputs. The Am25LS2519 is packaged in a space saving (0.3-inch row spacing) 20-pin package.

BLOCK DIAGRAM


## CONNECTION DIAGRAM <br> Top View

## D-20-1



CD001870

L-20-1


Note: Pin 1 is marked for orientation

METALLIZATION AND PAD LAYOUT


DIE SIZE $0.083^{\prime \prime} \times 0.099^{\prime \prime}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Am25LS2519 |  |
| :---: | :---: |
| Device type Quad D R |  |


| Valid Combinations |  |
| :--- | :--- |
| Am25LS2519 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.



Convenient Register Content Monitor or Test Point

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ DC Voltage Applied to Outputs For High Output State $\qquad$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

C Input Voltage $\qquad$ . V to $+\mathrm{V}_{\text {Cc }}$ max

DC Input Current ...............................................30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ........................................... 4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.
.
aity of the device is garanted.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Con | tions ( | 2) | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | MIL, $\mathrm{IOH}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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{I}^{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| 1 IH | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| loz | Off-State (High-Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  | MIL |  | 24 | 36 | mA |
|  |  |  |  | COM'L |  | 24 | 39 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type. 3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Inputs grounded; outputs open.

SWITCHING CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPHL | Clock to $\mathrm{Y}_{\mathrm{i}}$ |  | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 22 | 33 | ns |
| tPHL |  |  |  | 20 | 30 |  |
| tplH | Clock to $\mathrm{W}_{\mathrm{i}}$ (Either Polarity) |  |  |  | 24 | 36 | ns |
| tPHL |  |  |  | 24 | 36 |  |
| tphi. | Clear to $Y_{i}$ |  |  |  | 29 | 43 | ns |
| tplH | Clear to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 25 | 37 |  |
| tPHL |  |  |  | 30 | 45 | ns |  |
| tple | Polarity to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 23 | 34 | ns |
| tPHL |  |  |  | 25 | 37 |  |
| $t_{\text {pw }}$ | Clear |  |  | 18 |  |  | ns |
| $t_{\text {pw }}$ | Clock Pulse Width | LOW |  | 15 |  |  | ns |
|  |  | HIGH |  | 18 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data |  |  | 15 |  |  | ns |
| $t_{n}$ | Data |  |  | 5 |  |  | ns |
| $\mathrm{t}_{\text {s }}$ | Data Enable |  |  | 20 |  |  | ns |
| $t_{n}$ | Data Enable |  |  | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Set-up Time, Clear Recovery (Inactive) to clock |  |  | 20 | 15 |  | ns |
| ${ }_{\mathrm{Z} \mathrm{ZH}}$ | Output Enable to W or Y |  |  |  | 11 | 17 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 13 | 20 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | Output Enable to W or Y |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =5.0 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 13 | 20 | ns |
| tLz |  |  |  |  | 11 | 17 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 35 | 45 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | COMMERCIAL <br> Am25LS2519 |  | MILITARYAm25LS2519 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Clock to $\mathrm{Y}_{\mathrm{i}}$ |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 39 |  | 42 | ns |
| tpHL |  |  |  |  | 39 |  | 45 |  |  |
| tPLH | Clock to $W_{i}$ (Either Polarity) |  |  |  | 41 |  | 43 | ns |  |
| tPHL |  |  |  |  | 44 |  | 48 |  |  |
| $\mathrm{t}_{\text {PHL }}$ | Clear |  |  |  | 52 |  | 58 | ns |  |
| tPLH | Clear to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 42 |  | 43 | ns |  |
| tPHL |  |  |  |  | 51 |  | 53 |  |  |
| tplH | Polarity to $\mathrm{W}_{\mathrm{i}}$ |  |  |  | 41 |  | 45 | ns |  |
| tpHL |  |  |  |  | 42 |  | 44 |  |  |
| $\mathrm{t}_{\text {pw }}$ | Clear |  | 20 |  |  | 20 |  | ns |  |
| $t_{\text {pw }}$ | Clock | LOW | 20 |  |  | 20 |  | ns |  |
|  |  | HIGH | 20 |  |  | 20 |  |  |  |
| $\mathrm{t}_{\text {s }}$ | Data |  | 15 |  |  | 15 |  | ns |  |
| $t_{\text {h }}$ | Data |  | 10 |  |  | 10 |  | ns |  |
| $\mathrm{t}_{\text {s }}$ | Data Enable |  | 25 |  |  | 25 |  | ns |  |
| $t_{n}$ | Data Enable |  | 0 |  |  | 0 |  | ns |  |
| $t_{s}$ | Set-up Time, Clear Recovery (Inactive) to Clock |  | 23 |  |  | 24 |  | ns |  |
| ${ }_{\text {t }}$ | Output Enable to $W_{i}$ or $Y_{i}$ |  |  |  | 24 |  | 27 |  |  |
| t ZL |  |  |  |  | 29 |  | 35 |  |  |
| ${ }_{\text {thz }}$ | Output Enable to $\mathrm{W}_{\mathrm{i}}$ or |  | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | 33 |  | 45 | ns |  |
| tLZ |  |  |  | 22 |  | 26 |  |  |
| ${ }^{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ | 30 |  | 25 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am25LS2519 LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



## Am25LS2520

Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control

## DISTINCTIVE CHARACTERISTICS

- Buffered common clock enable input
- Buffered common asynchronous clear input
- Three-state outputs
- 8-bit, high-speed parallel register with positive edgetriggered, D-type flip-flops
- Am25LS Family offers improved sink current, source current and noise margin


## GENERAL DESCRIPTION

The Am25LS2520 is an 8-bit register built using advanced Low-Power Schottky technology. The register consists of eight D-type flip-flops with a buffered common clock, a buffered common clock enable, a buffered asynchronous clear input, and three-state outputs.

When the clear input is LOW, the internal flip-flops of the register are reset to logic 0 (LOW), independent of all other inputs. When the clear input is HIGH, the register operates in the normal fashion.

When the three-state output enable ( $\overline{\mathrm{OE}})$ input is LOW, the Y outputs are enabled and appear as normal TTL outputs.

When the output enable $(\overline{\mathrm{OE}})$ input is HIGH , the $Y$ outputs are in the high impedance (three-state) condition. This does not affect the internal state of the flip-flop $Q$ output.

The clock enable input ( $\bar{E}$ ) is used to selectively load data into the register. When the $\bar{E}$ input is HIGH, the register will retain its current data. When the $\bar{E}$ is LOW, new data is entered into the register on the LOW-to-HIGH transition of the clock input.

This device is packaged in a space-saving (0.4-inch row spacing) 22-pin package and in a 24-pin flatpack.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S18 | Quad D Register |
| Am2920 | Octal D-Type Flip-flop |
| Am2954/5 | Octal D Registers |

## CONNECTION DIAGRAM Top View

F-24


D-22, P-22


L-28-1


Note: Pin 1 is marked for orientation
*Reserved - do not use.

## LOGIC SYMBOL



METALLIZATION AND PAD LAYOUT


DIE SIZE $0.080^{\prime \prime} \times 0.111^{\prime \prime}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The D flip-flop data inputs. |
| 1 | CLR | 1 | When the clear input is LOW, the $Q_{i}$ outputs are LOW, regardless of the other inputs. When the clear input is HIGH, <br> data can be entered into the register. |
| 11 | CP | 1 | Clock Pulse for the Register; enters data into the register on the LOW-to-HIGH transition. |
|  | $Y_{i}$ | $O$ | The register three-state outputs. |
| 21 | $\bar{E}$ | 1 | Clock Enable. When the clock enable is LOW, data on the $D_{i}$ input is transferred to the $Q_{i}$ output on the LOW-to-HIGH <br> clock transition. When the clock enable is HIGH, the $Q_{i}$ outputs do not change state, regardless of the data or clock <br> input transitions. |
| 20 | $\overline{O E}$ | I | Output Control. When the $\overline{O E}$ input is HIGH, the $Y_{i}$ outputs are in the high impedance state. When the $\overline{O E}$ input is <br> LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

FUNCTION TABLE

|  |  |  |  |  |  |  | Internal |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Function | OE |  | Outputs |  |  |  |  |
| Hi-Z | H | X | X | X | X | X | Z |
| Clear | H | L | X | X | X | L | Z |
|  | L | L | X | X | X | L | L |
| Hold | H | H | H | X | X | NC | Z |
|  | L | H | H | X | X | NC | NC |
| Load | H | H | L | L | $\uparrow$ | L | Z |
|  | H | H | L | H | $\uparrow$ | H | Z |
|  | L | H | L | L | $\uparrow$ | L | L |
|  | L | $H$ | L | $H$ | $i$ | H | H |

$\mathrm{H}=$ HIGH $\quad \uparrow=$ LOW-to-HIGH Transition
$L=$ LOW $\quad X=$ Don't Care
$N C=$ No change $\quad Z=$ High-Impedance


A typical Computer Control Unit for a microprogrammed machine.


The Am25LS2520 is a useful device in interfacing with the Am9080A system buses.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\ldots . . \ldots \ldots . . \ldots \ldots . . . . . . . . . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$ DC Input Voltage.................................-0.5V to +7.0V
DC Output Current, Into Outputs .......................... 30 mA
DC Input Current .............................. -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
 +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (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}$ | MIL, $\mathrm{IOH}^{=}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{IOH}^{\text {a }}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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}$ | $1 \mathrm{OL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=8$. |  |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| 1 H | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4$ |  | , |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 24 | 37 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All outputs open, $\bar{E}=G N D, D i$ inputs $=C L R=\overline{O E}=4.5 \mathrm{~V}$. Apply momentary ground, then 4.5 V to clock input.

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {PLH }}$ | Clock to $Y_{i}$ ( $\overline{O E}$ LOW) | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 18 | 27 | ns |
| tPHL |  |  |  | 24 | 36 |  |
| tpHL | Clear to $Y$ |  |  | 22 | 35 | ns |
| $t_{s}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 10 | 3 |  | ns |
| th | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 10 | 3 |  | ns |
| $t_{s}$ | Enable (E) |  | 15 | 10 |  | ns |
|  |  |  | 20 | 12 |  |  |
| $t_{h}$ | Enable (E) |  | 0 | 0 |  | ns |
| $\mathrm{t}_{5}$ | Clear Recovery ( (n-Active) to Clock |  | 11 | 7 |  | ns |
| $t_{w}$ | Clock |  | 20 | 14 |  | ns |
|  |  |  | 25 | 13 |  |  |
| $t_{\text {pw }}$ | Clear |  | 20 | 13 |  | ns |
| t ZH | $\overline{O E}$ to $Y_{i}$ |  |  | 9 | 13 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 14 | 21 |  |
| $\mathrm{thz}^{\text {r }}$ | $\overline{O E}$ to $Y_{i}$ | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 20 | 30 | ns |
| tLz |  | $R_{L}=2.0 \mathrm{k} \Omega$ |  | 24 | 36 |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  | 40 |  | MHz |

Note 1. Per industry convention, $f_{m a x}$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS2520 | Am25LS2520 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Clock to $Y_{i}$ ( $\overline{O E}$ LOW) |  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 33 |  | 39 |  |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  |  | 45 |  | 54 | ns |
| tPHL | Clear to Y |  |  |  |  | 43 |  | 51 | ns |
| $\mathrm{t}_{\text {s }}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  |  | 15 |  | ns |
| $t_{\text {th }}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  |  | 15 |  | ns |
| $\mathrm{t}_{\mathbf{s}}$ | Enable ( $\overline{\mathrm{E}}$ ) | Active | 17 |  |  | 20 |  | ns |
|  |  | Inactive | 20 |  |  | 23 |  |  |
| th | Enable (E) |  | 0 |  |  | 0 |  | ns |
| $t_{s}$ | Clear Recovery (In-Active) to Clock |  | 13 |  |  | 15 |  | ns |
| $\mathrm{t}_{\mathrm{pw}}$ | Clock | HIGH | 25 |  |  | 30 |  | ns |
|  |  | LOW | 30 |  |  | 35 |  |  |
| $t_{\text {pw }}$ | Clear |  | 22 |  |  | 25 |  | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  |  | 19 |  | 25 |  |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 30 |  | 39 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $Y_{i}$ |  | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 35 |  | 40 | ns |
| tLz |  |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ | - | 39 |  | 42 |  |
| $f_{\text {max }}$ | Maximum Clock Frequency(Note 1) |  | . | 25 |  | 20 |  | MHz |

[^21]

## Am25LS2521

Eight-Bit Equal-to Comparator

## DISTINCTIVE CHARACTERISTICS

- 8-bit byte oriented equal comparator
- Cascadable using $\bar{E}_{I N}$
- High-speed, Low-Power Schottky technology
- $t_{\text {pd }} A \cdot B$ to $E_{O U T}$ in 9ns
- Standard 20 -pin package


## GENERAL DESCRIPTION

The Am25LS2521 is an 8-bit "equal to' comparator capable of comparing two 8-bit words for "equal to" with provision for expansion or external enabling. The matching of the two 8-bit inputs plus a logic LOW on the $\bar{E}_{I N}$ produces an active LOW on the output EOUT.

The logic expression for the device can be expressed as: $\bar{E}_{\mathrm{OUT}}=\overline{\left(A_{0} \odot B_{0}\right)\left(A_{1} \odot B_{1}\right)\left(A_{2} \odot B_{2}\right)\left(A_{3} \odot B_{3}\right)\left(A_{4} \odot B_{4}\right)}$
$\left(A_{5} \odot B_{5}\right) Y(A 6 \odot B 6)\left(A_{7} \odot B_{7}\right) E_{I N}$. It is obvious that the expression is valid where $A_{0}-A_{7}$ and $B_{0}-B_{7}$ are expressed as either assertions or negations. This is also true for pair of terms i.e. $A_{0}$ can be compared with $B_{0}$ at the same time $\bar{A}_{1}$ is compared with $\bar{B}_{1}$. It is only essential that the polarity of the paired terms be maintained.

## BLOCK DIAGRAM



## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29806 | Chip Select Decoder |
| Am29809 | 9-Bit Comparator |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25LS2521

$L^{B}$ Screening Option
Blank - Standard processing B - Burn-in

Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadiess chip carrier
P-20-pin plastic DIP
$X$ - Dice
Device type
8-Bit Equal-to-Comparator

| Valid Combinations |  |
| :--- | :--- |
| Am25LS2521 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


Note: This part does not have internal pull up resistors. In this application external pull ups shouid be added to the 16 ports.

## MICROPROCESSOR ENABLE CONTROLLED, SELECTABLE, ADDRESS DECODER

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ (Ambient) Temperature Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ .-0.5 V to +7.0 V DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ $\ldots . .0 .5 \mathrm{~V}$ to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | 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} \quad I_{O H}=-440 \mu \mathrm{~A} \\ & \hline \end{aligned}$ |  | MIL | 2.5 |  |  |  |
|  |  |  |  | COM'L | 2.7 |  |  | Volts |
| 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{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{loL}^{2}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{1+}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 |  |
|  |  |  |  | COM'L |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{l}_{\text {IN }}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
|  | Input LOW Current | $V_{C C}=$ MAX, $V_{\text {IN }}=0.4 \mathrm{~V}$ |  | $\mathrm{A}_{\mathrm{i}}, \mathrm{B}_{\mathrm{i}}$ |  |  | -0.36 |  |
| 112 |  |  |  | $\overline{\mathrm{E}}$ |  |  | -0.72 | mA |
| ${ }_{1} \mathrm{H}$ | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  | $\mathrm{A}_{\mathrm{i},} \mathrm{B}_{\mathrm{i}}$ |  |  | 20 |  |
|  |  |  |  | $\overline{\mathrm{E}}$ |  |  | 40 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=$ MAX, $V_{\text {IN }}=7.0 \mathrm{~V}$ |  | $\mathrm{A}_{\mathrm{i},} \mathrm{B}_{\mathrm{i}}$ |  |  | 0.1 |  |
|  |  |  |  | $\bar{E}$ |  |  | 0.2 | mA |
| Isc | Output Short Circuit Current (Note 3) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  | 27 | 40 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. $\bar{E}=G N D$, all other inputs and outputs open.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpliH | $\mathrm{A}_{i}$ or $\mathrm{B}_{i}$ to Equal | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 9 | 15 |  |
| $t_{\text {PHL }}$ |  |  |  | 9 | 15 | ns |
| ${ }_{\text {tPLH }}$ | $E$ to Equal |  |  | 5 | 7 | ns |
| tPHL |  |  |  | 6 | 8 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions |  | AL |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS2521 |  | Am25LS2521 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tpl | $A_{i}$ or $B_{i}$ to Equal Output | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 20 |  | 22 | ns |
| tPHL |  |  |  | 19 |  | 21 |  |
| tpl | $\bar{E}$ to Equal Output |  |  | 10.5 |  | 12 | ns |
| tPHL |  |  |  | 12.5 |  | 15 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

Am25LS2521
LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25LS2535

Eight-Input Multiplexer with Control Register

## DISTINCTIVE CHARACTERISTICS

- High speed eight-input multiplexer
- On-chip Multiplexer Select and Polarity Control Register
- Output polarity control for inverting or non-inverting output
- Common register enable
- Asynchronous register clear
- Three-state output for expansion
- Am25LS features improved noise margin, higher drive, and faster operation


## GENERAL DESCRIPTION

The Am25LS2535 is an eight-input Multiplexer with Control Register. The device features high speed from clock to output and is intended for use in high speed computer control units or structured state machine designs.

The Am25LS2535 contains an internal register which holds the A, B, and C multiplexer select lines as well as the POL (polarity) control bit. When the Register Enable input ( $\overline{\mathrm{RE}})$ is LOW, new data is entered into the register on the LOW-toHIGH transition of the clock. When $\overline{\mathrm{RE}}$ is HIGH, the register retains its current data. An asynchronous clear input (CLR) is used to reset the register to a logic LOW level.

The A, B and C register outputs select one of eight multiplexer data inputs. A HIGH on the Polarity Control flip-
flop output causes a true (non-inverting) multiplexer output, and a LOW causes the output to be inverted. In a computer control unit, this allows testing of either true or complemented flag data at the microprogram sequencer test input.

An active LOW Multiplexer Enable input ( $\overline{\mathrm{ME}}$ ) allows the selected multiplexer input to be passed to the output. When $\overline{M E}$ is HIGH, the output is determined only by the Polarity Control bit.

The Am25LS2535 also features a three-state Output Enable control ( $\overline{\mathrm{OE}})$ for expansion. When $\overline{O E}$ is LOW, the output is enabled. When $\overline{O E}$ is HIGH, the output is in the high impedance state.



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).



## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.



AF001980
A versatile one-of-sixteen Test Select with Polarity Control and Test Select Hold.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Ambient) Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
.............................
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to +7.0 V

DC Input Voltage -0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
$\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots .0 .5 \mathrm{~F}$ to +5.5 V
DC Output Current, Into Outputs ...........................30mA
DC Input Current
utputs -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test C | nditions ( N | 2) | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{MIL}, \mathrm{IOH}=-2.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ |  | 2.4 | 3.2 |  |  |
| 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}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}^{\prime}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=0.4 V \end{aligned}$ | $\overline{M E}$, $\overline{O E}, \overline{R E}$ |  |  |  | -0.72 | mA |
|  |  |  | $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \mathrm{CP}, \overline{\mathrm{CLR}}$ |  |  |  | -2.0 |  |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=2.7 V \end{aligned}$ | $\overline{M E}, \overline{O E}, \overline{R E}$ |  |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{D}_{\mathrm{N}}, \mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{POL}, \mathrm{CP}, \overline{\mathrm{CLR}}$ |  |  |  | 50 |  |
| 11 | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X \\ & V_{I N}=5.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\overline{\mathrm{ME}}, \overline{\mathrm{OE}}, \overline{\mathrm{RE}}$ |  |  |  | 0.1 | mA |
|  |  |  | DN, A, B, C, | $\bar{L}, \mathrm{CP}, \overline{\mathrm{CL}} \mathbf{R}$ |  |  | 1.0 |  |
| Ioz | Off-State (High-Impedance) Output Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 50 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -40 |  | -100 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=\mathrm{MAX}$ |  |  |  | 97 | 148 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. $D_{1}-D_{7}, A, B, C, P O L, \overline{M E}, C L R$ at GND. All other inputs and outputs open. Measured after a momentary ground then 4.5 V applied to clock input.


SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | CO | IAL |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tpLH | Clock to Y, POL-L | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 40 |  | 47 | ns |
| tpHL |  |  |  | 34 |  | 38 |  |
| tplH | Clock to Y, POL-H |  |  | 29 |  | 33 |  |
| tpHL |  |  |  | 35 |  | 41 |  |
| tPLH | $\mathrm{D}_{\mathrm{N}}$ to Y |  |  | 19 |  | 21 | ns |
| tpHL |  |  |  | 22 |  | 24 |  |
| tplH | $\overline{C L R}$ to $Y$ |  |  | 39 |  | 45 | ns |
| tPHL |  |  |  | 39 |  | 45 |  |
| tplH | $\overline{M E}$ to $Y$ |  |  | 22 |  | 26 | ns |
| tphL |  |  |  | 19 |  | 20 |  |
| $\mathrm{t}_{\mathrm{ZL}}$ | $\overline{O E}$ to $Y$ |  |  | 19 |  | 24 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 22 |  | 29 |  |
| tLZ | $\overline{\mathrm{OE}}$ to Y | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 24 |  | 30 | ns |
| $\mathrm{tHz}^{\text {H }}$ |  |  |  | 24 |  | 30 |  |
| $t_{s}$ | A, B, C POL | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ | 11 |  | 12 |  | ns |
|  | $\overline{\mathrm{RE}}$ |  | 18 |  | 20 |  |  |
| $\mathrm{t}_{5}$ | $\overline{\text { CLR }}$ Recovery |  | 6 |  | 7 |  | ns |
| $t_{\text {pw }}$ | Clock |  | 11 |  | 12 |  | ns |
|  | Clear (LOW) |  | 11 |  | 12 |  |  |
| $t_{n}$ | A, B, C, POL, $\overline{\mathrm{RE}}$ |  | 3 |  | 3 |  | ns |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.


Note: Actual current flow direction shown.

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am2922 | 8 Input Multiplexer |
| Am2923 | 8 Input Multiplexer |

## Am25LS2536

Eight-Bit Decoder with Control Storage


## GENERAL DESCRIPTION

The Am25LS2536 is an eight-bit decoder with control storage. It provides a conventional 8-bit decoder function with two enable inputs which may also be used for data input. This can be used to implement a demultiplexer function. In addition, the exclusive "OR' gate allows for polarity control of the selected output. The 3-state outputs are enabled by a LOW on the ( $\overline{O E}$ ) output enable.

The three control bits representing the output selection and the single bit polarity control are stored in 'D' type flipflops. These flip-flops have both Clear, Clock, and Clock Enable functions provided. The $\bar{G}_{1}$ and $\mathrm{G}_{2}$ input provide either polarity for input control or data.

## BLOCK DIAGRAM

8-Bit Decoder/Demultiplexer with Control Storage


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2537 | 1 of 10 Decoder |
| Am25LS2538 | 1 of 8 Decoder |
| Am25LS2539 | Dual 1 of 4 Decoder |
| Am25LS2548 | Chip Select Address Decoder |
| Am2921 | 1 of 8 Decoder |
| Am2924 | 3 to 8 Line Decoder/Demultiplexer |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| Am25LS2536 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

Note: Pin 1 is marked for orientation


| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| 2 | $\overline{C L R}$ | 1 | Clear. When the CLEAR input is LOW, the control register outputs ( $Q_{A}, Q_{B}, Q_{C}, Q_{P O L}$ ) are set LOW regardless of any other inputs. |
| 1 | CP | 1 | Clock. Enters data into the control register on the LOW-to-HIGH transition. |
| 3 | $\overline{C E}$ | 1 | Clock Enable. Allows data to enter the control register when $\overline{\mathrm{CE}}$ is LOW. When $\overline{\mathrm{CE}}$ is HIGH, the $\mathrm{Q}_{\mathrm{i}}$ outputs do not change state, regardless of data or clock input transitions. |
| 4, 5, 6 | A, B, C | 1 | Inputs to the control register which are entered on the LOW-to-HIGH clock transition if $\overline{\mathrm{CE}}$ is LOW. |
| 7 | POL | 1 | Input to the control register bit used for determining the polarity of the selected output. |
| 19 | $\bar{G}_{1}$ | 1 | Active LOW part of the expression $G=\bar{G}_{1} \oplus G_{2}$ where $G$ is either data input for the selected $Y_{n}$ or is used as an input enable. |
| 18 | $\mathrm{G}_{2}$ | 1 | Active HIGH part of the expression $\mathrm{G}=\overline{\mathrm{G}}_{1} \mathrm{G}_{2}$. |
|  | $Y_{n}$ | 0 | The three-state outputs. When active ( $\overline{O E}=$ LOW), one of eight outputs is selected by the code stored in the control register, with the polarity of all eight determined by the bit stored in the POL flip-flop of the control register. The selected output can further be controlled by $G$ according to the expression $Y_{\text {SELECTED }}=\bar{G} \oplus Q_{P O L}$. |
| 8 | $\overline{O E}$ |  | Output Enable. When $\overline{\mathrm{OE}}$ is HIGH the $Y_{n}$ outputs are in the high impedance state; when $\overline{\mathrm{OE}}$ is LOW the $Y_{n}$ 's are in their active state as determined by the other control logic. The $\overline{O E}$ input affects the $Y_{n}$ output buffers only and has no effect on the control register or any other logic. |

FUNCTION TABLE

|  | Inputs |  |  |  |  |  |  |  |  | Internal Registers |  |  |  | Three-State Outputs |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode | C | B | A | POL | $\overline{\mathbf{C E}}$ | $\overline{\text { CLR }}$ | G* | $\overline{\mathrm{OE}}$ | CP | Qc | $Q_{B}$ | $Q_{A}$ | Qpol | $Y_{0}$ | $Y_{1}$ | $\mathrm{Y}_{2}$ | $\mathrm{Y}_{3}$ | $Y_{4}$ | $Y_{5}$ | $\mathrm{Y}_{6}$ | $Y_{7}$ |
| Clear | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $L$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\bar{L}$ | $\stackrel{H}{\mathrm{H}}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | H H | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | H <br> H |
| Hold | X | X | X | X | H | H | NC | L | $\dagger$ | NC | NC | NC | NC | NC | NC | NC | NC | NC | NC | NC | NC |
| Select | L $L$ $L$ $L$ $H$ $H$ $H$ $H$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $X$ $X$ | $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $X$ $X$ | L $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $X$ $X$ | $\begin{aligned} & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & L \end{aligned}$ | L $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ | H H H H H H H H H H H H H H H H H H | H $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ L L | $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ |  | $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $H$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $X$ $X$ | $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $L$ $L$ $H$ $H$ $X$ $X$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & H \\ & H \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & X \end{aligned}$ | $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ $L$ | $H$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ | L $H$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ $L$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ | L $L$ $H$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ $H$ $L$ $H$ $H$ $H$ $H$ $H$ $L$ $H$ | $L$ $L$ $L$ $H$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $L$ $H$ $H$ $H$ $H$ $L$ $H$ | $L$ $L$ $L$ $L$ $H$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $L$ $H$ $H$ $H$ $H$ $H$ | $L$ $L$ $L$ $L$ $L$ $H$ $L$ $L$ $H$ $H$ $H$ $H$ $H$ $L$ $H$ $H$ $H$ $L$ | L $L$ $L$ $L$ $L$ $L$ $H$ $L$ $H$ $H$ $H$ $H$ $H$ $H$ $L$ $H$ $L$ $H$ | $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $L$ |
| Output <br> Disable | X | X | X | X | X | X | X | H | X | NC | NC | NC | NC | Z | Z | Z | Z | Z | Z | Z | Z |
|  |  |  | N | Chan | nge |  | = Don' | 't Care |  | High | -Imp | edanc |  | Lo | to- | h T | ansi |  |  |  |  |

* 

| $\bar{G}_{1}$ | $G_{2}$ | $G$ |
| :---: | :---: | :---: |
| $L$ | $L$ | $L$ |
| $L$ | $H$ | $H$ |
| $H$ | $L$ | $L$ |
| $H$ | $H$ | $L$ |




## Am25LS2537

One-of-Ten Decoder with Three-State Outputs and Polarity Control

## DISTINCTIVE CHARACTERISTICS

- Three-state outputs
- Separate output polarity control
- Inverting and non-inverting enable inputs
- Does not respond to codes above nine
- A.C. parameters specified over operating temperature and power supply ranges


## GENERAL DESCRIPTION

The Am25LS2537 is a demultiplexer/one-of-ten decoder that accepts four active high BCD inputs and selects one-of-ten mutually exclusive outputs. The device features three-state outputs as well as a buffered common polarity control such that the outputs are mutually exclusive activelow or mutually exclusive active-high. The logic design of the Am25LS2537 ensures that all outputs are unselected when the binary codes greater than nine are applied to the inputs. The inputs A, B, C, and D of the Am25LS2537 correspond to the respective binary weight of $1,2,4$, and 8

The output enable ( $\overline{\mathrm{OE}}$ ) input controls the three-state outputs. When the $\overline{O E}$ input is HIGH, the outputs are in the high-impedance state. When the $\overline{O E}$ input is LOW, the
outputs are enabled. The polarity (POL) input is used to drive the $Y$ outputs to either the active-HIGH state or the active-LOW state. When the POL input is LOW, the outputs are active-HIGH. When the POL input is HIGH, the $Y$ outputs are active-LOW. The device features one activeHIGH and one active-LOW enable input which can be used for gating the decoder or can be used with incoming data for demultiplexing applications.

The Am25LS2537 is packaged in a space saving (0.3-inch row spacing) 20-pin package. The device also features Am25LS family faster switching specifications, higher noise margin, and twice the fan-out over the military temperature range when compared with Am54LS/74LS devices.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2536 | 8-Bit Decoder |
| Am25LS2538 | 1-of-8 Decoder |
| Am25LS2539 | Dual 1-of-4 Decoder |
| Am25LS2548 | Chip Select Address Decoder |
| Am2921 | 1-of-8 Decoder |
| Am2924 | 3-to-8 Line Decoder/Demultiplexer |

## CONNECTION DIAGRAM <br> Top View



L-20-1


Note: Pin 1 is marked for orientation

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25LS2537


Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless chip carrier
P- 20-pin plastic DIP
X - Dice
Device type
1-of-10 Decoder

| Valid Combinations |  |
| :--- | :--- |
| Am25LS2537 | PC |
|  | DC, DM |
|  | FM, LM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 | Description |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6, 7, 16, 17 | A, B, C, D | 1 | To select inputs to the decoder. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15 | E1 | 1 | The active-LOW enable input. A HIGH on the E1 input inhibits the decoder function regardless of any other inputs. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14 | E2 | 1 | The active-HIGH enable input. A LOW on the E2 input forces all the decoder functions to the inactive state regardless of any other inputs. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 | POL | 1 | The polarity control for the output function. When the polarity control is HIGH, the outputs are active-LOW. When the POL input is LOW, the outputs are active-HIGH. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 | $\overline{O E}$ | 0 | Output Enable. An active-LOW three-state control used to enable the outputs. A HIGH level input forces the output to the high-impedance (off) state. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | $Y_{i}$ | 0 | Decoder outputs. The ten outputs of the decoder. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| FUNCTION |  |  | INPUTS |  |  |  |  |  |  |  | OUTPUTS |  |  |  |  |  |  |  |  |  |
|  |  |  | $\overline{O E}$ | E1 | E2 | POL | D | C | B | A | $\mathrm{Y}_{0}$ | $\mathrm{Y}_{1}$ | $\mathrm{Y}_{2}$ | $\mathrm{Y}_{3}$ | $\mathrm{Y}_{4}$ | $Y_{5}$ | $\mathrm{Y}_{6}$ | $\mathrm{Y}_{7}$ | $\mathrm{Y}_{8}$ | $\mathrm{Y}_{9}$ |
| 3-State |  |  | H | X | X | X | X | X | X | X | Z | Z | Z | Z | Z | Z | Z | Z | Z | Z |
| Disable |  |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{gathered} \mathrm{H} \\ \mathrm{H} \\ \mathrm{X} \\ \mathrm{X} \end{gathered}$ | $\begin{aligned} & X \\ & X \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \end{aligned}$ | $L$ $H$ $L$ $H$ | L $H$ $L$ $H$ |
| Active-HIGH Output |  |  | $\begin{aligned} & \hline L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ | H $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ | L L L L L L L L L L L L L L | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & H \\ & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \\ & H \\ & L \end{aligned}$ | $\begin{aligned} & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | L L L L L $H$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ $L$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | L L $L$ $L$ $L$ $L$ $L$ $H$ $L$ $L$ $L$ $L$ $L$ $L$ | L L L L L L L L L L L L L L | $\begin{aligned} & \hline \mathrm{L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \\ & \mathrm{~L} \end{aligned}$ |
| Active-LOW | Output |  |  | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \end{aligned}$ | $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$ $H$ $H$ $H$ $H$ $H$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & L \\ & L \\ & L \\ & L \\ & H \\ & H \\ & H \\ & H \\ & \hline \end{aligned}$ | $\begin{aligned} & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \\ & L \\ & L \\ & H \\ & H \\ & \hline \end{aligned}$ | L $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ $L$ $H$ |  | H $H$ $L$ $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$ $H$ $H$ | $\begin{aligned} & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & \hline \end{aligned}$ | H <br> H <br> H <br> H <br> L <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H | l $H$ $H$ $H$ $H$ $H$ $L$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ | H <br> H <br> H <br> H <br> H <br> H <br> L <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H | H <br> H <br> H <br> H <br> H <br> H <br> H <br> L <br> H <br> H <br> H <br> H <br> H <br> H <br> H <br> H | H H H H H H H $H$ L $H$ $H$ $H$ $H$ $H$ $H$ $H$ $H$ | $\begin{aligned} & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & H \\ & L \end{aligned}$ |
| $\begin{aligned} & H=H I G H \\ & L=L O W \end{aligned}$ |  | $\begin{aligned} & X=0 \\ & Z=1 \end{aligned}$ | Don't igh-Im | are pedan |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## APPLICATIONS



AF000751
One-of-Twenty Decoder with Active-High or Active-Low Output Polarity. Could be used for I/O Decoding in an Am9080A system.


BCD to Decimal (One-of-Ten) Decoder.

## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature ..................... $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| (Ambient) Temperature Under Bia | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential |  |
| DC Voltage Applied to Outputs For |  |
| DC Input Voltage | -0.5V to +7.0 V |
| DC Output Current, | mA |
|  | mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.75 V to +5.25 V

Military (M) Devices
Temperature . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (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{MIL}, \mathrm{l}^{\text {OH }}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, $\mathrm{IOH}^{\prime}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| $\mathrm{VOL}_{\text {O }}$ | Output LOW Voltage (Note 5) | $\begin{aligned} & V_{C C}=M_{I N} \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $1 \mathrm{OL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{l} \mathrm{OL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{lOL}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| IL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| $\mathrm{IH}_{\mathrm{H}}$ | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| Ioz | Off-State (High-Impedance) Output Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 25 | 40 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test conditions: $\mathrm{A}=\mathrm{B}=\mathrm{C}=\mathrm{D}=\overline{\mathrm{E} 1}=\mathrm{GND} ; \mathrm{E} 2=\mathrm{POL}=\overline{\mathrm{OE}}=4.5 \mathrm{~V}$.


SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | CO | AL |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS2537 |  | Am25LS2537 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tpLH | A, B, C, D to $Y_{i}$ | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 41 |  | 48 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 32 |  | 39 |  |
| tPLH | E1 to $\mathrm{Y}_{\mathrm{i}}$ |  |  | 34 |  | 40 |  |
| tPHL |  |  |  | 38 |  | 45 | ns |
| tPLH | E2 to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| tPHL |  |  |  | 42 |  | 49 |  |
| $\mathrm{t}_{\text {PLH }}$ | POL to $Y_{i}$ |  |  | 32 |  | 37 | ns |
| tPHL |  |  |  | 42 |  | 52 |  |
| t ZH | OE Control to $\mathrm{Y}_{\mathrm{i}}$ |  |  | 44 |  | 55 | ns |
| t ZL |  |  |  | 23 |  | 25 |  |
| $\mathrm{thz}^{\text {H }}$ | OE Control to $\mathrm{Y}_{\mathrm{i}}$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | 33 |  | 37 | ns |
| $\mathrm{t}_{\mathrm{L} Z}$ |  |  |  | 38 |  | 42 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am25LS2538

One-of-Eight Decoder
with Three-State Outputs and Polarity Control

## DISTINCTIVE CHARACTERISTICS

- Three-state decoder outputs
- Buffered common output polarity control
- Inverting and non-inverting enable inputs
- A. C. parameters specified over operating temperature and power supply ranges


## GENERAL DESCRIPTION

The Am25LS2538 is a three-line to eight-line decoder/ demultiplexer fabricated using advanced Low-Power Schottky technology. The decoder has three buffered select inputs-A, B, and C-that are decoded to one-of-eight Y outputs. Two active-HIGH and two active-LOW enables can be used for gating the decoder or can be used with incoming data for demultiplexing applications.

A separate polarity (POL) input can be used to force the function active-HIGH or active-LOW at the output. Two separate active-LOW output enables ( $\overline{\mathrm{OE}}$ ) inputs are pro-
vided. If either $\overline{\mathrm{OE}}$ input is HIGH , the output is in the highimpedance (off) state. When the POL input is LOW, the $Y$ outputs are active-HIGH and when the POL input is HIGH, the Y outputs are active-LOW.

The device is packaged in a space saving (0.3-inch row spacing) 20-pin package. It also features Am25LS family improved switching specifications, higher noise margin, and twice the fan-out over the military temperature range when compared with Am54LS/74LS devices.

BLOCK DIAGRAM

|  | RELATED PRODUCTS |  |
| :---: | :---: | :---: |
|  | Part No. | Description |
|  | Am25LS2536 | 8-Bit Decoder |
|  | Am25LS2537 | 1-of-10 Decoder |
|  | Am25LS2539 | Dual 1-of-4 Decoder |
|  | Am25LS2548 | Chip Select Address Decoder |
|  | Am2921 | 1-of-8 Decoder |
|  | Am2924 | 3-to-8 Line Decoder/Demultiplexer |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS2538
    |
    Device type
        1-of-8 Decoder
```

$L^{B}$ Screening Option
Blank - Standard processing
B - Burn-in
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

Package
D- 20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless chip carrier
P - 20-pin plastic DIP
X-Dice

Device type 1-of-8 Decoder

| Valid Combinations |  |
| :--- | :--- |
| Am25LS2538 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.




AF001081
Two Am25LS2538s can be used to perform a one-of-sixteen-bit mask function or a one-of-sixteen-bit select function to perform bit manipulation in a microprocessor system.

## Examples:

| D | C | B | A POL | $\mathbf{0}$ | $\mathbf{1}$ | 2 | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ | $\mathbf{7}$ | $\mathbf{8}$ | $\mathbf{9}$ | $\mathbf{1 0}$ | 11 | 12 | 13 | 14 | 15 | Function |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bit Select |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bit Select |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bit Mask |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Bit Mask |

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For High Output State $\qquad$ . 0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage $\qquad$ -0.5 V to +7.0 V
DC Output Current, Into Outputs $\qquad$ ............ 30 mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage........................... +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M \mathbb{N} \\ & V_{I N}=V_{I H} \text { or } V_{\mathbb{I L}} \\ & \hline \end{aligned}$ | $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ (MIL) |  | 2.4 | 3.4 |  | Volts |
|  |  |  | $1 \mathrm{OH}=-2.6 \mathrm{~mA}(\mathrm{COM}$ 'L) |  | 2.4 | 3.4 |  |  |
| VOL | Output LOW Voltage (Note 5) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOL}=4.0$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{l} \mathrm{OL}=12$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input voltage for all inp | al HIGH |  | 2.0 |  |  | Volts |
|  |  | Guaranteed input | al LOW | MIL |  |  | 0.7 |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | voltage for all inp |  | COM'L |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\text {CC }}=$ MIN, $\mathrm{IIN}=$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}$ |  |  |  |  | -0.36 | mA |
| ${ }_{1 / H}$ | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $V_{C C}=$ MAX, $V_{\text {IN }}$ |  |  |  |  | 0.1 | mA |
|  | Off-State (High-Impedance) |  | $\mathrm{V}_{\mathrm{O}}=0.4$ |  |  |  | -20 |  |
| loz | Output Current | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=2.4$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=\mathrm{MAX}$ |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  |  | 21 | 34 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test conditions: $A=B=C=D=\bar{E}_{1}=\mathrm{E}_{2}=\mathrm{GND}$ : $\mathrm{E} 3=\mathrm{E}_{4}=\mathrm{POL}=\mathrm{OE}_{1}=\overline{\mathrm{OE}} 2=4.5 \mathrm{~V}$.
5. $\mathrm{V}_{\mathrm{OL}}$ is specified with total device $\mathrm{l}_{\mathrm{OL}}=60 \mathrm{~mA}$ (max).

SWITCHING CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | $A, B, C$ to $Y_{i}$ | $\begin{aligned} C_{L} & =15 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 20 | 30 | ns |
| tPHL |  |  |  | 15 | 22 |  |
| tplH | $\bar{E}_{1}, \bar{E}_{2}$ to $Y_{i}$ |  |  | 19 | 28 | ns |
| tPHL |  |  |  | 20 | 30 |  |
| tPLH | $E_{3}, E_{4}$ to $Y_{i}$ |  |  | 21 | 31 | ns |
| tPHL |  |  |  | 23 | 34 |  |
| ${ }_{\text {tPLH }}$ | POL to $Y_{i}$ |  |  | 16 | 24 | ns |
| tPHL |  |  |  | 20 | 30 |  |
| t ZH | $\overline{O E}_{1}, \overline{O E}_{2}$ to $Y_{i}$ |  |  | 17 | 25 | ns |
| t ZL |  |  |  | 14 | 21 |  |
| ${ }_{\text {thz }}$ | $\bar{O} E_{1}, \bar{O} E_{2}$ to $Y_{i}$ | $\mathrm{C}_{\mathrm{L}}=5.0 \mathrm{pF}$ |  | 17 | 25 | ns |
| tLZ |  | $\mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega$ |  | 20 | 30 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMMERCIAL <br> Am25LS2538 |  | MILITARY <br> Am25LS2538 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | A, B, C to $Y_{i}$ | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 36 |  | 42 | ns |
| tPHL |  |  |  | 29 |  | 37 |  |
| tPLH | $\bar{E}_{1}, \bar{E}_{2}$ to $Y_{i}$ |  |  | 34 |  | 39 |  |
| tPHL |  |  |  | 38 |  | 45 | ns |
| tple | $E_{3}, E_{4}$ to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| tPHL |  |  |  | 43 |  | 52 |  |
| tple | POL to $\mathrm{Y}_{i}$ |  |  | 29 |  | 34 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 39 |  | 49 |  |
| $\mathrm{t}_{\mathrm{Z} \mathrm{H}}$ | $\overline{O E}_{1}, \overline{O E}_{2}$ to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 23 |  | 25 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}_{1}, \overline{O E}_{2}$ to $Y_{i}$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{\mathrm{L}}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | 29 |  | 33 | ns |
| $t_{L Z}$ |  |  |  | 33 |  | 36 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.
Am25LS2538
LOW-POWER SCHOTTKY INPUT/OUTPUT
CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25LS2539

## Dual One-of-Four Decoder with Three-State Outputs and Polarity Control

## DISTINCTIVE CHARACTERISTICS

- Two independent decoders/demultiplexers
- Three-state outputs
- Buffered common polarity control
- A. C. parameters specified over operating temperature and power supply ranges


## GENERAL DESCRIPTION

The Am25LS2539 is a dual two-line to four-line decoder/ demultiplexer fabricated using advanced Low-Power Schottky technology. Each decoder has two buffered select inputs - $A$ and $B$ which are decoded to one-of-four $Y$ outputs. An enable input ( $\overline{\mathrm{E}}$ ) is used for gating or can be used as a data input for demultiplexing applications. When the enable input goes HIGH, all four decoder functions are inhibited.
An output enable ( $\overline{\mathrm{OE}}$ ) input is used to control the threestate outputs of the device. When the $\overline{O E}$ input is LOW, the outputs are enabled. When the $\overline{O E}$ input is HIGH, the
outputs are in the high-impedance (off) state. The device also has separate buffered polarity (POL) inputs to force the outputs to either an active-HIGH state or an activeLOW state. When the POL input is LOW, the outputs are active-HIGH and when the POL input is HIGH, the outputs are active-LOW. The device is packaged in a space saving ( 0.3 -inch row spacing) 20 -pin package. The device features Am25LS family improved switching specification, higher noise margin, and twice the fan-out over the military temperature range when compared with Am54LS/74LS devices.


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2536 | 8-Bit Decoder |
| Am25LS2537 | 1-of-10 Decoder |
| Am25LS2538 | 1-of-8 Decoder |
| Am25LS2548 | Chip Select Address Decoder |
| Am2921 | 1-ot-8 Decoder |
| Am2924 | 3-to-8 Line Decoder/Demultiplexer |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am25LS2539
```



```
Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial ( \(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) ) M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-20-pin CERDIP
F-20-pin flatpak L-20-pin leadless chip carrier P -20-pin plastic DIP \(X\) - Dice
Device type
Dual 1-of-4 Decoder
```

| Valid Combinations |  |
| :--- | :--- |
| Am25LS2539 | PC |
|  | DC, DM |
|  | FM |
|  | LC, LM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| Pin No. | Name | I/O | Description |
| :--- | :--- | :---: | :--- |
|  | A, B | I | Select the two select inputs to the decoder/demultiplexer. |
| 15,16 | $\bar{E}$ Enable | I | The enable input to the decoder. A HIGH input forces the decoding functions to be inhibited <br> regardless of the A and B inputs. |
| 13,4 | POL | 1 | Polarity Input. The polarity input forces the outputs to either an active-HIGH state or an active-LOW <br> state. A LOW on the polarity input forces the output active-HIGH. A HIGH on the polarity input forces <br> the outputs active-LOW. |
| 14,5 | $\overline{\mathrm{OE}}$ | I | Output Enable. A LOW on the $\overline{\mathrm{OE}}$ input enables the outputs. A HIGH on the $\overline{\mathrm{OE}}$ inputs forces the <br> outputs to the high high-impedance (off) state. |
|  | $\mathrm{Y}_{0}, \mathrm{Y}_{1}$, <br> $\mathrm{Y}_{2}, \mathrm{Y}_{3}$ | O | The four decoder/demultiplexer outputs. |

FUNCTION TABLE

| Function | Inputs |  |  |  |  | Outputs |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\overline{\mathbf{O E}}$ | E | POL | B | A | $\mathbf{Y}_{\mathbf{0}}$ | $\mathbf{Y}_{\mathbf{1}}$ | $\mathbf{Y}_{\mathbf{2}}$ | Y $_{\mathbf{3}}$ |  |
|  | H | X | X | X | X | Z | Z | Z | Z |  |
| Disable | L | H | L | X | X | L | L | L | L |  |
|  | L | H | H | X | X | H | H | H | H |  |
| Active-High | L | L | L | L | L | H | L | L | L |  |
|  | L | L | L | L | H | L | H | L | L |  |
|  | L | L | L | H | L | L | L | H | L |  |
| Active-Low | L | L | H | L | L | L | H | H | H |  |
| Output | H |  |  |  |  |  |  |  |  |  |
|  | L | L | H | L | H | H | L | H | H |  |
|  | L | H | L | H | H | L | H |  |  |  |


| $H=$ HIGH | $X=$ Don't Care |
| :--- | :--- |
| $L=$ LOW | $Z=$ High-Impedance |



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias s.... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ .0 .5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage $\qquad$ Outputs .-0.5 V to +7.0 V
DC Output Current, Into Outputs $\ldots . . . . . . . . . . .30 \mathrm{~mA}$ DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military ( $M$ ) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
$\qquad$ .+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ | MIL, ${ }^{\mathrm{OH}} \mathrm{=}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | COM'L, ${ }^{\mathrm{OHH}}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| Vol | Output LOW Voltage (Note 5) | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{I L} \end{aligned}$ | $\mathrm{IOL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{IOL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
|  |  |  | $\mathrm{lOL}=12 \mathrm{~mA}$ |  |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{MIN}, \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| 112 | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| $I_{1 H}$ | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| loz | Off-State (High-Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2$. |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  |  | 22 | 37 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test conditions: $\mathrm{A}=\mathrm{B}=\overline{\mathrm{E}}=\mathrm{GND}: \mathrm{POL}=\overline{\mathrm{OE}}=4.5 \mathrm{~V}$.
5. $V_{O L}$ is specified with total device $l_{\mathrm{OL}}=60 \mathrm{~mA}$ (max).

SWITCHING CHARACTERISTICS ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {PLH }}$ | A, B to $Y_{i}$ | $\begin{gathered} C_{L}=15 \mathrm{pF} \\ R_{L}=2.0 \mathrm{k} \Omega \end{gathered}$ |  | 22 | 33 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$. |  |  |  | 17 | 25 |  |
| ${ }_{\text {tPLH }}$ | $\bar{E}$ to $Y_{i}$ |  |  | 19 | 28 | ns |
| tphL |  |  |  | 21 | 31 |  |
| tplH | POL to $Y_{i}$ |  |  | 16 | 24 | ns |
| $\mathrm{t}_{\text {PHL }}$ |  |  |  | 19 | 28 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | 15 | 23 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 15 | 22 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 19 | 28 | ns |
| $t{ }_{L}$ |  |  |  | 23 | 34 |  |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | CO | AL |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS2539 |  | Am25LS2539 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tplH | A, B, to $\mathrm{Y}_{\mathrm{i}}$ | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 41 |  | 48 | ns |
| tpHL |  |  |  | 34 |  | 42 |  |
| tplH | $\overline{\mathrm{E}}$ to $\mathrm{Y}_{\mathrm{i}}$ |  |  | 34 |  | 40 | ns |
| tpHL |  |  |  | 38 |  | 45 |  |
| tplH | POL to $Y_{i}$ |  |  | 29 |  | 34 | ns |
| tpHL |  |  |  | 39 |  | 49 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | 38 |  | 45 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  | 24 |  | 25 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $Y_{i}$ | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | 33 |  | 37 | ns |
| tLz |  |  |  | 36 |  | 37 |  |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

Am25LS2539•Am54LS/74LS LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## Am25LS2548

Chip Select Address Decoder with Acknowledge

## DISTINCTIVE CHARACTERISTICS

- One-of-Eight Decoder provides eight chip select outputs
- Acknowledge output responds to enables and read or write command
- Open-collector Acknowledge output for wired-OR application
- Inverting and non-inverting enable inputs for upper address decoding


## GENERAL DESCRIPTION

The Am25LS2548 Address Decoder combines a three-line to eight-line decoder with four qualifying enable inputs (two active HIGH and two active LOW) and the acknowledge output required for "ready" or 'wait state"' control of all popular MOS microprocessors.

The acknowledge output, $\overline{\mathrm{ACK}}$, is active LOW and responds to the combination of all enables active and a read $(\overline{\mathrm{RD}})$ or write $(\overline{\mathrm{WR}})$ input command.

The eight chip select outputs are individually active LOW in response to the combination of all enables active and the corresponding 3 -bit input code at inputs $\mathrm{A}, \mathrm{B}$, and C .

The Am25LS2548 is intended for chip select decoding in small, medium or large systems where multiple chip selects must be generated and address space must be allocated conservatively.

## BLOCK DIAGRAM



RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25LS2536 | 8-Bit Decoder |
| Am25LS2537 | 1-of-10 Decoder |
| Am25LS2538 | 1-of-8 Decoder |
| Am25LS2539 | Dual 1-of-4 Decoder |
| Am2921 | 1-of-8 Decoder |
| Am2924 | 3-to-8 Line Decoder/Demultiplexer |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| Am25LS2548 | PC |
|  | DC, DM |
|  | FM, LM |
|  | LC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
| 6, 7, 17 | A, B, C | 1 | Three-line to eight-line chip select decoder inputs. |
| 16, 15 | $\bar{E}_{1}, \bar{E}_{2}$ | 1 | The active LOW enable inputs. A HIGH on either the $\overline{\mathrm{E}}_{1}$ or $\overline{\mathrm{E}}_{2}$ input forces all decoded functions to be disabled, and forces $\overline{A C K}$ HIGH. |
| 14, 13 | $E_{3}, E_{4}$ | 1 | The active HIGH enable inputs. A LOW on either the $\mathrm{E}_{3}$ or $\mathrm{E}_{4}$ input forces all the decoded functions to be inhibited, and forces $\overline{A C K}$ HIGH. |
| 4,5 | $\overline{\mathrm{WR}}, \overline{\mathrm{RD}}$ | 1 | The write input, $\bar{W} \bar{R}$, and read input, $\overline{\mathrm{RD}}$, are active LOW inputs used as conditions for an active LOW output at the acknowledge, $\overline{A C K}$, output. |
| 3 | $\overline{\text { ACK }}$ | 0 | The acknowledge output, $\overline{A C K}$, is an active LOW output used to signal the microprocessor that specific devices have been selected. $\overline{A C K}$ goes LOW only when $\bar{E}_{1}$ and $\bar{E}_{2}$ are LOW, $E_{3}$ and $E_{4}$ are HIGH and WR or $\overline{R D}$ is LOW. |
|  | $\bar{Y}_{i}$ | 0 | The eight active LOW chip select outputs. |

## FUNCTION TABLES

CHIP SELECT OUTPUTS $\mathbf{Y}_{\mathbf{i}}$

| C | B | A | $\bar{E}_{\mathbf{1}}$ | $\bar{E}_{\mathbf{2}}$ | $\mathbf{E}_{\mathbf{3}}$ | $\mathbf{E}_{\mathbf{4}}$ | $\overline{\mathbf{Y}}_{\mathbf{0}}$ | $\overline{\mathbf{Y}}_{\mathbf{1}}$ | $\overline{\mathbf{Y}}_{\mathbf{2}}$ | $\overline{\mathbf{Y}}_{\mathbf{3}}$ | $\overline{\mathbf{Y}}_{\mathbf{4}}$ | $\overline{\mathbf{Y}}_{\mathbf{5}}$ | $\overline{\mathbf{Y}}_{\mathbf{6}}$ | $\overline{\mathbf{Y}}_{\mathbf{7}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | L | L | H | H | L | H | H | H | H | H | H | H |
| L | L | H | L | L | H | H | H | L | H | H | H | H | H | H |
| L | H | L | L | L | H | H | H | H | L | H | H | H | H | H |
| L | H | H | L | L | H | H | H | H | H | L | H | H | H | H |
| H | L | H | L | L | H | H | H | H | H | H | H | L | H | H |
| H | H | L | L | L | H | H | H | L | H | H |  |  |  |  |
| H | H | H | L | L | H | H | H | H | H | H | H | H | L | H |
| X | X | X | H | X | X | X | H | H | H | H | H | H | H | H |
| X | X | X | X | H | X | X | H | H | H | H | H | H | H | H |
| X | X | X | X | X | L | X | H | H | H | H | H | H | H | H |
|  | X | L | H | H | H | H | H | H | H | H |  |  |  |  |

ACKNOWLEDGE OUTPUT $\overline{\text { ACK }}$

| $\mathrm{E}_{1}$ | $\bar{E}_{2}$ | $E_{3}$ | $E_{4}$ | $\overline{\mathbf{R D}}$ | $\overline{W R}$ | $\overline{\text { ACK }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | X | X | X | X | H |
| X | H | X | X | x | X | H |
| X | X | L | X | X | X | H |
| X | X | X | L | X | X | H |
| L | L | H | H | L | X | L |
| L | L | H | H | X | L | L |



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$
Ambient Temperature Under Bias ......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$
DC Input Voltage $\qquad$ .-0.5 V to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current .............................-30mA to +5.0mA
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature .$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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}=-440 \mu \mathrm{~A}$ |  | 2.4 | 3.4 |  | Volts |
| VOL | Output LOW Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } V_{\mathbb{I L}} \end{aligned}$ | $\mathrm{OLL}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{lOL}=8$. |  |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{H}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 | Volts |
|  |  |  |  | COM'L |  |  | 0.8 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| 1 H | Input HIGH Current | $V_{C C}=M A X, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 15 | 20 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test conditions: $A=B=C=\bar{E}_{1}=E_{2}=G N D: R D=W R=E_{3}=E_{4}=4.5 \mathrm{~V}$.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | A, B or C to $\bar{Y}_{i}$ (Three Level Delay) | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 14 | 20 | ns |
| $\mathrm{tPHL}^{\text {P }}$ |  |  |  | 19 | 27 | ns |
| tPLH | A, B, or $C$ to $\bar{Y}_{i}$ (Two Level Delay) |  |  | 13 | 18 | ns |
| tPHL |  |  |  | 15 | 21 | ns |
| tPLH | $\bar{E}_{1}, \bar{E}_{2}$ to $\bar{Y}_{i}$ |  |  | 13 | 18 | ns |
| tPHL |  |  |  | 16 | 23 | ns |
| tPLH | $E_{3}, E_{4}$ to $\bar{Y}_{i}$ |  |  | 15 | 21 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 19 | 27 | ns |
| tplH | $\overline{\mathrm{WR}}, \overline{\mathrm{RD}}$ to $\overline{\mathrm{ACK}}$ |  |  | 25 | 35 | ns |
| tpHL |  |  |  | 16 | 22 | ns |
| tplH | $E_{1}, \bar{E}_{2}$ to $\overline{A C K}$ |  |  | 29 | 40 | ns |
| tPHL |  |  |  | 25 | 35 | ns |
| tPLH | $E_{3}, E_{4}$ to $\overline{A C K}$ |  |  | 29 | 40 | ns |
| tPHL |  |  |  | 25 | 35 | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | CO | AL |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25LS2548 |  | Am25LS2548 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | A, B or $C$ to $Y_{i}$ (Three Level Delay) | $\begin{aligned} & C_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 27 |  | 30 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 34 |  | 36 | ns |
| tpLH | A, B or $C$ to $Y_{i}$ (Two Level Delay) |  |  | 23 |  | 25 | ns |
| tPHL |  |  |  | 28 |  | 31 | ns |
| tpLH | $\bar{E}_{1}, \bar{E}_{2}$ to $\bar{Y}_{i}$ |  |  | 23 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 29 |  | 31 | ns |
| tPLH | $E_{3}, E_{4}$ to $\bar{Y}_{i}$ |  |  | 27 |  | 28 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ |  |  |  | 34 |  | 36 | ns |
| tplh | $\overline{W R}, \overline{R D}$ to $\overline{A C K}$ |  |  | 45 |  | 45 | ns |
| $\mathrm{tPHL}^{\text {Pr }}$ |  |  |  | 31 |  | 35 | ns |
| $\mathrm{t}_{\text {PLH }}$ | $\bar{E}_{1}, \mathrm{E}_{2}$ to $\overline{A C K}$ |  |  | 45 |  | 45 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 39 |  | 40 | ns |
| tple | $E_{3}, E_{4}$ to $\overline{A C K}$ |  |  | 45 |  | 45 |  |
| tPHL |  |  |  | 39 |  | 40 | ns |

Am25LS2548
LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS


Note: Actual current flow direction shown.

## DISTINCTIVE CHARACTERISTICS

- Multiplies two 8 -bit numbers - 16-bit output
- Combinatorial - no clocks required
- Full $8 \times 8$ multiply in 45 ns typ.
- Cascades to $16 \times 16$ in 110 ns typ.
- Expandable to multiples of 8 bits
- MSB and MSB outputs for easy expansion
- Unsigned, two's complement or mixed operands
- Implements common rounding algorithms with additional logic
- Three-state outputs
- Transparent 16-bit latch in Am25S557
- Industry standard pin-outs


## GENERAL DESCRIPTION

The Am25S557 and Am25S558 are high-speed, combinatorial, $8 \times 8$-bit multipliers. Both use an array of full adders to form and add partial products in a single unclocked operation, resulting in a 16-bit parallel output product.

Mode control inputs $X_{M}$ and $Y_{M}$ allow the multiplier to accept either unsigned or two's complement numbers fromeither respective input to provide an unsigned or signed output. The mode control lines are held LOW for unsigned input words and HIGH for two's complement.

The Am25S557 and Am25S558 are easily expandable to longer work lengths. Both $\mathrm{S}_{15}$ and $\overline{\mathrm{S}}_{15}$ are available to allow expansion in either signed or unsigned modes without external inverters. In the 16-bit by 16-bit configuration (32bit output) the typical multiply time is 110 ns .

Both configurations offer three-state output flexibility and the Am25S557 adds a 16-bit transparent latch between the multiplier array and the three-state output buffers (including $\bar{S}_{15}$ ).

Rounding provisions for 8 -bit truncated output configurations are particularly optimized for maximum flexibility. The Am25S557 internally develops proper rounding for either signed or unsigned numbers by combining rounding input $R$ with $X_{M}, Y_{M}, \bar{X}_{M}$ and $\bar{Y}_{M}$ as follows:
$R_{U}=\bar{X}_{M} \cdot \bar{Y}_{M} \cdot R=$ Unsigned Rounding input to $2^{7}$ adder.

$$
R_{S}=\left(X_{M}+Y_{M}\right) R=\text { Signed Rounding input to } 2^{6} \text { adder. }
$$

Since the Am25S558 does not require the use of pin 9 for the latch enable input, ( $G$ ), $R_{S}$ and $R_{U}$ are brought out separately.

## BLOCK DIAGRAM



BD001780
*Pin 11 is $G$ for Am25S557 and $R_{U}$ for Am25S558.



MODE CONTROL INPUTS

| Operating <br> Mode | Input Data |  | Mode <br> Control |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathrm{X}_{\mathbf{0}}-\mathrm{X}_{\mathbf{7}}$ | $\mathrm{Y}_{\mathbf{0}}-\mathrm{Y}_{\mathbf{7}}$ | $\mathrm{X}_{\mathrm{M}}$ | $\mathrm{Y}_{\mathbf{M}}$ |
|  | UNSIGNED | UNSIGNED | L | L |
| MIXED | UNSIGNED | 2's COMP | L | H |
|  | 2's COMP | UNSIGNED | H | L |
| SIGNED | 2's COMP | 2's COMP | H | H |

ROUNDING INPUTS
Am25S557

| Inputs |  |  | Adds |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{X}_{\mathbf{M}}$ | $\mathbf{Y}_{\mathbf{M}}$ | $\mathbf{R}$ | $\mathbf{2}^{\mathbf{7}}$ | $\mathbf{2}^{\mathbf{6}}$ |
| L | L | H | YES | NO |
| L | H | H | NO | YES |
| $H$ | L | H | NO | YES |
| $H$ | $H$ | $H$ | NO | YES |
| $X$ | $X$ | $L$ | NO | NO |

## Am25S558

| Inputs |  | Adds |  | Normally Used With |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{R u}_{\mathbf{U}}$ | $\mathbf{R}_{\mathbf{S}}$ | $\mathbf{2}^{\mathbf{7}}$ | $\mathbf{2}^{\mathbf{6}}$ | $\mathbf{X}_{\mathbf{M}}$ | $\mathbf{Y}_{\mathbf{M}}$ |
| L | L | NO | NO | X | $\mathbf{X}$ |
| L | H | NO | YES | $\mathrm{X}_{\mathrm{M}}+\mathrm{Y}_{\mathbf{M}}=\mathrm{H}$ |  |
| H | L | YES | NO | L | L |
| H | H | YES | YES | $*$ | $*$ |

* Most rounding applications require a HIGH level for RU or RS, but not both.

I/O MAPPED INTERFACE
WITH MOS MICROPROCESSOR


AF001270


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ........................ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature Under Bias......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State
-0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$
DC Input Voltage .0 .5 V to +5.5 V
DC Output Current, Into Outputs ........................... 30mA
DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } \\ & V_{I L} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{IL}}=0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=2.0 \mathrm{~V} \end{aligned}$ | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ | 2.4 | 3.0 |  | Volts |
| VOL | Output LOW Voltage | $\begin{aligned} & \hline V_{C C}=M I N \\ & V_{I N}=V_{I H} \text { or } \\ & V_{I L} \\ & \hline \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{IL}} & =0.8 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IH}} & =2.0 \mathrm{~V} \\ \mathrm{lOL} & =8.0 \mathrm{~mA} \end{aligned}$ |  |  | 0.3 | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
|  |  | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.8 | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level |  |  | COM'L |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IIN}^{\text {a }}$ = -18 mA |  |  |  |  | -1.5 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.5 \mathrm{~V}$ |  |  |  |  | -1.0 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| 11 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1} \mathrm{~N}=5.5 \mathrm{~V}$ |  |  |  |  | 1 | mA |
| lo | Off State (High Impedance) Output Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | +100 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=$ MAX |  |  | -20 |  | -90 | mA |
| ICC | Power Supply Current (Note 4) | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  |  |  | 280 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Test with pin 21 at 4.5 V , all other input pins at GND, all outputs open Am25S557 conditions the same except initialize with G (pin 11) at 4.5 V , then GND.


| Test | $\mathrm{V}_{\mathrm{x}}$ | Output Waveform - Measurement Level |
| :---: | :---: | :---: |
| All tPD | 5.0 V |  |
| $t_{\text {PHZ }}$ | 0.0 V |  |
| ${ }_{\text {t PLZ }}$ | 5.0 V |  |
| ${ }_{\text {tPZ }}$ | 0.0 V |  |
| ${ }_{\text {tpzL }}$ | 5.0 V |  |

WF002350
$\mathrm{C}_{\mathrm{L}}$ Includes probe and jig capacitance.

## SET-UP AND HOLD TIMES

PULSE WIDTH


Notes:1. Diagram shown for HIGH data only. Output transition may be opposite sense.
2. Cross hatched area is don't care condition.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description | Test Conditions | COMMERCIAL <br> Am25S557 |  |  | $\frac{\text { MILITARY }}{\text { Am25S557 }}$ |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| tpD | $X_{i}, Y_{i}$ to $S_{0}$ to $S_{7}$ | $\begin{gathered} C_{L}=30 \mathrm{pF} \\ R_{L}=560 \Omega \\ \text { (See test figures) } \end{gathered}$ |  | 45 | 60 |  | 55 | 70 | ns |
| tPD | $X_{i}, Y_{i}$ to $S_{8}$ to $S_{15}$ or $\bar{S}_{15}$ |  |  | 50 | 80 |  | 60 | 90 | ns |
| $t_{s}$ | $X_{i}, Y_{i}$ to $G$ Set-up Time |  | 65 |  |  | 75 |  |  | ns |
| $t_{h}$ | $X_{i}, Y_{i}$ to $G$ Hold Time |  | -5 |  |  | -5 |  |  | ns |
| tPD | $G$ to $S_{1}$ |  |  | 30 | 45 |  | 30 | 50 | ns |
| tpW | Latch Enable Pulse Width |  | 25 | 15 |  | 30 | 15 |  | ns |
| tphz | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{0}$ to $\mathrm{S}_{15}$ |  |  | 15 | 30 |  | 15 | 40 | ns |
| tphZ | $\overline{\mathrm{OE}}$ to $\overline{\mathrm{S}}_{15}$ |  |  | 25 | 40 |  | 25 | 50 | ns |
| tpLZ | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 15 | 30 |  | 15 | 40 | ns |
| tpZH | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 20 | 35 |  | 20 | 40 | ns |
| tPZL | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 20 | 35 |  | 20 | 40 | ns |

[^22]| Parameters | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am25S558 |  |  | Am25S558 |  |  |  |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| tPD | $X_{1}, Y_{1}$ to $S_{0}$ to $S_{7}$ | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ <br> $R_{L}=580 \Omega$ <br> (See test figures) |  | 35 | 55 |  | 35 | 65 | ns |
| tPD | $\mathrm{X}_{1}, \mathrm{Y}_{1}$ to $\mathrm{S}_{0}$ to $\mathrm{S}_{15}$ or $\bar{S}_{15}$ |  |  | 55 | 75 |  | 55 | 85 | ns |
| tpHz | $\overline{O E}$ to $\mathrm{S}_{0}$ to $\mathrm{S}_{15}$ |  |  | 15 | 30 |  | 15 | 40 | ns |
| tpHz | $\overline{\mathrm{O}}$ to $\bar{S}_{15}$ |  |  | 25 | 40 |  | 25 | 50 | ns |
| tplz | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 15 | 30 |  | 15 | 40 | ns |
| tpZH | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 20 | 35 |  | 20 | 40 | ns |
| tpzL | $\overline{\mathrm{OE}}$ to $\mathrm{S}_{1}$ |  |  | 20 | 35 |  | 20 | 40 | ns |

*AC performance over the operatíng temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am25S557/Am25S558

 INPUT/OUTPUT CURRENT INTERFACE CONDITIONS

IC000380

RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am29516/7 | 16 by 16-Bit Multiplier |
| Am25S05 | 4 by 2-Bit Multiplier |
| Am25LS14A | 8 -Bit Serial/Parallel Multiplier |

# Am25LS2568/Am25LS2569 

## Four-Bit Up/Down Counters with Three-State Outputs

## DISTINCTIVE CHARACTERISTICS

- 4-bit synchronous counter, synchronously programmable
- Both synchronous and asynchronous clear inputs
- Three-state counter outputs interface directly with bus organized systems
- Internal look-ahead carry logic and two count enable lines for high speed cascaded operation
- Ripple carry output for cascading
- Clock carry output for convenient modulo configuration
- Fully buffered outputs
- Second sourced as the 54LS/74LS568 and LS569
- Advanced Low-Power Schottky technology


## GENERAL DESCRIPTION

The Am25LS2568 and Am25LS2569 are programmable up/down BCD and Binary counters respectively with threestate outputs for bus organized systems. All functions except output enable ( $\overline{\mathrm{OE}}$ ) and asynchronous clear ( $\overline{\mathrm{ACLR}}$ ) occur on the positive edge of the clock input (CP).

With the $\overline{\text { LOAD input LOW, the outputs will be programmed }}$ by the parallel data inputs ( $A, B, C, D$ ) on the next clock edge. Counting is enabled only when $\overline{\mathrm{CEP}}$ and $\overline{\mathrm{CET}}$ are LOW and LOAD is HIGH. The up-down input (U/D) controls the direction of count, HIGH counts up and LOW counts down. Internal look-ahead carry logic and an active LOW ripple carry output ( $\overline{\mathrm{RCO}}$ ) allows for high-speed counting
and cascading. During up-count, the $\overline{\mathrm{RCO}}$ is LOW at binary 9 for the LS2568 (binary 15 for the LS2569) and upon down-count, it is LOW at binary 0. Normal cascaded operations require only the $\overline{\mathrm{RCO}}$ to be connected to the succeeding block at CET. When counting, the clocked carry output (CCO) provides a HIGH-LOW-HIGH pulse for a duration equal to the LOW time of the clock pulse and only when $\overline{\mathrm{RCO}}$ is LOW. Two active LOW reset lines are available, synchronous clear ( $\overline{\mathrm{SCLR}}$ ) and a master reset asynchronous clear ( $\overline{\mathrm{ACLR}})$. The output control ( $\overline{\mathrm{OE}}$ ) input forces the counter output into the high-impedance state when HIGH and when LOW, the counter outputs are enabled.

BLOCK DIAGRAM


Am25LS2569 (BINARY)


## CONNECTION DIAGRAM Top View

D-20-1


CD001640


CD001650

Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am25LS2568/69
 $\stackrel{B}{L}$ Screening Option Blank - Standard processing B - Burn-in

- Temperature (See Operating Range) C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ $\mathrm{M}-$ Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-20-pin CERDIP
F-20-pin flatpak
L-20-pin leadless chip carrier
P-20-pin plastic DIP
X-Dice
Device type
BCD and Binary Counters

| Valid Combinations |  |
| :--- | :--- |
|  | DC, DCB, DM, |
| Am25LS2568// | DMB |
| FM, FMB |  |
| Am25LS2569 | LC, LM, LMB |
|  | PC, PCB |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

| PIN DESCRIPTION |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin No. | Name | 1/0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3, 4, 5, 6 | A, B, C, D | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 | CEP | 1 |  | Count Enable Parallel. Can be used to enable and inhibit counting in high speed cascaded operation. $\overline{\mathrm{CEP}}$ must be LOW to count. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12 | CET | 1 |  | Clock Pulse. All synchronous functions occur on the LOW-to-HIGH transition of the clock. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 | CP | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11 | LOAD | 1 |  | Enables parallel load of counter outputs from data inputs on the next clock edge. Must be HIGH to count. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | U/ $\bar{D}$ | 1 |  | Up/Down Count Control. HIGH counts up and LOW counts down. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 | $\overline{\text { ACLR }}$ | 1 |  | Asynchronous Clear. Master reset of counters to zero when $\overline{\text { ACLR }}$ is LOW, independent of the clock. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 | $\overline{\text { SCLR }}$ | 1 |  | Synchronous clear of counters to zero on the next clock edge when SCLR is LOW. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 | $\overline{\mathrm{OE}}$ | 1 |  | The four counter outputs. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & 16,15 \\ & 14,13 \\ & \hline \end{aligned}$ | $\begin{aligned} & Y_{A}, Y_{B}, \\ & Y_{C}, Y_{D} \end{aligned}$ | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 | $\overline{\mathrm{RCO}}$ | 0 |  | Ripple Carry Output. Output will be LOW on the maximum count on up-count. Upon down-count, $\overline{\mathrm{RCO}}$ is LOW Clock Carry Output. While counting and $\overline{\text { RCO }}$ is LOW, CCO will follow the clock HIGH-LOW-HIGH tra |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 | CCO | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Am25LS2568/2569 FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | INPUTS |  |  |  |  |  |  |  |  |  |  |  | UTPUTS |  |  |  |  |  |
| MODE | LOAD | CEP | CET | U/D | ASYNC CLEAR | SYNC CLEAR | $\overline{O E}(1)$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{3}$ | CP | $\mathbf{Q}_{0}$ | $Q_{1}$ | $\mathbf{Q}_{2}$ | $\mathbf{Q}_{3}$ | RC | CLOCK CARR |
| Clear (ASYNC) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline x \\ & X \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 0 | $\begin{aligned} & 0 \\ & 0 \\ & \hline \end{aligned}$ | 0 | 1 | $\square^{1}(2)$ |
| Clear <br> (SYNC) | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \end{aligned}$ | $\begin{aligned} & \hline \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\dagger$ | 0 | 0 | 0 | 0 0 | 1 | $\square^{1}(2)$ |
| Load | $\begin{aligned} & \hline 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline x \\ & \mathrm{x} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline x \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ |  |  |  | $\begin{gathered} \hline X \\ 0 \\ 1(3) \\ \hline \end{gathered}$ | $\dagger$ |  |  |  |  | 1 0 0 | $\begin{aligned} & { }^{1}(2) \\ & 丂^{5}(2) \end{aligned}$ |
| Count Up | 1 | 0 | 0 | 1 | 1 | 1 | 0 | X | X | X | X | $\dagger$ |  |  |  |  | (4) | 5) |
| Count Down | 1 | 0 | 0 | 0 | 1 | 1 | 0 | X | X | X | X | $\dagger$ |  |  |  |  | (6) | (5) |
| Inhibit | 1 1 1 | 0 <br> 1 <br> 1 | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | x <br> x <br> x | 1 1 1 | 1 <br> 1 <br> 1 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ |  |  |  |  | $\dagger$ |  |  |  |  | N.C. N.C. N.C. | 1 1 1 |
| Output Disable | X | X | X | X | X | X | 1 | X | X | X | X | X | z | Z | Z | Z | N.C. | N.C. |
| $\dagger=$ CLOCK LOW-to-HIGH transition <br> $Q_{n+1}=$ Next higher count in binary sequence <br> X = Don't Care <br> $D_{n}=D_{0}$ thru $D_{3}$ input level prior to clock transition <br> $Q_{n-1}=$ Next lower count in binary sequence <br> N.C. $=$ No change <br> Notes: 1. Register performs all correct logic for any state of $\overline{O E}$, but $\overline{O E}=0$ to view outputs. <br> 2. Follows CLOCK if CET $=$ CEP $=0$, otherwise remains HIGH. <br> 3. 1001 for LS68. <br> 4. LOW for one full CLOCK cycle when maximum count is reached, otherwise remains HIGH. <br> 5. Follows CLOCK when $\mathrm{RC}=0$. <br> 6. LOW for one full CLOCK cycle when minimum count is reached, otherwise remains HIGH. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

2. Follows CLOCK if $\mathrm{CET}=\mathrm{CEP}=0$, otherwise remains HIGH
3. 1001 for LS68
4. LOW for one full CLOCK cycle when maximum count is reached, otherwise remains HIGH.
5. Follows CLOCK when $\mathrm{RC}=0$.
6. LOW for one full CLOCK cycle when minimum count is reached, otherwise remains HIGH.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous $\qquad$ .-0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$ . -0.5 V to $+\mathrm{V}_{\mathrm{Cc}}$ max DC Input Voltage..................................-0.5V to + 7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current ..............................-30mA to +5.0 mA

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

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 device reliability.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test | Conditions (Note 2) |  |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{I N}=V_{I H} \\ & \text { or } V_{I L} \end{aligned}$ | $Y_{i}$ | MIL, $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |  |  | 2.4 | 3.4 |  | Volts |
|  |  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  | 2.4 | 3.2 |  |  |
|  |  |  | $\begin{aligned} & \overline{\mathrm{RCO}}, \\ & \mathrm{CCO} \end{aligned}$ | $\mathrm{IOH}^{\prime}=-440 \mu \mathrm{~A}$ |  | MIL | 2.5 | 3.4 |  |  |
|  |  |  |  |  |  | COM'L | 2.7 | 3.4 |  |  |
| 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}=4.0 \mathrm{~mA}$ |  |  |  |  | 0.4 | Volts |
|  |  |  |  | $\mathrm{IOL}=8.0 \mathrm{~mA}$ |  |  |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs. |  |  | MIL |  |  |  | 0.7 | Volts |
|  |  |  |  |  | COM |  |  |  | 0.8 |  |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{IIN}=-18 \mathrm{~mA}$ |  |  |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=0.4 V \end{aligned}$ |  | $\overline{\text { ACLR }}$, $\overline{O E}, \mathrm{U} / \overline{\mathrm{D}}, \overline{\text { LOAD }}$ |  |  |  |  | -0.3 | mA |
|  |  |  |  | A, B, C, D, CP, CEP |  |  |  |  | -0.4 |  |
|  |  |  |  | $\overline{\mathrm{CET}}$, $\overline{\text { SCLR }}$ |  |  |  |  | -0.65 |  |
| 1 IH | Input HIGH Current | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=2.7 \mathrm{~V}$ |  |  |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{1 \mathrm{~N}}=7.0 \mathrm{~V}$ |  |  |  |  |  |  | 0.1 | mA |
|  | Off-State (High-Impedance) Output Current | $V_{C C}=\mathrm{MAX}$ |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  |  | -20 | $\mu \mathrm{A}$ |
| loz |  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  |  | 20 |  |
| Isc | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  |  |  | -15 |  | -85 | mA |
| Icc | Power Supply Current (Note 4) | $V_{C C}=$ MAX |  |  |  |  |  | 28 | 43 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. $\overline{\mathrm{O}}=\mathrm{HIGH}$, all other inputs $=\mathrm{GND}$, all outputs open.


Note 1. Per industry convention, $f_{m a x}$ is the worst case value of the maximum device operating frequency with no constraints on $t_{r}$, $t_{f}$, pulse width or duty cycle.



## Am26S and Am26LS Interface Family Index

Am26S02 Schottky Dual Retriggerable, Resettable Monostable Multivibrator ..... 10-1Am26S10/Am26S11Am26S12/Am26S12AAm26LS27/Am26LS28Am26LS29Am26LS30
Quad Bus Transceivers ..... 10-7
Quad Bus Transceivers ..... 10-15
Dual EIA RS-485 Party Line Transceivers ..... 10-19
Quad Three-State Single Ended RS-423 Line Driver ..... 10-20
Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver ..... 10-26
Am26LS31
Am26LS32/Am26LS33
Quad High Speed Differential Line Driver ..... 10-33
Quad Differential Line Receivers ..... 10-39
Am26LS32BAm26LS34Quad Differential Line Receiver10-42
Quad Differential Line Receiver ..... $10-46$
Am26LS38
Quad Differential Backplane Transceiver ..... 10-50

## DISTINCTIVE CHARACTERISTICS

- Advanced Schottky technology with PNP inputs
- Retriggerable $0 \%$ to $100 \%$ duty cycle
- 28 ns to $\infty$ output pulse width range
- $100 \mathrm{k} \Omega$ maximum timing resistor value
- Am26S02XM typical pulse width change of only $1.0 \%$ over $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ with $\mathrm{R}_{\mathrm{X}}=100 \mathrm{k} \Omega$
- Am26S02XC typical pulse width change of only $0.4 \%$ over $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ with $\mathrm{R}_{\mathrm{x}}=100 \mathrm{~K} \Omega$


## GENERAL DESCRIPTION

The Am26S02 is a dual DC level sensitive, retriggerable, resettable monostable multivibrator built using advanced Schottky technology. The output pulse duration and accuracy depend on the external timing components of each multivibrator. The Am26S02 features PNP inputs to reduce the input loading.

Provision is made on each multivibrator circuit for triggering the PNP inputs on either the rising or falling edge of an input signal by including an inverting and non-inverting trigger input. These PNP inputs are DC coupled making triggering independent of the input rise or fall time. Each time the monostable trigger input is activated from the OR
trigger gate, full pulse length triggering occurs independent of the present state of the monostable.

The direct clear PNP input allows a timing cycle to be terminated at any time during the cycle. A LOW on the clear input forces the $Q$ output LOW regardless of the $\bar{I}_{0}$ or $\bar{I}_{1}$ inputs.

The Am26S02XM has a typical pulse width change of only $1.0 \%$ over the full military $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range and the Am26S02XC has a typical pulse width change of only $0.4 \%$ over the commerical $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range with a $R_{x}=100 \mathrm{k} \Omega$.

SCHEMATIC DIAGRAM (One Monostable Multivibrator Shown)


## CONNECTION DIAGRAM

Top View


Note: Pin 1 is marked for orientation

## LOGIC SYMBOL


$\mathrm{V}_{\mathrm{CC}}=\operatorname{Pin} 16$
$\mathrm{GND}=\operatorname{Pin} 8$

METALLIZATION AND PAD LAYOUT


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am26S02


D-16-pin CERDIP
D-16-pin CERDIP
$\mathrm{F}-16$-pin flatpak P-16-pin plastic DIP X - Dice

## Device type

Schottky Dual Multivibrator
Package B - Burn-in


Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

- Screening Option

Blank - Standard processing

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


## OPERATION RULES (Cont.)

3. Pulse width change measurements.

The pulse width $t_{p w} Q$ is specified and measured with components of better than $0.1 \%$ accuracy. If measurements are made with reduced component tolerances, the expected accuracy should be adjusted accordingly. Note that pulse width temperature stability improves as $R_{x}$ increases.
4. Timing for $C_{x} \leqslant 1000 \mathrm{pF}$.

When using capacitor of less than or equal to 1000 pF in value, the output pulse width should be determined from the output pulse width versus external timing capacitance graph.
5. Timing for $C_{x}>1000 \mathrm{pF}$.

For capacitors of greater than 1000 pF in value, the output pulse width, $\mathrm{t}_{\mathrm{pw}} \mathrm{Q}$, is determined by:

$$
t_{p w} Q=0.30 C_{x} R_{x}\left(1+\frac{0.11}{R_{x}}\right)
$$

where
$\mathrm{R}_{\mathrm{X}}$ is in kilohms
$C_{x}$ is in picofarads
$t_{p w} Q$ is in nanoseconds


TC001030

$$
R_{1} \leqslant 0.6 \times R_{x} M A X .
$$



TC001020

$$
R_{2}<0.7 \times h_{\text {FEQ } 1} \times R_{x}
$$

## 6. Protection of electrolytic timing capacitors.

If the electrolytic capacitor to be used as $\mathrm{C}_{\mathrm{x}}$ cannot withstand 1.0 volt reverse bias, one of the two circuit techniques shown below should be used to protect the electrolytic capacitor from the reverse voltage. The accuracy of the pulse width may be dependent on the diode (transistor) characteristics.

The output pulse width, $\mathrm{t}_{\mathrm{pw}} \mathrm{Q}$ for the diode circuit modifies the previous timing equation as follows:

$$
t_{p w} Q=0.26 C_{x} R_{x}\left(1+\frac{0.13}{R_{x}}\right)
$$

The output pulse width for the transistor circuit is:

$$
t_{p w} Q=0.21 C_{x} R_{x}\left(1+\frac{0.16}{R_{x}}\right)
$$

Notice that the transistor circuit allows values of timing resistor $\mathrm{R}_{\mathbf{2}}$ larger than the $\mathrm{R}_{\mathrm{x}}$ MIN. $<\mathrm{R}_{\mathrm{x}}<\mathrm{R}_{\mathrm{x}}$ MAX. to obtain longer output pulse widths for a given $\mathrm{C}_{\mathrm{x}}$.

## TRIGGER AND RETRIGGER

## 1. Triggering.

The minimum pulse width signal into input $\bar{I}_{0}$ or input $\mathrm{I}_{1}$ to cause the device to trigger is 20 ns . Refer to the truth table for the appropriate input conditions.

## 2. Retriggering.

The retriggered pulse width, $\mathrm{t}_{\mathrm{pwr}} \mathrm{Q}$, is the time during which the output is active after the device is retriggered during a timing cycle. It differs from the initial pulse width $\mathrm{t}_{\mathrm{pw}} \mathrm{Q}$ timing equations as follows:

$$
t_{p w r} Q=t_{p w} Q+t_{p L H}
$$

where PLLH is the propagation delay time from the $\bar{I}_{0}$ or $I_{1}$ input to the output. Note that tPLH is typically 14 ns and therefore becomes relatively unimportant as $\mathrm{t}_{\mathrm{pw}} \mathrm{Q}$ increases.
3. Rapid retriggering.

A minimum retriggering time does exist. That is, the device cannot be retriggered until a minimum recovery time has elapsed. The minimum retrigger time is approximately:
$\mathrm{t}_{\text {retrig }} \mathrm{MIN} .=0.2 \mathrm{C}_{\mathrm{x}}$
C is in picofarads
$t$ is in nanoseconds


WF002460

## CLEAR

A LOW on the clear inputs terminates the timing cycle. A new trigger cycle cannot be initiated while the clear is LOW. With the clear HIGH, the device is under the command of the $l_{1}$ and $\mathrm{T}_{0}$ inputs.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ........................ $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous...............-0.5V to +7.0 V DC Voltage Applied to Outputs For
HIGH Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{Cc}} \max$
DC Input Voltage $\qquad$ -0.5 V to +5.5 V
DC Output Current, Into Outputs $\qquad$ .............. 30 mA DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-2 \mathrm{~mA} \\ & V_{I N}=V_{I H} \text { or } V_{\text {IL }} \\ & \hline \end{aligned}$ | 2.5 | 2.8 |  | Volts |
| VOL | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{IOL}=20 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \hline \end{aligned}$ |  | 0.38 | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs | 2.0 |  |  | Voits |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.4 | -1.2 | Volts |
| IIL (Note 3) | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.5 \mathrm{~V}$ |  | -0.15 | -0.4 | mA |
| $\mathrm{I}_{\mathrm{H}}$ (Note 3) | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  | 0.1 | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| Isc | Output Short Circuit Current (Note 4) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\text {Out }}=1.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \text { Only } \\ & \hline \end{aligned}$ | -8 | -15 | -35 | mA |
| İC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{l}_{1 \mathrm{X}}=0.33 \mathrm{~mA}$ (Notes $5 \& 6$ ) |  | 48 | 69 | mA |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN, or MAX, use the appropriate value specified under Electrical Characteristics for the applicable device type.
3. Actual input currents $=$ Unit Load $\times$ Input Load Factor (See Loading Rules).
4. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
5. ICC is measured with pin 5 and 11 grounded and $I_{X X}$ applied to pins 2 and 14.
6. $I_{X}$ is the current into the $R_{X} C_{X}$ node to simulate $R_{X}$.

## TYPICAL PERFORMANCE CURVES



OP001280

Normalized Output Pulse Width Versus Operating Duty Cycle


OP001320

Output Pulse Width Versus External Timing Capacitance


OP001260

Typical Normalized Output Pulse Width Versus Supply Voltage


OP001270

SWITCHING CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters |  | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpLH | $\bar{I}_{0}$ to Q |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}, \\ \mathrm{R}_{\mathrm{X}}=5 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{X}}=0 \mathrm{pF} \end{gathered}$ |  | 13 | 20 | ns |
| $\mathrm{t}_{\text {PHL }}$ | $\bar{I}_{0}$ to $\bar{Q}$ |  |  |  | 15 | 23 | ns |
| tplH | $l_{1}$ to Q |  |  |  | 12 | 20 | ns |
| tPHL | $I_{1}$ to $\bar{Q}$ |  |  |  | 12 | 20 | ns |
| tplh | Clear to $\overline{\mathrm{Q}}$ |  |  |  | 21 |  | ns |
| tPHL | Clear to Q |  |  |  | 9 | 13 | ns |
| ${ }^{\text {tpw }}$ | Pulse Width | To HIGH or $l_{1}$ LOW |  | 20 | 10 |  | ns |
|  |  | $\bar{I}_{0}$ LOW to $\mathrm{I}_{1} \mathrm{HIGH}$ |  | 16 | 7 |  | ns |
|  |  | Clear LOW |  | 24 | 16 |  | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Clear Recovery (inactive) to Trigger |  |  | -10 | -22 |  | ns |
| tow (Min) | Minimum Pulse Width Q Output |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{R}_{\mathrm{X}}=5.0 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{X}}=0 \mathrm{pF} \\ R_{\mathrm{L}}=1.0 \mathrm{k} \Omega \end{gathered}$ | 27 | 33 | 39 | ns |
| ${ }^{\text {tpw }}$ Q | Pulse Width Q Output |  | $\begin{gathered} V_{C C}=5.0 \mathrm{~V}, R_{L}=280 \Omega, C_{L}=15 \mathrm{pF} \\ R_{X}=10 \mathrm{k} \Omega, C_{X}=1000 \mathrm{pF} \text { (CK05 Type) } \end{gathered}$ | 3.23 | 3.42 | 3.61 | $\mu \mathrm{s}$ |
| $\mathrm{R}_{\mathrm{X}}$ | Timing Resistor |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | 5 |  | 100 | k $\Omega$ |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 5 |  | 50 |  |

## Am26S10/Am26S11

Quad Bus Transceivers

## DISTINCTIVE CHARACTERISTICS

- Input to bus is inverting on Am26S10
- Input to bus is non-inverting on Am26S11
- Quad high-speed open collector bus transceivers
- Driver outputs can sink 100 mA at 0.8 V maximum
- Bus compatible with Am2905, Am2906, Am2907
- Advanced Schottky processing
- PNP inputs to reduce input loading


## GENERAL DESCRIPTION

The Am26S10 and Am26S11 are quad Bus Transceivers consisting of four high-speed bus drivers with open-collector outputs capable of sinking 100 mA at 0.8 volts and four high-speed bus receivers. Each driver output is connected internally to the high-speed bus receiver in addition to being connected to the package pin. The receiver has a Schottky TTL output capable of driving ten Schottky TTL unit loads.

An active LOW enable gate controls the four drivers so that outputs of different device drivers can be connected together for party-line operation. The enable input can be conveniently driven by active LOW decoders such as the Am25LS139.

The bus output high-drive capability in the LOW state allows party-line operation with a line impedance as low as $100 \Omega$. The line can be terminated at both ends, and still give considerable noise margin at the receiver. The receiver typical switching point is 2.0 volts.

The Am26S10 and Am26S11 feature advanced Schottky processing to minimize propagation delay. The device package also has two ground pins to improve ground current handling and allow close decoupling between $\mathrm{V}_{\mathrm{cc}}$ and ground at the package. Both $\mathrm{GND}_{1}$ and $\mathrm{GND}_{2}$ should be tied to the ground bus external to the device package.

## BLOCK DIAGRAM



| Part No. | Description |
| :--- | :--- |
| 26S12 | Quad Bus Transceiver |
| 26S12A | Quad Bus Transceiver |
| 2915A | Quad Three-State Bus Transceiver with Interface Logic |
| 2916A | Quad Three-State Bus Transceiver with Interface Logic |
| 2917A | Quad Three-State Bus Transceiver with Interface Logic |



Note: Pin 1 is marked for orientation


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am26S10/11


Package
D- 16-pin CERDIP
F-16-pin flatpak P - 16-pin plastic DIP X-Dice

Device type
Quad Bus Transceivers
 B - Burn-in

Package
$L^{\text {B }}$ Screening Option
Blank - Standard processing
Temperature (See Operating Range)
C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am26S10 | DC, DM |
| Am26S11 | FM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


Am26S10

| Inputs |  | Outputs |  |
| :---: | :---: | :---: | :---: |
| $\bar{E}$ | I | $\bar{B}$ | $\mathbf{Z}$ |
| L | L | H | L |
| L | H | L | H |
| $\mathbf{H}$ | X | Y | $\bar{Y}$ |

H = HIGH Voltage Level $Y=V$ lage Leve

TYPICAL APPLICATION


10052 PARTY LINE OPERATION.

Am26S11

| Inputs |  | Outputs |  |
| :---: | :---: | :---: | :---: |
| $\bar{E}$ | $\bar{T}$ | $\bar{B}$ | $\mathbf{Z}$ |
| L | L | L | $H$ |
| L | $H$ | $H$ | L |
| $H$ | $X$ | $Y$ | $\bar{Y}$ |

L = LOW Voltage Leve!
$X=$ Don't Care
her Bus Transceiver)

AF001020

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature Under Bias......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential Continuous $\qquad$ DC Voltage Applied to Outputs For High Output State $\qquad$ DC Input Voltage. $\qquad$ $\ldots . . . . . .-0.5 \mathrm{~V}$ to $+\mathrm{V}_{\mathrm{CC}} \max$ .......................... 0.5 V to +5.5 V
DC Output Current, Into Bus $\qquad$
DC Output Current, Into Outputs
(Except Bus) $\qquad$ 200 mA

DC Input Current $\qquad$ -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) |  | Min | $\begin{aligned} & \text { Typ } \\ & \text { (Note 1) } \end{aligned}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage (Receiver Outputs) | $\begin{aligned} & V_{C C}=M I N, I_{O H}=-1.0 \mathrm{~mA} \\ & V_{I N}=V_{I L} \text { or } V_{I H} \end{aligned}$ | MIL | 2.5 | 3.4 |  | Volts |
|  |  |  | COM'L | 2.7 | 3.4 |  |  |
| Vol | Output LOW Voltage (Receiver Outputs) | $\begin{aligned} & V_{G C}=\mathrm{MIN}, \mathrm{IOL}_{2}=20 \mathrm{~mA} \\ & V_{\text {IN }}=V_{I L} \text { or } V_{\text {IH }} \end{aligned}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level (Except Bus) | Guaranteed input logical HIGH for all inputs |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level (Except Bus) | Guaranteed input logical LOW for all inputs |  |  |  | 0.8 | Volts |
| $v_{1}$ | Input Clamp Voltage (Except Bus) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current (Except Bus) | $V_{C C}=M A X, V_{I N}=0.4 \mathrm{~V}$ | Enable |  |  | -0.36 | mA |
|  |  |  | Data |  |  | -0.54 |  |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current (Except Bus) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ | Enable |  |  | 20 | $\mu \mathrm{A}$ |
|  |  |  | Data |  |  | 30 |  |
| 1 | Input HIGH Current (Except Bus) | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current (Except Bus) | $\mathrm{V}_{\text {cC }}=\mathrm{MAX}$ ( Note 3) | MIL | -20 |  | -55 | mA |
|  |  |  | COM'L | -18 |  | -60 |  |
| ICCL | Power Supply Current (All Bus Outputs LOW) | $\begin{aligned} & V_{C C}=M A X \\ & \text { Enable }=\text { GND } \end{aligned}$ | Am26S10 |  | 45 | 70 | mA |
|  |  |  | Am26S11 |  |  | 80 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Electrical Characteristics for the applicable device
2. type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

Bus Input/Output Characteristics

| Parameters | Description | Test Conditions (Note 2) |  |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOL | Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ | MIL. | $\mathrm{lOL}=40 \mathrm{~mA}$ |  | 0.33 | 0.5 | Volts |
|  |  |  |  | $\mathrm{IOL}=70 \mathrm{~mA}$ |  | 0.42 | 0.7 |  |
|  |  |  |  | $\mathrm{l} \mathrm{OL}=100 \mathrm{~mA}$ |  | 0.51 | 0.8 |  |
|  |  |  | COM'L | $\mathrm{IOL}^{\text {a }}=40 \mathrm{~mA}$ |  | 0.33 | 0.5 |  |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=70 \mathrm{~mA}$ |  | 0.42 | 0.7 |  |
|  |  |  |  | $\mathrm{l}_{\mathrm{OL}}=100 \mathrm{~mA}$ |  | 0.51 | 0.8 |  |
| 10 | Bus Leakage Current | $V_{C C}=M A X$ |  | $\mathrm{V}_{\mathrm{O}}=0.8 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
|  |  |  | MIL | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 200 |  |
|  |  |  | COM'L | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  | 100 |  |
| loff | Bus Leakage Current (Power Off) | $\mathrm{V}_{\mathrm{O}}=4.5 \mathrm{~V}$ |  |  |  |  | 100 | $\mu \mathrm{A}$ |
| $V_{\text {TH }}$ | Receiver Input HIGH Threshold | $\begin{aligned} & \text { Bus Enable }=2.4 \mathrm{~V} \\ & V_{C C}=M A X \end{aligned}$ |  | MIL | 2.4 | 2.0 | : | Volts |
|  |  |  |  | COM'L | 2.25 | 2.0 |  |  |
| $V_{T L}$ | Receiver Input LOW Threshold | $\begin{aligned} & \text { Bus Enable }=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{MIN} \end{aligned}$ |  | MIL |  | 2.0 | 1.6 | Volts |
|  |  |  |  | COM'L |  | 2.0 | 1.75 |  |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For conditions shown as MIN or MAX, use the appropriate value specified under Electrical Characteristics for the applicable device type.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

## TYPICAL PERFORMANCE CURVES

Typical Bus Output Low Voltage Versus Ambient Temperature


OP001370

Receiver Threshold Variation Versus Ambient Temperature


OP001380

## SWITCHING TEST CIRCUIT



TC000900

Note 1. Includes Probe and Jig Capacitance.
SWITCHING CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )

| Parameters | Description |  | Test conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Data Input to Bus | Am26S10 | $\begin{gathered} \mathrm{R}_{\mathrm{B}}=50 \Omega \\ \mathrm{C}_{\mathrm{B}}=50 \mathrm{pF} \text { (Note 1) } \end{gathered}$ |  | 10 | 15 | ns |
| tPHL |  |  |  |  | 10 | 15 |  |
| tplH |  | Am26S11 |  |  | 12 | 19 |  |
| tPHL |  |  |  |  | 12 | 19 |  |
| tPLH | Enable Input to Bus | Am26S10 |  |  | 14 | 18 | ns |
| tPHL |  |  |  |  | 13 | 18 |  |
| tpl |  | Am26S11 |  |  | 15 | 20 |  |
| tPHL |  |  |  |  | 14 | 20 |  |
| tplH | Bus to Receiver Out |  | $\begin{gathered} \mathrm{R}_{\mathrm{B}}=50 \Omega, \mathrm{R}_{\mathrm{L}}=280 \Omega \\ \mathrm{C}_{\mathrm{B}}=50 \mathrm{pF}\left(\text { Note 1) } \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}\right. \end{gathered}$ |  | 10 | 15 | ns |
| tPHL |  |  |  | 10 | 15 |  |
| $\mathrm{tr}_{\mathrm{r}}$ | Bus |  |  | $\begin{gathered} \mathrm{R}_{\mathrm{B}}=50 \Omega \\ \mathrm{C}_{\mathrm{B}}=50 \mathrm{pF}(\text { Note } 1) \end{gathered}$ | 4.0 | 10 |  | ns |
| $\mathrm{tf}_{\mathrm{f}}$ | Bus |  | 2.0 |  | 4.0 |  | ns |

Note 1. Includes probe and jig capacitance.

## WAVEFORMS




# Am26S12/Am26S12A 

Quad Bus Transceivers

## DISTINCTIVE CHARACTERISTICS

- Quad high-speed bus transceivers
- Driver outputs can sink 100 mA at 0.7 V typically
- Choice of receiver hysteresis characteristics


## GENERAL DESCRIPTION

The Am26S12/Am26S12A are high-speed quad Bus Transceivers consisting of four high-speed bus drivers with open-collector outputs capable of sinking 100 mA at 0.7 volts and four high-speed bus receivers. Each driver output is brought out and also connected internally to the highspeed bus receiver. The receiver has an input hysteresis characteristic and a TTL output capable of driving ten TTL loads.

An active LOW, two-input AND gate controls the four drivers so that outputs of different device drivers can be connected together for party-line operation. The enable inputs can be conveniently driven by active LOW decoders such as the Am54S/74S139.

The high-drive capability in the LOW state allows party-line operation with a line impedance as low as $100 \Omega$. The line
can be terminated at both ends, and still give considerable noise margin at the receiver. The hysteresis characteristic of the Am26S12 receiver is chosen so that the receiver output switches to a HIGH logic level when the receiver input is at a HIGH logic level and moves to 1.4 volts typically, and switches to a LOW logic level when the receiver input is at a LOW logic level and moves to 2.0 volts typically. This hysteresis characteristic makes the receiver very insensitive to noise on the bus.

The Am26S12A is functionally identical to the Am26S12 but has a different hysteresis characteristic so that the output switches with the input being typically at 1.2 volts or 2.25 volts. In both devices the threshold margin, the difference between the switching points, is greater than 0.4 volts.

## BLOCK DIAGRAM



BD001800

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| $26 S 10$ | Quad Bus Transceiver |
| 26S11 | Quad Bus Transceiver |
| 2915A | Quad Three-State Bus Transceiver with Interface Logic |
| 2916A | Quad Three-State Bus Transceiver with Interface Logic |
| 2917A | Quad Three-State Bus Transceiver with Interface Logic |

## CONNECTION DIAGRAM

Top View


CD004070

Note: Pin 1 is marked for orientation


## METALLIZATION AND PAD LAYOUT



DIE SIZE: $0.071^{\prime \prime} \times 0.072^{\prime \prime}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Am26S12/12A


Blank - Standard processing B - Burn-in

Temperature (See Operating Range)
C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
Package
D-16-pin CERDIP
F-16-pin flatpak
P-16-pin plastic DIP
X-Dice
Device type
Quad Bus Transceivers

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am26S12 | DC, DM |
| Am26S12A | FM |
|  | XC, XM |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## Am26S12／26S12A APPLICATION


$100 \Omega$ PARTY LINE OPERATION

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 16 to Pin 8) Continuous...............-0.5V to +7.0 V
DC Voltage Applied to Outputs For
High Output State $\qquad$
有
$\ldots \ldots \ldots \ldots . . . . . . . . .5 \mathrm{~V}$ to +5.5 V
DC Output Current, Into (Bus)
DC Output Current, Into Outputs
(Receiver) .200 mA

DC input Current $\qquad$ 30 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
+4.75 V to +5.25 V
Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .............................. +4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Notes: 1. Typical limits are at $\mathrm{V} C \mathrm{C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. For the Am26S12FM, Am26S12AFM the output current must be limited at 60 mA or the maximum case temperature limited to $125^{\circ} \mathrm{C}$ for correct operation.
3. Hysteresis characteristics data tested at $25^{\circ} \mathrm{C}$ only.

SWITCHING CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )

| Parameters | Description | Conditions | Min | Typ | Max |
| :--- | :--- | :--- | :---: | :---: | :---: |
| UpLH | Turn Off Delay Input to Bus | $C_{L B}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{LB}}=100 \Omega$ |  | 7 | 11 |
| tpHL | $\mathrm{C}_{\mathrm{LB}}=300 \mathrm{pF}, \mathrm{R}_{\mathrm{LB}}=50 \Omega$ | ns |  |  |  |
| tpLH | Turn On Delay Input to Bus | $\mathrm{C}_{\mathrm{LB}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{LB}}=50 \Omega$ | 14 | 21 | ns |
| tpHL | Turn Off Delay Enable to Bus | $\mathrm{C}_{\mathrm{LB}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{LB}}=50 \Omega$ |  | 10 | 15 |
| tpLH | Turn On Delay Enable to Bus | $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$ | ns |  |  |
| tpHL | Turn Off Delay Bus to Output | $C_{L}=15 \mathrm{pF}$ | 10 | 15 | ns |
|  | Turn On Delay Bus to Output |  | 26 | ns |  |

# Am26LS27/Am26LS28 

Dual EIA RS-485 Party Line Transceivers

## DISTINCTIVE CHARACTERISTICS

- Dual EIA RS-aaa party line transceiver
- 5 MHz max. baud rate
- Drives dual terminated twisted pair line with up to 32 transcievers on line
- Output short cicuit protected to $\mathrm{V}_{\mathrm{CM}}$ limits
- High $Z$ output at $V_{c c}=\max$. and zero
- Separate enable gating for serial applications (27LS27)
- Three state receiver outputs with common enable (26LS28)

BLOCK DIAGRAM

Am26LS27


BD001720

Am26LS28


BD001710

CONNECTION DIAGRAM Top View


## Am26LS29

## DISTINCTIVE CHARACTERISTICS

- Four single ended line drivers in one package for maximum package density
- Output short-circuit protection
- Individual rise time control for each output
- High capacitive load drive capability
- Low ICC and IEE power consumption ( $26 \mathrm{~mW} /$ driver typ.)
- Meets all requirements of RS-423
- Three-state outputs for bus oriented systems
- Outputs do not clamp line with power off or in hiimpedance state over entire transmission line voltage range of RS-423
- Low current PNP inputs compatible with TTL, MOS and CMOS
- Available in military and commercial temperature range
- Advanced low power Schottky processing


## GENERAL DESCRIPTION

The Am26LS29 is a quad single ended line driver, designed for digital data transmission. The Am26LS29 meets all the requirements of EIA Standard RS-423 and Federal STD 1030. It features four buffered outputs with high source and sink current, and output short circuit protection.

A slew rate control pin allows the use of an external capacitor to control slew rate for suppression of near end cross talk to receivers in the cable.

The Am26LS29 has three-state outputs for bus oriented systems. The outputs in the hi-impedance state will not clamp the line over the transmission line voltage of RS-423. A typical full duplex system would use the Am26LS29 line driver and up to twelve Am26LS32 line receivers or an Am26LS32 line receiver and up to thirty-two Am26LS29 line drivers with only one enabled at a time and all others in the three-state mode.

The Am26LS29 is constructed using advanced low-power Schottky processing.

## BLOCK DIAGRAM



BD001730

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| 26 LS30 | Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver |
| 26LS32 | Quad Differential Line Receiver |
| 26LS33 | Quad Differential Line Receiver |



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

|  |  |
| :---: | :---: |

Device type
Quad Single Line Driver

| Valid Combinations |  |
| :--- | :--- |
| Am26LS29 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

TYPICAL APPLICATION


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Supply Voltage

V+ .7.0V
V.7 .0 V
Power Dissipation ........................................................... 600 mW
Input Voltage ...................................... 0.5 to +15.0 V
Output Voltage (Power Off) $\qquad$ .. $\pm 15 \mathrm{~V}$
Lead Soldering Temperature (10) seconds) $.300^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) +4.75 V to +5.25 V -4.75 V to -5.25 V

Military (M) Devices

$\left(V_{E E}\right) . . . . . . . . . . . . . . . . . . . . . . .-4.75$ to -5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{0}$ | Output Voltage | $\mathrm{R}_{\mathrm{L}}=\infty$ (Note 3) | $\mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ | 4.0 | 4.4 | 6.0 | Volts |
| $\overline{V_{O}}$ |  |  | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ | -4.0 | -4.4 | -6.0 | Volts |
| $V_{T}$ | Output Voltage | $R_{L}=450 \Omega$ | $\mathrm{V}_{1 N}=2.4 \mathrm{~V}$ | 3.6 | 4.1 |  | Volts |
| $\overline{V_{T}}$ |  |  | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ | -3.6 | -4.1 |  | Volts |
| $\left\|V_{T}\right\| \cdot\left\|\overline{V_{T}}\right\|$ | Output Unbalance | $\left\|V_{C C}\right\|=\left\|V_{E E}\right\|, R_{L}=450 \Omega$ |  |  | 0.02 | 0.4 | Volts |
| ${ }_{1 \times}+$ | Output Leakage Power Off | $V_{C C}=V_{E E}=0 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=10 \mathrm{~V}$ |  | 2.0 | 100 | $\mu \mathrm{A}$ |
| $1 \mathrm{x}-$ |  |  | $\mathrm{V}_{\mathrm{O}}=-10 \mathrm{~V}$ |  | -2.0 | -100 | $\mu \mathrm{A}$ |
| Is ${ }^{+}$ | Output Short Circuit Current | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  | -70 | -150 | mA |
| Is- |  |  | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  | 60 | 150 | mA |
| ISLEW | Slew Control Current | $\mathrm{V}_{\text {SLEW }}=\mathrm{V}_{\text {EE }}+0.9 \mathrm{~V}$ |  |  | $\pm 110$ |  | $\mu \mathrm{A}$ |
| Icc | Positive Supply Current | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=100$ |  |  | 18 | 30 | mA |
| IEE | Negative Supply Current | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}, \mathrm{R}_{\mathrm{L}}=\infty$ |  |  | -10 | -22 | mA |
| 10 | Off State (High Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=10 \mathrm{~V}$ |  | 2.0 | 100 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=-10 \mathrm{~V}$ |  | -2.0 | -100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Low Level Input Voltage |  |  |  |  | 0.8 | Volts |
| IIH | High Level Input Current | $\mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |  |  | 1.0 | 40 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{IN}} \leqslant 15 \mathrm{~V}$ |  |  | 10 | 100 | $\mu \mathrm{A}$ |
| ILL | Low Level Input Current | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  | -30 | -200 | $\mu \mathrm{A}$ |
| $V_{1}$ | Input Clamp Voltage | $1 \mathrm{ln}=-12 \mathrm{~mA}$ |  |  |  | -1.5 | Volts |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=-5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. Symbols and definitions correspond to EIA RS-423 where applicable.
3. Output voltage is +3.9 V minimum and -3.9 V minimum at $-55^{\circ} \mathrm{C}$.

TYPICAL PERFORMANCE CURVES

## Slew Rate (Rise or Fall Time) Versus External Capacitor



CAPACITANCE - pF
OP001290


TC000850

Figure 1. Rise Time Control.

## SWITCHING TEST CIRCUIT



TC000860

## SWITCHING TEST WAVEFORM



WF002260

Figure 2. Three State Delays
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=-5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tr}_{\mathrm{r}}$ | Rise Time | $R_{L}=450 \Omega, C_{L}=500 \mathrm{pF}$, Fig. 1 | $\mathrm{C}_{\mathrm{C}}=50 \mathrm{pF}$ |  | 3.0 |  | $\mu \mathrm{s}$ |
|  |  |  | $\mathrm{C}_{\mathrm{C}}=0 \mathrm{pF}$ |  | 120 | 300 | ns |
| $t_{f}$ | Fall Time | $R_{L}=450 \Omega, C_{L}=500 \mathrm{pF}$, Fig. 1 | $\mathrm{C}_{\mathrm{C}}=50 \mathrm{pF}$ |  | 3.0 |  | $\mu \mathrm{s}$ |
|  |  |  | $\mathrm{C}_{\mathrm{C}}=0 \mathrm{pF}$ |  | 120 | 300 | ns |
| Src | Slow Rate Coefficient | $\mathrm{R}_{\mathrm{L}}=450 \Omega, C_{L}=500 \mathrm{pF}$, Fig. 1 |  |  | . 06 |  | $\mu \mathrm{s} / \mathrm{pF}$ |
| tLz | Output Enable to Output | $R_{L}=450 \Omega, C_{L}=500 \mathrm{pF}, \mathrm{C}_{\mathrm{C}}=0 \mathrm{pF}$, Fig. 2 |  |  | 180 | 300 | ns |
| ${ }_{t} \mathrm{HZ}$ |  |  |  |  | 250 | 350 |  |
| $\mathrm{t}_{\mathrm{LL}}$ |  | $R_{L}=450 \Omega, C_{L}=500 \mathrm{pF}, \mathrm{C}_{C}=0 \mathrm{pF}$, Fig. 2. |  |  | 250 | 350 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  |  | 180 | 300 |  |



## Am26LS30

Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver

## DISTINCTIVE CHARACTERISTICS

- Dual RS-422 line driver or quad RS-423 line driver
- Driver outputs do not clamp line with power off or in hiimpedance state
- Individually three-state drivers when used in differential mode
- Low ICC and IEE power consumption

RS-422 differential mode $35 \mathrm{~mW} /$ driver typ. RS-423 single-ended mode $26 \mathrm{~mW} /$ driver typ.

- Individual slew rate control for each output
- $50 \Omega$ transmission line drive capability (RS-422 into virtual ground)
- Low current PNP inputs compatible with TTL, MOS and CMOS
- High capacitive load drive capability
- Exact replacement for DS16/3691
- Advanced low power Schottky processing


## GENERAL DESCRIPTION

The Am26LS30 is a line driver designed for digital data transmission. A mode control input provides a choice of operation either as two differential line drivers which meet all of the requirements of EIA Standard RS-422 or four independent single-ended RS-423 line drivers.

In the differential mode the outputs have individual threestate controls. In the hi-impedance state these outputs will not clamp the line over a common mode transmissin line voltage of $\pm 10 \mathrm{~V}$. A typical full duplex system would be the

Am26LS30 differential line driver and up to twelve Am26LS32 line receivers or an Am26LS32 line receiver and up to thirty-two Am26LS30 differential drivers.

A slew rate control pin allows the use of an external capacitor to control slew rate for suppression of near end cross talk to receivers in the cable.

The Am26LS30 is constructed using Advanced Low Power Schottky processing.

## BLOCK DIAGRAM

Logic for Am26LS30 with
Mode Control HIGH (RS-423)


BD001750
RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| $26 L S 29$ | Quad Three-State Single Ended RS-423 Line Driver |
| 26LS32 | Quad Differential Line Receiver |
| 26LS33 | Quad Differential Line Receiver |



| Am26LS30 FUNCTION TABLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\qquad$ | INPUTS |  | OUTPUTS |  |  |
|  | MODE | A(D) | B(C) | A(D) | B(C) |
| 0 | 0 | 0 | 0 | 1 |  |
| 0 | 0 | 1 | $Z$ | $Z$ |  |
| 0 | 1 | 0 | 1 | 0 |  |
| 0 | 1 | 1 | $Z$ | $Z$ |  |
| 1 | 0 | 0 | 0 | 0 |  |
| 1 | 0 | 1 | 0 | 1 |  |
| 1 | 1 | 0 | 1 | 0 |  |
| 1 | 1 | 1 | 1 | 1 |  |

TYPICAL APPLICATION


AF001100

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Supply Voltage
V+ 7.0V

V-
.............. 7.0 V

Power Dissipation 600 mW
Input Voltage e... $\qquad$
Output Voltage (Power Off) $\qquad$ -0.5 to $+\begin{array}{r}15.0 \mathrm{~V} \\ +15 \mathrm{~V}\end{array}$
Lead Soldering Temperature ( 10 seconds) $.300^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) +4.75 V to +5.25 V
( $\mathrm{V}_{\mathrm{EE}}$ )
GND
Military (M) Devices
Temperature ................................ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) ...................... +4.5 V to +5.5 V

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

DC CHARACTERISTICS over operating range unless otherwise specified
EIA RS-422 Connection, Mode Voltage $\leqslant 0.8 \mathrm{~V}$

| Parameters | Description | Test Conditions (Note 3) |  | Min | Typ (Note 1 | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{0}$ | Differential Output Voltage, $\mathrm{V}_{\mathrm{A}, \mathrm{B}}$ | $\mathrm{R}_{\mathrm{L}}=\infty$ | $\mathrm{V}_{\text {IN }}=2.0 \mathrm{~V}$ |  | 3.6 | 6.0 | Volts |
| $\bar{V}_{0}$ |  |  | $\mathrm{V}_{\text {IN }}=0.8 \mathrm{~V}$ |  | -3.6 | -6.0 | Voits |
| $\mathrm{V}_{\top}$ | Differential Output Voltage, $\mathrm{V}_{\mathrm{A}, \mathrm{B}}$ | $R_{L}=100 \Omega$ | $\mathrm{V}_{\text {IN }}=2.0 \mathrm{~V}$ | 2.0 | 2.4 |  | Volts |
| $\overline{V_{T}}$ |  |  | $\mathrm{V}_{\text {IN }}=0.8 \mathrm{~V}$ | -2.0 | -2.4 |  | Volts |
| $\mathrm{V}_{\mathrm{OS}}, \overline{\mathrm{V}_{\mathrm{OS}}}$ | Common Mode Offset Voltage | $\mathrm{R}_{\mathrm{L}}=100 \Omega$ |  |  | 2.5 | 3.0 | Volts |
| $\left\|V_{T}\right\| \cdot\left\|\overline{V_{T}}\right\|$ | Difference in Differential Output Voltage | $\mathrm{R}_{\mathrm{L}}=100 \Omega$ |  |  | 0.005 | 0.4 | Voits |
| $\left\|\mathrm{V}_{\text {OS }}\right\|-\left\|\bar{v}_{\text {OS }}\right\|$ | Difference in Common Mode Offset Voltage | $\mathrm{R}_{\mathrm{L}}=100 \Omega$ |  | , | 0.005 | 0.4 | Volts |
| $\mathrm{V}_{\text {Ss }}$ | $\left\|\mathrm{V}_{\mathrm{T}}-\bar{V}_{T}\right\|$ | $\mathrm{R}_{\mathrm{L}}=100 \Omega$ |  | 4.0 | 4.8 |  | Volts |
| $V_{\text {CMR }}$ | Output Voltage Common Mode Range | $\mathrm{V}_{\text {ENABLE }}=2.4 \mathrm{~V}$ |  | $\pm 10$ |  |  | Volts |
| 1XA | Output Leakage Current | $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ | $V_{\text {CMR }}=10 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| 1×B |  |  | $V_{\text {CMR }}=-10 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| lox | Off State (High Impedance) Output Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | $V_{\text {CMR }} \leqslant 10 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
|  |  |  | $V_{\text {CMR }} \geqslant-10 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| ${ }_{\text {ISA }}$, ISB | Output Short Circuit Current | $\mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ | $\mathrm{V}_{\text {OA }}=6.0 \mathrm{~V}$ |  | 80 | 150 | mA |
|  |  |  | $\mathrm{V}_{\mathrm{OB}}=0 \mathrm{~V}$ |  | -80 | -150 | mA |
|  |  | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ | $V_{\text {OA }}=0 \mathrm{~V}$ |  | -80 | -150 | mA |
|  |  |  | $\mathrm{V}_{\mathrm{OB}}=6.0 \mathrm{~V}$ |  | 80 | 150 | mA |
| ICC | Supply Current |  |  |  | 18 | 30 | mA |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  |  | 2.0 |  |  | Voits |
| VIL | Low Level Input Voltage |  |  |  |  | 0.8 | Volts |
| $\mathrm{IH}^{\text {H }}$ | High Level Input Current | $\mathrm{V}_{\mathrm{IN}}=2.4 \mathrm{~V}$ |  |  | 1.0 | 40 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {IN }} \leqslant 15 \mathrm{~V}$ |  |  | 10 | 100 | $\mu \mathrm{A}$ |
| ILL | Low Level Input Current | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |  |  | -30 | -200 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $1 \mathrm{IN}=-12 \mathrm{~mA}$. |  |  |  | -1.5 | Volts |

DC. CHARACTERISTICS over operating range unless otherwise specified

EIA RS-423 Connection, Mode Voltage $\geqslant 2.0 \mathrm{~V}$


Notes: 1. Typical Imits are at $V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=-5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. Symbols and definitions correspond to EIA RS-423 where applicable.
3. Output voltage is +3.9 V minimum and -3.9 V minimum at $-55^{\circ} \mathrm{C}$.

## PERFORMANCE CURVE

Slew Rate (Rise or Fall Time) Versus External Capacitor


OP001300


Figure 1. Rise Time Control for RS-423.

## RS-422 CONNECTION



Figure 2.

## SWITCHING TEST CIRCUIT



TC000920

SWITCHING TEST WAVEFORM


WF002260

Figure 3. Three State Delays.

## SWITCHING CHARACTERISTICS

EIA RS-422 Connection, $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=\mathrm{GND}$, $\mathrm{Mode}=0.4 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{r}$ | Differential Output Rise Time | Fig. 2, $\mathrm{R}_{\mathrm{L}}=100 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ |  | 120 | 200 | ns |
| $t_{f}$ | Differential Output Fall Time | Fig. 2, $\mathrm{R}_{\mathrm{L}}=100 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ |  | 120 | 200 | ns |
| tPDH | Output Propagation Delay | Fig. 2, $\mathrm{R}_{\mathrm{L}}=100 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ |  | 120 | 200 | ns |
| tPDL | Output Propagation Delay | Fig. 2, $R_{L}=100 \Omega, C_{L}=500 \mathrm{pF}$ |  | 120 | 200 | ns |
| tLZ | Output Enable to Output | $\mathrm{R}_{\mathrm{L}}=450 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}, \mathrm{C}_{\mathrm{C}}=0 \mathrm{pF}$, Fig. 3 |  | 180 | 300 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 250 | 350 |  |
| $\mathrm{t}_{\mathrm{ZL}}$ |  | $\mathrm{R}_{\mathrm{L}}=450 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}, \mathrm{C}_{\mathrm{C}}=0 \mathrm{pF}$, Fig. 3 |  | 250 | 350 |  |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 180 | 300 |  |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=\mathrm{GND}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
2. Symbols and definitions correspond to EIA RS-422 where applicable.
3. $R_{L}$ connected between each output and its complement.

## SWITCHING CHARACTERISTICS

RS-423 Connection, $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{EE}}=-5.0 \mathrm{~V}$, Mode $=2.4 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Parameters | Description | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tr}_{\mathrm{r}}$ | Rise Time | Fig. 1, $\mathrm{R}_{\mathrm{L}}=450 \Omega, C_{L}=500 \mathrm{pF}$ | $\mathrm{C}_{\mathrm{C}}=50 \mathrm{pF}$ |  | 3.0 |  | $\mu \mathrm{s}$ |
|  |  |  | $\mathrm{C}_{\mathrm{C}}=0$ |  | 120 | 300 | ns |
| $t_{f}$ | Fall Time | Fig. 1, $\mathrm{R}_{\mathrm{L}}=450 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}$ | $\mathrm{C}_{\mathrm{C}}=50 \mathrm{pF}$ |  | 3.0 |  | $\mu \mathrm{s}$ |
|  |  |  | $C_{C}=0$ |  | 120 | 300 | ns |
| Src | Slow Rate Coefficient | Fig. 1, $\mathrm{R}_{\mathrm{L}}=450 \Omega, C_{L}=500 \mathrm{pF}$ |  |  | . 06 |  | $\mu \mathrm{s} / \mathrm{pF}$ |
| tpDH | Output Propagation Delay | Fig. 1, $\mathrm{R}_{\mathrm{L}}=450 \Omega, C_{L}=500 \mathrm{pF}, \mathrm{C}_{C}=0$ |  |  | 180 | 300 | ns |
| tPDL | Output Propagation Delay | Fig. $1, \mathrm{R}_{\mathrm{L}}=450 \Omega, \mathrm{C}_{\mathrm{L}}=500 \mathrm{pF}, \mathrm{C}_{C}=0$ |  |  | 180 | 300 | ns |

## Am26LS30 EQUIVALENT CIRCUIT



IC000230

## Am26LS31

## DISTINCTIVE CHARACTERISTICS

- Output skew - 2.0ns typical
- Input to output delay - 12 ns
- Operation from single +5 V supply
- 16-pin hermetic and molded DIP package
- Outputs won't load line when $V_{C C}=0$
- Four line drivers in one package for maximum package density
- Output short-circuit protection
- Complementary outputs
- Meets the requirements of EIA standard RS-422
- High output drive capability for $100 \Omega$ terminated transmission lines
- Available in military and commercial temperature range
- Advanced low-power Schottky processing


## GENERAL DESCRIPTION

The Am26LS31 is a quad-differential line driver, designed for digital data transmission over balanced lines. The Am26LS31 meets all the requirements of EIA standard RS422 and federal standard 1020. It is designed to provide unipolar differential drive to twisted-pair or parallel-wire transmission lines.

The circuit provides an enable and disable function common to all four drivers. The Am26LS31 features 3-state outputs and logical OR-ed complementary enable inputs. The inputs are all LS compatible and are all one unit load.
The Am26LS31 is constructed using advanced low-power Schottky processing.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| 26 LS30 | Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver |

## CONNECTION DIAGRAM Top View



Note: Pin 1 is marked for orientation

METALLIZATION AND PAD LAYOUT


DIE SIZE 0.067" $\times \mathbf{0 . 0 8 4 "}$

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| Am26LS31 | PC |
|  | DC, DM |
|  | FM |
|  | XC, XM |

## Valid Combinations

Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

TYPICAL APPLICATION


## ABSOLUTE MAXIMUM RATINGS

Storage Temperature Range ............... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage .....................................................7.0V
Input Voltage ....................................................... 7.0 V
Output Voltage.....................................................5.5V
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 2) | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OH}}=-20 \mathrm{~mA}$ | 2.5 | 3.2 |  | Volts |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{IOL}=20 \mathrm{~mA}$ |  | 0.32 | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=$ Min | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage | $\mathrm{V}_{\mathrm{CC}}=$ Max |  |  | 0.8 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  | -0.20 | -0.36 | mA |
| IIH | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  | 0.5 | 20 | $\mu \mathrm{A}$ |
| 1 | Input Reverse Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=7.0 \mathrm{~V}$ |  | 0.001 | 0.1 | mA |
|  | Off-State (High Impedance) Output Current | $V_{C C}=$ MAX |  | 0.5 | 20 | $\mu \mathrm{A}$ |
| 10 |  |  |  | 0.5 | -20 |  |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{N}}=18 \mathrm{~mA}$ |  | -0.8 | -1.5 | Volts |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=$ Max | -30 | -60 | -150 | mA |
| ICC | Power Supply Current | $V_{C C}=$ Max, all outputs disabled |  | 60 | 80 | mA |
| tplH | Input to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Load $=$ Note 2 |  | 12 | 20 | ns |
| $t_{\text {PHL }}$ | Input to Output | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Load $=$ Note 2 |  | 12 | 20 | ns |
| SKEW | Output to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Load $=$ Note 2 |  | 2.0 | 6.0 | ns |
| tLz | Enable to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=10 \mathrm{pF}$ |  | 23 | 35 | ns |
| ${ }_{\text {thz }}$ | Enable to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, \mathrm{C}_{L}=10 \mathrm{pF}$ |  | 17 | 30 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ | Enable to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$, Load $=$ Note 2 |  | 35 | 45 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ | Enable to Output | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$, Load $=$ Note 2 |  | 30 | 40 | ns |

Notes: 1. All typical values are $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
2. $C_{L}=30 \mathrm{pF}, \mathrm{V}_{I N}=1.3 \mathrm{~V}$ to $\mathrm{V}_{\text {OUT }}=1.3 \mathrm{~V}, \mathrm{~V}_{\text {PULSE }}=0 \mathrm{~V}$ to +3.0 V , See Below.

## PERFORMANCE CURVES



SWITCHING TEST CIRCUIT FOR THREE-STATE OUTPUTS

PROPAGATION DELAY
(Notes 1 and 3)


## ENABLE AND DISABLE TIMES

## (Notes 2 and 3)



Notes: 1. Diagram shown for Enable LOW.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.
3. Pulse Generator for All Pulses: Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{o}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 15 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 6.0 \mathrm{~ns}$.


IC000310

## Am26LS32/Am26LS33

Quad Differential Line Receivers

## DISTINCTIVE CHARACTERISTICS

- Input voltage range of 15 V (differential or common mode) on Am26LS33; 7V (differential or common mode) on Am26LS32
$- \pm 0.2 \mathrm{~V}$ sensitivity over the input voltage range on Am26LS32;
- $\pm 0.5 \mathrm{~V}$ sensitivity on Am26LS33
- 6 k minimum input impedance with 30 mV input hysteresis
- The Am26LS32 meets all the requirements of RS-422 and RS-423
- Operation from single +5 V supply
- Fail safe input-output relationship. Output always high when inputs are open
- Three-state drive, with choice of complementary output enables, for receiving directly onto a data bus.


## GENERAL DESCRIPTION

The Am26LS32 is a quad line receiver designed to meet the requirements of RS-422 and RS-423, and Federal Standards 1020 and 1030 for balanced and unbalanced digital data transmission.

The Am26LS32 features an input sensitivity of 200 mV over the input voltage range of $\pm 7 \mathrm{~V}$.

The Am26LS33 features an input sensitivity of 500 mV over the input voltage range of $\pm 15 \mathrm{~V}$.

The Am26LS32 and Am26LS33 provide an enable and disable function common to all four receivers. Both parts feature 3-state outputs with 8 mA sink capability and incorporate a fail safe input-output relationship which keeps the outputs high when the inputs are open.

The Am26LS32 and Am26LS33 are constructed using Advanced Low-Power Schottky processing.

## BLOCK DIAGRAM



BD001640

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| 26 LS29 | Quad Three-State Single Ended RS-423 Line Driver |
| 26LS30 | Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver |
| 26LS31 | Quad High Speed Differential Line Receiver |

## CONNECTION DIAGRAM Top View



Note: Pin 1 is marked for orientation

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).
Am26LS32/33

$L$ Screening Option Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
Package
D-16-pin CERDIP
F-16-pin flatpak
$\mathrm{P}-16$-pin plastic DIP
X-Dice
Device type
Quad Line Receivers

| Valid Combinations |  |
| :--- | :--- |
|  | PC |
| Am26LS32 | DC, DM |
| Am26LS33 | FM |
|  | XC, XM |



## OPERATING RANGES

Commercial (C) Devices
Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
+4.75 V to +5.25 V
Military (M) Devices
Temperature
$.55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
.+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Note: 1. All typical values are $V_{C C}=5.0 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.

## SWITCHING TEST CIRCUIT FOR THREE-STATE OUTPUTS

PROPAGATION DELAY
(Notes 1 and 3)

ENABLE AND DISABLE TIMES
(Notes 2 and 3)


Notes: 1. Diagram shown for Enable LOW.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.
3. Pulse Generator for All Pulses: Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{0}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 15 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 6.0 \mathrm{~ns}$.

## Am26LS32B

Quad Differential Line Receiver

## DISTINCTIVE CHARACTERISTICS

- $\pm 100 \mathrm{mV}$ sensitivity over $\mathrm{V}_{I N}$ range of 0 V to 5 V
- $\pm 200 \mathrm{mV}$ sensitivity over $\mathrm{V}_{\mathrm{CM}}$ range
- -7 V to +12 V input voltage range - differential or common mode
- Guaranteed input voltage hysteresis limits
- 80 mV minimum
- 200 mV maximum
- 3V maximum open circuit input voltage
- Three-state outputs disabled during power-up and power down
- Maximum guarantees for tpD skew
- All AC and DC parameters guaranteed over COM'L and MIL operating temperature ranges
- Single +5 V supply
- Advanced low-power Schottky processing


## GENERAL DESCRIPTION

The Am26LS32B is a quad line receiver designed to meet the requirements of RS-422 and RS-423, CCITT V. 10 and V.11, and Federal Standards 1020 and 1030 for balanced and unbalanced digital data transmission.

The Am26LS32B features an input sensitivity of 200 mV over the common mode input voltage range of -7 V to +12 V .

The Am26LS32B is the first device in the Am26LS32 configuration to guarantee minimum hysteresis and propagation delay skew while maintaining better propagation delay guarantees than the Am26LS32. This allows a more
critical analysis of performance in high noise environments and better performance in terms of signal quality, resulting in better system performance.

The Am26LS32B provides an enable and disable function common to all four receivers. It features three-state outputs with 24 mA sink capability and incorporates a fail safe inputoutput relationship which keeps the outputs high when the inputs are open.

The Am26LS32B is constructed using Advanced LowPower Schottky processing.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| $26 L$ S29 | Quad Three-State Single Ended RS-423 Line Driver |
| 26 LS30 | Dual Differential RS-422 Party Line/Quad Single Ended RS-423 Line Driver |
| 26LS33 | Quad Differential Line Receiver |



## ABSOLUTE MAXIMUM RATINGS

Supply Voltage 7.0V

Commom Mode Range $\pm 25 \mathrm{~V}$
Differential Input Voltage ...................................... $\pm 25 \mathrm{~V}$
Enable Voltage..................................................... 7.0 V
Output Sink Current ........................................... 50mA
Storage Temperature Range $\ldots \ldots \ldots \ldots . . .-65^{\circ} \mathrm{C}$ to $+165^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military ( $M$ ) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Note: 1. All typical values are $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## SWITCHING TEST CIRCUIT FOR THREE-STATE OUTPUTS


PROPAGATION DELAY
(Notes 1 and 3)

ENABLE AND DISABLE TIMES
(Notes 2 and 3)



Notes: 1. Diagram shown for Enable LOW.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.
3. Pulse Generator for All Pulses: Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{O}}=50 \Omega ; \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns} ; \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Propagation Delay, Input to Output | $C_{L}=50 \mathrm{pF}$ <br> See test circuit |  | 16 | 21 | ns |
| tpHL |  |  |  | 17 | 21 | ns |
| tSKEW | Propagation Delay Skew, tPLH - tpHL |  |  | 1.5 | 3.0 | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ | Output Enable Time, ENABLE to Output |  |  | 16 | 22 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 10 | 16 | ns |
| tLZ | Output Disable Time, ENABLE to Output | $C_{L}=5 \mathrm{pF}$ <br> See test circuit |  | 11 | 18 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 13 | 18 | ns |

## SWITCHING CHARACTERISTICS* over operating range unless otherwise specified

|  | Descriptions | Test Conditions | COMMERCIAL <br> Am26LS32B |  | MILITARY Am26LS32B |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters |  |  | Min | Max | Min | Max |  |
| tplH | Propagation Delay, Input to Output | $C_{L}=50 \mathrm{pF}$ <br> See test circuits |  | 26 |  | 26 | ns |
| tPHL |  |  |  | 26 |  | 26 | ns |
| tSKEW | Propagation Delay Skew, tpLH - tpHL |  |  | 4.0 |  | 4.0 | ns |
| tZL | Output Enable Time, ENABLE to Output |  |  | 33 |  | 33 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 22 |  | 22 | ns |
| tLZ | Output Disable Time, ENABLE to Output | $C_{L}=5 \mathrm{pF}$ <br> See test circuit |  | 27 |  | 27 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 27 |  | 27 | ns |

[^23]
## DISTINCTIVE CHARACTERISTICS

- Meets all requirements of EIA Standards RS-422, RS423, CCITT V. 10 and V.11, and the new party line standard in development under EIA Project Number 1360.
- $\pm 200 \mathrm{mV}$ sensitivity over input voltage range
- $\pm 150 \mathrm{mV}$ sensitivity for $\mathrm{V}_{\mathrm{CM}}=0$
- -7 V to +12 V common mode input voltage range
- $12 \mathrm{k} \Omega$ minimum input impedance
- Maximum guarantees for tPD skew
- All AC and DC parameters guaranteed over MIL and COM'L temperature ranges
- Guaranteed input voltages hysteresis limits
- 120 mV minimum
- 300 mV maximum
- No internal failsafe
- Pin compatible with Am26LS32/32B/33


## GENERAL DESCRIPTION

The Am26LS34 is a high performance, quad, differential line receiver. It has higher impedance and higher input voltage hysteresis than the similar Am26LS32B. The Am26LS34 also does not have internal fail-safè to allow greater user flexibility.
Input threshold sensitivty is specified for three different $\mathrm{V}_{\mathrm{CM}}$ ranges. The improved sensitivity, guaranteed hystere-
sis and skew limits allow a more critical analysis of system performance in high noise environments and better system performance capability.
All performance parameters are guaranted over $\pm 10 \%$ supplies and over the operating temperature range. In addition; IOL is specified to 24 mA for easy system bus interfacing.

## BLOCK DIAGRAM



BD001640

## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| 26 LS29 | Quad Three-State Single Ended RS-423 Line Driver |
| 26 SS30 | Dual Differential RS--422 Party Line/Quad Single Ended RS-423 Line Driver |
| 26 LS32 | Quad Differntial Line Receiver |
| 26LS33 | Quad Differential Line Receiver |



## ABSOLUTE MAXIMUM RATINGS

Supply Voltage..................................................... 7.0 V
Commom Mode Voltage ....................................... $\pm 25 \mathrm{~V}$
Differential Input Voltage .........................................30V
Enable Voltage..................................................... 7.0 V
Output Sink Current ........................................... 50mA
Storage Temperature Range ............... $-65^{\circ} \mathrm{C}$ to $+165^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


Note: 1. All typical values are $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

SWITCHING TEST CIRCUIT FOR THREE-STATE OUTPUTS


PROPAGATION DELAY
(Notes 1 and 3)


Notes:

1. Diagram shown for Enable LOW.
2. $S_{1}$ and $S_{2}$ of Load Circuit are closed except where shown.
3. Pulse Generator Rate $\leqslant 1.0 \mathrm{MHz} ; \mathrm{Z}_{\mathrm{o}}=50 \Omega ; \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Propagation Delay, Input to Output | $C_{\mathrm{L}}=50 \mathrm{pF}$ <br> See test circuit |  | 18 | 24 | ns |
| tPHL |  |  |  | 20 | 24 | ns |
| tSKEW | Propagation Delay Skew, tpLH - tpHL |  |  | 2 | 4 | ns |
| $\mathrm{t}_{\mathrm{LL}}$ | Output Enable Time, ENABLE to Output |  |  | 16 | 22 | ns |
| ${ }_{\text {Z }}$ |  |  |  | 10 | 16 | ns |
| tLz | Output Disable Time, ENABLE to Output | $C_{L}=5 \mathrm{pF}$ <br> See test circuit |  | 11 | 18 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 13 | 18 | ns |

SWITHCING CHARACTERISTICS* over operating range unless otherwise specified

| Parameters | Description | Test Conditions | COMM | RCIAL | MIL | ARY | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Am26LS34 |  | Am26LS34 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tPLH | Propagation Delay, Input to Output | $C_{L}=50 \mathrm{pF}$ <br> See test circuit |  | 30 |  | 30 | ns |
| tPHL |  |  |  | 30 |  | 30 | ns |
| tSKEW | Propagation Delay Skew, tpLH - tpHL |  |  | $\pm 5$ |  | $\pm 5$ | ns |
| $\mathrm{t}_{\mathrm{ZL}}$ | Output Enable Time, ENABLE to Output |  |  | 33 |  | 33 | ns |
| $\mathrm{t}_{\mathrm{ZH}}$ |  |  |  | 22 |  | 22 | ns |
| tLZ | Output Disable Time, ENABLE to Output | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF} \\ \text { See test circuit } \end{gathered}$ |  | 27 |  | 27 | ns |
| $\mathrm{t}_{\mathrm{Hz}}$ |  |  |  | 27 |  | 27 | ns |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## Am26LS38

## Quad Differential Backplane Transceiver

## PRELIMINARY

## DISTINCTIVE CHARACTERISTICS

- 10 Mb data rate
- 0.45V DC noise margin
- Biasing line terminations allow low voltage swing while maintaining high noise margin
- Pair delay 55 ns maximum
- Controlled driver skew to minimize noise
- Driver register and receiver latch with register bypass mode
- Driver output short-circuit protected to $V_{C C}$ limits
- Outputs disabled during power-up and down
- Three-state receiver outputs maintain Hi-Z during power-up and down and over $\mathrm{V}_{\mathrm{CC}}$ range


## GENERAL DESCRIPTION

The Am26LS38 is a high performance backplane transceiver designed to integrate Schottky TTL performance, high noise immunity and wired logic capability into a low cost differential backplane structure. The resulting backplane
can have up to 24 receiver unit loads in a party-line, wiredOR logic configuration, with a guaranteed fail-safe state, and operates from a single 5V power supply.

BLOCK DIAGRAM


BD001380


## PIN DESCRIPTION

| Pin No. | Name | $1 / 0$ | Description |
| :---: | :---: | :---: | :---: |
|  | $\begin{array}{\|l} \hline B A, B B, \\ B C, B D \\ \left(B_{1}\right), \frac{B A}{B A}, \\ B B, \\ B D \\ \left.\hline B B_{i}\right) \end{array}$ | 1/0 | Paired open emitter ( $\mathrm{B}_{\mathrm{i}}$ )/open collector ( $\overline{\mathrm{B}}_{\mathrm{i}}$ ) driver outputs and receiver inputs. The driver outputs are either simultaneously active or simultaneously inactive. In the inactive state $\left(\mathrm{Dl}_{\mathrm{i}}=\mathrm{LOW}\right)$ both drivers $\left(\mathrm{B}_{\mathrm{i}}\right.$ and $\left.\overline{\mathrm{B}}_{\mathrm{i}}\right)$ are turned off and the voltage differential representing the OFF state is determined by the line terminating resistor networks. In the active state ( $\mathrm{Dl}_{\mathrm{i}}=\mathrm{HIGH}$ ), both drivers are driven on and act to reverse the voltage differential across the line to produce the ON state. <br> The open-emitter/open-collector outputs are always connected in a wired-OR (or wired-AND) configuration. A driver is disabled by making its outputs inactive. |
| 23 | $\overline{\mathrm{BE}}$ | 1 | Bus Enable operates to enable or disable all output drivers by making them inactive when $\overline{\mathrm{BE}}=\mathrm{HIGH}$ and controlled by data input when $\overline{\mathrm{BE}}=\mathrm{LOW}$. |
| 13 | CP | 1 | Clock Pulse input to the driver register enters data on the LOW-to-HIGH transition. |
|  | DIA, DIB, DIC, <br> DID ( $\mathrm{Dli}_{\mathrm{i}}$ ) | 1 | Data inputs to each driver's buffer or register. A HIGH input to $\mathrm{DI}_{\mathrm{i}}$ will result in an active (ON) output. A LOW input will cause an inactive (OFF) output. |
|  | DOA, <br> DOB, <br> DOC, <br> DOD ( $\mathrm{DO}_{\mathrm{i}}$ ) | 0 | Receiver data latch outputs. An inactive bus (OFF state) will produce a LOW DO ${ }_{i}$ output and an active bus (ON state) will produce a HIGH DO; output. |
| 14 | EN | 1 | Clock Enable for the driver registers. $\overline{E N}=$ LOW enables $\mathrm{DI}_{\mathrm{i}}$ data to be clocked into the respective register. $\overline{E N}=H I G H$ acts to hold previous data in each register regardless of the state of CP. |
| 2 | $\overline{\mathrm{OE}}$ | 1 | Output Enable for the receiver latch output buffer. When $\overline{\mathrm{OE}}$ is LOW the outputs are enabled. When $\overline{\mathrm{OE}}$ is HIGH all receiver outputs are in the high impedance state. |
| 1 | RLE | 1 | Receiver Latch Enable for the receiver latches. When RLE is HIGH the latches are transparent. When RLE is LOW received data meeting the setup and hold requirements relative to the HIGH-to-LOW transition of RLE will be stored. |
| 11 | S | 1 | Select input control for the drivers. When S is HIGH driver data from the registers will be selected (Register Mode). When $S$ is LOW (Buffer Mode) the drivers respond to the $D I_{i}$ inputs directly, bypassing the driver registers. |

## FUNCTION TABLE

| Inputs |  |  |  |  |  |  |  |  | Outputs |  |  | Function |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RLE | CP | EN | $\overline{O E}$ | S | $\overline{\mathrm{BE}}$ | Dij | $\mathbf{B}_{\mathbf{i}}$ | $\overline{B_{i}}$ | $B_{i}$ | $\overline{B_{i}}$ | DO ${ }_{\mathbf{i}}$ |  |  |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \end{aligned}$ | $\bar{L}$ | $\bar{L}$ | $L$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & H \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | Driver buffer mode (loop test) |  |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\uparrow$ | $\bar{L}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\bar{L}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \hline \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & H \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | Driver register mode |  |
| $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $L$ | $\begin{aligned} & \hline \mathrm{x} \\ & \mathrm{x} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x \\ & x \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\bar{H}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \mathrm{NA} \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | Receiver latch mode |  |
| L | X | X | L | X | H | X | X | X | X | X | $\mathrm{DO}_{\mathrm{i}_{\mathrm{n}-1}}$ | Receiver in circulation |  |
| X | X | X | H | X | H | X | X | X | X | X | Z | Receiver output in high impedance state |  |


| $H=$ HIGH | $\mathrm{DO}_{\mathrm{i}_{n}-1}=$ Previous state of $\mathrm{DO}_{\mathrm{i}}$ | $X=$ Don't care |
| :--- | :--- | :--- |
| $L=$ LOW | $Z=$ High impedance | NA $=$ Not applicable |

L
$Z=H i g h$ impedance
NA $=$ Not applicable

## FUNCTIONAL DESCRIPTION

The Am26LS38 represents a new approach in backplane transceiver design. Its unipolar differential signalling scheme minimizes problems associated with crosstalk and the loss of noise immunity due to common mode voltage while providing high speed, party line and wired logic capabilities.
A good ground system and shielding are the best methods for limiting noise on the backplane. Ground planes can significantly reduce inductive ground voltage ringing. Where multilayer PC backplane are not a reasonable choice, a differential bus can be created using the Am26LS38 and twisted pair or any balanced transmission medium.
A backplane designed with an Am26LS38 has 3 main elements; 1) a driver section, 2) a receiver section, 3) and a controlled impedance differential line with a pre-biasing line termination. The scheme for driver, receiver, and termination resistors is shown in Figure A.

## SYSTEM OPERATION

The system has two operational states.

1. Active - driver outputs on
2. Passive - driver outputs off

This 2-state (active/passive) operation makes passive or wired logic functions possible. In the passive state, the lines assume a known polarity and voltage (pre-biased bus). The passive bus state may be assigned either the false (wired-OR) or true (wired-AND) sense, potentially reducing the number of backplane signal lines.

The 2-state driver employs active pull-down (open collector) and active pull-up (open emitter) output stages (Figure A). When a driver is active, both output stages turn on. This impresses a 0.5 V minimum voltage differential on the bus, reversing the voltage across $\mathrm{R}_{2}$. In the passive mode both output stages are off. The voltage levels and polarities return to the conditions set by the pre-biasing resistive network. In either state the voltage across the differential lines are symmetrical about $\mathrm{V}_{\mathrm{CC}} / 2$. The system achieves high speeds because the voltage levels required to change state are very close together.

The receiver is designed with $\mathrm{a} \pm 50 \mathrm{mV}$ threshold voltage. This low threshold level combined with a driver output greater than 500 mV provides a high degree of tolerance to attenuation and reflection effects in the cable. Receiver hysteresis provides differential noise immunity. Without hysteresis, a small amount of noise around the switching threshold could cause errors.

Propagation delay skew (tpHL-tpLH) is controlled. The system allows up to 1.5 V of common mode voltage.

## TERMINATING THE TRANSMISSION LINE OR BUS

Common mode reflections in the line can be reduced significantly by symmetrically terminating the bus. This increases the tolerance to common mode noise. Centering the network at $\mathrm{V}_{\mathrm{CC}} / 2\left(\mathrm{R}_{1}=\mathrm{R}_{3}\right)$ further improves the performance by causing all induced noise and reflections to appear as a common mode signal (Figure B)

Figure B. Object Circuit


DF000310

Figure A. The Scheme for Driver, Receiver, and Termination Resistors


A first order approximation of resistor values may be developed by letting the ratio of $R_{1}$ to $R_{2}$ be 2:1, and the Thevenin equivalent resistance of the termination equal the characteristic impedance of the line $\left(Z_{0}\right)$.

Then:
(1) $V_{O C}=V_{T} \frac{R_{2}}{R_{2}+2 R_{1}}$
(2) $R_{T H}=\frac{2 R_{1} R_{2}}{2 R_{1}+R_{2}}$

From equation (1) and (2),
(3) $R_{1}=\frac{V_{T} R_{T H}}{2 V_{O C}}$
(4) $R_{2}=\frac{V_{T} R_{T H}}{V_{T}-V_{O C}}$

If $\mathrm{V}_{\mathrm{T}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OC}}=1.0 \mathrm{~V}$, and $\mathrm{R}_{\mathrm{TH}}=90 \Omega=\mathrm{Z}_{0}$, we can derive that $R_{1} \sim 220 \Omega, R_{2} \sim 110 \Omega$.

Second order adjustments require attention to unit loading factors (receiver differential input resistance is in parallel with $\mathrm{R}_{2}$ ), transmission rates and a host of other factors.

## DATA PATH

Figure C shows the data path from one driver to another receiver for one bit of the bus interface.

The transmit register or buffer and receiver latch are configured to provide two modes of operation. The register and latch can provide local storage for output and input data. In the nonstorage mode the buffer input to the driver can be selected and the receiver can be wired transparent. Incorporating storage on-chip provides improved speed and lower package count without significant penalty in the non-storage mode.

Figure C. The Data Path for One Bit of the Bus Interface


EQUIVALENT CIRCUIT
Recommended Termination


Operating Temperature Range

| $\mathbf{Z}_{\mathbf{0}}$ | $\mathbf{R}_{\mathbf{1}}=\mathbf{R}_{\mathbf{1}}{ }^{\prime}$ | $\mathbf{R}_{\mathbf{2}}=\mathbf{R}_{\mathbf{2}}{ }^{\prime}$ |
| :---: | :---: | :---: |
| $90 \Omega$ | $220 \Omega$ | $110 \Omega$ |
| $120 \Omega$ | $300 \Omega$ | $150 \Omega$ |

Minimum line $V_{0}$ (differential voltage) $=0.5 \mathrm{~V}$

Equivalent Termination Versus DC Resistance

| $Z_{0}$ | $\mathrm{R}_{0}$ |
| :---: | :---: |
| $88.0 \Omega$ | $44.0 \Omega$ |
| $120.0 \Omega$ | $60.0 \Omega$ |



## OPERATING RANGES

Commercial (C) Devices
Temperature $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................ +4.75 V to +5.25 V
Military (M) Devices
Temperature. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage

$$
+4.5 \mathrm{~V} \text { to }+5.5 \mathrm{~V}
$$

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

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bus Driver Output |  |  |  |  |  |  |  |
| $\mathrm{V}_{0}$ | Output Differential Voltage (Driver Active) $\mathrm{V}_{\mathrm{Bi}}-\mathrm{V}_{\mathrm{Bi}}$ | $\begin{aligned} & \overline{\mathrm{BE}}=\mathrm{LOW} \\ & \mathrm{DI}_{i}=H I G H \\ & \text { Test Circuit \#1 } \end{aligned}$ |  | 0.5 |  |  | Volts |
|  | Output Current | $\begin{aligned} & \mathrm{DI}_{\mathrm{i}}=\mathrm{HIGH} \\ & \text { Test Circuit \#2 } \\ & \mathrm{BE}=\mathrm{LOW} \end{aligned}$ | la | -22.5 | -55 | -115 | mA |
| Iss |  |  | Ib | +22.5 | +55 | +115 |  |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | -75 | -1 | -250 | mA |
| Bus Receiver Input |  |  |  |  |  |  |  |
| $V_{\text {TH }}$ | Differential Input Threshold Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CM}}=0 \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{OL}} \text { or } \mathrm{V}_{\mathrm{OH}} \end{aligned}$ |  | -50 | $\pm 10$ | $+50$ | mV |
| RIN | Input Resistance to GND | $0 \leqslant V_{C C} \leqslant V_{C C}$ Max |  | 4 | 5.7 |  | $\mathrm{k} \Omega$ |
| RIN | Differential Input Resistance | $0 \leqslant \mathrm{~V}_{\text {CC }} \leqslant \mathrm{V}_{\text {CC }}$ Max |  | 8 | 11.4 |  | $\mathrm{k} \Omega$ |
| Vos | Center Voltage | Test Circuit \#3 Active and Passive |  | 2.0 | $\mathrm{V}_{\mathrm{cc}} / 2$ | 3.0 | Volts |
| $\|\mathrm{VOS}\| \cdot\|\overline{\mathrm{VOS}}\|$ | Center Voltage Difference (Active vs Passive) | Test Circuit \#3 |  |  | 90 | 300 | mV |


| Non-Bus Input and Outputs |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{VOH}^{\text {O }}$ | Output HIGH Voltage | $\Delta \mathrm{V}_{\text {IN }}=+0.1 \mathrm{~V}$ | $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{IOH}^{\prime}=-24 \mathrm{~mA}$ | 2.0 | 3.3 |  |  |
| VOL | Output LOW Voltage | $\Delta \mathrm{V}_{\mathbb{I N}}=-0.1 \mathrm{~V}$ | $\mathrm{MIL}, \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |  |  | 0.5 | Volts |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{IOL}=48 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | Guaranteed Input Logical HIGH Voltage for All inputs |  | 2.0 |  |  | Volts |
| $V_{\text {IL }}$ | Input LOW Voltage | Guaranteed Input Logical LOW Voltage for All Inputs |  |  |  | 0.8 | Volts |
| IIL | Input LOW Current | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ | Data |  | -275 | -400 | $\mu \mathrm{A}$ |
|  |  |  | Control |  | -0.65 | -1.0 | mA |
|  |  |  | Clock |  | -0.65 | -1.0 | mA |
| $\mathrm{IIH}^{\text {H }}$ | Input HIGH Current | $\mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 0.1 | $+50$ | $\mu \mathrm{A}$ |
| Isc | Output Short Circuit Current | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | -75 | -150 | -250 | mA |
| 1 | Input Leakage Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA |
| $\mathrm{V}_{\text {IC }}$ | Input Clamp Voltage | $\mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  | -0.75 | -1.2 | Volts |
| Ioz | Leakage Current Passive | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  |  | $+50$ | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  |  | -50 |  |
| ICC | Power Supply Current | $\overline{\mathrm{BE}}, \overline{\mathrm{OE}}=\mathrm{HIGH}$ | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  | 145 | mA |
|  |  |  | $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  | 130 |  |
|  |  |  | -55 to $+125^{\circ} \mathrm{C}$ |  | 110 | 160 |  |

## SWITCHING TEST CIRCUIT

Test Circuit \#1


Test Circuit \#3

Test Circuit \#2



Notes: 1. $C_{L}=50 \mathrm{pF}$ unless otherwise specified.
2. $S_{1}$ and $S_{2}$ are closed except where shown.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified




## SWITCHING WAVEFORMS (Cont.)

(5) RLE to $\mathrm{DO}_{\mathbf{i}}$


WF002070
(6) $\overline{O E}$ to $\mathrm{DO}_{\mathbf{i}}$


WF002080

| Sosex | Nuwerich device miex | 1 |
| :---: | :---: | :---: |
| SYSTEMS DESIGN CONSIDERATIONS AND TRAINING |  | 2 |
|  |  | 3 |
|  | MORY CONTROL MEMORY TIMING/CONTROL UNITS ERROR DETECTION AND CORRECTION | 4 |
| Am2900 PROCESSORS AND PERIPHERALS | BIT-SLICE PROCESSORS MICROCODE SEQUENCERS IS PEERIPHERALS | 5 |
|  |  | 6 |
|  |  | 7 |
|  | 8, 9, AND 10 -BIT IMOX BUS INTERFACE DIAGNOSTIC REGISTERS Comparators | 8 |
| ${ }_{\text {Ammisis }}^{\text {am }}$ | ita Performance schottiry logic <br>  | ¢ |
|  | Mich perfomact schorne fus mitefice | 16 |
| ${ }_{\substack{8100 \\ 8800}}$ | Mos michoppocssor supopr ppopucr |  |
| MEMORIES, MOS' PERIPHERALS | Proms, , ipolat rams, mos static rams <br>  <br> Mos Lill fripherais VERY High speo Dita Acoustion | 12 |
| ¢enter | Packagime orderna ing imation <br>  | 1 |

## MOS Microprocessor Support Products

Am7960 Coded Data Transceiver ..... 11-1
Am7990 Local Area Network Controller for Ethernet (Lance) ..... 11-12
Am7991A/Am7992A Serial Interface Adapter (SIA) ..... 11-37Am8120 Octal D-Type Flip-Flop with Clear, Clock Enableand Three-State Control11-50
Am8127 AmZ8000 Clock Generator ..... 11-56
Am8152A/53A Video System Controller (VSC) ..... 11-67
8284A/8284A-1 Clock Generator and Driver for 8086, 8088 Processors ..... 11-83
8286/8287 Octal Bus Transceivers ..... 11-92
8288 Bus Controller ..... 11-98

# Am7960 

Coded Data Transceiver

## ADVANCED INFORMATION

## DISTINCTIVE CHARACTERISTICS

- Manchester encoder-decoder transceiver
- Matched filter receiver
- Frequency agile for data rates between 500 Kbps and 3Mbps
- 32dB dynamic range (transmit to receive)
- 'Modem-like" controller interface
- Transmit edge rate control
- High impedance interface to coupling transformer
- 2 V differential output to $37.5 \Omega$


## GENERAL DESCRIPTION

The Am7960 is a combination of a Manchester encoder/ decoder and a transceiver. It is designed for use in synchronous communications systems which require common mode isolation in point-to-point or common bus architecture. It is frequency agile over the range of 0.5 Mbps to 3 Mbps . This 5 V device provides 32 dB of dynamic range, and guarantees 2 V output into $37.5 \Omega$. A single external
component controls the slew rate of the transmitter, and a matched filter in the receiver minimizes false starts improving reliability.

The Am7960 has a modem-like controller interface which makes it compatible with nearly every existing synchronous communications controller (USARTs, SCCs, etc).


## RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am7990 | Local Area Network Controller Par Ethernet |
| Am7991A | Serial Interface Adapter |


| Pin No. | Name | I/O | Description |
| :---: | :--- | :--- | :--- |
| Controller Transmit Interface Signals |  |  |  |


|  | TxC | O | Transmit Clock. Transmit Clock is data transmit bit clock. All transmit interface signals are synchronized to this clock. <br> This signal is always active. |
| :--- | :--- | :---: | :--- |
|  | TxD | 1 | Transmit Data. Transmit Data is the serial transmit data. |
|  | $\overline{R T S}$ | 1 | Request to Send. The communication controller indicates that it wishes to transmit data by asserting Request to Send. <br> Once started, only negating Request to Send can stop transmission. |
|  | $\overline{\text { CTS }}$ | O | Clear to Send. The Am7960 asserts Clear to Send when it can encode and transmit data on the channel. |


| Controller Receive Interface Signals |  |  |  |
| :--- | :--- | :---: | :--- |
|  | RxC | 0 | Receive Clock. Receive Clock is the data receive bit clock. All controller receive interface signals with the exception of <br> Advance Carrier Presence are synchronized to this clock. When there is no carrier on the line, this signal is OFF. |
|  | RxD | 0 | Receive Data. Receive Data is the serial receive data. |
|  | $\overline{\text { ACP }}$ | 0 | Advance Carrier Presence. Advance Carrier Presence is asserted whenever the receiver has detected line activity. It <br> is negated after there has been no line activity for 2 bit times (quiet line). During transmission Advance Carrier <br> Presence is internally negated. This signal is asynchronous with both Transmit Clock and Receive Clock. |
|  | $\overline{\mathrm{CP}}$ | O | Carrier Presence. Carrier Presence is asserted after internal clock acquisition and immediately before asserting <br> Receive Clock. It is negated after either end of message or quiet line. |
|  | CS | 0 | Carrier Sense. Carrier Sense is asserted immediately before the first receive data bit and negated after either a <br> Manchester coding violation or quiet line. |


| Channel Interface Signals |  |  |
| :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{T} \times \mathrm{L}_{0} \\ & \mathrm{TXL}_{1} \\ & \hline \end{aligned}$ | 0 | Transmit Outputs. The difference between these outputs ( $\mathrm{TxL}_{0}-\mathrm{TxL}_{1}$ ) is the channel transmit signal. There are provisions for controlling both the transmit slew rate and the short circuit current. |
| TV CC | 1 | Transmit Power Supply. The transmitter has a separate power supply input. |
| TSRC | 1/0 | Slew Rate Control. This pin is used to control the transmit slew rate with external passive components. |
| $\begin{array}{\|l\|l\|} \hline \mathrm{RxL}_{0} \\ \mathrm{RxL}_{1} \end{array}$ | 1 | Receiver inputs. The difference between these inputs ( $\mathrm{R} \times \mathrm{L}_{0}-\mathrm{RxL} L_{1}$ ) is the channel receive signal. |
| Global Signals |  |  |
| MRST | 1 | Master Reset. Master Reset is an asynchronous transceiver reset. When asserted, all interface signals will be inhibited with the exception of Transmit Clock. It has an internal pullup resistor, internal discharge clamp diode, and input hysteresis to provide power-on reset with a single external capacitor to ground. |
| MODE | 1 | Mode Control. Mode Control determines if the Am7960 will internally generate and recognize line preamble. When LOW, the Mode Control is in Mode 0 and uses preamble. When HIGH, the Mode Control is in Mode 1 and is preamble transparent. This input has an internal pullup resistor. |
| TEST | 1 | Test Control. Test Control is not a user function. This input is used to functionally test the device. It should always be LOW when active. |
| $\begin{array}{\|l\|} \hline x_{1} \\ x_{2} \end{array}$ | 1 | Crystal Oscillator Connections. $X_{1}$ and $X_{2}$ are the Crystal Oscillator Connections. The Am7960 can be either operated from a crystal or driven from an external TTL clock. |
| $\begin{array}{\|l\|} \hline v_{\mathrm{CC} 1} \\ \mathrm{v}_{\mathrm{CC} 2} \\ \hline \end{array}$ | 1 | Power Supply. $\mathrm{V}_{\mathrm{CC} 1}$ and $\mathrm{V}_{\mathrm{CC} 2}$ are 5.0 volt nominal power supply pins. |
| $\mathrm{GND}_{1}$ $\mathrm{GND}_{2}$ |  | Ground Pins. |

## DETAILED DESCRIPTION

The Am7960 has two operating modes: Mode 0 and Mode 1. When transmitting, Mode 0 inserts a 32-bit preamble, Manchester encodes the transmit data, and appends End Of Message. When receiving, Mode 0 identifies and removes preamble, decodes the Manchester line data, and removes End Of Message. Mode 1 is identical to Mode 0 except preamble is neither generated on transmit nor detected upon reception; the Coded Data Transceiver simply passes data (bit for bit) onto the media and recovers it at the destination. One of these two modes will interface to almost all existing synchronous controllers.
Manchester encoding is employed in the Am7960. A 1 bit is encoded as a 0 followed by a 1 ; a 0 bit is a 1 followed by a 0 . Line end of message is two consecutive bits of 1 s . In Mode 0 , the preamble will be a Manchester 1 followed by 30 bits of alternating Manchester 0 and 1 bits followed by a final 1.

## TRANSMIT

The Am7960 has a modem-like contrbller interface. Transmission is initiated by asserting Request To Send. Once started, only negating Request To Send can stop transmission. All receive signals are active with the exception of Advance

Carrier Presence which will be off for the duration of the transmission. In either mode, Clear-To-Send is activated one transmit clock cycle before the Am7960 expects transmit data.

## RECEIVE

The Receiver has three status lines: Advance Carrier Presence, Carrier Presence, and Carrier Sense. Advance Carrier Presence indicates that the receiver is detecting line activity. It is asynchronous with both Transmit Clock and Receive Clock. Advance Carrier Presence is asserted for line signals above the Positive Presence Level or below the Negative Presence Level for more than 40 ns . Line signals between the presence levels or less than 16 ns will be rejected. Once asserted, Advance Carrier Presence will remain active until line signal is absent for 2 bit times (quiet line).

After the Am7960 has detected an active line, it attempts to acquire Receive Clock. Clock qualification is achieved by sampling the presence levels. To qualify, a line signal must either be above the Positive Presence Level and then go below the Negative Presence Level or below the Negative Presence Level and then go above the Positive Presence Level in $3 / 4$ to $1 \frac{1}{4}$ bit times. After this occurs, the next line data transition starts the internal clock recovery circuitry. If line becomes quiet or End Of Message detected, the clock will not
be reacquired until Advance Carrier Presence is OFF and then reasserted.

Active Carrier Presence indicates that the Am7960 has an internally acquired clock. Receive Clock will be active whenever Carrier Presence is active. Carrier Presence will remain active until either the line is quiet or End Of Message is detected.

Carrier Sense becomes active when the Am7960 intends to transmit Receive Data to the controller. Carrier Sense stays active until either the line is quiet or an invalid Manchester cell is detected. Receive Data is OFF until Carrier Sense becomes active and remains active until Carrier Presence becomes inactive.

The Am7960 decodes the line data by sampling the $1 / 4$ and $3 / 4$ bit intervals with respect to the start of the cell. If these samples are opposite, valid Manchester data has been decoded. If these samples are the same and the next $1 / 4$ sample is the same, the receiver has detected End Of Message.

In Mode 0, valid preamble is defined as at least seven receive clocks, the last four as decoded Manchester 1011 . Until this criteria is met, the Am7960 will continue to hunt for preamble.

## CHANNEL

The transmitter/receiver interface has been designed to provide a high impedance, low capacitance channel interface. There are provisions to externally control the transmit short circuit current as well as the slew rate of the transmit signals. Slew limiting the transmit signal decreases both the effect of channel intersymbol interference and the presence of undesired harmonic frequencies.

The receiver provides a high impedance input over the tota input operating range. A common mode voltage reference minimizes the number of external components needed for use with coupling or isolation transformers. The receiver's high input sensitivity and large. dynamic range allows reception of both large (near end) and small (far end) signals. Its range also allows for operation immediately adjacent to an active transmitter without overload damage

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature Under Bias ................... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage Above Ground Potential....-0.5V to +7.0 V
Transmit Supply Current (Max)............................. 250 mA
Receiver Common Mode Voltage ............ -0.5 V to +5.5 V
Receiver Differential Input Voltage ...........................4.5V
DC Output Current, Into Outputs, (Logic Outputs) ..... 30mA
DC Input Voltage (Logic Inputs)...............-0.5V to +5.5 V
DC Input Current (Logic Inputs) .......... -30 mA to +5.0 mA
Power Dissipation 30 mA to +5.0 mA
Lead Soldering Temperature ( 10 seconds) .............. $300^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature .................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified


| Name | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Receive Channel Interface Signals |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{IN}}$ | Differential Receiver Input Voltage | Note 10 |  | $V_{T}$ Max |  |  | V |
|  |  |  |  | $\mathrm{V}_{T} \mathrm{Max}$ |  |  |  |
| $\mathrm{V}_{\text {TH }}$ | Differential Receiver Offset Voltage | Note 11 |  | -5 |  | 5 | mV |
| $\mathrm{V}_{\text {CM }}$ | Common Mode Receiver Input Voltage | Note 12 |  | 1.0 |  | 3.0 | V |
| $\mathrm{V}_{\text {CPP }}$ | Positive Static Carrier Presence Level | Note 10 |  | 20 |  | 35 | mV |
| $\mathrm{V}_{\text {CPN }}$ | Negative Static Carrier Presence Level | Note 10 |  | -20 |  | -35 | mV |
| $\mathrm{R}_{\mathrm{R}}$ | Differential Receiver Input Resistance |  | $\begin{aligned} & \hline V_{T}<V_{I N}<V_{T} \\ & 0<V_{C C}<\mathrm{Max} \\ & \hline \end{aligned}$ | 20 |  |  | $k \Omega$ |
| $\mathrm{C}_{\mathrm{R}}$ | Differential Receiver Input Capacitance |  | $\mathrm{V}_{\mathrm{T}}<\mathrm{V}_{\mathbb{I}}<\mathrm{V}_{\text {T }}$ |  |  | 3 | pF |
| Global Signals |  |  |  |  |  |  |  |
| $\mathrm{R}_{\mathrm{N}}$ | Differential Node Resistance | Note 13 | $\begin{aligned} & V_{T}<V_{I N}<V_{T} \\ & 0<V_{C C}<\operatorname{Max} \\ & \hline \end{aligned}$ | 20 | 30 |  | $k \Omega$ |
| $\mathrm{C}_{\mathrm{N}}$ | Differential Node Capacitance | Note 13 | $\begin{aligned} & \mathrm{V}_{T}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\top} \\ & 0<\mathrm{V}_{\mathrm{CC}}<\mathrm{Max} \\ & \hline \end{aligned}$ | - |  | 10 | pF |
| ICC | Power Supply Current |  | $\mathrm{V}_{\mathrm{CC}}=$ Max |  |  | 190 | mA |

Notes: 1. Output signals $\overline{A C P}, \overline{C P}, \overline{C S}$ and $\overline{C T S}$.
2. Output signals $T \times C$, RxC and RxD
3. Inputs TxD and RTS.
4. Inputs TEST and MODE.
5. Input MRST only.
6. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
7. $V_{T}$ and $V_{T}$ are the differential output signals $T \times L_{0}{ }^{-}{ }^{-1} \times L_{1}$ depending upon signal polarity.
8. $V_{O S}$ and $V_{O S}$ are the average of $T_{X L_{0}}$ and $\mathrm{TXL}_{1}$ depending upon signal polarity.
9. $I_{T}$ and $I_{T}$ are the transmit output currents.
10. $\mathrm{V}_{\mathrm{IN}}$ is the differential input signal $\mathrm{RxL}_{0}-\mathrm{RxL}_{1}$.
11. Offsets are for differential input signals (Figure 1).
12. $\mathrm{V}_{\mathrm{CM}}$ is the average $\mathrm{R} \times \mathrm{L}_{0}$ and $\mathrm{RxL}_{1}$.
13. Node impedance is with transmitter and receiver connected.


SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Number | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmit Clock |  |  |  |  |  |  |  |
| 1 | Transmit Clock Period | Note 2 | . | 330 |  |  | ns |
| 2 | Transmit Clock Width LOW | Note 2 |  | 45\% |  | 55\% | TxC |
| 3 | Transmit Clock Width HIGH | Note 2 |  | 45\% |  | 55\% | TxC |
| 4 | Transmit Clock Rise Time | Note 2 | $C_{L}=50 \mathrm{pF}$ |  |  | 5 | ns |
| 5 | Transmit Clock Fall Time | Note 2 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 5 | ns |
| Transmit Control |  |  |  |  |  |  |  |
| 6 | Setup RTS to + TxC | Notes 1 and 2 |  | 15 |  |  | ns |
| 7 | Hold RTS to 1 TxC | Notes 1 and 2 |  | 5 |  |  | ns |
| 8 | Minimum Inter-Packet Delay |  |  |  | 3 |  | TxC |
| 9 | $\uparrow$ TXC to $\overline{\text { ACP }}$ Inhibit | Notes 1 and 2 |  | 0.3 |  | 0.5 | TxC |
| 10 | $\uparrow$ TxC to $\overline{\text { ACP }}$ Enable | Notes 1 and 2 |  | 2.3 |  |  | TxC |
| 11 | $\uparrow$ TxC to CTS Enable | Notes 1 and 2 |  |  |  | . 35 | TxC |
| 12 | $\dagger$ TxC to CTS Disable | Notes 1 and 2 |  |  |  | . 35 | TxC |
| 13 | Setup TxD to + TxC | Notes 1 and 2 |  | 15 |  |  | ns |
| 14 | Hold TxD to t TxC | Notes 1 and 2 |  | 5 |  |  | ns |
| Transmit Latency |  |  |  |  |  |  |  |
| 15 | $\dagger$ TxC to Encoded Data Line Clock Transition | Notes 3 and 4 |  | 0.75 |  | 1.0 | TxC |
| 16 | $\dagger$ TxC to Transmitter Disable | Notes 3 and 5 |  | 2.25 |  |  | TxC |
| Receive Clock and Data |  |  |  |  |  |  |  |
| 17 | Receive Clock Period | Note 2 |  | 92\% |  | 108\% | TxC |
| 18 | Receive Clock Width LOW | Note 2 |  | 42\% |  | 58\% | TxC |
| 19 | Receive Clock Width HIGH | Note 2 |  | 42\% |  | 58\% | TxC |
| 20 | Receive Clock Rise Time | Note 2 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 5 | ns |
| 21 | Receive Clock Fall Time | Note 2 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 5 | ns |
| 22 | $t$ RxC to Valid RxD | Note 2 |  | -5 |  | 20 | ns |
| 23 | Receive Data Rise Time | Note 2 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 10 | ns |
| 24 | Receive Data Fall Time | Note 2 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 10 | ns |
| Receive Control |  |  |  |  |  |  |  |
| 25 | Line Active to $\overline{\text { ACP }}$ Active | Notes 1 and 6 |  | 0.15 |  | 0.4 | TxC |
| 26 | Line Quiet to $\overline{\mathrm{ACP}}$ Inactive | Notes 1 and 7 |  | 2.15 |  | 2.4 | TxC |
| 27 | $\overline{\text { ACP Width LOW }}$ | Note 1 |  | 0.1 |  |  | TxC |
| 28 | $\overline{\text { ACP }}$ Width HIGH | Note 1 |  | 0.1 |  |  | TxC |
| 29 | $\overline{\overline{A C P}}$ Active to $\overline{\mathrm{CP}}$ Active | Notes 1 and 9 |  | 1.5 |  |  | TxC |
| 30 | $\overline{\mathrm{CP}}$ Inactive to $\overline{\mathrm{ACP}}$ Inactive | Note 1 |  | 0 |  |  | ns |
| 31 | 1st Line Data Transition to 1 RxC | Notes 2 and 8 |  | 3.5 |  |  | TxC |
|  |  | Notes 2 and 9 |  | 1.0 |  |  |  |
| 32 | $\overline{\mathrm{CP}}$ Active to $\uparrow \mathrm{RxC}$ | Notes 1 and 2 |  | 60 |  |  | ns |
| 33 | $\downarrow$ RxC to Inactive CP | Notes 1 and 2 |  | 0 |  | 0.1 | TxC |
| 34 | $\overline{\text { CS Active to } \dagger \text { RxC }}$ | Notes 1, 2 and 8 |  | 60 |  |  | ns |
| 35 | $\downarrow$ RxC to $\overline{C S}$ Active | Notes 1, 2 and 9 |  | 0 |  | 0.1 | TxC |
| 36 | $\downarrow$ RxC to $\overline{C S}$ Inactive | Notes 1 and 2 |  | 0 |  | 0.1 | TxC |
| 37 | $\overline{\mathrm{CP}}$ Active to $\overline{\mathrm{CS}}$ Active | Notes 1 and 9 | $\cdots$ | 7 |  |  | RxC |
| Channel Transmit Signals |  |  |  |  |  |  |  |
| 38 | Transmit Slew Rate Coefficient |  | - |  | TBD |  |  |
| 39 | Transmit Rise Time | Notes 3 and 10 |  | 24\% | 30\% | 36\% | TxC |
| 40 | Transmit Fall Time | Notes 3 and 10 |  | 24\% | 30\% | 36\% | TxC |
| 41 | Transmit Common Mode Pulse Width | Notes 3 and 11 |  |  | 15 | 40 | ns |
| 42 | Bit Cell Edge to Bit Cell Center | Note 12 |  | 48\% |  | 52\% | TxC |
| 43 | Bit Cell Center to Bit Cell Center | Note 12 |  | 98\% |  | 102\% | TxC |
| 44 | Bit Cell Center to Bit Cell Edge | Note 12 |  | 48\% |  | 52\% | TxC |
| 45 | Transmit Waveform | Note 13 |  |  | onoton |  |  |



## TRANSMIT MODE 0




TRANSMIT MODE 1



Figure 2. Receiver Jitter


## Am7990*

Local Area Network Controller for Ethernet (LANCE)

## DISTINCTIVE CHARACTERISTICS

- Ethernet and IEEE 802.3 compatible
- Easily interfaced to 8086, 68000, Z8000, LSI-II microprocessors
- On-board DMA and buffer management, 48 byte FIFO
- 24-bit wide linear addressing (Bus Master Mode)
- Network and packet error reporting
- Diagnostic Routines
- Internal/external loop back
- CRC logic check
- Time domain reflectometer


## GENERAL DESCRIPTION

The Am7990 Local Area Network Controller for Ethernet (LANCE) is a 48 -pin VLSI device designed to greatly simplify interfacing a microcomputer or minicomputer to an Ethernet Local Area Network. This chip, in conjunction with the Am7991A Serial Interface Adapter (SIA) and closely coupled local memory and microprocessor, is intended to
provide the user with a complete interface module for an Ethernet network. The Am7990 is designed using a scaled N-Channel MOS technology and is compatible with a variety of microprocessors. On-board DMA, advanced buffer management and extensive error reporting and diagnostics facilitate design and improve system performance.

BLOCK DIAGRAM


BD002061
RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| 7960 | Coded Data Transceiver |
| 7991A | Serial Interface Adapter |
| 7995 | Ethernet Transceiver |



Data/Address Lines (Input/Output 3-State)
The time multiplexed Address/Data bus. During the address portion of a memory transfer, DAL $\mathrm{O}_{0}$ - DAL ${ }_{15}$ contains the lower 16 bits of the memory address. The upper 8 bits of address are contained in $\mathrm{A}_{16}-\mathrm{A}_{23}$.
During the data portion of a memory transfer, DALO0-DAL 15 contains the read or write data, depending on the type of transfer.
The LANCE drives these lines as a Bus Master and as a Bus Slave.

High Order Address Bus (Output 3-State) The additional address bits necessary to extend the DAL lines to access a 24-bit address. These lines are driven as a Bus Master only.
(Input/Output 3-State)
Indicates the type of operation to be performed in the current bus cycle. This signal is an output when the LANCE is a Bus Master.
High - Data is taken off the DAL by the chip. Low - Data is placed on the DAL by the chip.
The signal is an input when the LANCE is a Bus Slave.
High - Data is placed on the DAL by the chip. Low - Data is taken off the DAL by the chip.
t/O pins 15 and 16 are programmable through bit (00) of $\mathrm{CSR}_{3}$.
$\overline{B_{M}}, \overline{B_{1}}$
If $\mathrm{CSR}_{3}(00) \mathrm{BCON}=0$
I/O Pin $15=\overline{\mathrm{BM}_{0}}$ (Output 3-state)
I/O PIN $16=\overline{\mathrm{BM}_{1}}$ (Output 3-state)
$\overline{\mathrm{BM}_{0}}, \overline{\mathrm{BM}_{1}}$ (Byte Mask). This indicates the byte(s) on the DAL are to be read or written during this bus transaction. The LANCE drives these lines only as a Bus Master. It ignores the Byte Mask lines when it is a Bus Slave and assumes word transfers.
Byte selection using Byte Mask is done as described by the following table.

| $\overline{B_{1}}$ | $\overline{B_{0}}$ |  |
| :--- | :--- | :--- |
| LOW | LOW | Whole Word |
| LOW | HIGH | Upper Byte |
| HIGH | LOW | Lower Byte |
| HIGH | HIGH | None |

## BYTE, BUSAKO

If $\mathrm{CSR}_{3}(00) \mathrm{BCON}=1$
I/O PIN $15=$ BYTE (Output 3-state)
I/O PIN $16=$ BUSAKO (Output)

Byte selection may also be done using the BYTE line and DAL 00 line, latched during the address portion of the bus cycle. The LANCE drives BYTE only as a Bus Master and ignores it when a Bus Slave selection is done (similar to $\overline{\mathrm{BM}_{0}}$, $\left.\overline{B M_{1}}\right)$.
Byte selection is done as outlined in the following table.

| BYTE | DAL 00 |  |
| :--- | :--- | :--- |
| LOW | LOW | Whole Word |
| LOW | HIGH | Illegal Condition |
| HIGH | LOW | Lower Byte |
| HIGH | HIGH | Upper Byte |

BUSAKO is a bus request daisy chain output. If the chip is not requesting the bus and it receives HLDA, BUSAKO will be driven low. If the LANCE is requesting the bus when it receives HLDA, BUSAKO will remain high.

## Byte Swapping

In an effort to be compatible with the variety of 16 -bit microprocessors available to the designer, the LANCE may be programmed to swap the position'of the upper and lower order bytes on data involved in transfers with the internal FIFO.
Byte swapping is done when $B S W P=1$. The most significant byte of the word in this case will appear on DAL lines 7-0 and the least significant byte on DAL lines 15-8.
When BYTE $=\mathrm{H}$ (indicating a byte transfer) the table indicates on which part of the 16 -bit data bus the actual data will appear.
Whenever byte swap is activated, the only data that is swapped is data traveling to and from the FIFO.

| Signal Line | Mode Bits |  |
| :---: | :---: | :---: |
|  | $\begin{gathered} \text { BSWP }=0 \\ \text { and } B C O N=1 \end{gathered}$ | $\begin{gathered} \text { BSWP }=1 \\ \text { and } B C O N=1 \end{gathered}$ |
| $\begin{aligned} & \text { BYTE }=L \text { and } \\ & \text { DAL }_{00}=L \end{aligned}$ | Word | Word |
| $\begin{aligned} & \text { BYTE }=L \text { and } \\ & \text { DAL }_{00}=H \end{aligned}$ | Illegal | Illegal |
| BYTE $=\mathrm{H}$ and DAL $00=\mathrm{H}$ | Upper Byte | Lower Byte |
| BYTE $=\mathrm{H}$ and $\mathrm{DAL}_{00}=\mathrm{L}$ | Lower Byte | Upper Byte |

CS Chip Select (Input)
Indicates, when asserted, that the LANCE is the slave device of the data transfer. $\overline{\mathrm{CS}}$ must be valid throughout the data portion of the bus cycle. $\overline{\mathrm{CS}}$ must not be asserted when $\overline{\mathrm{HLDA}}$ is LOW.

## Register Address Port Select (Input)

 When LANCE is slave, ADR indicates which of the two register ports is selected. ADR LOW selects register data port; ADR HIGH selects register address port, ADR must be valid throughout the data portion of the bus cycle and is only used by the LANCE when CS is low.Address Latch Enable (Output 3-State)
Used to demultiplex the DAL lines and define the address portion of the bus cycle. This I/O pin is programmable through bit (01) of $\mathrm{CSR}_{3}$.
As ALE $\left(\mathrm{CSR}_{3}(01), \mathrm{ACON}=0\right)$, the signal transitions from a HIGH to a LOW during the address portion of the transfer and remains low during the data portion. ALE can be used by a Slave device to control a latch on the bus address lines. When ALE is high the latch is open and when ALE goes low the latch is closed.
As $\overline{\mathrm{AS}}\left(\operatorname{CSR}_{3}(01), \mathrm{ACON}=1\right)$, the signal pulses LOW during the address portion of the bus transaction. The low to high transition of AS can be used by a slave device to strobe the address into a register.

The LANCE drives the ALE/ $\overline{\mathrm{AS}}$ line only as a Bus Master.

Data Strobe (Input/Output 3-State)
Defines the data portion of the bus transaction. $\overline{\mathrm{DAS}}$ is high during the address portion of a bus transaction and low during the data portion. The low to high transition can be used by a Slave device to strobe bus data into a register. $\overline{\text { DAS }}$ is driven only as a Bus Master.

Data/Address Line Out (Output 3-State)
An external bus transceiver control line. DALO is asserted when the LANCE drives the DAL lines. DALO will be low only during the address portion if the transfer is a READ. It will be low for the entire transfer if the transfer is a WRITE. DALO is driven only when LANCE is a Bus Master.

Data/Address Line in (Output 3-State)
An external bus transceiver control line. DALI is asserted when the LANCE reads from the DAL lines. It will be low during the data portion of a READ transfer, and remain high for the entire transfer if it is a WRITE. DALI is driven only when LANCE is a Bus Master.

## Bus Hold Request (Output Open Drain)

 Asserted by the LANCE when it requires access to memory. $\overline{\mathrm{HOLD}}$ is held LOW for the entire ensuing bus transaction. The function of this pin is programmed through bit ( 00 ) of $\mathrm{CSR}_{3}$. Bit (00) of $\mathrm{CSR}_{3}$ is cleared when RESET is asserted.When $\mathrm{CSR}_{3}(00) \mathrm{BCON}=0$
I/O pin $17=\overline{\text { HOLD }}$ (Output Open Drain)
When $\mathrm{CSR}_{3}$ (00) $\mathrm{BCON}=1$
I/O pin $17=\overline{\text { BUSRQ }}$ (Output Open Drain)
$\overline{B U S R Q}$ will be asserted only if I/O pin 17 is high prior to assertion.

## $\overline{\text { HLDA }}$

## TENA Transmit Enable (Output)

Transmit Output Bit Stream enable. A level asserted with the Transmit Output Bit Stream, TX, to enable the external transmit logic.

RCLK Receive Clock (Input)
A 10 MHz square wave synchronized to the Receive data and only active while receiving an Input Bit Stream.

Collision (Input)
A logical input that indicates that a collision is occurring on the channel.

RENA Receive Enable (Input)
A logical input that indicates the presence of carrier on the channel.

Transmit Clock (Input)
10 MHz clock.
(Input/Output Open Drain)
When the LANCE is a Bus Master, $\overline{\text { READY }}$ is an asynchronous acknowledgement from the bus memory that it will accept data in a WRITE cycle or that it has put data on the DAL lines in a READ cycle.
As a Bus Slave, the LANCE asserts READY when it has put data on the DAL lines during a READ cycle or is about to take data off the DAL lines during a write cycle. READY is a response to $\overline{\mathrm{DAS}}$ and will return HIGH after $\overline{\mathrm{DAS}}$ has gone HIGH. READY is an input when the LANCE is a Bus Master and an output when the LANCE is a Bus Slave.
(Input)
Bus Reset Signal. Causes the LANCE to cease operation, clears its internal logic, and enter an idle state. The stop bit in $\mathrm{CSR}_{0}$ is also set.

VCC Power supply pin +5 volts $\pm 5 \%$.
$v_{s s}$

## PRODUCT OVERVIEW

The parallel interface of the Local Area Network Controller for Ethernet (LANCE) has been designed to be "friendly" or easy to interface to a variety of popular 16-bit microprocessors. These microprocessors include the following: Z8000, 8086, 68000 and LSI-11. The LANCE has a 24-bit wide linear address space when it is in the Bus Master Mode allowing it to DMA directly into the entire address space of the above
microprocessors. A programmable mode of operation allows byte addressing in one of two ways: A Byte/Word control signal compatible with the 8086 and Z8000, or an Upper Data Strobe and Lower Data Strobe signal compatible with microprocessors such as the 68000. A programmable polarity on the Address Strobe signal eliminates the need for external logic. The LANCE interfaces with both multiplexed and demultiplexed data busses and features control signals for address/ data bus transceivers.

Figure 1. LANCE/CPU Interfacing
a. Multiplexed Bus


DF000390
b. Demultiplexed Bus


During initialization, the CPU loads the starting address of the initialization block into two internal control registers. The LANCE has four internal control and status registers (CSR $\mathrm{K}_{0}, 1$, 2, 3) which are used for various functions such as the loading of the initialization block address, different programming modes and status conditions. The host processor communicates with the LANCE during the initialization phase-for demand transmission and periodically to read the status bits following interrupts. All other transfers to and from the memory are handled as DMA under microword control.
Interrupts to the microprocessor are generated by the LANCE upon: 1) completion of its initialization routine, 2) the reception of a packet, 3) the transmission of a packet, 4) transmitter timeout error, 5) a missed packet and 6) memory error.
The cause of the interrupt is ascertained by reading CSR $_{0}$. Bit (06) of $\mathrm{CSR}_{0}$, (INEA) enables or disables interrupts to the microprocessor. In systems where polling is used in place of interrupts, bit (07) of $\mathrm{CSR}_{0}$ (INTR) indicates an interrupt condition.

The basic operation of the LANCE consists of two distinct modes: transmit and receive. In the transmit mode, the LANCE chip directly accesses data (in a transmit buffer) in memory. It prefaces the data with a preamble, sync pattern, and calculates and appends a 32-bit CRC. This packet is then ready for transmission to the Am7991A SIA. On transmission, the first byte of data loads into the 48 -byte FIFO. The LANCE then begins to transmit preamble while simultaneously loading the rest of the packet into FIFO for transmission.
In the receive mode, packets are sent via the SIA to the LANCE. The packets are loaded into the 48 -byte FIFO for preparation of automatic downloading into buffer memory. A CRC is calculated and compared with the CRC appended to the data packet. If the calculated CRC checksum doesn't agree with the packet CRC, an error bit is set.

## DETAILED DESCRIPTION

## ADDRESSING

Packets can be received using 3 different destination addressing schemes: physical, logical and promiscuous.
The first type is a full comparison of the 48 -bit destination address in the packet with the node address that was programmed into the LANCE during an initialization cycle. There are two types of logical address. One is group type mask where the 48 -bit address in the packet is put through a hash filter in order to map the 48 -bit physical addresses into 1 of 64 logical groups. If any of these 64 groups have been preselected as the logical address, then the 48 -bit address is stored in main memory. At this time, a look up is performed comparing the 48 -bit incoming address with the pre-stored 48 bit logical address. The mode can be useful if sending packets to all of a particular type of device simultaneously (i.e., send a packet to all file servers or all printer servers). Additional details on logical addressing can be found in the INITIALIZATION section under "Logical Address Filter.' The second logical address is a broadcast address where all nodes on the
network receive the packet. The last receive mode of operation is the so-called 'promiscuous mode' in which a node will accept all packets on the coax regardless of their destination address.

## COLLISION DETECTION AND IMPLEMENTATION

The Ethernet CSMA/CD network access algorithm is implemented completely within the LANCE. In addition to listening for a clear coax before transmitting, Ethernet handles collisions in a predetermined way. Should two transmitters attempt to seize the coax at the same time, they will collide and the data on the coax will be garbled. The transmitting nodes listen while they transmit, detect the collision, then continue to transmit for a predetermined length of time to "jam" the network and ensure that all nodes have recognized the collision. The transmitting nodes then delay a random amount of time according to the Ethernet 'truncated binary backoff'' algorithm in order that the colliding nodes don't try to repeatedly access the network at the same time. Up to 16 attempts to access the network are made by the LANCE before reporting back an error due to excessive collisions.

## ERROR REPORTING AND DIAGNOSTICS

Extensive error reporting is provided by the LANCE. Error conditions reported relate either to the network as a whole or to data packets. Network-related errors are recorded as flags in the CSRs and are examined by the CPU following interrupt. Packet-related errors are written into descriptor entries corresponding to the packet.
System errors include:

- Babbling Transmitter
- Transmitter attempting to transmit more than 1518 data bytes.
- Collision
- Collision detection circuitry nonfunctional
- Missed packet
- Insufficient buffer space
- Memory timeout
- Memory response failure

Packet-related errors:

- CRC
- Invalid data
- Framing
- Packet did not end on a byte boundary
- Overflow/Underflow
- Indicates abnormal latency in servicing a DMA request
- Buffer
- Insufficient buffer space available

The LANCE performs several diagnostic routines which enhance the reliability and integrity of the system. These include a CRC logic check and two loop back modes (internal/ external). Errors may be introduced into the system to check error detection logic. A Time Domain Reflectometer is incorporated into the LANCE to aid system designers locate faults in the Ethernet cable. Shorts and opens manifest themselves in reflections which are sensed by the TDR.

Figure 2. LANCE/Processor Memory Interface


## BUFFER MANAGEMENT

A key feature of the LANCE and its on-board DMA channel is the flexibility and speed of communication between the LANCE and the host microprocessor through common memory locations. The basic organization of the buffer management is a circular queue of tasks in memory called descriptor rings, as shown in Figure 2. There are separate descriptor rings to describe transmit and receive operations. Up to 128 tasks may be queued up on a descriptor ring awaiting execution by the LANCE. Each entry in a descriptor ring holds a pointer to a data memory buffer and an entry for the length of the data buffer. Data buffers can be chained or cascaded in order to handle a long packet in multiple data buffer areas. The LANCE searches the descriptor rings in a "look ahead manner" to determine the next empty buffer in order to chain buffers together or to handle back-to-back packets. As each buffer is filled, an "own" bit is reset, allowing the host processor to process the data in the buffer.

## LANCE INTERFACE

CSR bits such as ACON, BCON and BSWP are used for programming the pin functions used for different interfacing
schemes. For example, ACON is used to program the polarity of the Address Strobe signal (ALE/ $\overline{\mathrm{AS}}$ ).

BCON is used for programming the pins, for handling either the BYTE/WORD method, for addressing word organized; byte addressable memories where the BYTE signal is decoded along with the least significant address bit to determine upper or lower byte, or an explicit scheme in which two signals labeled as BYTE MASK ( $\overline{\mathrm{BM}}_{0}$ and $\overline{\mathrm{BM}}_{1}$ ) indicate which byte is addressed. When the BYTE scheme is chosen, the $\overline{\mathrm{BM}}_{1}$ pin can be used for performing the function BUSAKO.
$B C O N$ is also used to program pins for different DMA modes. In a daisy chain DMA scheme, 3 signals are used (BUSRQ, HLDA, $\bar{B} U S A K O)$. In systems using a DMA controller for arbitration, only HOLD and HLDA are used.

All data transfers from the LANCE in the Bus Master mode are timed by ALE, $\overline{\mathrm{DAS}}$, and $\overline{\text { READY. The automatic adjustment of }}$ the LANCE cycle by the READY signal allows synchronization with variable cycle time memory due either to memory refresh or to dual port access. Bus cycles are a minimum of 600 ns in length and can be increased in 100 ns increments.


Note: 1. There are two types of delays which depend on which internal register is accessed.
Type 1 refers to access of $\mathrm{CSR}_{0}, \mathrm{CSR}_{3}$ and RAP.
Type 2 refers to access of $\mathrm{CSR}_{1}$ and $\mathrm{CSR}_{2}$ which are longer than Type 1 delay.

## READ SEQUENCE

The read cycle is begun by valid addresses being placed on DAL $00-\mathrm{DAL}_{15}$ and $\mathrm{A}_{16}-\mathrm{A}_{23}$. The BYTE MASK signals are placed valid to indicate a word, upper byte or lower byte memory reference. READ indicates the type of cycle. ALE or $\overline{\mathrm{AS}}$ are pulsed, and the trailing edge of either can be used to latch addresses. DAL $00-$ DAL $L_{15}$ go into a 3 -state mode and $\overline{\mathrm{DAS}}$ falls low to signal the beginning of the memory access. The memory responds by placing READY low to indicate that the DAL lines have valid data. The LANCE then latches memory data on the rising edge of $\overline{\mathrm{DAS}}$, which in turn ends the memory cycle and READY returns to high.

The bus transceiver controls, $\overline{\text { DALI }}$ and $\overline{\text { DALO }}$, are used to control the bus transceivers. $\overline{\text { ALII }}$ signals to strobe data toward the LANCE, and DALO signals to strobe data or addresses away from the LANCE. During a read cycle, DALO goes inactive before DALI becomes active to avoid 'spiking" of the bus transceivers.

## WRITE SEQUENCE

The write cycle is very similar except that the DAL 00 -DAL ${ }_{15}$ lines change from containing addresses to data after ALE or $\overline{A S}$ go inactive. After data is valid on the bus $\overline{\mathrm{DAS}}$ goes active. Data to memory is held valid after $\overline{\mathrm{DAS}}$ goes inactive.


WF001630
 READY. This is a critical parameter. The synchronization must occur within two internal clock ticks 100 ns . Therefore, the setup time will be 100 ns plus the accumulated propagation delays, and the ready slips will occur on 100 ns increments.

## BUS ACQUISITION TIMING



Note: 1. $\overline{\text { RESET }}$ is an asynchronous input to the LANCE and is not part of the Bus Acquisition timing. When RESET is asserted, the LANCE becomes a Bus Slave.

## DIFFERENCES BETWEEN ETHERNET VERSIONS 1 AND 2

a. Version 2 specifies that the collision detect of the transceiver must be activated during the interpacket gap time.
b. Version 2 specifies some network management functions, such as reporting the occurrence of collisions, retries and deferrals.
c. Version 2 specifies that when transmission is terminated, the differential transmit lines are driven OV diff. (half step).

## DIFFERENCES BETWEEN IEEE 802.3 AND ETHERNET

a. 802 specifies a 2-byte length field rather than a type field. The length field (802) describes the actual amount of data in the frame.
b. 802 allows the use of a PAD field in the data section of a frame, while Ethernet specifies the minimum packet size at 64 bytes. The use of a PAD allows the user to send and receive packets which have less than 46 bytes of data.

Differences between Ethernet and 802 at the physical layer include the following:

|  | 802 | Ethernet |
| :--- | :--- | :--- |
| End of Transmis- <br> sion State | Half Step | High State (Rev 1) <br> or Half Step |
| Common Mode <br> Voltage | $\pm 5.5 \mathrm{~V}$ | $0-+5 \mathrm{~V}$ |
| Common Mode | Less than | $1.6 \mathrm{~mA} \pm 40 \%$ |
| Current | 1 mA |  |
| Input Threshold | $\pm 160 \mathrm{mV}$ | $\pm 175 \mathrm{mV}$ |
| Fault Protection | 16 V | 0 V |

## PROGRAMMING SPECIFICATION

This section defines the control and Status Registers and the memory data structures required to program the Am7990 (LANCE).

## PROGRAMMING THE Am7990 (LANCE)

The Am7990 ( $(-A N C E)$ is designed to operate in an environment that includes close coupling with a local memory and a microprocessor (HOST). The Am7990 LANCE is programmed by a combination of registers and data structures resident within the chip and in memory. There are four Control and Status Registers (CSRs) within the chip which are programmed by the HOST device. Once enabled, the chip has the ability to access memory locations to acquire additional operating parameters.
The Am7990 has the ability to do independent buffer management as well as transfer data packets to and from the Ethernet. There are three memory structures accessed by the Chip:

1. Initialization Block - 12 words in contiguous memory starting on a word boundary. It also contains the operating parameters necessary for device operation. The initialization block is comprised of:

- Mode of Operation
- Physical Address
- Logical Address Mask
- Location to Receive and Transmit Descriptor Rings
- Number of Entries in Receive and Transmit Descriptor Rings

2. Receive and Transmit Descriptor Rings - Two ring structures, one each for incoming and outgoing packets. Each entry in the rings is 4 words long and each entry must start on a quadword boundary. The Descriptor Rings are comprised of:

- The address of a data buffer.
- The length of that data buffer.
- Status information associated with the buffer.

3. Data Buffers - Contiguous portions of memory reserved for packet buffering. Data buffers may begin on arbitrary byte boundaries.

In general, the programming sequence of the chip may be summarized as:

1. Programming the chip's CSRs by a host device to locate an initialization block in memory. The byte control, byte addressing, and address latch enable modes are defined here also.
2. The chip loads itself with the information contained within the initialization block.
3. The chip accesses the descriptor rings for packet handling.

## CONTROL AND STATUS REGISTERS

There are four Control and Status Registers (CSRs) resident within the chip. The CSRs are accessed through two bus addressable ports, an address port (RAP) and a data port (RDP).

## ACCESSING THE CONTROL AND STATUS REGISTERS

The CSRs are read (or written) in a two step operation. The address of the CSR to be accessed is written into the address port (RAP) during a bus slave transaction. During a subsequent bus slave transaction, the data being read from (or written into) the data port (RDP) is read from (or written into) the CSR selected in the RAP.

Once written, the address in RAP remains unchanged until rewritten.

To distinguish the data port from the address port, a discrete 1/O pin is provided.

| ADR I/O Pin | Port |
| :---: | :--- |
| L | Register Data Port (RDP) |
| $H$ | Register Address Port (RAP) |

## Register Data Port (RDP)



AF001450

| Bit | Name | Description |
| :---: | :---: | :---: |
| 15:00 | CSR Data | Writing data into RDP writes the data into the CSR selected in RAP. Reading the data from the RDP reads the data from the CSR selected in RAP. CSR $1, \mathrm{CSR}_{2}$ and $\mathrm{CSR}_{3}$ are accessible only when the STOP bit of $\mathrm{CSR}_{0}$ is set. <br> If the STOP bit is not set while attempting to access CSR $_{1}$, $\mathrm{CSR}_{2}$ or $\mathrm{CSR}_{3}$, the chip will return READY, but a READ operation will return undefined data. WRITE operation is ignored. |

## Register Address Port (RAP)




## CONTROL AND STATUS REGISTER DEFINITION



The LANCE updates $\mathrm{CSR}_{0}$ by logical "'ORING" the previous and present value of $\mathrm{CSR}_{0}$.

| Bit | Name | Description |
| :---: | :---: | :--- |
| 15 | ERR | ERROR summary is set by the |
|  | "OR' of BABL, CERR, MISS and |  |
|  | MERR. ERR remains set as long |  |
|  | as any of the error flags are true. |  |

ERR is read only; writing it has no effect. It is cleared by Bus RESET, by setting the STOP bit, or clearing the individual error flags.
BABBLE is a transmitter timeout error. It indicates that the transmitter has been on the channel longer than the time required to send the maximum length packet.
BABL is a flag which indicates excessive length in the transmit buffer. It will be set after 1519 data bytes have been transmitted; the chip will continue to transmit until the whole packet is transmitted or there is a failure. When BABL error occurs, an interrupt will be generated if $\operatorname{INEA}=1$.

BABL is READ/CLEAR ONLY and is set by the chip, and cleared by writing a " 1 " into the bit. Writing a ' 0 ' has no effect. It is cleared by RESET or by setting the STOP bit.

| Bit | Name |
| :---: | :--- | | Description |
| :--- |

CERR is READ/CLEAR ONLY and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 " has no effect. It is cleared by RESET or by setting the STOP bit.

MISS MISSED PACKET is set when the receiver loses a packet because it does not own a receive buffer and the silo has overflowed, indicating loss of data. MISS is not valid in internal loopback mode.

Silo overflow is not reported because there is no receive ring entry in which to write status.
When MISS is set, an interrupt will be generated if $\operatorname{INEA}=1$.
MISS is READ/CLEAR ONLY, and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 " has no effect. It is cleared by- $\overline{\mathrm{RESET}}$ or by setting the STOP bit.
MERR MEMORY ERROR is set when the chip is the Bus Master and has not received READY within $25.6 \mu \mathrm{~s}$ after asserting the address on the DAL lines.

When a Memory Error is detected, the receiver and transmitter are turned off and an interrupt is generated if INEA $=1$.
MERR is READ/CLEAR ONLY, and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 " has no effect. It is cleared by RESET or by setting the STOP bit.
RINT RECEIVER INTERRUPT is set when the chip updates an entry in the Receive Descriptor Ring for the last buffer received before fall of carrier.

When RINT is set, an interrupt is generated if $\operatorname{INEA}=1$.

RINT is READ/CLEAR ONLY, and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 " has no effect. It is cleared by RESET or by setting the STOP bit.

| Bit | Name | Description |
| :--- | :--- | :--- |
| 09 | TINT | TRANSMITTER INTERRUPT is <br> set when the chip updates an <br> entry in the transmit descriptor <br> ring for the last buffer sent before <br> the end of transmission. |

When TINT is set, an interrupt is generated if $\operatorname{INEA}=1$.

TINT is READ/CLEAR ONLY and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 " has no effect. It is cleared by $\overline{\text { RESET }}$ or by setting the STOP bit.

INITIALIZATION DONE indicates that the chip has completed the initialization procedure started by setting the INIT bit. When IDON is set, the chip has read the Initialization Block from memory and stored the new parameters.
When IDON is set, an interrupt is generated if $\operatorname{INEA}=1$.
IDON is READ/CLEAR ONLY, and is set by the chip and cleared by writing a " 1 " into the bit. Writing a " 0 "' has no effect. It is cleared by $\overline{\text { RESET or by setting }}$ the STOP bit.
INTR INTERRUPT FLAG is set by the "OR" of BABL, MISS, MERR, RINT, TINT and IDON. If INEA $=1$ and $\operatorname{INTR}=1$, the INTR I/O pin will be low.
INTR is READ ONLY; writing this bit has no effect. INTR is cleared by RESET, by setting the STOP bit, or by clearing the condition causing the interrupt.

INTERRUPT ENABLE allows the INTR I/O pin to be driven low when the Interrupt Flag is set. If INEA $=1$ and $\operatorname{INTR}=1$, the INTR I/O pin will be low. If INEA $=0$, the INTR I/O pin will be high, regardless of the state of the Interrupt Flag.
INEA is READ/WRITE and cleared by RESET or by setting the STOP bit.



## Control and Status Register 3 (CSR $\mathbf{S}_{\mathbf{3}}$ )

$\mathrm{CSR}_{3}$ allows redefinition of the Bus Master interface.

$$
\mathbf{R A P}=\mathbf{3}
$$

READ/WRITE : Accessible only when the STOP bit of CSR $_{0}$ is ONE. $\mathrm{CSR}_{3}$ is cleared by RESET or by setting the STOP bit in $\mathrm{CSR}_{0}$.


| Bit | Name | Description |
| :--- | :---: | :--- |
| $15: 03$ | RES | Reserved and read as ' 0 '. <br> 02 |
| BSWP | BYTE SWAP allows the chip to <br> operate in systems that consider <br> bits (15:08) to be the least signifi- <br> cant byte and bits (07:00) to be <br> the most significant byte. |  |

When $\mathrm{BSWP}=$ ! , the chip will swap the high and low bytes on DMA data transfers between the silo and bus memory. Only data from silo transfers is swapped; the Initialization Block data and the Descriptor Ring entries are NOT swapped.

BSWP is READ/WRITE and cleared by RESET or by setting the STOP bit in CSR ${ }_{0}$.
01 ACON ALE CONTROL defines the assertive state of ALE when the chip is a Bus Master. ACON is READ/WRITE and cleared by $\overline{\text { RESET }}$ and by setting the STOP bit in $\mathrm{CSR}_{0}$.

| ACON | ALE |
| :---: | :--- |
| 0 | Asserted High |
| 1 | Asserted Low |

$00 \quad$ BCON BYTE CONTROL redefines the Byte Mask and Hold I/O pins. BCON is READ/WRITE and cleared by $\overline{\mathrm{RESET}}$ or by setting the STOP bit in CSR ${ }_{0}$.

|  | I/O Pin | /O | O Pin |
| :---: | :---: | :---: | :---: |
| BCON | 16 | 15 | 17 |
| 0 | $\overline{\mathrm{BM}}_{1}$ | $\overline{B M}_{0}$ | HOLD |
|  | BUSAKO | BYTE | $\overline{\text { BUSRQ }}$ |

All data transfers from the LANCE in the Bus Master mode are in words. However, the LANCE can handle odd address boundaries and/or packets with an odd number of bytes.

## INITIALIZATION

## INITIALIZATION BLOCK

Chip initialization includes the reading of the initialization block in memory to obtain the operating parameters. The following is a definition of the Initialization Block.

The initiaiization Biock is read by the chip when the INIT bit in CSR $_{0}$ is set. The INIT bit should be set before or concurrent with the STRT bit to insure proper parameter initialization and chip operation. After the chip has read the Initialization Block, IDON is set in CSR $_{0}$ and an interrupt is generated if INEA $=1$.


Base Address of Block

| TLEN-TDRA (23:16) | IADR + 22 |
| :---: | :--- |
| TDRA (15:00) | IADR + 20 |
| RLEN-RDRA (23:16) | IADR +18 |
| RDRA (15:00) | IADR +6 |
| LADRF (63:48) | IADR +14 |
| LADRF (47:32) | IADR +12 |
| LADRF (31:16) | IADR +10 |
| LADRF (15:00) | IADR +08 |
| PADR (47:32) | IADR +06 |
| PADR (31:16) | IADR +04 |
| PADR (15:00) | IADR +02 |
| MODE | IADR +00 |

## Mode

The Mode Register allows alteration of the chip's operating parameters. Normal operation is with the Mode Register clear.


| Bit | Name | Description |
| :--- | :--- | :--- |
| 15 | PROM | PROMISCUOUS mode. When <br> PROM $=1$, all incoming packets <br> are accepted. |
| $14: 07$ | RES | RESERVED |



Rings are aligned on quadword boundaries.


AF000480

| Bit | Name | Description |
| :--- | :--- | :--- |
| $15: 13$ | TLEN | TRANSMIT RING LENGTH is the |
|  |  | number of entries in the Transmit <br>  <br>  <br>  <br>  <br>  <br>  <br>  <br>  |


|  |  | TLEN | Number of Entries |
| :---: | :---: | :---: | :---: |
|  |  | 0 | 1 |
|  |  | 1 | 2 |
|  |  | 2 | 4 |
|  |  | 3 | 8 |
|  |  | 4 | 16 |
|  |  | 5 | 32 |
|  |  | 6 | 64 |
|  |  | 7 | 128 |
| 12:08 | RES | RESERVED |  |
| $\begin{aligned} & 07: 00 \\ & 15: 03 \end{aligned}$ | TDRA | TRANSMIT DESCRIPTOR RING ADDRESS is the base address (lowest address) of the Transmit Descriptor Ring. |  |
| 02:00 |  | MUST B <br> are TDR <br> zeroes <br> Rings a <br> boundari | EROES. These bits 2:00) and must be ause the Transmit igned on quadword |

## BUFFER MANAGEMENT

Buffer Management is accomplished through message descriptors organized in ring structures in memory. Each message descriptor entry is four words long. There are two rings allocated for the device: a Receive ring and a Transmit ring. The device is capable of polling each ring for buffers to either empty or fill with packets to or from the channel. The device is also capable of entering status information in the descriptor entry. Chip polling is limited to looking one ahead of the descriptor entry the chip is currently working with.

The location of the descriptor rings and their length are found in the initialization block, accessed during the initialization procedure by the chip. Writing a 'ONE' into the STRT bit of $\mathrm{CSR}_{0}$ will cause the chip to start accessing the descriptor rings and enable it to send and receive packets.

The chip communicates with a HOST device (probably a mircoprocessor) through the ring structures in memory. Each entry in the ring is either 'owned' by the chip or the HOST. There is an ownership bit (OWN) in the message descriptor entry. Mutual exclusion is accomplished by a protocol which states that each device can only relinquish ownership of the descriptor entry to the other device; it can never take ownership, and no device can change the state of any field in any entry after it has relinquished ownership.

## DESCRIPTOR RINGS

Each descriptor in a ring in memory is a 4-word entry. The following is the format of the receive and the transmit descriptors.

## Receive Message Descriptor Entry

Receive Message Descriptor $0\left(\mathrm{RMD}_{0}\right)$


| Bit | Name | Description |
| :--- | :--- | :--- |
| $15: 00$ | LADR | The LOW ORDER 16 address <br> bits of the buffer pointed to by <br> this descriptor. LADR is written by <br> the host and unchanged by the <br> chip. |

## Receive Message Descriptor $1\left(\right.$ RMD $\left._{1}\right)$



| Bit | Name | Description |
| :--- | :--- | :--- |
| 15 | OWN | This bit indicates that the |

This bit indicates that the host ( $O W N=0$ ) or by the chip ( $O W N=1$ ). The chip clears the OWN bit after filling the buffer pointed to by the descriptor entry. The host sets the OWN bit after emptying the buffer. Once the chip or host has relinquished ownership of a buffer, it must not change any field in the four words that comprise the descriptor entry.
14 ERR" ERROR summary is the "OR" of FRAM, OFLO, CRC or BUFF. ERR is set by the chip and cleared by the host.

FRAM FRAMMING ERROR indicates that the incoming packet contained a noninteger multiple of eight bits and there was a CRC error. If there was not a CRC error on the incoming packet, then FRAM will not be set even if there was a noninteger multiple of eight bits in the packet. FRAM is not valid in internal loopback mode. FRAM is set by the chip and cleared by the host.

| Bit | Name | Description |
| :---: | :---: | :---: |
| 12 | OFLO | OVERFLOW error indicates that the receiver has lost all or part of the incoming packet due to an inability to store the packet in a memory buffer before the internal silo overflowed. OFLO is set by the chip and cleared by the host. |
| 11 | CRC | CRC indicates that the receiver has detected a CRC error on the incoming packet. CRC is set by the chip and cleared by the host. |
| 10 | BUFF | BUFFER ERROR is set any time the chip does not own the next buffer while data chaining a received packet. This can occur in either of two ways: 1) the OWN bit of the next buffer is zero, or 2) silo overflow occurred before the chip received the next STATUS. BUFF is set by the chip and cleared by the host. |

If a Buffer Error occurs, an Overflow Error may also occur internally in the SILO, but will not be reported in the descriptor status entry unless both BUFF and OFLO errors occur at the same time.
START OF PACKET indicates that this is the first buffer used by the chip for this packet. It is used for data chaining buffers. STP is set by the chip and cleared by the host.

END OF PACKET indicates that this is the last buffer used by the chip for this packet. It is used for data chaining buffers. If both STP and ENP are set, the packet fits into one buffer and there is no data chaining. ENP is set by the chip and cleared by the host.
The HIGH ORDER 8 address bits of the buffer pointed to by this descriptor. This field is written by the host and unchanged by the chip.



| Bit | Name | Mescription <br> Must be ones. This field is set by <br> the host and unchanged by the <br> chip. |
| :--- | :--- | :--- |
| $15: 12$ | ONES |  |

Transmit Message Descriptor 3 ( TMD $_{3}$ )


| Bit | Name | Description |
| :--- | :--- | :--- |
| 15 | BUFF | BUFFER ERROR is set by the <br> chip during transmission when <br> the chip does not find the ENP <br> flag in the current buffer and does <br> not own the next buffer. This can <br> occur in either of two ways: either <br> the OWN bit of the next buffer is <br> zero, or silo underflow occurred <br> before the chip received the next <br>  <br>  <br>  <br>  <br> STATUS signal. BUFF is set by <br> the chip and cleared by the host. <br> BUFF error will disable the <br> transmitter $\left(C S R_{0}=\right.$ TXON $\left.=0\right)$ |

Bit Name | Description |  |
| :--- | :--- |
|  | If a Buffer Error occurs, an | Underflow Error will also occur internally in the SILO. An underflow Error will not be reported in the descriptor status entry unless both BUFF and UFLO errors occur at the same time.

UNDERFLOW ERROR indicates that the transmitter has truncated a message due to data late from memory. UFLO indicates that the silo has emptied before the end of the packet was reached.

UFLO is set by the chip and cleared by the host.
RES
RESERVED bit. The chip will write this bit with a " 0 ."
LCOL LATE COLLISION indicates that a collision has occurred after the slot time of the channel has elapsed. The chip does not retry on late collisions. LCOL is set by the chip and cleared by the host.
LCAR LOSS OF CARRIER is set when the carrier input (RENA) to the chip goes false during a chipinitiated transmission. The chip does not re-try upon loss of carrier. It will continue to transmit the whole packet LCAR until packet is finished. LCAR is not valid in INTERNAL LOOPBACK MODE. LCAR is set by the chip and cleared by the host.

RETRY ERROR indicates that the transmitter has failed in 16 attempts to successfully transmit a message due to repeated collisions on the medium. If DRTY $=1$ in the MODE register, RTRY will set after 1 failed transmission attempt. RTRY is set by the chip and cleared by the host.

TIME DOMAIN REFLECTOMETRY reflects the state of an internal chip counter that counts from the start of a transmission to the occurrence of a collision. This value is useful in determining the approximate distance to a cable fault. The TDR value is written by the chip and is valid only if RTRY is set.


## 68000 TO LANCE INTERFACE

The goal of this interface was to be compatible with 8 MHz and faster 68000s while minimizing parts count. The Am22V10 could be used to eliminate the two flip-flops shown. Autovectoring is used since the Am7990 does not return a vector during interrupt acknowledge cycles. Note program BSWP, $B C O N$ to 1 and ACON to 0 .
/AS RW BYTE/HOLD NC/BG AO NC/BGACK GND /CS/TB/ UDS/DAS/CLR BR NC/LDS/RB VCC

If (/BGACK) RB $=$ CS**RW*UDS $^{*}+$ CS**R**LDS $^{*}$
If (/BGACK) TB $=$ CS*/RW
If (BGACK) UDS $=$ DAS $^{*} / A O^{*} B Y T E+/ B Y T E * D A S$
If (BGACK) LDS $=D A S^{*} A O * B Y T E+/ B Y T E * D A S$
If (/BGACK) DAS = UDS*LDS
$C L R=/ A S * B G$
$B R=/ H O L D$


## 186 TO LANCE INTERFACE

This PAL design assumes that the 186 and LANCE are on the same board. The data bus buffer is only enabled if the LANCE is not selected. It seems natural to program the LANCE for ALE output. However, the PAL equations or indeed a discrete design is easier if/AS is used. This is because the LANCE tristates ALE; the 186 does not. Note data will be valid on the falling edge of/WR in min mode, meeting the apparent requirement of the LANCE in early data sheets. Data set up time is specified with respect to the rising edge of DAS in later data sheets; thus the designer has more flexibility. All transfers to or from the LANCE must be words. Program ACON to 1, BCON and BSWP to 0 .

ALE/AS DTR NC NC DEN NC/READY HLDA GND /CS ARDY READ/R/T/DAS/WR/RD LE VCC

If (/HLDA) DAS = RD + WR
If (/HLDA)/READ $=$ DTR
If (/HLDA) T = DTR*/CS
If (/HLDA) R = /DTR*DEN*/CS
If (HLDA) RD = READ*DAS
If (HLDA) WR = /READ*DAS
$/ L E=/ A L E+/ A S$
$/ A R D Y=/$ READY

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature with Applied Powers $\qquad$ Ground Potential .$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous $\qquad$
DC Voltage Applied to Outputs For High Output State $\qquad$ -0.5 V to $+\mathrm{V}_{\mathrm{CC}}$ max
DC input Voltage $\qquad$ .... -0.5 V to +5.5 V
DC Output Current, Into Outputs ..........................: 20mA
DC Input Current ..............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature ..................................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ............................. +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | Min | Typ | Max |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage |  | -0.5 |  | Units |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage |  | 2 |  | 0.8 |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output LOW Voltage | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |  | $\mathrm{~V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ | Volts |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | 0.5 |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | 2.4 |  | Volts |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters |  | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bus Slave Timing |  |  |  |  |  |  |  |
| 1 | ${ }^{\text {t }}$ CSH | Chip Select Hold Time after DAS LOW to HIGH |  | 0 |  |  | ns |
| 2 | ${ }^{\text {t }}$ CSS | Chip Select Setup Time before $\overline{\text { DAS HIGH to LOW }}$ |  | 0 |  |  | ns |
| 3 | tsAH | ADR Hold Time following D- |  | 0 |  |  | ns |
| 4 | tsas | ADR Setup Time before $\overline{\text { DAS }}$ HIGH to LOW |  | 0 |  |  | ns |
| 5 | ${ }^{\text {t }}$ SDO1 | Data Delay following $\overline{\text { DAS }}$ HIGH to LOW | $\mathrm{CSR}_{0}, \mathrm{RAP}, \mathrm{CSR}_{3}$ |  | 400 |  | ns |
|  | tSDO2 |  | $\mathrm{CSR}_{1}, \mathrm{CSR}_{2}$ |  | 1200 |  |  |
| 6 | tsRDS | Read Data Setup Time before $\overline{\text { READY }}$ HIGH to LOW |  | 75 |  |  | ns |
| 7 | tsRDH | Data Hold Time following $\overline{\text { DAS }}$ LOW to HIGH (Read Cycle) |  | 0 |  | 35 | ns |
| 8 | tSRYH | READY Hold Time after DAS LOW to HIGH |  | 0 |  | 35 | ns |
| 9 | tsRH | READ Hold Time after DAS LOW to HIGH |  | 0 |  |  | ns |
| 10 | ${ }_{\text {tSRO1 }}$ | READY Driver Turn on Time after $\overline{\mathrm{DAS}}$ HIGH to LOW | $\mathrm{CSR}_{0}, \mathrm{CSR}_{3}, \mathrm{RAP}$ |  | 600 |  | ns |
|  | tSRO2 |  | $\mathrm{CSR}_{1}, \mathrm{CSR}_{2}$ |  | 1400 |  |  |
| 11 | tsRS | READ Setup Time before DAS HIGH to LOW |  | 0 |  |  | ns |
| 12 | ${ }^{\text {tSWDH }}$ | Data Hold Time after DAS LOW to HIGH (Write Cycle) |  | 0 |  |  | ns |
| 13 | tswDS | Data Setup Time before $\overline{\text { DAS }}$ HIGH to LOW (Write Cycle) |  | 0 |  |  | ns |

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters |  | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bus Master Timing |  |  |  |  |  |  |  |
| 1 | tXAS | Extended Address Setup Time before ALE HIGH to LOW |  | 75 |  |  | ns |
| 2 | tXAH | Extended Address Hold Time after $\overline{\text { DAS }}$ LOW to HIGH |  | 35 |  |  | ns |
| 3 | $t_{\text {AS }}$ | Address Setup Time before ALE HIGH to LOW |  | 75 |  |  | ns |
| 4 | $t_{\text {AH }}$ | Address Hold Time after ALE HIGH to LOW |  | 35 |  |  | ns |
| 5 | trdas | READ Data Setup Time before DAS LOW to HIGH |  | 50 |  |  | ns |
| 6 | $t_{\text {RDAH }}$ | READ Data Hold Time after DAS LOW to HIGH |  | 0 |  |  | ns |
| 7 | $t_{\text {ALEW }}$ | ALE Width |  | 130 |  |  | ns |
| 8 | twDS | WRITE Data Setup Time before $\overline{\text { DAS }}$ LOW to HIGH |  | 200 |  |  | ns |
| 9 | twDH | WRITE Data Hold Time DAS LOW to HIGH |  | 35 |  |  | ns |
| 10 | t DDAS | WRITE Data Setup Time before $\overline{\text { DAS }}$ HIGH to LOW |  | 0 |  |  | ns |
| 11 | tosw | $\overline{\text { DAS }}$ Width |  | 200 |  |  | ns |
| 12 | tDALE | Delay from DAS LOW to HIGH to ALE LOW to HIGH |  | 70 |  |  | ns |
| 13 | $t_{\text {ADAS }}$ | Delay from ALE HIGH to LOW to DAS HIGH to LOW |  | 80 |  |  | ns |
| 14 | $t_{\text {tridF }}$ | Delay from $\overline{\text { DALO }}$ LOW to HIGH to $\overline{\text { DAS }}$ HIGH to LOW (Read Cycle) |  | 35 |  |  | ns |
| 15 | trdys | प्READY Setup Time before $\overline{\text { DAS }}$ LOW to HIGH (See Note) |  | 75 |  | 250 | ns |
| 16 | $\mathrm{t}_{\text {RDYH }}$ | $\overline{\text { READY }}$ Hold Time after $\overline{\mathrm{DAS}}$ LOW to HIGH |  | 0 |  |  | ns |
| 17 | tos | $\overline{\text { DALO }}$ Setup Time before ALE HIGH to LOW |  | 110 |  |  | ns |
| 18 | $\mathrm{t}_{\mathrm{ROH}}$ | $\overline{\text { DALO }}$ Hold Time after ALE HIGH to LOW (Read Cycle) |  | 35 |  |  | ns |
| 19 | $\mathrm{t}_{\text {ROIF }}$ | Delay from $\overline{\text { DALO LOW }}$ to HIGH to $\overline{\text { DALI HIGH to LOW }}$ (Read Cycle) |  | 35 |  |  | ns |
| 20 | tris | $\overline{\text { DALI }}$ Setup Time before $\overline{\text { DAS }}$ LOW to HIGH (Read Cycle) |  | 135 |  |  | ns |
| 21 | $t_{\text {RIH }}$ | $\overline{\text { DALI }}$ Hold Time after $\overline{\mathrm{DAS}}$ LOW to HIGH (Read Cycle) |  | 0 |  |  | ns |
| 22 | $\mathrm{t}_{\text {RIOF }}$ | Delay from DALI LOW to HIGH to DALO HIGH to LOW (Read Cycle) |  | 55 |  |  | ns |
| 23 | twDSI | Delay from $\overline{\text { DAS }}$ LOW to HIGH to $\overline{\text { DALO }}$ LOW to HIGH (Write Cycle) |  | 35 |  |  | ns |
| 24 | $t_{\text {ARYD }}$ | Delay from the falling edge of ALE to the falling edge of READY to insure a minimum Bus Cycle time (600ns). |  |  |  | 80 | ns |

Note: The $\overline{R E A D Y}$ setup time before negation of $\overline{\text { DAS }}$ is a function of the synchronization time of $\overline{R E A D Y}$. The synchronization must occur within two clock ticks ( 100 ns ). Therefore, the setup time is 100 ns plus any accumulated propagation delays. Ready slips occur on 100 ns increments.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

| Parameters |  | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bus Acquisition Timing |  |  |  |  |  |  |  |
| 1 | tDON | Bus Master Driver Enable Time after Assertion of HLDA |  | 0 |  | 250 | ns |
| 2 | tDOFF | Bus Master Driver Disable Time after Deassertion of HOLD |  | 0 |  | 50 | ns |
| 3 | trw | $\overline{\text { RESET Pulse Width (Note 1) }}$ |  | 200 |  |  | ns |
| 4 | thHA | HOLDA $\downarrow$ to HOLD |  | 0 |  |  |  |
| 5 | tTCT | TCLK Period |  | 99 |  | 101 | ns |
| 6 | ${ }_{\text {t }}$ TCL | TCLK Low Time |  | 45 |  | 55 | ns |
| 7 | ${ }_{\text {t }}$ | TCLK High Time |  | 45 |  | 55 | ns |
| 8 | tTCR | Rise Time of TCLK |  | 0 |  | 8 | ns |
| 9 | tTCF | Fall Time of TCLK |  | 0 |  | 8 | ns |
| 10 | tTEP | TENA Propagation Delay after the Rising Edge of TCLK | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 95 | ns |
| 11 | tTEH | TENA Hold Time after the Rising Edge of TCLK | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 5 |  |  | ns |
| 12 | tTDP | TX Data Propagation Delay after the Rising Edge of TCLK | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 95 | ns |
| 13 | ttD | TX Data Hold Time after the Rising Edge of TCLK | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | 5 |  |  | ns |
| 14 | trct | RCLK Period |  | 85 |  | 118 | ns |
| 15 | $\mathrm{t}_{\mathrm{RCH}}$ | RCLK High Time |  | 38 |  |  | ns |
| 16 | $\mathrm{t}_{\mathrm{HCL}}$ | RCLK Low Time |  | 38 |  |  | ns |
| 17 | ${ }_{\text {t }}$ | Pise Time of RCLLK |  | 0 |  | 8 | ns |
| 18 | $t_{\text {tref }}$ | Fall Time of RCLK |  | 0 |  | 8 | ns |
| 19 | trin | RX Data Rise Time |  | 0 |  | 8 | ns |
| 20 | trif | RX Data Fall Time |  | 0 |  | 8 | ns |
| 21 | $\mathrm{t}_{\text {RDH }}$ | RX Data Hold Time (RCLK to RX Data Change) |  | 5 |  |  | ns |
| 22 | trds | RX Data Setup Time (RX Data Stable to the Rising Edge of RCLK) |  | 60 |  |  | ns |
| 23 | tDPL | RENA Low Time |  | 120 |  |  | ns |
| 24 | ${ }_{\text {t }}$ | CLSN High Time |  | 80 |  |  | ns |

Note: 1. $\overline{R E S E T}$ is an asynchronous input and does not occur as part of the Bus Acquisition cycle.

## SERIAL LINK TIMING



Note: 1.25 ns offset from TCLK ( $1 / 4$ bit time and $3 / 4$ bit time from TCLK positive edge).
Timing measurements are made at the following voltages, unless otherwise specified:

|  | High | Low |
| :--- | :---: | :--- |
| Output | 2.0 V | 0.8 V |
| Input | 2.0 V | 0.8 V |
| Float | V | 0.5 V |

# Am7991A/Am7992A* 

Serial Interface Adapter (SIA)

## DISTINCTIVE CHARACTERISTICS

- Crystal controlled Manchester Encoder
- Manchester Decoder acquires clock and data within six bit times with an accuracy of $\pm 3 \mathrm{~ns}$
- Carrier/collision detected for greater than -300mV
- No carrier/collision for less than -175 mV
- Receiver decodes Manchester data with up to $\pm 20 \mathrm{~ns}$ clock jitter (at 10 MHz )
- Input signal conditioning rejects transient noise - Transients <10ns for collision detector inputs
- Transients $<16 \mathrm{~ns}$ for carrier detector inputs
- TTL compatible host interface
- Transmit accuracy $\pm 0.01 \%$ (without adjustments)


## GENERAL DESCRIPTION

The Am7991A Serial Interface Adapter (SIA) is a Manchester Encoder/Decoder compatible with both Ethernet and IEEE-802.3 specifications. In an Ethernet/IEEE-802.3 application the Am7991A interfaces the Am7990 Local Area Network Controller for Ethernet (LANCE) to the Ethernet transceiver cable, acquires clock and data within 6 bit-
times, and decodes Manchester data with up to $\pm 20 \mathrm{~ns}$ phase jitter at 10 MHz . SIA provides both guaranteed signal threshold limits and transient noise suppression circuitry in both data and collision paths to minimize false start conditions.

BLOCK DIAGRAM
Serial Interface Adapter (SIA)


RELATED PRODUCTS

| PART NO | DESCRIPTION |
| :--- | :--- |
| Am7990 | Local Area Network Controller for Ethernet |
| Am7995 | Ethernet Transceiver |

## CONNECTION DIAGRAM

 Top View
## D-24-1



TYPICAL ETHERNET NODE


## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

| Am7991A/92A |  |
| :---: | :---: |

Device type
Serial Interface Adapter (SIA)


Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

* 7992A only available in D-24-SLIM.


## PIN DESCRIPTION

Transmit Enable (Input)
TTL compatible input. Active high data encoder enable. Signals meeting setup and hold time to TCLK will allow encoding of Manchester data from TX to Transmit + and Transmit - .
Collision (output)
A TTL active high output. Signals at the Collision $\pm$ terminals meeting threshold and pulse width requirements will produce a logic high at CLSN output. When no signal is present at Collision $\pm$, CLSN output will be low.

Receive Clock (output)
A MOS/TTL output recovered clock. When there is no signal at Receive $\pm$ and TEST is high, RCLK is low. RCLK is activated after the third negative data transmission at Receive $\pm$, and remains active until end of message. When TEST is low, RCLK is enabled independent of Receive $\pm$.

## Transmit (Input)

TTL compatible input. When TENA is high, signals at TX meeting setup and hold time to TCLK will be encoded as normal Manchester at Transmit + and Transmit -.
TX High: Transmit + is negative with respect to Transmit - for first half of data bit cell.
TX Low: Transmit + is positive with respect to Transmit - for first half of data bit cell.

Transmit Clock (output)

MOS/TTL output. TCLK provides symmetrical high and low clock signals at data rate for reference timing of data to be encoded. It also provides clock signals for the controller chip (Am7990 - LANCE) and an internal timing reference for receive path voltage controlled oscillators.

Receiver (Inputs)
Receive - A differential input. A pair of internally biased line receivers consisting of a carrier detect receiver with offset threshold and noise filtering to detect the signal, and a data recovery receiver with no offset for Manchester data decoding.

## Collision + <br> Collision (Inputs)

A differential input. An internally biased line receiver input with offset threshold and noise filtering. Signals at Collision $\pm$ have no effect on data path functions.

Transmit Mode Select
An open collector output and sense amplifier input.
TSEL Low: . Idle transmit state Transmit + is positive with respect to Transmit -.
TSEL High: Idle transmit state Transmit + and Transmit - are equal, providing "zero" differential to operate transformer coupled loads.

When connected with an RC network, TSEL is held low during transmission. At the end of transmission the open collector output is disabled, allowing TSEL to rise and provide a smooth transmission from logic high to "zero' differential idle. Delay and output return to zero are externally controlled by the RC time constant TSEL.

## Biased Crystal Oscillator

$X_{1}$ is the input and $X_{2}$ is the bypass port. When connected for crystal operation, the system clock which appears at TCLK is half the frequency of the crystal oscillator. $\mathrm{X}_{1}$ may be driven from an external source of two times the data rate.

Frequency Setting Voltage Controlled Oscillator ( $\mathrm{V}_{\text {co }}$ ) Loop Filter
This loop filter output is a reference voltage for the receive path phase detector. It also is a reference for timing noise immunity circuits in the collision and receive enable path. Nominal reference $\mathrm{V}_{\mathrm{CO}}$ gain is 1.25 TCLK frequency $\mathrm{MHz} / \mathrm{V}$.

PF
Transmit (outputs)
A differential line output. This line pair is intended to operate into terminated transmission lines. For signals meeting setup and hold time to TCLK at TENA and TX Manchester clock the data is outputted at Transmit + /Transmit -. When operating into a $78 \Omega$ terminated transmission line signalling meets the required output levels and skew for both Ethernet and IEEE 802.3 drop cables.

|  | positive with respect to Transmit |
| :--- | :--- |
| TSEL High: | Idle transmit state Transmit + <br> and Transmit" are equal, pro- <br> viding "ezero" differential to op- <br> erate transformer coupled loads. |
|  |  |





## TEST

## Test Control (Input)

A static input that is connected to $\mathrm{V}_{\mathrm{CC}}$ for normal Am7991 operation and to ground for testing of receive path function. When TEST is grounded RCLK and RX are enabled so that receive path loop may be functionally tested.

| GND $_{1}$ | High Current Ground |
| :--- | :--- |
| GND $_{2}$ | Logic Ground |
| GND $_{3}$ | Voltage Controlled Oscillator Ground |
| $\mathbf{V C C 1}$ | High Current and Logic Supply |
| $\mathbf{V C C 2}$ | Voltage Controlled Oscillator Supply |

## DETAILED DESCRIPTION

The Am7991A Serial Interface Adapter (SIA) has three basic functions. It is a Manchester Encoder/line driver in the transmit path, a Manchester Decoder with noise filtering and quick lock-on characteristics in the receive path, and a signal detect/converter ( 10 MHz differential to TTL ) in the collision path. In addition, the SIA provides the interface between the TTL logic environment of the Local Area Network Controller for Ethernet (LANCE) and the differential signaling environment in the transceiver cable.

## TRANSMIT PATH

The transmit section encodes separate clock and NRZ data input signals meeting the set up and hold time to TCLK at TENA and TX, into a standard Manchester II serial bit stream. The transmit outputs (transmit + /transmit -) are designed to operate into terminated transmission lines. When operating into a $78 \Omega$ terminated transmission line, signaling meets the required output levels and skew for both Ethernet and IEEE-802.3

Figure 1. Transmit Section


DF000190

## Transmitter Timing and Operation

A 20 MHz fundamental mode crystal oscillator provides the basic timing reference in the SIA. It is divided by two to create the transmit clock reference (TCLK). Both 20 MHz and 10 MHz clocks are fed into the Manchester Encoder to generate the transitions in the encoded data stream. The 10 MHz clock, TCLK, is used by the SIA to internally synchronize transmit data (TX) and transmit enable (TENA). TCLK is also used as a stable bit rate clock by the receive section of the SIA and by other devices in the system (the AM7990 LANCE used TCLK to drive its internal state machine). The oscillator may use an external $.005 \%$ crystal or an external TTL level input as a reference. Transmit accuracy of $.01 \%$ is achieved (no external adjustments are required).

TENA is activated when the first bit of data is made available on TX. As long as TENA remains High, signals at TX will be encoded as Manchester and will appear at transmit + and transmit -. When TENA goes Low, the differential transmit outputs go to one of two idle states:

- Mode 1 - (TSEL High) The idle state of transmit + /transmit - yields 'zero' differential to operate transformer coupled loads.
- Mode 2 - (TSEL Low) in this idle state, transmit + is positive to transmit - (logical High). (Figure 11A)


## RECEIVE PATH

The principle function of the receiver is the separation of the Manchester encoded data stream into clock and NRZ data.

## Input Signal Conditioning

Before the data and clock can be separated it must be determined whether there is "real' data or unwanted noise at the transceiver interface. The Am7991A SIA carrier detection receiver provides a static noise margin of -175 mV to -300 mV for received carrier detection. These DC thresholds assure that no signal more positive than -175 mV is ever decoded and that signals more negative than -300 mV are always decoded. Transient noise of less than 10 ns duration in the collision path and 16 ns duration in the data path are also rejected.

Figure 2. Receiver


DF000200
The stage prevents unwanted idle state noise on the transceiver cable from causing 'false starts' in the receiver. This helps assure a valid response to "real' data.

The receiver section (Figure 3) consists of two data paths. The receive data path is designed to be a zero threshold, high bandwidth receiver. The carrier detection receiver is similar, but with an additional bias generator. Only data amplitudes larger than the bias level are interpreted as valid data. The noise rejection filter prevents noise transients <16ns from enabling the data receiver output. The collision detector similarly rejects noise transients <10ns.

## Receiver Section Timing

Receive Enable (RENA) is the "carrier present" indication established when a signal of sufficient amplitude ( $\mathrm{V}_{\text {IDC }}$ ) and duration (thPWR) is present at the receive inputs. Receive Clock (RCLK) and Receive Data ( RX ) become available after the third negative data transition at receive + /receive - inputs, and stay active until end of packet. During reception, RX is synchronous with RCLK changing after the rising edge of RCLK.
The receiver detects the end of a packet when the normal transition on the differential inputs cease. After the last Low-to-High transition, RENA goes Low and RCLK completes
one last cycle, storing the last data bit. It then goes Low, and remains Low. (See Receive End of Packet Timing diagrams.) When TEST is Low, RCLK does not go Low and stay Low but continues to run.

## Receive Clock Control

To ensure quick capture of incoming data the receiver phase-locked-loop is frequency locked to the transmit oscillator and it phase locks to incoming data edges.

Clock and data are available within 6 bit times (accurate to within $\pm 3 \mathrm{~ns}$ ). The SIA will decode jittered data of up to $\pm 20 \mathrm{~ns}$ (Figure 4).

## Differential 1/0 Terminations

The differential input for the Manchester data (receive $\pm$ ) is externally terminated by two $40.2 \Omega \pm 1 \%$ resistors and one
optional common mode bypass capacitor. The differential input impedance $Z_{\text {IDF }}$ and the common mode input $Z_{\text {ICM }}$ are specified so that the Ethernet specification for cable termination impedance is met using standard $1 \%$ resistor terminators. The collision $\pm$ differential input is terminated in exactly the same way as the receive input (See External Component diagram)

## Collision Detection

The Ethernet Transceiver detects collisions on the Ethernet and generates a 10 MHz signal on the transceiver cable (collision +/collision-). This collision signal passes through an input stage which assures signal levels and pulse duration. When the signal is detected by the SIA, the SIA sets the CLSN line High. This condition continues for approximately 190ns after the last Low-to-High transition on collision + /collision-.

Figure 3. Receiver Section Detail


Figure 4. Maximum Jitter Impact on Sampling


DF000180

Am7991A
External Component Diagram


AF000450
Notes: 1. Connect $R_{1}, C_{1}$, for 0 differential nontransmit. Connect to ground for logic 1 differential nontransmit.
2. Pin 20 shown for normal device operation.
3. Nodes $A$ and $B$ may be connected directly to ground for proper decoder operation, or to the common mode bypass $\mathrm{C}_{4}$ and $\mathrm{C}_{5}$. Some direct coupled transceivers require $\mathrm{C}_{4}$ and $\mathrm{C}_{5}$ to ground for proper operation.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with
Power Applied............................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
Continuous ................................
DC Voltage Applied to Outputs For
High Output State $\qquad$
$\qquad$ .-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$ DC Input Voltage (Logic Inputs) ............................ +5.5 V DC Input Voltage (Rec Coll) $\qquad$ -6 V to +6 V
 DC Output Current, Into Outputs ............................100mA DC Input Current (Logic Inputs) ........................... $\pm 30 \mathrm{~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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage
ge..
Military (M) Devices
Temperature $\qquad$
Supply Voltage ............................. 4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output High Voltage RXD, RENA, CLSN,TCLK | $\mathrm{IOH}=-1.0 \mathrm{~mA}$ | 2.4 | 3.4 |  | V |
| VOL | Output Low Voltage RCLK, TCLK, RENA RXD, CLSN, TSEL | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 | V |
|  |  | $\mathrm{IOL}=1 \mathrm{~mA}$ |  |  | 0.4 |  |
| $V_{O D}$ | Differential Output Voltage (Transmit+)-(Transmit-) | $\mathrm{RL}=78 \Omega$ | 550 |  | 900 | mV |
|  |  |  | -550 |  | -900 |  |
| VOD OFF | Transmit Differential Output İdle Voltage |  | -20 | 0.5 | 20 | mV |
| IOD OFF | Transmit Differential Output Idle Current |  | -0.5 | $\pm 00.1$ | 0.5 | mA |
| $\mathrm{V}_{\text {CMT }}$ | Common Mode Output Transmit |  | 0 |  | 5 | V |
| $\mathrm{V}_{\text {ODI }}$ | Differential Output Voltage Imbalance (Transmit $\pm$ ) \||Vol-| $\overline{V_{0}} \\|$ |  |  | 5 | 20 | mV |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage TTL |  | 2.0 |  |  | V |
| IIH | Input High Current TTL | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | +50 | $\mu$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage TTL |  |  |  | 0.8 | V |
| ILL | Input Low Current TTL | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  | -400 | $\mu$ |
| VIRD | Differential Input Threshold (Rec Data) |  | -25 | 0 | +25 | mV |
| VIDC | Differential Input Threshold (Carrier/Collision $\pm$ ) |  | -175 | -225 | -300 | mV |
| Icc | Power Supply Current | tosc $=50 \mathrm{~ns}$ |  | 100 | 180 | mA |
|  |  | $\mathrm{t}_{\mathrm{OSC}}=50 \mathrm{~ns}, \mathrm{~T}_{\mathrm{A}}=\mathrm{MAX}$ |  |  | 160 |  |
| 1 | Input Breakdown Current $\mathrm{V}_{1}=+5.5$ ( $\mathrm{T}_{\mathrm{X}}$, TENA) |  |  |  | 1 | mA |
| VIC | $\mathrm{I}_{\mathrm{N}}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| Isco | RXD, TCLK, CLSN, RENA Short Circuit Current |  | -40 |  | -150 | mA |
| RIDF | Differential Input Resistance | $\mathrm{V}_{\text {CC }}=0$ to MAX | 6k | 8.4k | 13k | $\Omega$ |
| RICM | Common Mode Input Resistance | $\mathrm{V}_{\mathrm{CC}}=0$ to MAX | 1.5k | 2.1 k | 3.25k | $\Omega$ |
| VICM | Receive and Collision Input Voltage | IIN $=0$ | 2.5 | 3.5 | 4.2 | V |
| IILD | Receive and Collision Input Low Current | $\mathrm{V}_{1 \mathrm{~N}}=-1 \mathrm{~V}$ | -0.32 | -1.06 | -1.64 | mA |
| 1 IHD | Receive and Collision Input High Current | $\mathrm{V}_{\text {IN }}=6 \mathrm{~V}$ | +0.14 | +0.6 | +1.10 | mA |
| $\mathrm{l}_{1 \mathrm{HZ}}$ | Receive and Collision Input High Current | $\mathrm{V}_{\mathrm{CC}}=0, \mathrm{~V}_{\text {IN }}=+6 \mathrm{~V}$ | 0.4 | 1.28 | 1.86 | mA |

## SWITCHING TEST CIRCUIT

Figure 5. Test Load for RX, RENA, RCLK, TCLK


TC000470

Figure 6. Transmit $\pm$ Output Test Circuit


TC000461

Figure 7. Receive $\pm$ and Collision $\pm$ Input Test Circui t


TC000480

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right.$ )

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Receiver Specification |  |  |  |  |  |  |
| $t_{\text {RCT }}$ | RCLK Cycle Time | tosc $=50 \mathrm{~ns}$ | 85 |  | 118 | ns |
| ${ }_{\text {tren }}$ | RCLK High Time. |  | 38 |  |  | ns |
| $\mathrm{t}_{\mathrm{RCL}}$ | RCLK Low Time |  | 38 |  |  | ns |
| tren | RCLK Rise Time | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ <br> Figures 13 and 14 (Note 1) | 0 |  | 8 | ns |
| $t_{\text {tra }}$ | RCLK Fall Time |  | 0 |  | 8 | ns |
| trin | RX Rise Time |  | 0 |  | 8 | ns |
| trif | RX Fall Time |  | 0 |  | 8 | ns |
| $t_{\text {RDH }}$ | RX Hold Time (RCLK to RX Change) |  | 5 |  |  | ns |
| trDS | RX Prop Delay (RCLK to RX Stable) |  |  |  | 25 | ns |
| tDPH | RENA Turn-On Delay (VIDC on Receive $\pm$ to RENA ${ }_{H}$ ) | Figures 7 and 8 |  |  | 180 | ns |
| tDPO | RENA Turn-Off Delay ( $\mathrm{V}_{\text {IDH }}$ on Receive $\pm$ to RENA ${ }_{\text {L }}$ ) | Figures 7 and 9 |  |  | 160 | ns |
| tDPL | RENA Low Time | Figure 9 | 120 |  |  | ns |
| trpwR | Receive $\pm$ Input Pulse Width to Reject ( Input < VIDC) | Figures 7 and 14 |  |  | 16 | ns |
| trpwo | Receive $\pm$ Input Pulse Width to Turn-On (Input < $\mathrm{V}_{\text {IDC }}$ ) | Figures 7 and 14 | 40 |  |  | ns |
| trLT | Decoder Acquisition Time | Figure 8 |  |  | 600 | ns |
| Collision Specification |  |  |  |  |  |  |
| tCPWR | Collision Input Pulse Width to Reject (input < $\mathrm{V}_{\text {IDC }}$ ) | Figures 7 and 14 |  |  | 10 | ns |
| tcPWO | Collision Input Pulse Width to Turn-on (Collision $\pm$ Exceeds VIDC) | Figures 7, 12 and 14 | 26 |  |  | ns |
| tCPWE | Collision Input to Turn-Off CSLN (input > V ${ }_{\text {ILDO }}$ ) | Figures 7 and 14 | 80 |  |  | ns |
| tCPWN | Collision Input to Not Turn-Off CLSN (Input $>\mathrm{V}_{\text {IDC }}$ ) |  |  |  | 160 | ns |
| ${ }^{\text {t CPH }}$ | CLSN Turn-On Delay (VIDC on Collision $\pm$ to $\mathrm{CLSN}_{\mathrm{H}}$ ) | Figures 7, 12 and 13 |  |  | 180 | ns |
| ${ }_{\text {t }}$ | CLSN Turn-Off Delay ( $\mathrm{V}_{\text {IHD }}$ on Collision $\pm$ to $\mathrm{CLSN}_{\text {L }}$ ) |  |  |  | 160 | ns |


| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Specification |  |  |  |  |  |  |
| ${ }_{\text {t }}$ | TCLK Low Time | $\mathrm{tOSC}=50 \mathrm{~ns}$ <br> Figures 5 and 15 | 45 |  | 55 | ns |
| ${ }_{\text {tTCH }}$ | TCLK High Time |  | 45 |  | 55 | ns |
| ${ }_{\text {t TCR }}$ | TCLK Rise Time |  | 0 |  | 8 | ns |
| tTCF | TCLK Fall Time |  | 0 |  | 8 | ns |
| ttos, tes | TXD and TEN Setup Time | Figures 11 and 12 | 5 |  |  | ns |
| tTDH, ${ }_{\text {teh }}$ | TXD and TEN Hold Time |  | 5 |  |  | ns |
| t'OCE | Transmit $\pm$ Output, (Bit Cell Center to Edge) | Figures 6 and 11 | 49.5 |  | 50.5 | ns |
| tod | TCLK High to Transmit $\pm$ Output |  |  |  | 100 | ns |
| tTOR | Transmit $\pm$ Output Rise Time | $20-80 \%$ <br> Figure 11 | 1 |  | 5 | ns |
| ttof | Transmit $\pm$ Output Fall Time |  | 1 |  | 5 | ns |
| VOD1 | Transmit Return to Zero Differential at End of Message Voltage at 1 Bit Time |  |  |  |  | mV |
| $\mathrm{V}_{\text {OD2 }}$ | Transmit Return to Zero Differential at End of Message Voltage at 2 Bit Time |  |  |  |  | mV |
| VOD3 | Undershoot Voltage at Zero Differential Point on Transmit Return to Zero (End of Message) |  |  |  |  | mV |

Note 1. Assumes equal capacitance loading on RCLK and RX.
Figure 8. Receiver Timing - Start of Packet


Figure 9. Receiver Timing - End of Packet (Last Bit $=0$ )



Figure 11A. Transmitter Timing - Start of Transmission


Figure 11b. Start of Transmit - Modes 1 and 2



Figure 13. Collision Timing


Figure 14. Input Pulse Width Timing


WF001711

Figure 15. RCLK and TCLK Duty Cycle and Rise/Fall Time


WF002210

## Am8120

Octal D-Type Flip-Flop with Clear, Clock Enable and Three-State Control

## DISTINCTIVE CHARACTERISTICS

- Buffered common clock enable input
- Buffered common asynchronous clear input
- Three-state outputs
- 8-bit, high-speed parallel register with positive edgetriggered, D-type flip-flops


## GENERAL DESCRIPTION

The Am8120 is an 8-bit register built using advanced LowPower Schottky technology. The register consists of eight D-type flip-flops with a buffered common clock, a buffered common clock enable, a buffered asynchronous clear input, and three-state outputs.

When the clear input is LOW, the internal flip-flops of the regisier are reset to logic $\bar{O}$ (LOW), independent of all other inputs. When the clear input is HIGH, the register operates in the normal fashion.

When the three-state output enable ( $\overline{\mathrm{OE}}$ ) input is LOW, the Y outputs are enabled and appear as normal TTL outputs.

When the output enable ( $\overline{\mathrm{OE}}$ ) input is HIGH, the $Y$ outputs are in the high impedance (three-state) condition. This does not affect the internal state of the flip-flop $Q$ output.

The clock enable input $(\bar{E})$ is used to selectively load data into the register. When the $\bar{E}$ input is HIGH, the register will retain its current data. When the $\bar{E}$ is LOW, new data is entered into the register on the LOW-to-HIGH transition of the clock input.

This device is packaged in a slim 24-pin package ( 0.3 inch row spacing).

## BLOCK DIAGRAM



RELATED PRODUCTS

| Part No. | Description |
| :--- | :--- |
| Am25S18 | Quad D Register |
| Am2920 | Octal D Type Flip-flop |
| Am2954/5 | Octal D Registers |



## PIN DESCRIPTION

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{\mathrm{i}}$ | 1 | The D flip-flop data inputs. |
| 1 | $\overline{\text { CLR }}$ | 1 | When the clear input is LOW, the $Q_{i}$ outputs are LOW, regardiess of the other inputs. When the clear input is HIGH, data can be entered into the register. |
| 11 | CP | 1 | Clock Pulse for the Register; enters data into the register on the LOW-to-HIGH transition. |
|  | $\mathrm{Y}_{\mathrm{i}}$ | 0 | The register three-state outputs. |
| 23 | $\bar{E}$ | 1 | Clock Enable. When the clock enable is LOW, data on the $D_{i}$ input is transferred to the $Q_{i}$ output on the LOW-to-HIGH clock transition. When the clock enable is HIGH, the $Q_{i}$ outputs do not change state, regardless of the data or clock input transitions. |
| 22 | $\overline{O E}$ | 1 | Output Control. When the $\overline{\mathrm{OE}}$ input is HIGH , the $Y_{\mathrm{i}}$ outputs are in the high impedance state. When the $\overline{\mathrm{OE}}$ input is LOW, the TRUE register data is present at the $Y_{i}$ outputs. |

Function Table

| Inputs |  |  |  |  | Internal | Outputs | Function |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OE}}$ | $\overline{\text { CLR }}$ | $\bar{E}$ | $\mathrm{D}_{\mathbf{i}}$ | CP | $Q_{i}$ | $\mathrm{Y}_{\mathrm{i}}$ |  |
| H | X | x | x | $x$ | X | Z | $\mathrm{Hi}-\mathrm{Z}$ |
| $\begin{gathered} H \\ L \end{gathered}$ | $\begin{aligned} & L \\ & L \end{aligned}$ | $\left.\begin{array}{\|l\|} x \\ x \end{array} \right\rvert\,$ | $\begin{array}{\|l\|} \hline x \\ x \end{array}$ | $\left.\begin{array}{\|l\|} \hline x \\ x \end{array} \right\rvert\,$ | $\stackrel{L}{L}$ | $\begin{aligned} & \mathrm{Z} \\ & \mathrm{~L} \end{aligned}$ | Clear |
| $\begin{aligned} & H \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{\|l\|} \mathrm{H} \\ \mathrm{H} \end{array}$ | $\begin{array}{\|l\|} \hline x \\ x \end{array}$ | $\begin{array}{\|l\|} \hline x \\ x \end{array}$ | $\begin{aligned} & \mathrm{NC} \\ & \mathrm{NC} \end{aligned}$ | $\begin{gathered} z \\ N C \end{gathered}$ | Hold |
| H H L L | $\begin{aligned} & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \\ & \mathrm{H} \end{aligned}$ | L | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\dagger$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \\ & \mathrm{~L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & \mathrm{Z} \\ & Z \\ & L \\ & H \end{aligned}$ | Load |

$$
\begin{array}{ll}
H=H I G H & N C=\text { No Change } \\
L=\text { LOW } & \uparrow=\text { LOW-to-HIGH Transition } \\
X=\text { Don't Care } & Z=\text { High Impedance }
\end{array}
$$

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential Continuous
DC Voltage Applied to Outputs For High Output State $\qquad$ ..-0.5V to $+V_{\text {CC }} \max$
DC Input Voltage $\ldots-0.5 \mathrm{~V}$ to +7.0 V
DC Output Current, Into Outputs ........................... 30 mA
DC Input Current
... -30 mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage 4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions (Note 1) |  |  | Min | Typ <br> (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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{MiL}, \mathrm{IOH}^{\prime}=-1.0 \mathrm{~mA}$ |  | 2.4 | 3.4 |  | Volts |
|  |  |  | $\mathrm{COM}^{\prime} \mathrm{L}, \mathrm{l}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  | 2.4 | 3.4 |  |  |
| 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{l}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ |  |  |  | 0.4 | Volts |
|  |  |  | $\mathrm{l} \mathrm{ILL}=8.0 \mathrm{~mA}$ |  |  |  | 0.45 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed input logical LOW voltage for all inputs |  | MIL |  |  | 0.7 |  |
|  |  |  |  | COM'L |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{I}_{1 \mathrm{~N}}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 | Volts |
| ILL | Input LOW Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |  |  |  |  | -0.36 | mA |
| IH | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{IN}}=7.0 \mathrm{~V}$ |  |  |  |  | 0.1 | mA |
| 10 | Off-State (High-Impedance) Output Current | $V_{C C}=M A X$ | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=2.4$ |  |  |  | 20 |  |
| ISC | Output Short Circuit Current (Note 3) | $V_{C C}=M A X$ |  |  | -15 |  | -85 | mA |
| ICC | Power Supply Current (Note 4) | $V_{C C}=M A X$ |  |  |  | 24 | 37 | mA |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type. 2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. All outputs open, $\bar{E}=G N D, D_{i}$ inputs $=C L R=\overline{\mathrm{OE}}=4.5 \mathrm{~V}$. Apply momentary ground, then 4.5 V to clock input.

SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Clock to $Y_{i}$ ( $\overline{O E}$ LOW) |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 18 | 27 | ns |
| tpHL |  |  |  | 24 | 36 |  |
| tpHL | Clear to Y |  |  |  | 22 | 35 | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  |  | 10 | 3 |  | ns |
| $t_{\text {h }}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  |  | 10 | 3 |  | ns |
| $t_{s}$ | Enable ( $\overline{\mathrm{E}}$ ) | Active |  | 15 | 10 |  | ns |
|  |  | Inactive |  | 20 | 12 |  |  |
| th | Enable ( $\overline{\mathrm{E}}$ ) |  |  | 0 | 0 |  | ns |
| $t_{s}$ | Clear Recovery (In-Active) to Clock |  |  | 11 | 7 |  | ns |
| $t_{\text {pw }}$ | Clock | HIGH |  | 20 | 14 |  | ns |
|  |  | LOW |  | 25 | 13 |  |  |
| ${ }_{\text {tpw }}$ | Clear |  |  | 20 | 13 |  | ns |
| tzH | $\overline{O E}$ to $Y_{i}$ |  |  |  | 9 | 13 | ns |
| t ZL |  |  |  | 14 | 21 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | $\overline{O E}$ to $Y_{i}$ |  |  | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{\mathrm{L}}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 20 | 30 | ns |
| $\mathrm{t}_{\text {L } 2}$ |  |  |  |  | 24 | 36 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  |  |  | 40 |  | MHz |

Note 1. Per industry convention, $f_{\max }$ is the worst case value of the maximum device operating frequency with no constraints on $t_{\text {, }}$, , pulse width or duty cycle.

SWITCHING CHARACTERISTICS over operating range unless otherwise specified*

| Parameters | Description |  | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Clock to $\mathrm{Y}_{\mathrm{i}}$ ( $\overline{O E}$ LOW) |  |  | $\begin{aligned} C_{L} & =50 \mathrm{pF} \\ R_{L} & =2.0 \mathrm{k} \Omega \end{aligned}$ |  | 33 |  | 39 | ns |
| tphL |  |  |  |  | 45 |  | 54 |  |  |
| tpHL | Clear to Y |  |  |  | 43 |  | 51 | ns |  |
| $\mathrm{t}_{\text {s }}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  |  | 15 |  | ns |  |
| $t_{n}$ | Data ( $\mathrm{D}_{\mathrm{i}}$ ) |  | 12 |  |  | 15 |  | ns |  |
| $t_{s}$ | Enable ( $\overline{\mathrm{E}}$ ) | Active | 17 |  |  | 20 |  | ns |  |
|  |  | Inactive | 20 |  |  | 23 |  |  |  |
| $t_{n}$ | Enable (E) |  | 0 |  |  | 0 |  | ns |  |
| $\mathrm{t}_{\text {s }}$ | Clear Recovery (In-Active) to Clock |  | 13 |  |  | 15 |  | ns |  |
| $t_{\text {pw }}$ | Clock | HIGH | 25 |  |  | 30 |  | ns |  |
|  |  | LOW | 30 |  |  | 35 |  |  |  |
| $t_{\text {pw }}$ | Clear |  | 22 |  |  | 25 |  | ns |  |
| $\mathrm{t}_{\mathrm{ZH}}$ | $\overline{O E}$ to $Y_{i}$ |  |  |  | 19 |  | 25 | ns |  |
| $\mathrm{t}_{\mathrm{ZL}}$ |  |  |  |  | 30 |  | 39 |  |  |
| thz | $\overline{O E}$ to $\mathrm{Y}_{\mathrm{i}}$ |  | $\begin{aligned} & C_{L}=5.0 \mathrm{pF} \\ & R_{L}=2.0 \mathrm{k} \Omega \end{aligned}$ |  | 35 |  | 40 | ns |  |
| $t_{L Z}$ |  |  |  | 39 |  | 42 |  |  |
| $f_{\text {max }}$ | Maximum Clock Frequency (Note 1) |  |  |  | 25 |  | 20 |  | MHz |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## LOW-POWER SCHOTTKY INPUT/OUTPUT CURRENT INTERFACE CONDITIONS



Note: Actual current flow direction shown.

## DISTINCTIVE CHARACTERISTICS

- High-drive high-level clock output Special output provides clock signal matched to requirements of AmZ8000* CPU (4MHz and some 6 MHz applications), MMU and DMA devices.
- Synchronized WAIT state and time-out controls On-chip logic generates WAIT signal under control of Halt, Single-step, Status and Ready signals. Automatic time-out of peripheral wait requests.
- Four TTL-level clocks

Generates synchronized TTL compatible clocks at $16 \mathrm{MHz}, 2 \mathrm{MHz}$ and 1 MHz to drive memory circuits and LSI peripheral devices. An additional TTL clock is synchronized with the CPU high-level clock for registers, latches and other peripherals.

## GENERAL DESCRIPTION

The Am8127 Clock Generator and Controller provides the clock oscillator, frequency dividers and clock drivers for the complete array of Amz8000 CPUis, peripherais and memory system configurations. In addition to the special 4 MHz output driver for the AmZ8001* and AmZ8002* CPUs, a standard buffered TTL 16 MHz oscillator output is provided for a dynamic memory timing and control. In addition to 4 MHz applications, the Am8127 will also function in some $6 \mathrm{MHz} \mathrm{Z8000} \mathrm{applications} .\mathrm{The} \mathrm{Am8127} \mathrm{forms} \mathrm{an} \mathrm{integral}$ part of the dynamic memory support chip set including the Am8163 EDC and Refresh Controller, Am2964 Dynamic Memory Controller, Am2960 Error Detection and Correction Unit and Am2961/Am2962 EDC Bus Buffers. The oscillator is designed to operate with a 16 MHz crystal or with external 16 MHz drive. The Am8127 uses an internal divide-by-4 to provide 4 MHz clock drive to the AmZ8001/AmZ8002 CPU. Additional dividers generate synchronous buffered 4, 2 and 1 MHz clock outputs for use by peripheral devices. The clock divider counters are clearable to allow synchronization of the multiple clock outputs.

The controller functions include RESET, RUN/HALT, SIN-GLE-STEP, READY and a READY TIMEOUT counter which iimits a peripherai's wait request to 16 clock cycles. The CPU's WAIT input is controlled by RUN/HALT, Single-Step, Status and READY. When RUN/HALT is LOW the Am8127 drives the WAIT output LOW causing the CPU to add wait states (TW). The READY input is used by peripherals to request wait states. The active LOW input timeout enable, TOEN, is used to force TIME-OUT LOW and WAIT HIGH 16 clock cycles after a peripheral has requested a wait but fails to release the request. The CPU status lines $\mathrm{ST}_{1}, \mathrm{ST}_{2}$ and $\mathrm{ST}_{3}$ are decoded in the Am8127 to disable the TIMEOUT counter during CPU ''Internal Operations' and during refresh.

The $4 / 3$ input controls the clock duty cycle. An internal pullup resistor pulls this input high for AmZ8000 CPUs. A LOW input causes the cycle counter to output a 33\% duty cycle.

BLOCK DIAGRAM
CLOCK GENERATOR


* $\overline{\text { RESETOUT }}$ is active LOW when $4 / \overline{3}=\mathrm{HIGH}$



## PIN DESCRIPTION



TYPICAL CRYSTAL SPEC

| Mode | Fundamental AT cut |
| :--- | :---: |
| Resonance | Parallel or Series |
| Load | 32 pF |
| Stability | (Net of 56 pF C's shown + stray C) |
|  | (or to user requirement) |

WAIT, TIMEOUT FUNCTION TABLE

| RUN/ $/$ HALT | SSNC | $\mathrm{ST}_{3}$ | ST2 | $\mathrm{ST}_{1}$ | READY | TOEN | TIMEOUT COUNTER | TIMEOUT | WAIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| H | X | L | L | L | H | X | Cleared | H | H |
|  |  | L | L | L | L | X | Cleared | H | H |
|  |  | Any $\mathrm{ST}_{\mathrm{i}}=\mathrm{H}$ |  |  | H | L | Cleared | H | H |
|  |  |  |  |  | L | H | Hold | H | L |
|  |  |  |  |  | L | L | $\begin{aligned} & \text { Count +1 on } \\ & \text { ZCK } \end{aligned}$ | H until 16 clocks after ready $L$, then LOW one ZCK period | $\begin{aligned} & \text { L until } 16 \\ & \text { after ready } \\ & \text { HIGH one } Z C \end{aligned}$ |
| L | L | X |  |  | X | X | Hold | H | L |
|  | H |  |  |  | HIGH c ZCK pe |  |  |  |



CRYSTAL CONTROLLED OSCILLATOR


DF000380

EXTERNAL CLOCK DRIVE


DF000370

AmZ8000 APPLICATION
(50\% Duty Cycle ZCK)


DF000350

The typical operating configuration for Am8127 is shown above. The component values shown provide a 4 MHz clock output for the AmZ8002 CPU. The 27pF capacitor from C to ZCK is a bootstrap to ensure clock rise to $\mathrm{V}_{\mathrm{CC}}-0.4 \mathrm{~V}$ within
the specified rise time. The $22 \mu \mathrm{~F}$ reset capacitor is chosen to guarantee reset, plus adequate delay for reset during powerup with a slowly rising VCC supply voltage. Ground SSNO if RUN/FALT or S-S isn't used.

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias ....... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential
(Pin 24 to Pin 12) Continuous ............. -0.5 V to +7.0 V
DC Voltage Applied to Outputs For
High Output State
-0.5 V to $+\mathrm{V}_{\mathrm{CC}} \max$
DC Input Voltage
$X_{1}, 4 / \overline{3}$, SSNO, SSNC, RUN/ $\overline{\text { HALT }} \ldots . .-0.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Other Inputs
DC Voltage Applied to C -0.5 V to +5.5 V
DC Output Current, Into Outputs ........................... 30 mA DC Input Current .............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature ............................... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage .+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameter | Description |  |  | Test Con | Note 1) | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$ | ZCK | $\mathrm{I}_{\mathrm{OH}}=-0.1 \mathrm{~mA}$ |  | $\mathrm{VCC}^{-0.4}$ | $\mathrm{V}_{\mathrm{CC}}-0.1$ |  | Volts |
|  |  |  | TTL Outputs | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | MIL | 2.4 | 3.4 |  | Volts |
|  |  |  |  | $\mathrm{l}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | COM'L |  |  |  |  |
| VOL | Output LOW Voltage | $V_{C C}=\mathrm{MIN}$ |  | $\mathrm{IOL}^{\prime}=0.1 \mathrm{~mA}, \mathrm{ZCK}$ Output |  |  |  | 0.4 | Volts |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$, TTL Output |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Level | Guaranteed input HIGH Voltage |  | RESETIN |  | 2.8 | 2.25 |  | Volts |
|  |  |  |  | $\mathrm{ST}_{1}, \mathrm{ST}_{2}, \mathrm{ST}_{3}, \overline{\mathrm{CLR}}$, TOEN, $X_{1}$, READY |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed input LOW Voltage |  | $\mathrm{ST}_{1}, \mathrm{ST}_{2}, \mathrm{ST}_{3} . \mathrm{CLR}$, TOEN, $\mathrm{X}_{1}$, READY |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{MIN}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ (Note 3) |  |  |  |  |  | -1.5 | Volts |
| $\mathrm{V}_{\text {IN }}-\mathrm{V}_{\text {IL }}$ | RESETIN Hysteresis | $V_{C C}=M I N$ |  |  |  | 400 | 650 |  | mV |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=0.4 V \end{aligned}$ |  | SSNO |  |  |  | -1.6 | mA |
|  |  |  |  | SSNC, 4/3, RUN/HALT, READY |  |  |  | -1.2 | mA |
|  |  |  |  | TOEN, CLR, $\mathrm{X}_{1}$ |  |  |  | -0.72 | mA |
|  |  |  |  | RESETIN, $\mathrm{ST}_{1}, \mathrm{ST}_{2}, \mathrm{ST}_{3}$ |  |  |  | -0.36 | mA |
| $I_{\text {IH }}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=2.7 V \end{aligned}$ |  | $\begin{aligned} & 4 / \overline{3}, \text { SSNC, SSNO } \\ & \text { RUN } / \text { HALT } \end{aligned}$ |  |  | (Note 4) | -300 | $\mu \mathrm{A}$ |
|  |  |  |  | RESETIN |  |  | (Note 4) | -200 | $\mu \mathrm{A}$ |
|  |  |  |  | $\overline{C L R}$, READY, TOEN $\mathrm{ST}_{1}, \mathrm{ST}_{2}, \mathrm{ST}_{3}$ |  |  |  | + 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{X}_{1}$ |  |  |  | $+600$ | $\mu \mathrm{A}$ |
| II | Input HIGH Current | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I N}=5.5 \mathrm{~V} \\ & \hline \end{aligned}$ |  | CLR, READY, $\mathrm{ST}_{1}, \mathrm{ST}_{2}, \mathrm{ST}_{3}$ |  |  |  | + 1.0 | mA |
| Isc | Output Short Circuit Current (Note 5) | $V_{C C}=M A X$ |  | ZCK Output |  | -50 |  | -240 | mA |
|  |  |  |  | Others |  | -40 |  | -130 | mA |
| ICC | Power Supply Current | $V_{C C}=M A X$ |  | Operating, fosc $\leqslant 24 \mathrm{MHz}$ (Note 6) |  |  | 95 | 140 | mA |
|  |  |  |  |  | 120 | 180 |  |  |

Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Range for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not applicable to $X_{1}$.
4. Specification is negative because of internal input pull-up resistors
5. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
6. For oscillator frequencies up to 24 MHz , outputs open.

## STATIC INPUT ELECTRICAL CHARACTERISTICS

The static control inputs, SSNO, SSNC (Single Step), RUN/ $\overline{\text { HALT }}$ and $4 / \overline{3}$ (clock duty cycle control), are Low-Power Schottky TTI compatible inputs with internal pull-up resistors
to the +5 V supply. They may be left open for a HIGH input (e.g., $4 / \overline{3}$ is left open for operation with AmZ8001/8002), or grounded for a LOW input. SSNO, SSNC and RUN/HALT are intended to be grounded or opened by switches. $4 / \overline{3}$ is normally left open for AmZ8001/8002. These inputs are specified at $0.4 \mathrm{~V} / 2.4 \mathrm{~V}$ for test convenience.

| Parameter | Description | Test Conditions | Min | Typ | Max | Units |
| :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| $V_{I H}$ | Input HIGH Voltage | Guaranteed HIGH input voltage | RUN $\overline{H A L T}$, <br> SSNO | 2.4 |  |  |
| $V_{\mathrm{IL}}$ | Input LOW Voltage | Guaranteed LOW input voltage | SSNC,4/3 |  |  | Volts |


$\left(\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description |  | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{s}$ | READY to ZCK Set-up Time | (Note 9) | See Test Circuits ZCK $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ | $\mathrm{T} / 4+10$ | T/4 + 4.5 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | READY to ZCK Hold Time |  |  | T/4+2 | T/4 |  | ns |
| $\mathrm{t}_{5}$ | Status ST i $^{\text {to ZCK Set-up Time }}$ |  |  | T/4+12 | T/4 + 9.5 |  | ns |
| $t_{H}$ | Status $\mathrm{ST}_{\mathrm{i}}$ to ZCK Hold Time |  |  | T/4-3 | T/4-7.5 |  | ns |
| $t_{s}$ | TOEN to ZCK Set-up Time |  |  | 30 | 22 |  | ns |
| $t_{H}$ | TOEN to ZCK Hold Time |  |  | -10 | -16 |  | ns |
| tSKEW | ZCK to OSC |  |  | 3 | 6 | 10 | ns |
| tSKEW | ZCK to TCK |  |  | 0 | 4.0 | 7 | ns |
| tPLH | ZCK to RESET OUT Propagation Delay |  |  |  | 9.0 | 13 | ns |
| tpHL |  |  |  | 4 | 8 | ns |

Note: 9. T = ZCK period.

## SWITCHING CHARACTERISTICS OVER OPERATING RANGE OSCILLATOR, WAIT AND ZCK OUTPUTS*

|  | Description | Test Conditions | COMMERCIAL |  |  | MILITARY |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameters |  |  | Min | $\begin{gathered} \mathrm{Mr} \\ 0^{\circ} \mathrm{C} \end{gathered}$ | $70^{\circ} \mathrm{C}$ | Min | $\begin{array}{r} M \\ -55^{\circ} \mathrm{C} \end{array}$ | $125^{\circ} \mathrm{C}$ |  |
| $t_{\text {MAX }}$ | Oscillator Frequency | (Note 7) | 24 |  |  | 24 |  |  | MHz |
| trc | ZCK Rise Time | $\begin{gathered} C_{L}=80 \mathrm{pF} \\ \text { (Note 8) } \end{gathered}$ |  | 15 | 15 |  | 20 | 15 | ns |
| $\mathrm{t}_{4} \mathrm{C}$ | ZCK Fall Time $C_{L}=80 \mathrm{pF}$ |  |  | 14 | 14 |  | 20 | 14 | ns |
| trc | ZCK Rise Time | $\begin{gathered} \mathrm{C}_{\mathrm{L}}=200 \mathrm{pF} \\ \text { (Note 8) } \\ \hline \end{gathered}$ |  | 25 | 20 |  | 32 | 20 | ns |
| $\mathrm{t}_{\mathrm{f}} \mathrm{C}$ | ZCK Fall time $C^{\text {L }}=200 \mathrm{pF}$ |  |  | 25 | 20 |  | 32 | 20 | ns |
| tplH | READY to WAIT Propagation Delay | See Test Circuits |  | 17 | 17 |  | 19 | 19 | ns |
| tPHL |  |  |  | 19 | 19 |  | 19 | 19 | ns |
| tplH | Status $\mathrm{ST}_{\mathrm{i}}$ to WAIT Propagation Delay |  |  | 20 | 20 |  | 22 | 22 | ns |
| tphL |  |  |  | 25 | 25 |  | 25 | 25 | ns |
| ts | $\overline{\text { CLR }}$ to OSC ( I) Setup Time |  | 21 |  |  | 30 |  |  | ns |
| ${ }_{\mathrm{H}}^{\mathrm{H}}$ | CLR to OSC (I) Hold Time |  | -3 |  |  | 0 |  |  | ns |

*AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

## SWITCHING CHARACTERISTICS OVER OPERATING RANGE $4 / \overline{3}=$ HIGH (AmZ8000 Mode)

| Parameters | Description | Test Conditions | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| ts | READY to ZCK Setup Time | See Test Circuits ZCK, $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ | $\mathrm{T} / 4+14$ |  | $\mathrm{T} / 4+17$ |  | ns |
| ${ }_{\text {t }}^{\mathrm{H}}$ | READY to ZCK Hold Time |  | T/4+5 |  | $\mathrm{T} / 4+5$ |  | ns |
| ts | Status $\mathrm{ST}_{\mathrm{i}}$ to ZCK Setup Time |  | $\mathrm{T} / 4+15$ |  | T/4 + 20 |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Status $\mathrm{ST}_{i}$ to ZCK Hold Time |  | T/4 |  | T/4+5 |  | ns |
| ts | TOEN to ZCK Setup Time |  | 35 |  | 40 |  | ns |
| ${ }_{\mathrm{t}}^{\mathrm{H}}$ | TOEN to ZCK Hold Time |  | -5 |  | 0 |  | ns |
| tSKEW | ZCK to OSC Skew |  | 2 | 14 | 2 | 17 | ns |
| tSKEW | ZCK to TCK Skew |  | -2 | 10 | -2 | 14 | ns |
| tPLH | ZCK to RESETOUT Propagation Delay |  |  | 16 |  | 20 | ns |
| tPHL |  |  |  | 16 |  | 20 | ns |




WF002010

# Am8152A/53A 

Video System Controller (VSC)

## DISTINCTIVE CHARACTERISTICS

- Proportional Spacing Support (2-17 dots)
- 9-bit dot data parallel input, with expansion capability to seventeen bits
- Trailing blanks (0-3 dots)
- Buffered and Synchronized Vertical and Horizontal Sync Outputs are Character Clock Outputs
- Attribute Support:

Character Blink
Underline
Overstrike
Reverse
Highlight

- Background color selection


## GENERAL DESCRIPTION

The Am8152A/53A Video System Controller (VSC) provides interface between a CRT controller and a CRT monitor. The basic chip functions are:

- Support proportional and non-proportional character display
- Correctly synchronize and mix character attributes with video signals
- Output the video information in a four-level analog or digital format

The VSC consists of a parallel-to-serial converter which provides a video bit stream to on-chip attribute logic. This logic, under control of the attribute inputs, operates on the bit stream to generate grey scale video. Video outputs from the VSC are of two forms - analog and digital. The digitally encoded outputs implement four video levels: Blank, Black, Grey and White. Identical information is available in analog
form via differential outputs (current driven) into a nominal $75 \Omega$ impedance.
The Am8152A/53A also supports proportional spacing using a bit width programmable character clock. Character ROM pixel information is selectable from two to seventeen pixels per character. Up to three blank pixels can be appended to the character ROM input thereby facilitating right justification of text.

The difference between the Am8152A and the Am8153A is in the output scheme. The Am8152A has standard TTL outputs and operates in the $25-60 \mathrm{MHz}$ range, while the Am8153A has 10K ECL outputs and operates in the $40-100 \mathrm{MHz}$ range.
The Am8152A/53A is fabricated using AMD's advanced bipolar process with internal ECL logic. The device is available in conventional 48-pin dual in-line packages.

## BLOCK DIAGRAM

Figure 1.


## CONNECTION DIAGRAM <br> Top View

## D-48-1



## Leadless Chip Carrier

L-52-1


CD001510

## METALLIZATION AND PAD LAYOUT



## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).

```
Am8152A/53A
```



```
Blank - Standard processing B - Burn-in
Temperature (See Operating Range)
C - Commercial \(\left(0^{\circ} \mathrm{C}\right.\) to \(\left.+70^{\circ} \mathrm{C}\right)\)
M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\)
Package
D-48 pin CERDIP (D-48-1)
L-52 Pin Leadless Chip Carrier (L-52-1)
\(X\) - Dice
Device type
Video System Controller
```



Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

## PIN DESCRIPTION

MCLK $_{1}$
CLOCK $_{1}$ (output, non-TTL compatible) MCLK $_{1}$ is a system clock. It is intended to drive the Am8052 horizontal and vertical timing circuitry as well as the DMA operations. MCLK ${ }_{1}$ output is nominally a square wave divided down from the internal dot clock frequency according to the CLK ${ }_{1}$ DR (CLK ${ }_{1}$ Divide Ratio) input.

CLK $_{1}$ DR CLK 1 DIVIDE RATIO (inputs (3))
$\mathrm{CLK}_{1}$ DR are three inputs which control the $\mathrm{MCLK}_{1}$ divide ratio. The three inputs may be programmed to divide the MCLK ${ }_{1}$ signal by two, four, six, ..., sixteen

| CLK $_{1}$ DR |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 2 | 1 | 0 | $A^{(1)}$ | $B^{(1)}$ |
| L | L | L | 1 | 1 |
| L | L | $H$ | 2 | 2 |
| L | $H$ | L | 3 | 3 |
| L | $H$ | $H$ | 4 | 4 |
| H | L | L | 5 | 5 |
| H | L | H | 6 | 6 |
| $H$ | $H$ | L | 7 | 7 |
| H | H | 8 | 8 |  |

MCLK $_{2}$
CLOCK $_{2}$ (output, non-TTL compatible) $\mathrm{MCLK}_{2}$ is a character display clock. Its function is to control the character code and attribute data output rate from the appropriate Am8052 CRTC's ports.
$\mathrm{CLK}_{2} \mathrm{DR} \quad \mathrm{CLOCK}_{2}$ DIVIDE RATIO (inputs (4))
$\mathrm{CLK}_{2}$ DR are four inputs which control an internal divider to divide the dot clock frequency by a value from two to seventeen.

| $\mathrm{CLK}_{2}$ DR |  |  |  | $C^{(1)}$ | $D^{(1)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | , | 1 | 0 |  |  |
| L | L | L | L | 1 | 1 |
| L | L | L | H | 1 | 2 |
| L | L | H | L | 2 | 2 |
| L | L | H | H | 2 | 3 |
| L | H | L | L | 3 | 3 |
| L | H | L | H | 3 | 4 |
| L | H | H | L | 4 | 4 |
| L | H | H | H | 4 | 5 |
| H | L | L | L | 5 | 5 |
| H | L | L | H | 5 | 6 |
| H | L | H | L | 6 | 6 |
| H | L | H | H | 6 | 7 |
| H | H | L | L | 7 | 7 |
| H | H | L | H | 7 | 8 |
| H | H | H | L | 8 | 8 |
| H | H | H | H | 8 | 9 |

Note 1: A, B, C, and D are measured in EXTDCLK periods. (See Reset Timing on page 15).

## TCLK 2

$x_{1}, x_{2} /$ RES

TTL. CLOCK ${ }_{2}$ (output)
TCLK $_{2}$ is a TTL compatible version of MCLK ${ }_{2}$.
$X_{1}, X_{2} /$ RESET (inputs, $X_{2}$ is non-TTL compatible, reset is TTL compatible)
$X_{1}, X_{2} /$ RES are the external crystal inputs when the on-chip oscillator of the VSC is being used. The external crystal frequency is multiplied by five to produce the on-chip dot clock. If the external dot clock option is used, the $X_{1}$ should be tied LOW and $X_{2}$ /RES may be used as a reset input, to synchronize multiple VSC's. Note that the reset signal should be synchronous to the external dot clock.
$X_{3}$ (input, non-TTL compatible)
$X_{3}$ is used as an input to the on-chip voltagecontrolled oscillator. When the on-chip oscillator of the VSR is being used, $X_{3}$ should be connected to ground by an appropriate capacitor. If the external dot clock option is used, $X_{3}$ and $X_{1}$ should be tied LOW.

VERTICAL SYNC (input)
VSYNC is an input that must be synchronous to either MCLK ${ }_{1}$ or MCLK ${ }_{2}$, dependent on the SSEL input. If SSEL is HIGH, VSYNC must be synchronous to MCLK ${ }_{1}$.

VSDLD
VERTICAL SYNC DELAYED (output)
VSDLD is the delayed output of VSYNC, synchronous to MCLK 1 or MCLK 2 , depending on the setting of SSEL.

HORIZONTAL SYNC DELAYED (input)
HSYNC is an input that must be synchronous to either MCLK ${ }_{1}$ or MCLK 2 , dependent upon the SSEL input. If SSEL is LOW, HSYNC must be synchronous to MCLK ${ }_{2}$; if SSEL is HIGH, HSYNC must be synchronous to MCLK ${ }_{1}$.

HORIZONTAL SYNC (output)
HSDLD is the delayed output of HSYNC, synchronous to MCLK ${ }_{1}$ or MCLK ${ }_{2}$, depending upon the setting of SSEL.

SYNC SELECT (input)
The SSEL line determines if the VSYNC, HSYNC and BLANK are going to be synchronized to the MCLK $_{1}$ or MCLK 2 signals. A HIGH on SSEL also will resynchronize CLK 2 and CLK $_{1}$ during blanking.

HSDLD

SSEL

CBLANK
HSYNC


CHARACTER BLANK (input)
CBLANK forces video output levels ( $\mathrm{VID}_{1}, \mathrm{VID}_{2}$, VIDOUT and VIDOUT) to switch to the background color level.

| BLANK | BLANK (input) <br> BLANK is an input normally synchronous to MCLK $_{1}$, although it may be synchronous to $\mathrm{MCLK}_{2}$ in non-proportional spacing applications. The active pulse width of BLANK will usually overlap the inactive-to-active waveforms of HSYNC and VSYNC, as well as the active-toinactive portion of VSYNC. While BLANk is active TCLK $_{2} /$ MCLK $_{2}$ may be forced to synchronize to the MCLK ${ }_{1}$ clock. When BLANK goes inactive, the rising edges of MCLK ${ }_{1}$ and TCLK ${ }_{2}$ / $\mathrm{MCLK}_{2}$ must be synchronized in order to prevent 'dot walk" in proportional spacing applications. BLANK active also forces the video output level to "blank" regardless of DD, FORE or other inputs. |
| :---: | :---: |
| FORE | FOREGROUND VIDEO (input) <br> The FORE video input is "OR'ed' with the dot data output by the parallel-to-serial shift register to switch to the foreground color level (e.g., to implement underlines). |
| REV | REVERSE (input) <br> The REV input causes the foreground color levels to be transposed with the background color level for the total character period (including any tracking blanks). |
| FS | FOREGROUND SHIFT (input) <br> The FS input causes the shift in the video output levels to produce a highlight effect. See Table 1. |
| $\mathrm{TB}_{0}, \mathrm{~TB}_{1}$ | TRAILING BLANKS (inputs (2)) <br> The TB inputs concatenate 'blank' video dots to the tail end of the dot data contained in the parallel-to-serial shift register. TB can be specified to concatenate $0,1,2$ or 3 dots. The TB value is also added to the $\mathrm{CLK}_{2} \mathrm{DR}$ value to obtain the total. The combination of all CLK $K_{2}$ DR inputs being High (17 dots) and both TB inputs being High ( 3 trailing blanks) is not allowed. The maximum $\mathrm{CLK}_{2}$ period is 19 dot periods. |
| $D D_{0}-D_{8}$ | DOT DATA (inputs (9)) <br> The DD inputs accept parallel character dot matrix information for serial conversion for video output. DD data is accepted at the TCLK 2 / MCLK ${ }_{2}$ clock rate. $\mathrm{DD}_{0}$ is shifted out first. |
| BS | BACKGROUND SELECT (input) <br> The BS input specifies the color level of the background video. This input can be overridden by BLANK active. |

VIDOUT,
VIDOUT VID $_{1}$, VID $_{2}$ VIDEO DIGITAL (outputs (2), (8152A-TTL; 8153A-ECL) $\mathrm{VID}_{1}$ and $\mathrm{VID}_{2}$ are digitally encoded outputs of the video out. VID ${ }_{1}$ is the least significant bit. Encoding is as follows:

|  | VID <br> (VID- | VID <br> (HIGH- <br> (IGHT) |
| :--- | :---: | :---: |
| BIank Level | 0 | 0 |
| Black | 0 | 1 |
| Grey | 1 | 0 |
| White | 1 | 1 |

GRLVL GREY LEVEL (input)
The GRLVL input adjusts the current level output, via the VIDOUT and VIDOUT outputs, of the grey video level. There are two pre-selected grey levels; for GRLVL HIGH grey is brighter, for LOW grey is darker.

DW DOUBLE WIDTH (inputs)
The DW input, when active HIGH, causes the dot clock supplied to the TCLK $2 /$ MCLK $_{2}$ clock divide to be divided by two. This function is used to facilitate doubling the width of a character cell matrix in the horizontal direction. The trailing blank information is also widened during a double width character.

## EXTDCLK EXTERNAL DOT CLOCK

(input, 8152A-TTL; 8153A-ECL)
EXTDCLK is an external, TTL or ECL compatible dot clock input for use in multiple Am8152A/53A configurations. This signal replaces the internal oscillator function. To enable EXTDCLK both $\mathrm{X}_{1}$ and $X_{3}$ must be grounded.

AADJ
VIDEO OUTPUT
(analog outputs (2), non-TTL compatible)
VIDOUT and VIDOUT outputs in a differential mode the composite blank, and video dot levels to a nominal $75 \Omega$ load impedance from switched current sources.
$\mathrm{VID}_{1}, \mathrm{VID}_{2}$

GRLVL

ANALOG OUTPUTS CURRENT ADJUST (input, non-TTL compatible)
Analog output current adjust is used for setting the analog video output current to 13.3 mA . This is done by connecting AADJ to $\mathrm{V}^{-}$via an applicable $1 \%$ resistor.

Figure 2. Am8152/53A Application with Am8052 CRT Controller


AF002100

## RESET TIMING FOR Am8152A/53A



Note 1. See pin description

Am8153A 10K ECL SPECIFICATIONS


DOTCLOCK GENERATION MODE
EXTERNAL CLOCK FLOW THROUGH MODE


## CRYSTAL OSCILLATOR MULTIPLIER MODE



AF002160

## FUNCTIONAL DESCRIPTION

The Am8152A Video System Controller (VSC) supports both black and white and color video applications for CPUs, CRT controllers, and terminals. The essential functions of the VSC are to support proportional and non-proportional character display, to synchronize and mix character attributes with video, and to output the video in a four level analog or digital format.

## PARALLEL PIXEL LOADING

Pixel information that must be serialized for video transmission is loaded into the serial shift register via inputs $\mathrm{DD}_{0}-\mathrm{DD}_{8}$. Information is loaded on both edges of the MCLK ${ }_{2}$ character clock, as shown in Figure 3. The information set up on $\mathrm{DD}(0: 7)$ prior to the falling edge of MCLK ${ }_{2}$ is loaded into positions $\mathrm{VID}_{9}-\mathrm{VID}_{16}$. Note that $\mathrm{DD}_{8}$ information is ignored. Information set up on $\operatorname{DD}(0 ; 8)$ prior to the rising edge of $\mathrm{MCLK}_{2}$ is loaded into positions $\mathrm{VID}_{0}-\mathrm{VID}_{8}$. Thus, up to 17 bits of pixel information can be loaded into the shift register. Note that if the character width is nine pixels or less the information captured on the falling edge of the MCLK 2 is not used. Any trailing blank insertion only occurs after the total number of pixels for the character have been transmitted. $\mathrm{CLK}_{2} \mathrm{DR}(0: 3)$ and TB ( $0: 1$ ) determine the divide ratio for the character clock.


The sum of both values specifies the character clock period in dot clocks. During the trailing blank, the VSC shifts out what was loaded into the shift register. Therefore, it is the responsibility of the user to insure that the pixels output during the trailing blank dot period are set to the blank level.

## VIDEO OPERATION

Parallel video data is obtained from the character ROM inputs; bits are shifted out serially and mixed with attribute information such as underline, shifted underline, and any other video sources. Video is internally encoded into one of four levels: White, Grey, Black and Blank. White is the highest analog current level, and Blank is the lowest. This information is then output through two ports (see Figure 5/6). One port provides a single current source output into a $75 \Omega$ impedance and the second port outputs either encoded TTL or ECL video on two pins.

There are two distinct blank inputs to the Am8152A/53A. BLANK is the CRTC's horizontal and vertical retrace period input which causes a blank output level to the display. CBLANK is an attribute input to selectively blank a character cell by forcing the video information for the particular character cell period to switch to the selected background color level.

Figure 3. Shift Register Loading


DF000940

## VIDEO INPUTS/OUTPUTS

Video information may be input in a number of different ways. Table 1 depicts all the combinations of video outputs achievable with each of the various inputs. The background color is determined by a separate pin input allowing either a black or white background. Using the REVERSE VIDEO (REV) input, a grey background can also be selected. The foreground then becomes black or white according to the signal on the foreground SHIFT line. Foreground and video sums can be modified depending on the combination of background, foreground shift, and reverse inputs. The user may apply any of his video inputs to the foreground to obtain a desired effect.

## TABLE 1. Am8152A/53A VIDEO ATTRIBUTES

| BS | FS | REV | $\frac{\text { INPUTS }}{\text { CBLANK }}(\mathrm{DD}(0: 8)+\text { FORE })$ | Am8152A/53A VIDEO ATTRIBUTES |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |  |
| 0 | 0 | 0 | 1 | 4 |
| 0 | 0 | 1 | 0 |  |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 |  |
| 0 | 1 | 0 | 1 | - |
| 0 | 1 | 1 | 0 |  |
| 0 | 1 | 1 | 1 | $\bigcirc$ |
| 1 | 0 | 0 | 0 |  |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 |  |
| 1 | 0 | 1 | 1 |  |
| 1 | 1 | 0 | 0 |  |
| 1 | 1 | 0 | 1 | $\bigcirc$ |
| 1 | 1 | 1 | 0 |  |
| 1 | 1 | 1 | 1 | - |

## SYSTEM TIMING

The CPU clock (MCLK ${ }_{1}$ ) output is derived from an on-board oscillator by an externally programmable divide by two or three prescaler and a one to eight decoder. The internal oscillator is capable of operating a frequency of up to 100 MHz and in a fundamental or third harmonic mode. Figure 4 shows the output waveform of MCLK $\mathrm{M}_{1}$ and MCLK 2 .

The character clock $\left(\mathrm{MCLK}_{2}\right)$ output to the CRTC is frequency modulated according to the chosen number of dots per character cell. The duty cycle of $\mathrm{MCLK}_{2}$ is $50 \%$ ( $\pm 1$ dot clock period) and is derived from an internal crystal driven oscillator whose divide ratio is set by the width of the character ROM plus the number of trailing blanks. A double width input further modifies $\mathrm{MCLK}_{2}$ doubling the character width. During an active BLANK input $\mathrm{MCLK}_{2}$ is internally re-synchronized to $\mathrm{MCLK}_{1}$. This action aligns character cells at the left-end side of the display thereby eliminating "Dot Walk." The Vertical and Horizontal Sync (VSYNC, HSYNC) inputs from the CRT controller are buffered and delayed by a MCLK 1 or MCLK 2 clock period in order to phase correctly with the character video output.

## PROPORTIONAL/VARIABLE SPACING

Proportional spacing is achieved by programming on a charac-ter-by-character basis, a number of two to twenty dot clock periods per character. The character ROM pixel information is selectable from two to seventeen per character. Up to three trailing blank pixels can be concatenated to the character ROM input, making it easier to provide a straight right margin for right justification of text.

## COLOR APPLICATION

The Am8152A/53A may be used for many high-end color display applications. The foreground video and background information is mixed by the Am8152A/53A, and the encoded TTL video output can be used externally to select a color mix for the particular pixel being displayed. The horizontal and vertical synchronization, and video blank is output by the Am8152A/53A.

Figure 4. MCLK $_{1}$ /MCLK $_{2}$ Output Waveform


Figure 5. Analog Video Outputs and Digital Video Outputs for Am8152A


Figure 6. Analog Video Outputs and Digital Video Outputs for Am8153A

## ANALOG ELECTRICAL CHARACTERISTICS (see notes)

The following conditions apply unless otherwise specified:
COM'L $T_{A}=0$ to $+70^{\circ} \mathrm{C} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ ( $\mathrm{Min}=4.75 \mathrm{~V}$ Max $=5.25 \mathrm{~V}$ ) Am8152A: $\mathrm{V}^{-}=0 \mathrm{~V}$ Am8153A: $\mathrm{V}^{-}=-5.2 \mathrm{~V} \pm 5 \%$ MIL $T_{C}=-55$ to $+125^{\circ} \mathrm{C} \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%(\operatorname{Min}=4.50 \mathrm{~V} \operatorname{Max}=5.50 \mathrm{~V}) \quad \mathrm{V}^{-}=0 \mathrm{~V} \quad \mathrm{~V}^{-}=-5.2 \mathrm{~V} \pm 10 \%$

| Grey Level | $\mathrm{VID}_{2}$ | $\mathrm{VID}_{1}$ |  | VIDOUT |  | VIDOUT |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min (\%) | Max (\%) | Min (\%) | Max (\%) |
| X | 1 | 1 | IWhite | 0 | 0 | 100 | 100 |
| 1 | 1 | 0 | IGrey1 | 37 | 44 | 56 | 63 |
| 0 | 1 | 0 | IGrey2 | 45 | 53 | 47 | 55 |
| X | 0 | 1 | IBlack | 90.5 | 92.5 | 7.5 | 9.5 |
| X | 0 | 0 | IBlank | 100 | 100 | 0 | 0 |

DRIFT OVER OPERATING CONDITIONS
(For particular part)

| Grey Level | VID 2 | VID 1 |  | VIDOUT | VIDOUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| X | 1 | 1 | IWhite | 0 | 0 |
| 1 | 1 | 0 | IGrey 1 | 2\% Max | 2\% Max |
| 0 | 1 | 0 | IGrey2 | 2\% Max | 2\% Max |
| X | 0 | 1 | IBlack | 1\% Max | 1\% Max |
| X | O | 0 | İBlank | 0 | 0 |

## Notes:

1. Test Condition: Normal IWhite for VIDOUT +13.3 mA .
2. Positive current flowing into VIDOUT/VIDOUT.
3. $t_{R}, t_{F}=5 n s$ Max.
4. VIDOUT output currents normalized to IWhite. VIDOUT output currents
normalized
to I IBlank.
5. Min/Max values for VIDOUT and VIDOUT account for variation of different devices.
6. Am8152A

V Pull-Up: $8.5 \mathrm{~V} \geqslant \mathrm{~V}$ Pull-Up $\geqslant \mathrm{V}_{\mathrm{CC}}$
VIDOUT/VIDOUT: (V Pull-Up) $\geqslant$ VIDOUT $/ \overline{\text { VIDOUT }} \geqslant\left(\mathrm{V}_{\mathrm{CC}}-1 \mathrm{~V}\right)$
7. Am8153A
$\checkmark$
Pull-
Up:
$3.5 \mathrm{~V} \geqslant \mathrm{~V}$
Pull-
$\mathrm{Up} \geqslant 0 \mathrm{~V}$
VIDOUT/VIDOUT: (V Pull-Up) $\geqslant$ VIDOUT/VIDOUT $\geqslant-1.0 \mathrm{~V}$

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$
Supply Voltage to Ground Potential Continuous $\qquad$ -0.5 V to +7.0 V
DC Voltage Applied to Outputs for
High Output State
-0.5 V to $+\mathrm{V}_{\mathrm{Cc}}$
DC Input Voltage
-0.5 V to +5.5 V
DC Output Current into Outputs........................... 30 mA
DC Input Current

## OPERATING RANGES

Commercial (C) Devices
Temperature ............................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage ...................... +4.75 V to +5.25 V
Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

Am8152A DC CHARACTERISTICS (See Note 4)

| Parameters | Description | Test Conditions (Note 1) |  |  |  | Min | Typ (Note 2) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | Output HIGH Voltage | $V_{C C}=$ Min | $\begin{aligned} & \text { MCLK }_{1} \\ & \text { MCLK }_{2} \end{aligned}$ | $\mathrm{IOH}^{\prime}=-0.1 \mathrm{~mA}$ | MIL | 3.6 |  |  | Volts |
|  |  |  | TTL Outputs | $\begin{aligned} & \mathrm{l}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \mathrm{l}_{\mathrm{OH}}=-2.6 \mathrm{~mA} \end{aligned}$ | COM'L | 4.0 |  |  | Volts |
|  |  |  |  |  | MIL | 2.4 | 3.4 |  | Volts |
|  |  |  |  |  | COM'L | 2.4 | 3.4 |  | Volts |
| VOL | Output LOW Voltage | $V_{C C}=M i n$ |  | $\mathrm{OL}=0.1 \mathrm{~mA} \mathrm{MCLK}{ }_{1 / 2}$ |  |  |  | 0.3 | Volts |
|  |  |  |  | $\mathrm{IOL}=16 \mathrm{~mA} \mathrm{TTL} \mathrm{Outputs}$ |  |  |  | 0.5 | Voits |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed Input HIGH Voltage |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Level | Guaranteed Input LOW Voltage |  |  |  |  |  | 0.8 | Volts |
| $\mathrm{V}_{1}$ | Input Clamp Voltage | $V_{C C}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.2 | Volts |
| ILL | Input LOW Current | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=0.4 V \end{aligned}$ |  | All Inputs (Except RES, EXTDCLK) |  |  |  | -0.4 | mA |
|  |  |  |  | RES, EXTDCLK |  |  |  | $-1.0$ | mA |
| IIH | Input HIGH Current | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=2.7 \mathrm{~V} \end{aligned}$ |  | All Inputs (Except RES) |  |  |  | +50 | $\mu \mathrm{A}$ |
|  |  |  |  | RES |  |  |  | +600 | $\mu \mathrm{A}$ |
| 1 | Input HIGH Current at Max Input Voltage | $\begin{aligned} & V_{C C}=M a x \\ & V_{\text {IN }}=5.5 \mathrm{~V} \end{aligned}$ |  |  |  |  |  | +1.0 | mA |
| Isc | Output Short Current Current (Note 3) | $V_{C C}=$ Max |  | MCLK ${ }_{1}$, MCL |  | -50 |  | -250 | mA |
|  |  |  |  | Others |  | -40 |  | -130 | mA |
| Icc | Power Supply Current | $\begin{aligned} & V_{C C 1}=M a x \\ & V_{C C 2}=M a x \end{aligned}$ | Over Operating Range |  |  |  |  | 415 | mA |
|  |  |  | @ $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  |  |  | 375 | mA |
|  |  |  | @ $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  |  |  | 350 | mA |

Notes: 1. For conditions shown as Min or Max use the appropriate value specified under DC Characteristics for the applicable device type.
2. Typical limits are at $V_{C C}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Except : $X_{1}, X_{2}, X_{3}$, AADJ, VIDOUT, VIDOUT.

| Am8153A DC CHARACTERSTICS (See Note 4) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| The following conditions apply unless otherwise specified: <br>  |  |  |  |  |  |  |  |  |  |
| Parameters | Description | Test Conditions (Note 1) |  |  |  | Min | Typ (Note 2) | Max | Units |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $V_{C C}=M i n$ |  | $\mathrm{IOH}^{\prime}=-0.1 \mathrm{~mA}$ | MIL | 3.6 |  |  | Volts |
|  |  |  | $\begin{aligned} & \mathrm{MCLK}_{1} \\ & \mathrm{MCLK}_{2} \end{aligned}$ |  | COM'L | 4.0 |  |  | Volts |
|  |  |  | TTL Outputs | $\begin{aligned} & \mathrm{lOH}=-1 \mathrm{~mA} \\ & \mathrm{OH}=-2.6 \mathrm{~mA} \end{aligned}$ | MIL | 2.4 | 3.4 |  | Volts |
|  |  |  |  |  | COM'L | 2.4 | 3.4 |  | Volts |
| VOL | Output LOW Voltage | $V_{C C}=\operatorname{Min}$ |  | $\mathrm{IOL}=0.1 \mathrm{~mA} \mathrm{MCLK} 1 / 2$ |  |  |  | 0.3 | Volts |
|  |  |  |  | $\mathrm{IOL}=16 \mathrm{~mA} \mathrm{TTL} \mathrm{Outputs}$ |  |  |  | 0.5 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Level | Guaranteed Input HIGH Voltage |  |  |  | 2.0 |  |  | Volts |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Level | Guaranteed Input LOW Voltage |  |  |  |  |  | 0.8 | Volts |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=$ Min, $I_{1 N}=-18 \mathrm{~mA}$ |  |  |  |  |  | -1.2 | Volts |
| I/L | Input LOW Current | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=0.4 V \end{aligned}$ |  | All Inputs (Except RES) |  |  |  | -0.4 | mA |
|  |  |  |  | RES |  |  |  | -1.0 | mA |
| ${ }_{1 / \mathrm{H}}$ | Input HIGH Current | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=2.7 V \end{aligned}$ |  | All inputs (Except RES) |  |  |  | $+50$ | $\mu \mathrm{A}$ |
|  |  |  |  | RES |  |  |  | $+600$ | $\mu \mathrm{A}$ |
| 4 | Input HIGH Current at Max Input Voltage | $\begin{aligned} & V_{C C}=M a x \\ & V_{I N}=5.5 V \end{aligned}$ |  |  |  |  |  | $+1.0$ | mA |
| ISC | Output Short Current Current (Note 3) | $V_{C C}=M a x$ |  | $\mathrm{MCLK}_{1}, \mathrm{MCLK}_{2}$ |  | -50 |  | -250 | mA |
|  |  |  |  | Others |  | -40 |  | -130 | mA |
| $1!<C C>$ | Power Supply Current | $\begin{aligned} & V_{C C 1}=\operatorname{Max} \\ & V_{C C 2}=\operatorname{Max} \end{aligned}$ | Over Operating Range |  |  |  |  | 410 | mA |
|  |  |  | @ $T_{A}=70^{\circ} \mathrm{C}$ |  |  |  |  | 370 | mA |
|  |  |  | (a) $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  |  |  | 345 | mA |
| $1-$ | Power Supply Current | $\mathbf{V}^{-}=\operatorname{Max}$ | Over Operating Range |  |  |  |  | 40 | mA |
|  |  |  | (a) $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  |  |  |  | 37 | mA |
|  |  |  | (a) $\mathrm{T}_{\mathrm{C}}=125^{\circ} \mathrm{C}$ |  |  |  |  | 35 | mA |

Notes: 1. For conditions shown as Min or Max use the appropriate value specified under DC Characteristics for the applicable device type.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.
4. Except: $X_{1}, X_{2}, X_{3}$, AADJ, VIDOUT, VIDOUT, VID 1, VID 2, EXTDCLK.

## DC CHARACTERISTICS

| $\begin{aligned} & \text { COM'L } \\ & \text { MIL } \end{aligned}$ | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=0 \text { to } 70^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{C}}=-55 \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 V \pm 5 \% \\ & V_{C C}=5.0 V \pm 10 \% \end{aligned}$ | $\begin{aligned} & \mathrm{GND}=O \mathrm{~V} \\ & \text { GND }=0 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & V-=-5.2 V \pm 5 \% \\ & V-=-5.2 V \pm 10 \% \end{aligned}$ |  | $\begin{aligned} & (\operatorname{Max}=-5.46, \operatorname{Min}=-4.94) \\ & (\operatorname{Max}=-5.72, \operatorname{Min}=-4.68) \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Parameters | Test Conditions | $-55^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ | $25^{\circ} \mathrm{C}$ | $70^{\circ} \mathrm{C}$ | $125^{\circ} \mathrm{C}$ | Unit |
| 10K ECL Outputs | $\mathrm{VOH}_{\mathrm{OH}}$ (Max) <br> VOH (Min) <br> $\mathrm{V}_{\mathrm{OHA}}$ (Min) | $\begin{aligned} & 50 \Omega \\ & \text { to }-2 V \end{aligned}$ | $\begin{gathered} \hline-880 \\ -1080 \\ -1100 \end{gathered}$ | $\begin{gathered} -840 \\ -1000 \\ -1020 \end{gathered}$ | $\begin{aligned} & -780 \\ & -930 \\ & -950 \\ & \hline \end{aligned}$ | $\begin{aligned} & -720 \\ & -900 \\ & -920 \\ & \hline \end{aligned}$ | $\begin{aligned} & -630 \\ & -825 \\ & -845 \end{aligned}$ | $\begin{aligned} & \mathrm{mV} \\ & \mathrm{mV} \\ & \mathrm{mV} \end{aligned}$ |
| $\begin{aligned} & \mathrm{VID}_{1} \text { and } \\ & \mathrm{VID}_{2} \end{aligned}$ | Vola (Max) <br> $V_{\text {OL }}$ (Max) <br> $\mathrm{V}_{\mathrm{OL}}$ (Min) | $\begin{aligned} & 50 \Omega \\ & \text { to }-2 V \end{aligned}$ | $\begin{aligned} & -1635 \\ & -1655 \\ & -1920 \\ & \hline \end{aligned}$ | $\begin{aligned} & -1645 \\ & -1665 \\ & -1870 \end{aligned}$ | $\begin{aligned} & -1600 \\ & -1620 \\ & -1850 \\ & \hline \end{aligned}$ | $\begin{aligned} & -1605 \\ & -1625 \\ & -1830 \\ & \hline \end{aligned}$ | $\begin{aligned} & -1525 \\ & -1545 \\ & -1820 \end{aligned}$ | $\begin{aligned} & \mathrm{mV} \\ & \mathrm{mV} \\ & \mathrm{mV} \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \text { 10K ECL } \\ & \text { Input } \end{aligned}$ | $\mathrm{V}_{\mathrm{H}}$ (Max) $V_{\text {IHA }}$ (Min) |  | $\begin{gathered} -880 \\ -1255 \end{gathered}$ | $\begin{gathered} -840 \\ -1145 \\ \hline \end{gathered}$ | $\begin{gathered} -780 \\ -1105 \\ \hline \end{gathered}$ | $\begin{gathered} -720 \\ -1045 \\ \hline \end{gathered}$ | $\begin{array}{r} -630 \\ -1000 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mV} \\ & \mathrm{mV} \end{aligned}$ |
| EXTDCLK | VILA (Max) <br> $V_{\text {IL }}$ (Min) |  | $\begin{aligned} & -1510 \\ & -1920 \end{aligned}$ | $\begin{aligned} & -1490 \\ & -1870 \end{aligned}$ | $\begin{aligned} & -1475 \\ & -1850 \\ & \hline \end{aligned}$ | $\begin{aligned} & -1450 \\ & -1830 \end{aligned}$ | $\begin{aligned} & -1400 \\ & -1820 \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{mV} \\ \mathrm{mV} \end{gathered}$ |
|  | $\begin{aligned} & I_{H} \\ & I_{1 L} \end{aligned}$ | $\begin{aligned} & V^{-}=\operatorname{Max} \\ & V_{\mathbb{I N}}=V_{\text {IH }}(\text { Max }) \\ & V^{-}=\operatorname{Max}^{2} \\ & \mathrm{~V}_{\mathbb{I N}}=\mathrm{V}_{\mathbb{I L}} \text { (Min) } \\ & \hline \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | $\begin{aligned} & 200 \\ & 150 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
|  |  |  |  |  |  |  |  |  |

Am8152A SWITCHING CHARACTERISTICS OVER OPERATING RANGE
( $\mathrm{T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}^{-}=0 \mathrm{~V}$ )

| Number | Description |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | MCLK ${ }_{1}$ Period |  | 100 |  | ns |
| 2 | $\mathrm{CLK}_{2}$ Period |  | 70 |  | ns |
| 3 | MCLK $1_{1} \mathrm{HIGH}$ (See Note 5) | 4.0 V | 38 |  | ns |
| 4 | MCLK $1_{1}$ LOW (See Notes 3 and 5) | 0.3 V | 38 |  | ns |
| 5 | MCLK 2 HIGH (See Note 6) | 4.0 V | 23 |  | ns |
| 6 | MCLK 2 LOW (See Notes 3 and 6) | 0.3 V | 23 |  | ns |
| 7 | Data to MCLK ${ }_{2}$ /TCLK 2 RE (See Note 1) |  | 20 |  | ns |
| 8 | $\mathrm{MCLK}_{2} /$ TCLK $_{2}$ to Data Not Valid |  | 0 |  | ns |
| 9 | VSYNC/HSYNC to MCLK ${ }_{1}$ RE Setup (SSEL = HIGH) |  | 20 |  | ns |
| 10 | VSYNC/HSYNC to MCLK 2 RE Setup (SSEL = LOW) |  | 20 |  | ns |
| 11 | $\mathrm{TCLK}_{2}$ RE to MCLK 2 RE Delay |  | - | 8 | ns |
| 12 | $\mathrm{TCLK}_{2} \mathrm{FE}$ to $\mathrm{MCLK}_{2}$ FE Delay |  |  | - 12 | ns |
| 13 | $\mathrm{MCLK}_{1}$ to VSLD, HSLD (SSEL $=$ HIGH) |  |  | $6+T_{D}$ | ns |
| 14 | $\mathrm{TCLK}_{2}$ to VSLD, HSLD (SSEL = LOW) |  | - | $6+T_{D}$ | ns |
| 15 | DD(0:7) to $\mathrm{TCLK}_{2} \mathrm{FE}$ |  | 20 |  | ns |
| 16 | TCLK 2 RE to $\mathrm{VID}_{1} \mathrm{VID}_{2} \mathrm{VAL}$ (See Note 2) |  |  | $6+\mathrm{T}_{\mathrm{D}}$ | ns |
| 17 | BLANK FE to MCLK 2 RE Setup (SSEL = LOW) |  | 20 |  | ns |
| 18 | BLANK FE to MCLK ${ }_{1}$ FE Setup (SSEL = HIGH) |  | 20 |  | ns |
| 19 | BLANK RE to MCLK 1 RE Setup (SSEL = HIGH) |  | 20 |  | ns |
| 20 | BLANK RE to MCLK2 PE Setup (SSEL = LOW) |  | 20 |  | ns |
| 22 | $\mathrm{VID}_{1}$ to $\mathrm{VID}_{2}$ Skew |  | -5 | +5 | ns |
| 24 | EXTDCLK to MCLK ${ }_{1}$ |  |  | 20 | ns |
| 25 | EXTDCLK to TCLK |  |  | 13 | ns |
| 26 | EXTDCLK to MCLK |  |  | 23 | ns |
| 27 | EXTDCLK to $\mathrm{VID}_{1} / \mathrm{VID}_{2}$ |  |  | 13 | ns |
| 28 | EXTDCLK to HSDLD/VSDLD (SSEL HI) |  |  | 13 | ns |
| 29 | EXTDCLK to HSDLD/VSDLD (SSEL LO) |  |  | 13 | ns |
| 30 | EXTDCLK to Data in Setup |  | 9 |  | ns |
| 31 | EXTDCLK to Data Not Valid Hold |  | 11 |  | ns |
| 32 | EXTDCLK to H/V SYNC Setup |  | 10 |  | ns |
| 33 | EXTDCLK Period |  | 16.6 |  | ns |
| 34 | EXTDCLK LOW Cycle |  | 5 |  | ns |
| 35 | EXTDCLK HIGH Cycle |  | 5.0 |  | ns |
| 36 | Reset Pulse Width (High) |  | 10.0 |  | ns |
| 37 | Reset Low to EXTDCLK Setup |  | 8.0 |  | ns |

Notes: 1. Data includes CBLANK, FORE, REV, FS, $\mathrm{DD}_{0}-\mathrm{DD}_{8}, \mathrm{~TB} 0, \mathrm{~TB} 1, \mathrm{BS}, \mathrm{CLK}_{1} \mathrm{DR}, \mathrm{CLK}_{2} \mathrm{DR}, \mathrm{DW}$.
2. First Pixel of character. $T_{D}$ is pixel period as defined by oscillator frequency.
3. Max undershoot on these outputs is guaranteed to be -0.3 V .
4. TD is the dot clock period.
5. Guaranteed to 100 ns MCLK ${ }_{1}$ cycle time.
6. Guaranteed to 70 ns MCLK $\mathrm{K}_{2}$ cycle time (even divide ratio only).

Am8153A SWITCHING CHARACTERISTICS OVER OPERATING RANGE
( $\mathrm{T}_{\mathrm{A}}=0$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}^{-}=-5.2 \mathrm{~V} \pm 5 \%$ )

| Number | Description |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | MCLK ${ }_{1}$ Period |  | 100 |  | ns |
| 2 | CLK2 Period |  | 70 |  | ns |
| 3 | MCLK ${ }_{1}$ HIGH (See Note 5) | 4.0 V | 38 |  | ns |
| 4 | MCLK $_{1}$ LOW (See Notes 3 and 5) | 0.3 V | 38 |  | ns |
| 5 | MCLK 2 HIGH (See Note 6) | 4.0 V | 23 |  | ns |
| 6 | MCLK 2 LOW (See Notes 3 and 6) | 0.3 V | 23 |  | ns |
| 7 | Data to $\mathrm{MCLK}_{2} / \mathrm{TCLK}_{2} \mathrm{RE}$ (See Note 1) |  | $\begin{aligned} & 20+\mathrm{T}_{\mathrm{D}} \\ & \text { (See Note } \end{aligned}$ |  | ns |
| 8 | $\mathrm{MCLK}_{2} /$ TCLK $_{2}$ to Data Not Valid |  | 0 |  | ns |
| 9 | VSYNC/HSYNC to MCLK ${ }_{1}$ RE Setup (SSEL = HIGH) |  | $20+{ }^{\text {T }}$ d |  | ns |
| 10 | VSYNC/HSYNC to MCLK 2 RE Setup (SSEL = LOW) |  | $20+{ }^{\text {T }}$ D |  | ns |
| 11. | TCLK $_{2}$ RE to MCLK 2 RE Delay |  | - | 8 | ns |
| 12 | $\mathrm{TCLK}_{2} \mathrm{FE}$ to MCLK 2 FE Delay |  | + | 12 | ns |
| 13 | MCLK $_{1}$ to VSLD, HSLD (SSEL $=$ HIGH) |  | , | 6 | ns |
| 14 | TCLK 2 to VSLD, HSLD (SSEL = LOW) |  |  | 6 | ns |
| 15 | DD(0:7) to TCLK 2 FE |  | $20+T_{D}$ |  | ns |
| 16 | TCLK ${ }_{2}$ RE to $\mathrm{VID}_{1} \mathrm{VID}_{2}$ VAL (See Note 2) |  |  | 6 | ns |
| 17 | BLAANK FE to MiCLK̇ ${ }^{\text {RE }}$ RE Setup (SSEL=LOW) |  | $20+T_{D}$ |  | ns |
| 18 | BLANK FE to MCLK ${ }_{1}$ FE Setup (SSEL $=\mathrm{HIGH}$ ) |  | $20+T_{D}$ |  | ns |
| 19 | BLANK RE to MCLK 1 RE Setup (SSEL = HIGH) |  | $20+T_{D}$ |  | ns |
| 20 | BLANK RE to MCLK ${ }_{2}$ RE Setup (SSEL = LOW) |  | $20+\mathrm{T}_{\text {D }}$ |  | ns |
| 21 | $\mathrm{VID}_{1}$ to $\mathrm{VID}_{2}$ Skew |  | -2 | +2 | ns |
| 24 | EXTDCLK to MCLK ${ }_{1}$ |  |  | 20 | ns |
| 25 | EXTDCLK to TCI.K. |  |  | 10 | ns |
| 26 | EXTDCLK to MCLK 2 |  |  | 23 | ns |
| 27 | EXTOCLK to $\mathrm{VID}_{1} / \mathrm{VID}_{2}$ |  |  | 8 | ns |
| 28 | EXTIDCLK to HSDLD/VSDLD (SSEL HI) |  |  | 10 | ns |
| 29 | EXTDCLK to HSDLD/VSDLD (SSEL LO) |  |  | 10 | ns |
| 30 | EXTDCLK to Data in Setup |  | 9 |  | ns |
| 31 | EXTDCLK to Data Not Valid Hold |  | 11 |  | ns |
| 32 | EXTDCLK to H/V SYNC Setup |  | 10 |  | ns |
| 33 | EXTDCLK Period |  | 10 |  | ns |
| 34 | EXTDCLK LOW Cycle |  | 5 |  | ns |
| 35 | EXTDCLK HIGH Cycle |  | 3.5 |  | ns |
| 36 | Reset Pulse Width (High) |  | 10.0 |  | ns |
| 37 | Reset Low to EXTDCLK Setup |  | 8.0 |  | ns |

Notes: 1. Data includes CBLANK, FORE, REV, FS, $\mathrm{DD}_{0}-\mathrm{DD}_{8}, \mathrm{TBO}, \mathrm{TB} 1, \mathrm{BS}, \mathrm{CLK}_{1} \mathrm{DR}, \mathrm{CLK}_{2} \mathrm{DR}$, DW.
. First Pixel of character. $T_{D}$ is pixel period as defined by oscillator frequency.
. Max undershoot on these outputs is guaranteed to be -0.3 V .
4. $T_{D}$ is the dot clock period.
5. Guaranteed to 100 ns MCLK ${ }_{1}$ cycle time.
. Guaranteed to 70 ns MCLK 2 cycle time (even divide ratio only).



WF001750

## 8284A/8284A-1

Clock Generator and Driver for 8086, 8088 Processors

- Generates the System Clock for the 8086, 8088 Processors: $5 \mathrm{MHz}, 8 \mathrm{MHz}$ with 8284 A ; 10 MHz with $8284 \mathrm{~A}-1$
- Uses a crystal or a TTL signal for frequency source
- Provides local READY and Multibus* READY synchronization
- Generates system reset output from Schmitt trigger input
- Capable of clock synchronization with other 8284As


## GENERAL DESCRIPTION

The 8284A is a single chip clock generator/driver for the 8086, 8088 processors. The chip contains a crystal-con-
trolled oscillator, a divide-by-three counter, complete MULTIBUS* 'Ready" synchronization and reset logic.

BLOCK DIAGRAM


RELATED PRODUCTS

| Part No. | Description |
| ---: | :--- |
| Am8086 | 16 -Bit Microprocessor |
| 8288 | Bus Controller |

## CONNECTION DIAGRAM Top View



Note: Pin 1 is marked for orientation
ORDERING INFORMATION
AMD products are available in sevoral packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


| Valid Combinations |  |
| :--- | :--- |
| MD <br> P <br> $D$ | 8284 A |
| MD <br> $D$ | 8284 AB |
| D | $8284 \mathrm{~A}-1$ |
| Dice | $8284 \mathrm{~A}-1 \mathrm{~B}$ |

Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.

# PIN DESCRIPTION 

| Pin No． | Name | 1／0 | Description |
| :---: | :---: | :---: | :---: |
| 3， 7 | $\frac{\overline{\operatorname{AEN}}_{1}}{\mathrm{AEN}_{2}}$ | 1 | $\overline{\text { Address Enable．The } \overline{\text { AEN }} \text { signal is used to qualify the Bus Ready signal（RDY }{ }_{1} \text { or } \text { RDY }_{2} \text { ）．} \overline{\text { AEN }}_{1} \text { validates } \text { RDY }_{1} \text { while }}$ $\overline{A E N}_{2}$ validates $\mathrm{RDY}_{2}$ ．It is possible for the processor to access two Multi－Master System Busses if you use both signals．Both signals are tied LOW in non Multi－Master Systems． |
| 4， 6 | $\begin{aligned} & \mathrm{RDY}_{1}, \\ & \mathrm{RDY}_{2} \end{aligned}$ | 1 | Bus Ready．These signals are indications from a device located on the system bus that it is available or data has been received．RDY 1 and $R D Y_{2}$ are qualified by $\overline{\operatorname{AEN}}_{1}$ and $\overline{\operatorname{AEN}}_{2}$ respectively． |
| 15 | ASYNC | 1 | Ready Synchronous Select．The $\overline{A S Y N C}$ signal defines the synchronization mode of the READY logic．When $\overline{\text { ASYNC }}$ is open（internal pull－up resistor is provided）or pulled HIGH，there is one stage of READY Synchronization．When $\overline{A S Y N C}$ is LOW，there are two stages of READY Synchronization． |
| 5 | READY | 0 | Ready．READY is the synchronized RDY signal input．After the guaranteed hold time to the processor has been met， the READY signal is cleared． |
| 7， 16 | $x_{1}, x_{2}$ | 1 | Crystal In．These are the input pins for the attached crystal．The crystal frequency is 3 times the desired process clock frequency． |
| 13 | F／C | 1 | Frequency／Crystal Select．When F／$\overline{\mathrm{C}}$ is strapped HIGH，CLK is generated from the EFI input．When strapped LOW， the $F / \overline{\mathrm{C}}$ allows the processor clock to be generated by the crystal． |
| 14 | EFI | 1 | External Frequency．Used in conjunction with a HIGH signal on F／$\overline{\mathrm{C}}$, CLK is generated from the input frequency appearing on this pin．The input signal is a square wave 3 times the frequency of the desired CLK output． |
| 8 | CLK | 0 | Processor Clock．CLK is the clock output used by the processor and all devices which directly connect to the processor＇s local bus（including bipolar support chips and other MOS devices）．An output HIGH of $4.5 \mathrm{~V}\left(\mathrm{~V}_{C C}=5 \mathrm{~V}\right)$ is provided on this pin to drive MOS devices．The output frequency of CLK is $1 / 3$ of the crystal on EFI input frequency and a 1／3 duty cycle． |
| 2 | PCLK | 0 | Peripheral Clock．This signal is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK and has a $50 \%$ duty cycle． |
| 12 | OSC | 0 | Oscillator Output．This signal is the TTL level output of the internal oscillator circuitry．Its frequency is equal to that of the crystal． |
| 11 | $\overline{\mathrm{RES}}$ | 1 | $\overline{\text { Reset }}$ In．This signal is used to generate a RESET．The 8284A provides a Schmitt trigger input so that an RC connection can be used to establish the power－up reset of proper duration． |
| 10 | RESET | 0 | Reset．This signal is used to reset the 8086 family processors． |
| 1 | CSYNC | 1 | Clock Synchronization．This signal is designed to allow multiple 8284As to be synchronized to provide clocks that are in phase．CSYNC HIGH will reset the internal counters，when CSYNC goes LOW the counters will resume counting． CSYNC needs to be externally synchronized to EFI．When used with the internal oscillator，CSYNC should be hard wired to ground． |

## DETAILED DESCRIPTION

## OSCILLATOR

The oscillator circuit of the 8284A is designed primarily for use with a fundamental mode，series resonant crystal from which the operating frequency is derived．

The crystal frequency should be selected at three times the required CPU clock．$X_{1}$ and $X_{2}$ are the two crystal input crystal connections．The output of the oscillator is buffered and brought out on OSC so that other system timing signals can be derived from this stable，crystal－controlled source．

Two $510 \Omega$ series resistors are optional for systems which have a $V_{C C}$ ramp time greater than（or equal to） $1 \mathrm{~V} / \mathrm{ms}$ and／or inherent board capacitance between $X_{1}$ or $X_{2}$ exceeding 10 pF ．This capacitance value should not include the 8284A＇s pin capacitance．By limiting the stray capacitance to less than 10 pF on $\mathrm{X}_{1}$ or $\mathrm{X}_{2}$ ，the deviation from the desired fundamental frequency is minimized．

## CLOCK GENERATOR

The clock generator consists of a synchronous divide－by－three counter with a special clear input that inhibits the counting． This clear input，（CSYNC），allows the output clock to be synchronized with an external event（such as another 8284A clock）．It is necessary to synchronize the CSYNC input to the EFI clock external to the 8284A（see Figure 1）．This is accomplished with two Schottky flip－flops．The counter output is a $33 \%$ duty cycle clock at one－third the input frequency．
The F／ $\bar{C}$ input is a strapping pin that selects either the EFI input or the crystal oscillator as the clock for the $\div 3$ counter．If the EFI input is selected as the clock source，the oscillator section can be used independently for another clock source． Output is taken from OSC．

## CLOCK OUTPUTS

The CLK output is a $33 \%$ duty cycle MOS clock driver designed to drive the 8086 or 8088 processors directly．PCLK is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK．PCLK has a $50 \%$ duty cycle．

## RESET LOGIC

Reset logic for the 8284A is provided by a Schmitt trigger input （RES）and a synchronizing flip－flop to generate the reset timing．
The reset signal is synchronized to the falling edge of CLK．A simple RC network can be used to provide power－on reset by utilizing this function of the 8284A．

## READY SYNCHRONIZATION

Two READY inputs（RDY ${ }_{1}$, RDY $_{2}$ ）are provided to accommo－ date two Multi－Master system busses．Each input has a qualifier（ $\overline{\operatorname{AEN}}_{1}$ and $\overline{\mathrm{AE}} \mathrm{N}_{2}$ ，respectively）．The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals．If a Multi－Master system is not being used the $\overline{\text { AEN }}$ pin should be tied LOW．
To assure RDY setup and hold times are met，synchronization is required for all asynchronous active going edges of either RDY input．Inactive－going edges of RDY（in normally ready systems）do not require synchronization，but must satisfy RDY setup and hold as a matter of proper system design．

The two modes of RDY synchronization operation are defined by the $\overline{\text { ASYNC input．}}$

When $\overline{A S Y N C}$ is LOW，two stages of synchronization are provided for active RDY input signals．Positive－going asyn－ chronous RDY inputs will first be synchronized to flip－flop one at the rising edge of CLK and then synchronized to flip－flop two at the next falling edge of CLK；after which time the READY output will go active（HIGH）．Negative－going asynchro－
nous RDY inputs will be synchronized directly to flip-flop two at the falling edge of CLK, after which time the READY output will go inactive. This mode of operation is intended for use by asynchronous, (normally not ready), devices in the system which cannot be guaranteed by design to meet the required RDY setup timing $t_{\text {R1VCL }}$ on each bus cycle.

When $\overline{\text { ASYNC }}$ is high or left open, the first READY flip-flop is bypassed in the READY synchronization logic. RDY inputs are
synchronized by flip-flop two on the falling edge of CLK before they are presented to the processor. This mode is available for synchronous devices that can be guaranteed to meet the required RDY setup time.
$\overline{A S Y N C}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.

Figure 1. CSYNC Synchronization


## CLOCK HIGH AND LOW TIME (USING $X_{1}, X_{2}$ )



$$
R_{1}=R_{2}=510 \Omega
$$

## CLOCK HIGH AND LOW TIME (USING EFI)



## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature with Powers
Applied

(MIL) ......................................... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
All Output and Supply Voltages ............... -0.5 V to +7.0 V
All Input Voltage..................................... -1.0 V to +5.5 V
Power Dissipation ....................................................... 1W
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage $\qquad$ +4.75 V to +5.25 V

Military (M) Devices
Temperature $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{F}$ | Forward Input Current ( $\overline{\text { ASYNC }}$ ) | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |  | -1.3 | mA |
|  | Other Inputs | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |  | -0.5 |  |
| IR | Reverse Input Current ( $\overline{\text { ASYNC, }}$ | $\mathrm{V}_{\mathrm{H}}-\mathrm{V}_{\mathrm{C}} \mathrm{CC}$ |  | 50 | $\mu \mathrm{A}$ |
|  | Other Inputs | $V_{R}=5.25 \mathrm{~V}$ |  | 50 |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage | $\mathrm{I}^{\prime}=-5 \mathrm{~mA}$ |  | -1.0 | Volts |
| ICC | Power Supply Current |  |  | 162 | mA |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage |  |  | 0.8 | Volts |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage |  | 2.0 |  | Volts |
| $\mathrm{V}_{\text {IHR }}$ | Reset Input HIGH Voltage |  | 2.6 |  | Volts |
| VOL | Output LOW Voltage | 5 mA |  | 0.45 | Volts |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage CLK | -1mA | 4.0 | 2.5 | Volts |
|  | Other Outputs | -1mA | 2.4 |  |  |
| $\mathrm{V}_{\text {IHR }} \mathrm{V}_{\text {ILR }}$ | $\overline{\mathrm{RES}}$ Input Hysteresis |  | 0.25 |  | Volts |

SWITCHING TESTING CIRCUIT (CLK, READY)


TC000670

SWITCHING TESTING CIRCUIT
(CLK, READY)
SWITCHING TESTING WAVEFORM (input, output)

TC000680



C testing inputs are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " O '. Timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ".

SWITCHING CHARACTERISTICS over operating range unless otherwise specified

TIMING REQUIREMENTS

| Parameters | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {EHEL }}$ | External Frequency HIGH Time | 90\% - 90\% $\mathrm{V}_{\text {IN }}$ | 13 |  |  | ns |
| teleh | External Frequency LOW Time | $10 \%-10 \% \mathrm{~V}_{\text {IN }}$ | 13 |  |  | ns |
| $t_{\text {ELEL }}$ | EFI Period | MIL (Note 1) | $\mathrm{t}_{\text {EHEL }}+\mathrm{t}_{\text {ELEH }}+\delta$ |  |  | ns |
|  |  | COM'L, A-1 | 33 |  |  |  |
|  | XTAL Frequency |  | 12 |  | 25 | MHz |
| $\mathrm{t}_{\text {RIVCL }}$ | $\mathrm{RDY}_{1}$, RDY $_{2}$ Active Setup to CLK | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ | 35 |  |  | ns |
| $\mathrm{t}_{\text {fivCh }}$ | $\mathrm{RDY}_{1}, \mathrm{RDY}_{2}$ Active Setup to CLK | $\overline{\text { ASYNC }}=$ LOW | 35 |  |  | ns |
| trival | $\mathrm{RDY}_{1}, \mathrm{RDY}_{2}$ Inactive Setup to CLK |  | 35 |  |  | ns |
| tCLR1X | RDY ${ }_{1}$, RDY 2 Hold to CLK |  | 0 |  |  | ns |
| $t_{\text {AYVCL }}$ | $\overline{\text { ASYNC }}$ Setup to CLK |  | 50 |  |  | ns |
| tclay | $\overline{\text { ASYNC }}$ Hold to CLK |  | 0 |  |  | ns |
| taiVR1V | $\overline{\mathrm{AEN}_{1}}, \overline{\mathrm{AEN}} 2$ Setup to RDY ${ }_{1}, \mathrm{RDY}_{2}$ |  | 15 |  |  | ns |
| tCLA1X | $\overline{\mathrm{AEN}}{ }_{1}, \overline{\mathrm{AEN}}{ }_{2}$ Hold to CLK |  | 0 |  |  | ns |
| tYHEH | CSYNC Setup to EFI |  | 20 |  |  | ns |
| ${ }_{\text {tehyl }}$ | CSYNC Hold to EFI | MIL | 20 |  |  | ns |
|  |  | COM'L, A-1 | 10 |  |  |  |
| tyHYL | CSYNC Width |  | 2.tELEL |  |  | ns |
| $\mathrm{t}_{11 \mathrm{HCL}}$ | $\overline{\text { RES }}$ Setup to CLK | (Note 2) | 65 |  |  | ns |
| tCLITH | RES Hold to CLK | (Note 2) | 20 |  |  | ns |
| tILIH | Input Rise Time | From 0.8 V to 2.0 V |  |  | 20 | ns |
| tILIL | Input Fall Time | From 2.0 V to 0.8 V |  |  | 12 | ns |




## 8286/8287

## Octal Bus Transceivers

## DISTINCTIVE CHARACTERISTICS

- Data bus buffer/driver for $8086,8088,8080 \mathrm{~A}, 8085 \mathrm{~A}$, and 8048 processors
- Fully parallel 8 -bit transceivers: 8286 is noninverting 8287 is inverting
- 3-state inputs/outputs for interfacing with bus-oriented systems
- Available in 20-pin, $0.3^{\prime \prime}$ center molded DIP or ceramic package
- Advanced bipolar Schottky processing
- Bus port stays in hi-impedance state during power up/ down transition


## GENERAL DESCRIPTION

The 8286 and 8287 are 8-bit 3-state bipolar Schottky transceivers. They provide bidirectional drive for busoriented microprocessor and digital communications systems. Straight through bidirectional transceiver's are featured, with 16 mA drive capability on the A ports and 32 mA bus drive capability on the B ports. PNP inputs are incorporated to reduce input loading.

One input, Transmit/Receive determines the direction of logic signals through the bidirectional transceiver. The Chip Disable input disables both A and B ports by placing them in a 3 -state condition. Chip Disable is functionally the same as an active LOW chip select.



| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
|  | $A_{0}-A_{7}$ | 1/0 | A port inputs/outputs are receiver output drivers when $T / \bar{R}$ is Low and are transmit inputs when $T / \bar{R}$ is HIGH. |
|  | $B_{0}-B_{7}$ | 1/O | B port inputs/outputs are transmit output drivers when $T / \overline{\mathrm{R}}$ is HIGH and receiver inputs when $T / \overline{\mathrm{R}}$ is LOW. |
| 9 | CD | 1 | Chip Disable forces all output drivers into 3 -state when HIGH (same function as active LOW chip select, CS). |
| 11 | $T / \bar{R}$ | 1 | Transmit/度eceiver direction control determines whether A port or B port drivers are in 3-state. With $T / \bar{R}$ HIGH, A port is the input and B port is the output. With T/信 LOW, A port is the output and B port is the input. |


| Inputs | Conditions |  |  |
| :--- | :---: | :---: | :---: |
| Chip Disable | 0 | 0 | 1 |
| Transmit/Receive | 0 | 1 | X |
| A Port | Out | In | HI-Z |
| B Port | In | Out | HI-Z |

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\ldots \ldots \ldots \ldots \ldots \ldots \ldots . . .5^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

Input Voltage. $+5.5 \mathrm{~V}$
Output Voltage $+5.5 \mathrm{~V}$
Lead Temperature (Soldering, 10 seconds) $300^{\circ} \mathrm{C}$
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 device reliability.

## OPERATING RANGES

Commercial (C) Devices

$$
\begin{aligned}
& \text { Temperature } \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots .0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
& \text { Supply Voltage } \ldots \ldots \ldots \ldots \ldots \ldots \ldots+4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V}
\end{aligned}
$$

Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage
+4.5 V to +5.5 V
Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description |  | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |  | -1 | Volts |
| Icc | Power Supply Current | 8287 |  |  | 130 | mA |
|  |  | 8286 |  |  | 160 |  |
| $i_{F}$ | Forward Input Current |  | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |  | -0.2 | mA |
| $I_{\text {R }}$ | Reverse Input Current |  | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |  | 50 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OL }}\left(\mathrm{COM}{ }^{\prime} \mathrm{L}\right)$ | Output Low Voltage | B Outputs | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | . 45 | Volts |
|  |  | A Outputs | $\mathrm{IOL}=16 \mathrm{~mA}$ |  | . 45 |  |
| $\mathrm{V}_{\mathrm{OL}}$ (MIL) | Output Low Voltage | B Outputs | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  | . 45 | Volts |
|  |  | A Outputs | $\mathrm{IOL}=10 \mathrm{~mA}$ |  | . 45 |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | B Outputs | $\mathrm{IOH}^{\prime}=-5 \mathrm{~mA}$ | 2.4 |  | Volts |
|  |  | A Outputs | $\mathrm{IOH}=-1 \mathrm{~mA}$ | 2.4 |  |  |
| loff | Output Off Current |  | $\mathrm{V}_{\text {OFF }}=0.45 \mathrm{~V}$ |  | $l_{\text {F }}$ |  |
|  |  |  | $\mathrm{V}_{\text {OFF }}=5.25 \mathrm{~V}$ |  | IR |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | A Port | $\mathrm{V}_{\text {CC }}=5.0 \mathrm{~V}$ (See note 1) |  | 0.8 | Volts |
|  |  | B Port | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ (See note 1) |  | 0.9 |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ (See note 1) | 2.0 |  | Volts |
| $\mathrm{CIN}_{1}$ | Input Capacitance |  | $\begin{aligned} & \mathrm{F}=1 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  | 12 | pF |

## OPERATING CHARACTERISTICS

## Output Delay versus Capacitance




## SWITCHING TEST CIRCUITS




A OUTPUT
OUT O——


B OUTPUT


B OUTPUT

A OUTPUT


A OUTPUT

Values in parenthesis reflect MIL temp. conditions.
SWITCHING CHARACTERISTICS (See Note 2)



AC testing inputs are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " 0 "; timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ."

## DISTINCTIVE CHARACTERISTICS

- Bipolar drive capability
- 3-state output drivers
- Multi-master or I/O bus interface
- Flexible system configurations


## GENERAL DESCRIPTION

The 8288 optimizes 8086 or 8088 operations by providing command and control timing generation when the CPU is in maximum mode. It provides for highly flexible configurations for larger systems. It also adds powerful bipolar drive capability to the system.

The 8288 is implemented in bipolar technology in a 20-pin DIP.

BLOCK DIAGRAM


BD001570


| Valid Combinations |  |
| :--- | :--- |
| D | 8288 |
|  | $8288 B$ |



Valid Combinations
Consult the AMD sales office in your area to determine if a device is currently available in the combination you wish.


Note: Pin 1 is marked for orientation

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following Device number, speed option (if applicable), package type, operating range and screening option (if desired).

Top View

CD001840

| Pin No. | Name | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| 19, 3, 18 | $\overline{\mathrm{S}}_{0}, \overline{\mathrm{~S}}_{1}, \overline{\mathrm{~S}}_{2}$ | 1 | Status. These signals are the status input pins from the microprocessor. The 8288 decodes these inputs to generate command and control signals. |
| 2 | CLK | 1 | Clock. Clock signal from the clock generator. |
| 5 | ALE | 0 | Address Latch Enable. This signal strobes an address into the address latches. The latching occurs on the falling edge (HIGH to LOW) transition. |
| 16 | DEN | 0 | Data Enable. This signal enables the data transceivers onto the data bus (local or system). |
| 4 | DT/ $\overline{\mathrm{R}}$ | 0 | Data Transmit/Receive. This signal determines the direction of data flow through the transceivers. |
| 6 | $\overline{\text { AEN }}$ | 1 | Address Enable. This signal enables the 8288 command outputs at least 115 ns after it becomes active LOW. When this pin goes inactive, it 3-states the command output drivers. |
| 15 | CEN | 1 | Command Enable. This signal, when LOW, enables all command outputs and the DEN and PDEN control outputs are forced to their inactive states. |
| 1 | 10B | 1 | Input/Output Bus Mode. When strapped HIGH, the 8288 functions in the I/O Bus mode. When LOW, the 8288 functions in the System Bus mode. |
| 12 | $\overline{\text { AIOWC }}$ | 0 | Advanced I/O Write Command. The AIOWC gives I/O devices early indication of a write instruction by issuing an I/O Write Command earlier in the machine cycle. |
| 11 | IOWC | 0 | $\overline{1 / O W r i t e}$. This signal tells an 1/O device to read the data on the data bus. |
| 13 | IORC | 0 |  |
| 8 | AMWC | 0 | Advanced Memory Write. The AMWC gives memory devices an early indication of a write instruction by issuing a memory write command earlier in the machine cycle. |
| 9 | $\overline{\text { MWTC }}$ | 0 | Memory Write. This signal instructs the memory to record the data present on the data bus. |
| 7 | MRDC | 0 | Miemory $\overline{\text { read. }}$ This signal instructs the memory to drive its data onto the data bus. |
| 14 | $\overline{\text { INTA }}$ | 0 | Interrupt Acknowledge. This signal informs the interrupting device that its interrupt has been acknowledged and drives the vectoring information onto the data bus. |
| 17 | $\frac{\text { MCE/ }}{\text { PDEN }}$ | 0 | Master Cascade Enable/ $\overline{\text { Peripheral Data Enable. Dual Function pin: MCE (IOB LOW): This signal occurs during an }}$ interrupt sequence. Its function is to read a Cascade Address from a master Priority Interrupt Controller onto the data bus. PDEN (IOB HIGH): This signal enables the data bus transceiver for the I/O Bus during I/O instructions. It performs the same function for the I/O Bus that DEN performs for the system bus. |

## DETAILED DESCRIPTION

## COMMAND AND CONTROL LOGIC

The command logic decodes the three CPU status lines $\left(\bar{S}_{0}\right.$, $\overline{\mathrm{S}}_{1}, \overline{\mathrm{~S}}_{2}$ ) to determine what command is to be issued.

This chart shows the meaning of each status 'word.'"

| $\overline{\mathbf{s}}_{\mathbf{2}}$ | $\overline{\mathbf{s}}_{\mathbf{1}}$ | $\overline{\mathbf{s}}_{\mathbf{0}}$ | Processor State | 8288 <br> Command |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 1 | Interrupt Acknowledge | $\overline{\mathrm{INTA}}$ |
| 0 | 0 | 1 | Read 1/O Port | $\overline{\text { IORC }}$ |
| 0 | 1 | 0 | Write I/O Port | $\overline{\text { IOWC, }} \overline{\text { AlOWC }}$ |
| 0 | 1 | 1 | Halt | None |
| 1 | 0 | 0 | Code Access | $\overline{\text { MRDC }}$ |
| 1 | 0 | 1 | Read Memory | $\overline{\text { MRDC }}$ |
| 1 | 1 | 0 | Write Memory | $\overline{\text { MWTC, }} \overline{\text { AMWC }}$ |
| 1 | 1 | 1 | Passive | None |

## I/O BUS MODE

The 8288 is put into the I/O Bus mode by strapping the IOB pin HIGH. This mode allows one 8288 Bus Controller to handle two external buses. This allows the CPU to access the I/O Bus with no waiting involved. In the I/O Bus Mode, all I/O command lines ( $\overline{\mathbb{N T A}}, \overline{\overline{O R C}, \overline{\mathrm{OWC}}, \overline{\mathrm{AIOWC}}) \text { are always }}$ enabled. When the processor initiates an I/O Command, the 8288 immediately activates the command lines using $\overline{\text { PDEN }}$ and $D T / \bar{R}$ to control the $1 / O$ bus transceiver. There is no arbitration present in this system, so the I/O command lines should not be used to control the system bus. Normal memory access requires a "Bus Ready" signal ( $\overline{\mathrm{AEN}}$ LOW) before it will proceed. The IOB mode is recommended if $1 / 0$ or
peripherals dedicated to one processor exist in a multiprocessor based system.

## SYSTEM BUS MODE

The 8288 is put into the System Bus mode by strapping the IOB pin LOW. This mode is used when only one bus exists. No command is issued until 115 ns after the $\overline{\mathrm{AEN}}$ line is activated. Bus arbitration is assumed, and this logic will inform the bus controller via the $\overline{A E N}$ line when the bus is free for use. Both I/ O commands and memory wait for bus arbitration.

## COMMAND OUTPUTS

To prevent the processor from entering unnecessary wait states, the advanced write commands initiate write procedures early in the machine cycle.

The command outputs are:
$\overline{\text { MRDC }}$ - Memory Read Command
MWTC - Memory Write Command
$\overline{\text { IORC }}-1 / 0$ Read Command
IOWC - I/O Write Command
$\overline{\text { AMWC - Advanced Memory Write Command }}$
AIOWC - Advanced I/O Write Command
INTA - Interrupt Acknowledge
$\overline{\text { INTA }}$ (Interrupt Acknowledge) acts as an I/O read during an interrupt cycle. Its purpose is to inform an interrupting device that its interrupt is being acknowledged and that it should place vectoring information onto the data bus.

## CONTROL OUTPUTS

 Master Cascade Enable/Peripheral Data Enable (MCE/ $\overline{\text { PDEN }})$ are the control outputs of the 8288. The DEN signal determines when the external bus should be enabled onto the local bus while the $D T / \bar{R}$ determines the direction of the data transfer. These two signals usually go to the chip select and direction pins of a transceiver.

The MCE/PDEN function is determined by the IOB selection. When IOB is HIGH the $\overline{\text { PDEN serves as a dedicated data }}$ enable signal for the I/O or Peripheral System Bus.

## INTERRUPT ACKNOWLEDGE AND MCE

The MCE signal is used during an interrupt acknowledge cycle if the 8288 is in the System Bus mode (IOB Low). An interrupt sequence consists of two interrupt acknowledge cycles occurring back to back. No data or address transfers take place during the first cycle. Logic should be provided to mask off MCE during this cycle. Just before the second cycle begins the MCE signal gates a master Priority Interrupt Controller's (PIC) cascade address onto the processor's local bus where ALE (Address Latch Enable) strobes it into the address latches. On the leading edge of the second interrupt cycle the addressed slave PIC gates an interrupt vector onto the system data bus where it is read by the processor.

The MCE signal is not used if the system only contains one PIC. If this is the case the second Interrupt Acknowledge signal gates the interrupt vector onto the processor bus.

## ADDRESS LATCH ENABLE AND HALT

Address Latch Enable (ALE) occurs during each machine cycle and serves to strobe the current address into the address latches. ALE also serves to strobe the status ( $\overline{\mathrm{S}}_{0}, \overline{\mathrm{~S}}_{1}$, $\bar{S}_{2}$ ) into a latch for halt state decoding.

## COMMAND ENABLE

The Command Enable (CEN) input acts as a command qualifier for the 8288. If the CEN pin is HIGH the 8288 functions normally. If the CEN pin is pulled LOW, all command lines are held in their inactive state (not 3 -state). This feature can be used to implement memory partitioning and to eliminate address conflicts between system bus devices and resident bus devices.

ABSOLUTE MAXIMUM RATINGS
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
All Output and Supply Voltages $\ldots . . . . . . . . . .-0.5 \mathrm{~V}$ to +7.0 V
All Input Voltage...................................... -1.0 V to +5.5 V
Power Dissipation 1.5W

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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V

Military (M) Devices
Temperature
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |  | -1 | V |
| ICC | Power Supply Current |  |  | 230 | mA |
| $I_{F}$ | Forward Input Current | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |  | -0.7 | mA |
| IR | Reverse Input Current | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |  | 50 | $\mu \mathrm{A}$ |
| Vol | Output Low Voltage Command Outputs | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.5 | V |
|  | Control Outputs | $\mathrm{lOL}=16 \mathrm{~mA}$ |  | 0.5 | V |
| $\mathrm{VOH}_{\mathrm{OH}}$ | Output High Voltage Command Outputs | $\mathrm{IOH}^{\prime}=-5 \mathrm{~mA}$ | 2.4 |  | V |
|  | Control Outputs | $\mathrm{lOH}=-1 \mathrm{~mA}$ | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 |  | V |
| IOFF | Three-State Leakage | $\mathrm{V}_{\text {OFF }}=0.4$ to 5.25 V |  | 100 | $\mu \mathrm{A}$ |

SWITCHING TEST CIRCUIT

## SWITCHING TEST INPUT, OUTPUT WAVEFORM

Input/Output


AC Testing: Inputs are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " 0 ." The clock is driven at 4.3 V and 0.25 V . Timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ."
SWITCHING CHARACTERISTICS $\left(T_{A}=+25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\right)$

| Parameters | Description | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Timing Requirements |  |  |  |  |  |
| TCLCL | CLK Cycle Period |  | 100 |  | ns |
| TCLCH | CLK Low Time |  | 50 |  | ns |
| TCHCL | CLK High Time |  | 30 |  | ns |
| TSVCH | Status Active Setup Time |  | 35 |  | ns |
| TCHSV | Status Active Hold Time |  | 10 |  | ns |
| TSHCL | Status Inactive Setup Time |  | 35 |  | ns |
| TCLSH | Status Inactive Hold Time |  | 10 |  | ns |
| TILIH | Input Rise Time | From 0.8 V to 2.0 V |  | 20 | ns |
| TIHIL | Input Fall Time | From 2.0 V to 0.8 V |  | 12 | ns |
| Timing Responses |  |  |  |  |  |
| TCVNV | Control Active Delay |  | 5.0 | 45 | ns |
| TCVNX | Control Inactive Delay |  | 10 | 45 | ns |
| TCLLH TCMCH | ALE MCE Active Delay (from CLK) |  |  | 20 | ns |
| $\begin{aligned} & \text { TSVLH } \\ & \text { TSVMCH } \end{aligned}$ | ALE MCE Active Delay (from Status) |  |  | 20 | ns |
| TCHLL | ALE Inactive Delay | $\overline{\text { MRDC }}$ | 4.0 | 15 | ns |
| TCLML | Command Active Delay | $\overline{\text { ORC }}$ | 10 | 35 | ns |
| TCLMH | Command Inactive Delay | $\overline{\text { MWTC }} \quad \mathrm{IOL}=32 \mathrm{~mA}$ | 10 | 35 | ns |
| TCHDTL | Direction Control Active Delay | IOWC $\quad 1 \begin{aligned} & \text { OH }\end{aligned}=-5 \mathrm{~mA}$ |  | 50 | ns |
| TCHDTH | Direction Control Inactive Delay | $\overline{\text { INTA }} \quad C_{L}=300 \mathrm{pF}$ |  | 30 | ns |
| TAELCH | Command Enable Time | $\overline{\text { AMWC }}$ |  | 40 | ns |
| TAEHCZ | Command Disable Time | $\overline{\text { AIOWC }}$ |  | 40 | ns |
| TAELCV | Enable Delay Time |  | 115 | 200 | ns |
| TAEVNV | AEN to DEN | $\mathrm{OL}=16 \mathrm{~mA}$ |  | 20 | ns |
| TCEVNV | CEN to DEN, PDEN | $\mathrm{COH}_{\mathrm{L}}=80 \mathrm{pF}$ |  | 25 | ns |
| TCELRH | CEN to Command | ( |  | TCLML | ns |
| TOLOH | Output Rise Time | From 0.8 V to 2.0 V |  | 20 | ns |
| TOHOL | Output Fall Time | From 2.0 V to 0.8 V |  | 12 | ns |

## SWITCHING WAVEFORMS



WF002110

Notes: 1. Address/data bus is shown only for reference purposes.
2. Leading edge of ALE and MCE is determined by the falling edge of CLK or status going active, whichever occurs last.
3. All timing measurements are made at 1.5 V unless specified otherwise.

address enable (aEN) timing (3-state enable/disable)


WF002050
Note: CEN must be low or valid prior to $T_{2}$ to prevent the command from being generated.


## PALs, PROMs, MOS and Bipolar RAMs, MOS Peripherals, Analog and Data Acquisition

Bipolar PROM<br>Bipolar Memory RAM<br>MOS Memory<br>AMD 20-Pin PAL* Family<br>MOS Microprocessor

Functional Index and Selection Guide ..... 12-1
Functional Index and Selection Guide ..... 12-3
Functional Index and Selection Guide ..... 12-5
20-Pin IMOX ${ }^{\text {TM }}$ Programmable Array Logic Element. ..... 12-6
Family Selector Guide ..... 12-20

# Bipolar PROM 

Functional Index and Selection Guide

| Part Number | Organization | Access Time COM'L/MIL Max | $\begin{gathered} \mathrm{I}_{\mathrm{cc}} \\ \text { COM'L/MIL. } \\ \text { Max } \end{gathered}$ | Output | Number of Pins | Packages | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Am27LS18 ${ }^{1}$ | $32 \times 8$ | 50/65 | 80/80 | OC | 16 | D,P,F,L |  |
| Am27LS19 ${ }^{1}$ | $32 \times 8$ | 50/65 | 80/80 | 3 S | 16 | D,P,F,L | Low power |
| Am27S18 | $32 \times 8$ | 40/50 | 115/115 | OC | 16 | D,P,F,L |  |
| Am27S18A | $32 \times 8$ | 25/35 | 115/115 | OC | 16 | D,P,F,L |  |
| Am27S19 | $32 \times 8$ | 40/50 | 115/115 | 35 | 16 | D,P,F,L |  |
| Am27S19A | $32 \times 8$ | 25/35 | 115/115 | 35 | 16 | D,P,F,L |  |
| Am27S20 | $256 \times 4$ | 45/60 | 130/130 | OC | 16 | D,P,F,L |  |
| Am27S20A | $256 \times 4$ | 30/40 | 130/130 | OC | 16 | D, P,F,L |  |
| Am27S21 | $256 \times 4$ | 45/60 | 130/130 | 35 | 16 | D,P,F,L |  |
| Am27S21A | $256 \times 4$ | 30/40 | 130/130 | 35 | 16 | D,P,F,L |  |
| Am27S12 | $512 \times 4$ | 50/60 | 130/130 | OC | 16 | D,P,F,L |  |
| Am27S12A | $512 \times 4$ | 30/40 | 130/130 | OC | 16 | D,P,F,L |  |
| Am27S13 | $512 \times 4$ | 50/60 | 130/130 | 3 S | 16 | D,P,F,L |  |
| Am27S13A | $512 \times 4$ | 30/40 | 130/130 | 35 | 16 | D,P,F,L |  |
| Am27S15 | $512 \times 8$ | 60/90 | 175/185 | 3 S | 24 | D, P,F,L |  |
| Am27S25 | $512 \times 8$ | N.A. ${ }^{2}$ / ${ }^{\text {d.A. }}{ }^{2}$ | 185/185 | 35 | 24 | D,P,F,L | Output registers, THINDIP Pkg ${ }^{3}$ |
| Am27S25A | $512 \times 8$ | N.A. ${ }^{4}$ / ${ }^{\text {P.A. }}{ }^{4}$ | 185/185 | 35 | 24 | D, P,F,L | Output registers, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S27 | $512 \times 8$ | N.A. ${ }^{2} /{ }^{\text {N.A. }}{ }^{2}$ | 185/185 | 35 | 22 | D,P,L | Output registers |
| Am27S28 | $512 \times 8$ | 55/70 | 160/160 | OC | 20 | D,P,L |  |
| Am27S28A | $512 \times 8$ | 35/45 | 160/160 | OC | 20 | D,P,L |  |
| Am27S29 | $512 \times 8$ | 55/70 | 160/160 | 3 S | 20 | D,P,L |  |
| Am27S29A | $512 \times 8$ | 35/45 | 160/160 | 35 | 20 | D,P,L |  |
| Am27S30 | $512 \times 8$ | 55/70 | 175/175 | OC | 24 | D,P,F,L |  |
| Am27S30A | $512 \times 8$ | 35/45 | 175/175 | OC | 24 | D,P,F,L |  |
| Am27S31 | $512 \times 8$ | 55/70 | 175/175 | 3 S | 24 | D, P,F,L |  |
| Am27S31A | $512 \times 8$ | 35/45 | 175/175 | 3 S | 24 | D, P,F,L |  |
| Am27S32 | $1024 \times 4$ | 55/70 | 140/145 | OC | 18 | D,P,F,L |  |
| Am27S32A | $1024 \times 4$ | 35/45 | 140/145 | OC | 18 | D,P,F,L | Ulitra fast |
| Am27S33 | $1024 \times 4$ | 55/70 | 140/145 | 3 S | 18 | D,P,F,L |  |
| Am27S33A | $1024 \times 4$ | 35/45 | 140/145 | 35 | 18 | D,P,F,L | Uitra fast |
| Am27S35 | $1024 \times 8$ | N.A. ${ }^{2}$ / ${ }^{\text {P.A. }}{ }^{2}$ | 185 | 35 | 24 | D,P,F,L | Output registers, asynchronous initialize, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S35A | $1024 \times 8$ | N.A. ${ }^{4}$ /N.A. ${ }^{4}$ | 185 | 35 | 24 | D,P,F,L | Ultra fast, output registers, asynchronous initialize, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S37 | $1024 \times 8$ | N.A. ${ }^{2}$ N.A. ${ }^{2}$ | 185 | 35 | 24 | D,P,F,L | Output registers synchronous initialize, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S37A | $1024 \times 8$ | N.A. ${ }^{4}$ / ${ }^{\text {P.A. }}{ }^{4}$ | 185 | 35 | 24 | D,P,F,L | Ulitra fast, output registers, synchronous initialize, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S180 | $1024 \times 8$ | 60/80 | 185/185 | OC | 24 | D, P,F,L |  |
| Am27S180A | $1024 \times 8$ | 35/50 | 185/185 | OC | 24 | D, P,F,L | Ulitra fast |
| Am27S181 | $1024 \times 8$ | 60/80 | 185/185 | 3 S | 24 | D,P,F,L |  |
| Am27S181A | $1024 \times 8$ | 35/50 | 185/185 | 3 S | 24 | D, P,F,L | Ulitra fast |
| Am27PS181 | $1024 \times 8$ | 80/90 | 185/80 ${ }^{5}$ | 3 S | 24 | D,P,F,L | Power switched |
| Am27PS181A | $1024 \times 8$ | 65/75 | $185 / 80^{5}$ | 3 S | 24 | D,P,F,L | Power switched |
| Am27S280 | $1024 \times 8$ | 60/80 | 185/185 | OC | 24 | D,P,F,L | THINDIP Pkg ${ }^{3}$ |
| Am27S280A | $1024 \times 8$ | 35/50 | 185/185 | OC | 24 | D,P,F,L | Ultra fast, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S281 | $1024 \times 8$ | 60/80 | 185/185 | 3 S | 24 | D, P,F,L | THINDIP $\mathrm{Pkg}^{3}$ |


| Part Number | Organization | Access Time COM'L/MIL Max |  | Output | Number of Pins | Packages | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Am27S281A | $1024 \times 8$ | 35/50 | 185/185 | 3 S | 24 | D,P,F,L | Ultra fast, THINDIP Pkg ${ }^{3}$ |
| Am27PS281 | $1024 \times 8$ | 80/90 | 185/80 ${ }^{5}$ | 3 S | 24 | D,P,F,L | Power switched, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27PS281A | $1024 \times 8$ | 65/75 | 185/80 ${ }^{5}$ | 35 | 24 | D,P,F,L | Ultra fast, power switched, <br> THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S184 | $2048 \times 4$ | 50/55 | 150/150 | OC | 18 | D,P,F,L |  |
| Am27S184A | $2048 \times 4$ | 35/45 | 150/150 | OC | 18 | D,P,F,L | Ulitra fast |
| Am27S185 | $2048 \times 4$ | 50/55 | 150/150 | 3 S | 18 | D,P,F,L |  |
| Am27S185A | $2048 \times 4$ | 35/45 | 150/150 | 3 S | 18 | D,P,F,L | Ulitra fast |
| Am27LS184 | $2048 \times 4$ | 60/65 | 120/125 | OC | 18 | D,P,F,L | Low power |
| Am27LS185 | $2048 \times 4$ | 60/65 | 120/125 | 3 S | 18 | D,P,F,L | Low power |
| Am27PS185 | $2048 \times 4$ | 60/65 | 150/75 ${ }^{5}$ | 3 S | 18 | D,P,F,L | Power switched |
| Am27S190 | $2048 \times 8$ | 50/65 | 185/185 | OC | 24 | D,P,F,L |  |
| Am27S190A | $2048 \times 8$ | 35/50 | 185/185 | OC | 24 | D,P,F,L | Ulitra fast |
| Am27S191 | $2048 \times 8$ | 50/65 | 185/185 | 3 S | 24 | D,P,F,L |  |
| Am27S191A | $2048 \times 8$ | 35/50 | 185/185 | 3 S | 24 | D,P,F,L | Ulitra fast |
| Am27PS191 | $2048 \times 8$ | 65/75 | 185/80 ${ }^{5}$ | 35 | 24 | D,P,F,L | Power switched |
| Am27PS191A | $2048 \times 8$ | 50/65 | 185/80 ${ }^{5}$ | 3 S | 24 | D,P,F,L | Ultra fast, power switched |
| Am27S290 | $2048 \times 8$ | 50/65 | 185/185 | OC | 24 | D,P,F,L | THINDIP Pkg ${ }^{3}$ |
| Am27S290A | $2048 \times 8$ | 35/50 | 185/185 | OC | 24 | D,P,F,L | Ulitra fast, THINDIP Pkg ${ }^{3}$ |
| Am27S291 | $2048 \times 8$ | 50/65 | 185/185 | 35 | 24 | D,P,F,L | THINDIP Pkg ${ }^{3}$ |
| Am27S291A | $2048 \times 8$ | 35/50 | 185/185 | 3 S | 24 | D,P,F,L | Ulitra fast, THINDIP Pkg ${ }^{3}$ |
| Am27PS291 | $2048 \times 8$ | 65/75 | 185/80 ${ }^{5}$ | 35 | 24 | D,P,F,L | Power switched, THINDIP Pkg ${ }^{3}$ |
| Am27PS291A | $2048 \times 8$ | 50/65 | 185/80 ${ }^{5}$ | 3 S | 24 | D,P,F,L | Ultra fast, power switched THINDIP Pkg ${ }^{3}$ |
| Am27S40 | $4096 \times 4$ | 50/65 | 165/170 | OC | 20 | D,P,L |  |
| Am27S40A | $4096 \times 4$ | 35/50 | 165/170 | OC | 20 | D,P, L | Ulitra fast |
| Am27541 | $4096 \times 4$ | 50/65 | 165/170 | 35 | 20 | D,P, L |  |
| Am27S41A | $4096 \times 4$ | 35/50 | 165/170 | 35 | 20 | D,P,L | Ulitra fast |
| Am27PS41. | $4096 \times 4$ | 50/65 | 170/85 ${ }^{5}$ | 3 S | 20 | D,P,L | Power switched |
| Am27S43 | $4096 \times 8$ | 55/65 | 185 | 35 | 24 | D,P,F,L |  |
| Am27S43A | $4096 \times 8$ | 40/55 | 185 | 35 | 24 | D,P,F,L | Ulitra fast |
| Am27PS43 | $4096 \times 8$ | N.A. | N.A. | 3 S | 24 | D,P,F,L | Power switched |
| Am27S45 | $2048 \times 8$ | N.A. ${ }^{2}$ | 185/185 | 3 S | 24 | D,P,L | Output registers, asynchronous initialize, THINDIP Pkg ${ }^{3}$ |
| Am27S45A | $2048 \times 8$ | N.A. ${ }^{4}$ | 185/185 | 3 S | 24 | D,P,L | Ulitra fast, output registers, <br> asynchronous initialize, THINDIP $\mathrm{Pkg}^{3}$ |
| Am27S47 | $2048 \times 8$ | N.A. ${ }^{2}$ | 185/185 | 3 S | 24 | D,P,L | Output registers, synchronous initialize, THINDIP Pkg ${ }^{3}$ |
| Am27S47A | $2048 \times 8$ | N.A. ${ }^{4}$ | 185/185 | 3 S | 24 | D,P,L | Ulitra fast, output registers, <br> synchronous initialize, THINDIP Pkg ${ }^{3}$ |
| Am27S65 | $1024 \times 4$ | N.A. | 185/185 | 35 | 24 | D, P |  |
| Am27S65A | $1024 \times 4$ | N.A. | 185/185 | 3 S | 24 | D, P |  |
| Am27S75 | $2048 \times 4$ | N.A. | 185/185 | 35 | 24 | D, P |  |
| Am27S75A | $2048 \times 4$ | N.A. | 185/185 | 3 S | 24 | D,P |  |
| Am27S85 | $4096 \times 4$ | N.A. | 185/185 | 35 | 24 | D, P |  |
| Am27S85A | $4096 \times 4$ | N.A. | 185/185 | 35 | 24 | D, P |  |
| Am27S49 | $8192 \times 8$ | 55/65 | 190/190 | 35 | 24 | D,P, L |  |
| Am27S49A | $8192 \times 8$ | 40/55 | 190/190 | 3 S | 24 | D,P,L |  |

Notes: 1. Replaces Am27LS08/09
2. Contains built-in pipeline registers: nominal address to clock setup time $=35 \mathrm{~ns}$ (typ), clock to output $=20 \mathrm{~ns}$ (typ).
3. $300-\mathrm{mil}$ lateral pin spacing.
4. Contains built-in pipeline registers: nominal address to clock setup time $=25 \mathrm{~ns}$ (typ), clock to output $=\mathbf{1 5 n s}$ (typ).
5. $I_{\mathrm{CC}}$ are power up and power down current limits respectively.

## Bipolar Memory RAM

Functional Index and Selection Guide

BIPOLAR ECL RAM

| Part Number | Organization | Access Time <br> COM'L/MIL <br> Max | $\mathbf{I}_{\text {EE }}$ <br> COM'L/MIL <br> Max | ECL <br> Series | Number <br> of Pins | Packages | Comments |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Am10415SA | $1024 \times 1$ | $15 / 20$ | $-150 /-165$ | 10 K | 16 | $\mathrm{D}, \mathrm{P}, \mathrm{F}, \mathrm{L}$ |  |
| Am10415A | $1024 \times 1$ | $20 / 25$ | $-150 /-165$ | 10 K | 16 | $\mathrm{D}, \mathrm{P}, \mathrm{F}, \mathrm{L}$ |  |
| Am10415 | $1024 \times 1$ | $35 / 40$ | $-150 /-165$ | 10 K | 16 | $\mathrm{D}, \mathrm{P}, \mathrm{F}, \mathrm{L}$ |  |
| Am100415A | $1024 \times 1$ | $15 /-$ | $-150 /-$ | 100 K | 16 | $\mathrm{D}, \mathrm{P}, \mathrm{F}, \mathrm{L}$ |  |
| Am100415 | $1024 \times 1$ | $20 /-$ | $-150 /-$ | 100 K | 16 | $\mathrm{D}, \mathrm{P}, \mathrm{F}, \mathrm{L}$ |  |
| Am10470SA | $4096 \times 1$ | $15 / 20$ | $-230 /-255$ | 10 K | 18 | $\mathrm{D}, \mathrm{F}^{\prime}, \mathrm{L}$ |  |
| Am10470A | $4096 \times 1$ | $25 / 30$ | $-200 /-220$ | 10 K | 18 | $\mathrm{D}, \mathrm{F}^{1}, \mathrm{~L}$ |  |
| Am10470 | $4096 \times 1$ | $35 / 40$ | $-200 /-220$ | 10 K | 18 | $\mathrm{D}, \mathrm{F}^{1}, \mathrm{~L}$ |  |
| Am100470SA | $4096 \times 1$ | $15 /-$ | $-230 /-$ | 100 K | 18 | $\mathrm{D}, \mathrm{F}^{\prime}, \mathrm{L}$ |  |
| Am100470A | $4096 \times 1$ | $25 /-$ | $-195 /-$ | 100 K | 18 | $\mathrm{D}, \mathrm{F}^{1}, \mathrm{~L}$ |  |
| Am100470 | $4096 \times 1$ | $35 /-$ | $-195 /-$ | 100 K | 18 | $\mathrm{D}, \mathrm{F}^{1}, \mathrm{~L}$ |  |
| Am10474A | $1024 \times 4$ | $15 / 20$ | $-230 /-255$ | 10 K | 24 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am10474 | $1024 \times 4$ | $25 / 30$ | $-230 /-220$ | 10 K | 24 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am100474A | $1024 \times 4$ | $15 /-$ | $-230 /-$ | 100 K | 24 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am100474 | $1024 \times 4$ | $25 /-$ | $-200 /-$ | 100 K | 24 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am10480 | $16384 \times 1$ | $25 /-$ | $-200 /-$ | 10 K | 20 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am10480A | $16384 \times 1$ | $15 /-$ | $-230 /-$ | 10 K | 20 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am100480 | $16384 \times 1$ | $25 /-$ | $-200 /-$ | 100 K | 20 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| Am100480A | $16384 \times 1$ | $15 /-$ | $-230 /-$ | 100 K | 20 | $\mathrm{D}, \mathrm{F}, \mathrm{L}$ |  |
| A |  |  |  |  |  |  |  |

Note: 1. For Flat Package, Consult Factory.

BIPOLAR TTL RAM

| Part Number | Organization | Access Time COM'L/MIL Max | $\underset{\text { Max }}{\mathrm{I}_{\mathrm{Cc}}}$ | Output | Number of Pins | Packages <br> (Note 1) | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Am27S02A | $16 \times 4$ | 25/30 | 100/105 | OC | 16 | D,P,F,L | Ultra Fast |
| Am27S03A | $16 \times 4$ | 25/30 | 100/105 | 3 S | 16 | D,P,F,L |  |
| Am27S02 | $16 \times 4$ | 35/50 | 105/105 | OC | 16 | D,P,F,L |  |
| Am27S03 | $16 \times 4$ | 35/50 | 125/125 | 3 S | 16 | D,P,F,L |  |
| Am27LS02 | $16 \times 4$ | 55/65 | 35/38 | OC | 16 | D,P,F,L | Low Power |
| Am27LS03 | $16 \times 4$ | 55/65 | 35/38 | 3 S | 16 | D,P,F,L |  |
| Am74/54S289 | $16 \times 4$ | 35/50 | 105/105 | OC | 16 | D,P,F,L |  |
| Am74/54S189 | $16 \times 4$ | 35/50 | 125/125 | 3S | 16 | D,P,F,L |  |
| Am27S06A | $16 \times 4$ | 25/30 | 100/105 | OC | 16 | D,P,F,L | Noninverting Outputs |
| Am27S07A | $16 \times 4$ | 25/30 | 100/105 | 3S | 16 | D,P,F,L |  |
| Am27S06 | $16 \times 4$ | 35/50 | 100/105 | OC | 16 | D,P,F,L |  |
| Am27S07 | $16 \times 4$ | 35/50 | 100/105 | 3 S | 16 | D,P,F,L |  |
| Am27LS06 | $16 \times 4$ | 55/65 | 35/38 | OC | 16 | D,P,F,L | Noninverting Outputs, Low Power |
| Am27LS07 | $16 \times 4$ | 55/65 | 35/38 | 35 | 16 | $\overline{D, P, F, L}$ |  |
| Am3101A | $16 \times 4$ | 35/50 | 100/105 | OC | 16 | D,P,F,L |  |
| Am3101-1 | $16 \times 4$ | 35/50 | 100/105 | OC | 16 | D, P, F, L | Write <br> Transparent ${ }^{2}$ |
| Am3101 | $16 \times 4$ | 50/60 | 100/105 | OC | 16 | D,P,F,L |  |
| Am31L01A | $16 \times 4$ | 55/65 | 35/38 | OC | 16 | D, P, F, L | Low Power Write Transparent ${ }^{2}$ |
| Am31L01 | $16 \times 4$ | 80/90 | 35/38 | OC | 16 | D,P,F,L |  |
| Am74/5489-1 | $16 \times 4$ | 35/50 | 100/105 | OC | 16 | D,P,F,L | Write Transparent ${ }^{2}$ |
| Am74/5489 | $16 \times 4$ | 50/60 | 100/105 | OC | 16 | D,P,F,L |  |
| Am27LS00A | $256 \times 1$ | 35/45 | 115/115 | 35 | 16 | D,P,F,L | Ultra Fast |
| Am27LS01A | $256 \times 1$ | 35/45 | 115/115 | OC | 16 | D,P,F,L |  |
| Am29705A | $16 \times 4$ | 28/30 | 210/210 | 35 | 28 | D,P,F,L |  |
| Am29707 | $16 \times 4$ | 28/30 | 210/210 | 3 S | 28 | D,P,F,L |  |
| Am27LS00 | $256 \times 1$ | 45/55 | 70/70 | 3 S | 16 | D,P,F,L | Fast, Low Power |
| Am27LS01 | $256 \times 1$ | 45/55 | 70/70 | OC | 16 | D,P,F,L |  |
| Am27LS00-1A | $256 \times 1$ | 35/45 | 115/115 | 3 S | 16 | D,P,F,L | Noninverting Outputs |
| Am27LS01-1A | $256 \times 1$ | 35/45 | 115/115 | OC | 16 | D,P,F,L |  |
| Am27LS00-1 | $256 \times 1$ | 45/55 | 70/70 | 3 S | 16 | D,P,F,L |  |
| Am27LS01-1 | $256 \times 1$ | 45/55 | 70/70 | OC | 16 | D,P,F,L |  |
| Am93415A | $1024 \times 1$ | 30/40 | 155/170 | OC | 16 | D,P,F,L | Ulitra Fast |
| Am93425A | $1024 \times 1$ | 30/40 | 155/170 | 3 S | 16 | D,P,F,L |  |
| Am93415 | $1024 \times 1$ | 45/65 | 155/170 | OC | 16 | D,P,F,L |  |
| Am93425 | $1024 \times 1$ | 45/65 | 155/170 | 3 S | 16 | D,P,F,L |  |
| Am93412A | $256 \times 4$ | 35/45 | 155/170 | OC | $22^{3}$ | D,P,F,L | Ulitra Fast |
| Am93422A | $256 \times 4$ | 35/45 | 155/170 | 3 S | $22^{3}$ | D,P,F,L |  |
| Am93412 | $256 \times 4$ | 45/60 | 155/170 | OC | $22^{3}$ | D,P,F,L |  |
| Am93422 | $256 \times 4$ | 45/60 | 155/170 | 3 S | $22^{3}$ | D,P,F,L |  |
| Am93L412A | $256 \times 4$ | 45/55 | 80/90 | OC | $22^{3}$ | D,P,F,L | Low Power |
| Am93L422A | $256 \times 4$ | 45/55 | 80/90 | 3 S | $22^{3}$ | D,P,F,L |  |
| Am93L412 | $256 \times 4$ | 60/75 | 80/90 | OC | $22^{3}$ | D,P,F,L |  |
| Am93L422 | $256 \times 4$ | 60/75 | 80/90 | 3 S | $22^{3}$ | D,P,F,L |  |
| Am93L425A | $1024 \times 1$ | 45/55 | 65/75 | 3 S | 16 | D,P,F,L |  |

Notes: 1. $D=$ Hermetic DIP, $P=$ Molded DIP,F $=$ Cerpak, $L=$ Chip-Pak ${ }^{\text {TM }}$
2. Complement of data in is available on the outputs in the write mode when both $\overline{\mathrm{CS}}$ and $\overline{\mathrm{WE}}$ are low.
3. Cerpak $(F)$ is 24 pin.

## MOS Memory

## 1K STATIC RAMS

| Part Number | Organization | Access Time(ns) | Power Dissipation(mW) |  | Pins | Supply Voltage (V) | Temp Range | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Standby | Active |  |  |  |  |
| Am9122-25 | $256 \times 4$ | 25 | - | 660 | 22 | 5 | C | D, P |
| Am9122-35 | $256 \times 4$ | 35 | - | 660 | 22 | 5 | C,M | D, P |
| Am91L22-35 | $256 \times 4$ | 35 | - | 440 | 22 | 5 | C | D,P |
| Am91L22-45 | $256 \times 4$ | 45 | - | 440 | 22 | 5 | C,M | D, P |
| Am9122-60 | $256 \times 4$ | 60 | - | 248 | 22 | 5 | C | D,P |

4K STATIC RAMS

| Part Number | Organization | Access Time(ns) | Power Dissipation(mW) |  | Pins | Supply Voltage (V) | Temp Range | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Standby | Active |  |  |  |  |
| Am2147-35 | $4096 \times 1$ | 35 | 165 | 990 | 18 | 5 | C | D |
| Am2147-45 | $4096 \times 1$ | 45 | 165 | 990 | 18 | 5 | M | D,L |
| Am2147-55 | $4096 \times 1$ | 55 | 165 | 990 | 18 | 5 | C,M | D,L |
| Am2147-70 | $4096 \times 1$ | 70 | 110 | 880 | 18 | 5 | C,M | D,L |
| Am21L47-45 | $4096 \times 1$ | 45 | 83 | 688 | 18 | 5 | C | D |
| Am21L47-55 | $4096 \times 1$ | 55 | 83 | 688 | 18 | 5 | C | D |
| Am2148-55 | $1024 \times 4$ | 55 | 165 | 990 | 18 | 5 | C,M | D,L |
| Am2148-35 | $1024 \times 4$ | 35 | 165 | 990 | 18 | 5 | C | D,L |
| Am2148-45 | $1024 \times 4$ | 45 | 165 | 990 | 18 | 5 | C,M | D,L |
| Am2148-70 | $1024 \times 4$ | 70 | 165 | 990 | 18 | 5 | C,M | D,L |
| Am2149-35 | $1024 \times 4$ | 35 | N/A | 990 | 18 | 5 | C | D |
| Am21L48-45 | $1024 \times 4$ | 45 | 110 | 688 | 18 | 5 | C | D,L |
| Am2149-45 | $1024 \times 4$ | 45 | N/A | 990 | 18 | 5 | C,M | D |
| Am21L49-45 | $1024 \times 4$ | 45 | N/A | 688 | 18 | 5 | C | D, L |
| Am21L48-55 | $1024 \times 4$ | 55 | 110 | 688 | 18 | 5 | C | D,L |
| Am21L49-55 | $1024 \times 4$ | 55 | N/A | 688 | 18 | 5 | C | D,L |
| Am21L48-70 | $1024 \times 4$ | 70 | 110 | 688 | 18 | 5 | C | D,L |
| Am21L49-70 | $1024 \times 4$ | 70 | N/A | 688 | 18 | 5 | C | D, L |
| Am9150-25 | $1024 \times 4$ | 25 | N/A | 990 | 24 | 5 | C | D |
| Am9150-35 | $1024 \times 4$ | 35 | N/A | 990 | 24 | 5 | C,M | D |
| Am9150-45 | $1024 \times 4$ | 45 | N/A | 990 | 24 | 5 | C,M | D |

16K STATIC RAMS

| Part <br> Number | Organization | Access Time(ns) | Power Dis | tion(mW) | Pins | Supply Voltage (V) | Temp Range | Package |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Standby | Active |  |  |  |  |
| Am9128-10 | $2048 \times 8$ | 100 | 165 | 660 | 24 | 5 | C | D,P |
| Am9128-70 | $2048 \times 8$ | 70 | 165 | 770 | 24 | 5 | C | D, P |
| Am9128-90 | $2048 \times 8$ | 90 | 165 | 990 | 24 | 5 | M | D |
| Am2167-35 | $16384 \times 1$ | 35 | 165 | 660 | 20 | 5 | C | D,P |
| Am2167-45 | $16384 \times 1$ | 45 | 83 | 660/880 | 20 | 5 | C,M | D,P |
| Am2167-55 | $16384 \times 1$ | 55 | 83 | 660 | 20 | 5 | C,M | D, P |
| Am2167-70 | $16384 \times 1$ | 70 | 165 | 660 | 20 | 5 | C,M | D, P |
| Am2168-45 | $4096 \times 4$ | 45 | 165 | 550 | 20 | 5 | C | D,P |
| Am2168-55 | $4096 \times 4$ | 55 | 165 | 550 | 20 | 5 | C,M | D,P |
| Am2168-70 | $4096 \times 4$ | 70 | 165 | 550 | 20 | 5 | C,M | D,P |
| Am2169-45 | $4096 \times 4$ | 45 | NA | 550 | 20 | 5 | C | D,P |
| Am2169-55 | $4096 \times 4$ | 55 | NA | 550 | 20 | 5 | C,M | D, P |
| Am2169-70 | $4096 \times 4$ | 70 | NA | 550 | 20 | 5 | C,M | D,P |

# AMD 20-Pin PAL* Family 

20-Pin $\mathrm{IMOX}^{\text {™ }}$ Programmable Array Logic Elements

## DISTINCTIVE CHARACTERISTICS

- Fast
- High speed " A " versions ( $\mathrm{t}_{\mathrm{pd}}=25 \mathrm{~ns}, \mathrm{t}_{\mathrm{s}}=20 \mathrm{~ns}, \mathrm{t}_{\mathrm{co}}=15 \mathrm{~ns}$, max)
- Standard speed versions ( $\mathrm{t}_{\mathrm{pd}}=35 \mathrm{~ns}, \mathrm{t}_{\mathrm{s}}=30 \mathrm{~ns}, \mathrm{t}_{\mathrm{co}}=25 \mathrm{~ns}, \max$ )
- Flexible
- User programmability allows customized designs
- Eases design updates in prototype or product
- Low Cost
- Reduces board space/chip count
- Reduces design time
- Reduces inventory cost
- Reliable
- Proven Platinum-Silicide fuse technology
- Fully AC and DC tested
- Preload of output registers allows full logical testing


## GENERAL DESCRIPTION

AMD PALs are high speed electrically programmable array logic elements. They utilize the familiar sum-of-products (AND-OR) structure allowing users to program custom logic functions to fit most applications precisely.
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. 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).
The part types in the AMD PAL family are differentiated by the allocation of registered (with internal feedback) and combinatorial (bi-directional and dedicated) outputs. All combinatorial AMD PALs are available in both active HIGH (AND-OR) and active LOW (AND-OR-INVERT) versions.

## AMD PAL FAMILY CHARACTERISTICS

All members of the AMD PAL family have common electrical characteristics and programming procedures. All parts in this family are produced with a fusible link at each input to the AND gate array. Connections may be selectively removed by applying appropriate voltages to the circuit.

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.

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 lowfield, large-gap technology offers the best reliability for fusible link programmable logic.
The AMD PAL family is manufactured using Advanced Micro Devices' selective oxidation process, IMOX. This advanced process permits an increase in density and a decrease in internal capacitance resulting in the fastest possible programmable logic devices.
The AMD PAL family also incorporates the unique capability of preloading the output registers during testing to any desired value. Preload is invaluable when testing the logical functionality of a programmed AMD PAL.

| AMD PAL FAMILY TABLE |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Part Number | Array Inputs | Logic | OE | Outputs | ${ }^{t}$ pd (MAX)STD A |  | $\begin{array}{\|c\|} \hline \mathbf{t}_{\mathbf{s}} \\ (\text { MAX }) \\ \text { STDA } \\ \hline \end{array}$ |  | $\begin{gathered} \mathbf{t}_{\mathbf{c o}} \\ \text { (MAX) } \\ \text { STDA } \end{gathered}$ |  |  |
| AmPAL16R8 | (8) Dedicated <br> (8) Feedback | (8) 8-Wide AND-OR | Dedicated | Registered Inverting | - | - | 30 | 20 | 25 | 15 | ns |
| AmPAL16R6 | (8) Dedicated <br> (6) Feedback <br> (2) Bidirectional | (6) 8-Wide AND-OR | Dedicated | Registered Inverting | 35 | 25 | 30 | 20 | 25 | 15 | ns |
|  |  | (2) 7-Wide AND-OR-INVERT | Programmable | Bidirectional |  |  |  |  |  |  |  |
| AmPAL16R4 | (8) Dedicated <br> (4) Feedback <br> (4) Bidirectional | (4) 8-Wide AND-OR | Dedicated | Registered Inverting | 35 | 25 | 30 | 20 | 25 | 15 | $r$ |
|  |  | (4) 7-Wide AND-OR-INVERT | Programmable | Bidirectional |  |  |  |  |  |  |  |
| AmPAL16L8 | (10) Dedicated <br> (6) Bidirectional | (8) 7-Wide-AND-OR-INVERT | Programmable | (6) Bidirectional <br> (2) Dedicated | 35 | 25 | - | - | - | - |  |
| AmPAL16H8 | (10) Dedicated <br> (6) Bidirectional | (8) 7-Wide AND-OR | Programmable | (6) Bidirectional <br> (2) Dedicated | 35 | 25 | - | - | - | - |  |
| AmPAL16LD8 | (10) Dedicated <br> (6) Bidirectional | (8) 8-Wide AND-OR-INVERT | - | Dedicated | 35 | 25 | - | - | - |  |  |
| AmPAL16HD8 | (10) Dedicated <br> (6) Bidirectional | (8) 8-Wide AND-OR | - | Dedicated | 35 | 25 | - | - | - |  |  |

[^24]
## ABSOLUTE MAXIMUM RATINGS

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Temperature (Ambient) Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Supply Voltage to Ground Potential
(Pin 20 to Pin 10) Continuous ............. 0.5 V to +7.0 V
DC Voltage Applied to Outputs (Except
During Programming) $\ldots . . . . . . . . . . . . . .-0.5 \mathrm{~V}$ to $+\mathrm{V}_{\mathrm{CC}}$ max
DC Voltage Applied to Outputs During Programming $\qquad$
Output Current Into Outputs During
Programming (Max Duration of 1 sec ) ............... 200 mA
DC Input Voltage ................................ - 0.5 to +5.5 mA
DC Input Current ...............................-30mA to +5.0 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 device reliability.

## OPERATING RANGES

Commercial (C) Devices
Temperature $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Supply Voltage +4.75 V to +5.25 V
Military (M) Devices
Temperature $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage ............................... +4.5 V to +5.5 V Operating ranges define those limits over which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified

| Parameters | Description | Test Conditions |  |  | Min | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH | 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 |
|  |  |  | $\mathrm{I}_{\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}=24 \mathrm{~mA}$ | COM'L |  |  | 0.5 | Volts |
|  |  |  | $\mathrm{IOL}=12 \mathrm{~mA}$ | MIL |  |  |  |  |
| $\begin{aligned} & \hline \mathrm{V}_{\mathrm{IH}} \\ & \text { (Note 2) } \\ & \hline \end{aligned}$ | Input HIGH Level | Guaranteed input logical HIGH voltage for all inputs |  |  | 2.0 |  |  | Volts |
| $\begin{aligned} & V_{1 L} \\ & \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}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=0.40 \mathrm{~V}$ |  |  |  | -20 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{H}_{\mathrm{H}}$ | Input HIGH Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=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 |
| ISC | Output Short Circuit Current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V}$ ( Note 3) |  |  | -30 | -60 | -90 | mA |
| Icc | Power Supply Current | All inputs $=\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | $\begin{aligned} & \text { 16L8, } 16 \mathrm{HB}, 1 \\ & 16 \mathrm{~L} 8 \mathrm{~A}, 16 \mathrm{H} 8 \mathrm{~A}, 1 \end{aligned}$ | HD8, 16LD8 <br> HD8A, 16LD8A |  | 110 | 155 | mA |
|  |  |  | 16R8, 16R6, 16R4 16R8A, 16R6A, 16R4A |  |  | 120 | 180 |  |
| $V_{1}$ | Input Clamp Voltage | $V_{C C}=M 12, I_{\text {d }}=-18 \mathrm{~mA}$ |  |  |  | -0.9 | -1.2 | Volts |
| l OZH | 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}$ | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| lozl |  |  | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  |  | -100 |  |
| Cin | Input Capacitance | $\mathrm{V}_{\text {IN }}=2.0 \mathrm{~V} @ \mathrm{f}=1 \mathrm{MHz}$ (Note 5) |  |  |  | 6 |  | pF |
| COUT | Output Capacitance | $\mathrm{V}_{\text {OUT }}=2.0 \mathrm{~V} @ 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. $V_{\text {OUT }}=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.

## AC TEST LOAD



SWITCHING CHARACTERISTICS over operating range unless otherwise specified HIGH SPEED

| Parameters | Description | Test Conditions | Typ (Note 1) | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max | Min | Max |  |
| tPD | Input or Feedback to Non-Registered Output 16L8A, 16R6A, 16R4A, 16LD8A, 16H8A, 16HD8A | COM'L <br> $R_{1}=200$ <br> $\mathrm{R}_{2}=390$ $\begin{gathered} \text { MIL } \\ R_{1}=390 \\ R_{2}=750 \end{gathered}$ | 12 |  | 25 |  | 30 | ns |
| tea | Input to Output Enable 16L8A, 16R6A, 16R4A, 16H8A |  | 12 |  | 25 |  | 30 | ns |
| tER | Input to Output Disable 16L8A, 16R6A, 16R4A, 16H8A |  | 12 |  | 25 |  | 30 | ns |
| tpZX | Pin 11 to Output Enable 16R8A, 16R6A, 16R4A |  | 8 |  | 20 |  | 25 | ns |
| tpxZ | Pin 11 to Output Disable 16R8A, 16R6A, 16R4A |  | 8 |  | 20 |  | 25 | ns |
| tco | Clock to Output 16R8A, 16R6A, 16R4A |  | 8 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {s }}$ | Input or Feedback Setup Time 16R8A, 16R6A, 16R4A |  | 10 | 20 |  | 25 |  | ns |
| $\mathrm{th}_{\mathrm{H}}$ | Hold Time 16R8A, 16R6A, 16R4A |  | -10 | 0 |  | 0 |  | ns |
| tp | Clock Period |  |  | 35 |  | 45 |  | ns |
| tw | Clock Width |  |  | 15 |  | 20 |  | ns |
| $t_{\text {max }}$ | Maximum Frequency |  |  |  | 28.5 |  | 22 | MHz |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
2. tPD is tested with switch $S_{1}$ closed and $C_{L}=50 \mathrm{pF}$
3. For three-state outputs, 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 CHARACTERISTICS over operating range unless otherwise specified STANDARD SPEED

| Parameters | Description | Test Conditions | Typ <br> (Note 1) | COMMERCIAL |  | MILITARY |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max | Min | Max |  |
| tPD | Input or Feedback to Non-Registered Output 16L8, 16R6, 16R4, 16LD8, 16H8, 16HD8 | COM'L <br> $R_{1}=200$ $R_{2}=390$ $\begin{gathered} \text { MIL } \\ R_{1}=390 \\ R_{2}=750 \end{gathered}$ | 17 |  | 35 |  | 40 | ns |
| tea | Input to Output Enable 16L8, 16R6, 16R4, 16H8 |  | 17 |  | 35 |  | 40 | ns |
| ter | Input to Output Disable 16L8, 16R6, 16R4, 16H8 |  | 17 |  | 35 |  | 40 | ns |
| tpzX | Pin 11 to Output Enable 16R8, 16R6, 16R4 |  | 12 |  | 25 |  | 25 | ns |
| tpxz | Pin 11 to Output Disable 16R8, 16R6, 16R4 |  | 12 |  | 25 |  | 25 | ns |
| tco | Clock to Output 16R8, 16R6, 16R4 |  | 12 |  | 25 |  | 25 | ns |
| $\mathrm{t}_{\mathrm{s}}$ | Input or Feedback Setup Time 16R8, 16R6, 16R4 |  | 15 | 30 |  | 35 |  | ns |
| ${ }_{\text {t }}^{+}$ | Hold Time 16R8, 16R6, 16R4 |  | -10 | 0 |  | 0 |  | ns |
| tp | Clock Period |  |  | 55 |  | 60 |  | ns |
| tw | Clock Width |  |  | 20 |  | 25 |  | ns |
| $f_{\text {MAX }}$ | Maximum Frequency |  |  |  | 18 |  | 16.5 | MHz |

Notes: 1. Typical limits are at $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
2. tPD 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; $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



WF002570

KEY TO SWITCHING WAVEFORM

| WAVEFORM | inputs | OUTPUTS |
| :---: | :---: | :---: |
|  | MUST BE STEADY | WILL BE STEADY |
| $\pi \square I$ | MAY CHANGE FROMHTOL | WILL BE CHANGING FROM HTOL |
|  | MAY Change <br> FROML TOH | WILL BE CHANGING FROML TOH |
| WNux | DON'T CARE ANY CHANGE PERMITTED | CHANGING: STATE UNKNOWN |
|  | $\begin{aligned} & \text { DOES NOT } \\ & \text { APPLY } \end{aligned}$ | CENTER LINE IS HIGH IMPEDANCE "OFF" STATE |

KS000010



AMD 20-Pin PAL* Family





AMD 20-Pin PAL* Family
BLOCK DIAGRAM AmPAL16HD8/AmPAL16HD8A


BD002010

## 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 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 below.

The 16L8, 16R8, 16R6, 16R4, 16H8, 16LD8 and 16HD8 use identical programming conditions and sequences.

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 up part to $V_{C C P}$
2. Raise Pin 5 to $\mathrm{V}_{\mathrm{HH}}$.
3. Pulse Pin 11 from ground to $V_{O P}$ for a $50 \mu \mathrm{sec}$ duration.
4. Perform a normal end-of-programming verify cycle at $\mathrm{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 PALs normally have high programming yields ( $>98 \%$ ). Programming yield losses are frequently due to poor socket contact, equipment out of calibration or improperly used.

## PROGRAMMING PARAMETERS $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Parameters | Description |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{HH}}$ | Control Pin Extra High Level | Pin 1 @ 10-40mA | 10 | 11 | 12 | Voits |
|  |  | Pin 11 @ 10-40mA | 10 | 11 | 12 |  |
| $\mathrm{V}_{\text {OP }}$ | Program Voltage Pins 12-19 @ 15-200mA |  | 18 | 20 | 22 | Volts |
| $\mathrm{V}_{\text {IHP }}$ | Input High Level During Programming and Verify |  | 2.4 | 5 | 5.5 | Volts |
| VILP | 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 |
| $\mathrm{V}_{\text {CCL }}$ | $\mathrm{V}_{\mathrm{CC}}$ During First Pass Verification @ $\mathrm{I}_{\text {cC }}=50-200 \mathrm{~mA}$ |  | 4.1 | 4.3 | 4.5 | Volts |
| $\mathrm{V}_{\mathrm{CCH}}$ | $V_{C C}$ During Second Pass Verification @ $\mathrm{ICC}=50-200 \mathrm{~mA}$ |  | 5.4 | 5.7 | 6.0 | Volts |
| VBlown | Successful Blown Fuse Sense Level © Output | 16L8, 16R8, 16R6, 16R4, 16LD8 16L8A, 16R8A, 16R6A, 16R4A, 16LD8A |  | 0.3 | 0.5 | Volts |
|  |  | 16H8, 16HD8, 16H8A, 16HD6A | 2.4 | 3 |  |  |
| $\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 Voitage Change (Pin 11 Rising Edge) |  | 100 |  | 1000 | $\mathrm{V} / \mu \mathrm{sec}$ |
| $\mathrm{t}_{\mathrm{p}}$ | Fusing Time First Attempt |  | 40 | 50 | 100 | $\mu \mathrm{sec}$ |
|  | Subsequent Attempts |  | 4 | 5 | 10 | msec |
| tD | Delays Between Various Level Changes |  | 100 | 200 | 1000 | ns |
| tv | Period During which Output is Sensed for V Blown Level |  |  |  | 500 | ns |
| VONP | Pull-Up Voltage On Outputs Not Being Programmed |  | $\mathrm{V}_{\text {CCP }}-0.3$ | $\mathrm{V}_{\text {CCP }}$ | $\mathrm{V}_{\text {CCP }}+0.3$ | Volts |
| R | Pull-Up Resistor On Outputs Not Being Programmed |  | 1.9 | 2 | 2.1 | K $\Omega$ |

AMD PAL PROGRAMMING EQUIPMENT INFORMATION

| Source and <br> Location | Data I/O <br> 10525 Willows Rd. N.E. <br> Redmond, WA 98052 | Kontron Electronics, Inc. <br> 630 Price Avenue <br> Redwood City, <br> CA 94063 | Stag Microsystems <br> $528-5$ Weddel Drive <br> Sunnyvale, <br> CA 94086 |
| :--- | :--- | :--- | :--- |
| Programmer <br> Model(s) | Model-100, 29, <br> 19 or 17 | Model-MPP-80S <br> or EPP80 | Model-PPX |
| AMD PAL <br> Personality <br> Module | Logicpak <br> $950-1942-001$ | MOD-33 | PPM2200 |
| Socket <br> Adapter | $715-1947-003$ | SA37 | Am202S |


PF001100

TABLE 1. INPUT ADDRESSING


SIMPLIFIED PROGRAMMING DIAGRAM


PF000380
TABLE 2. PRODUCT TERM ADDRESSING

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

## 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:


PF001160

| Level forced on registered <br> output pin during preload cycle | Output state at the <br> output pin after cycle |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{HH}}$ | HIGH |
| 0 V to $\mathrm{V}_{\mathrm{CCH}}$ or OPEN | LOW |

## ORDERING INFORMATION

AMD products are available in several packages and operating ranges. The order number is formed by a combination of the following: Device number, speed option (if applicable), package type, operating range and screening option (if desired).


# MOS Microprocessor 

Family Selector Guide

|  | 8086/88 | 8085A | 8085A-2 | 8080A | Z8001/2 $\dagger$ | 28001/2-A |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Period | 200ns | 320ns | 200ns | 480ns | 250ns | 165ns |
| Clock Generator | 8284A | On-Chip | On-Chip | 8224 | 8127 | 8127 |
| Arithmetic Processing Unit | 8087 | $\begin{aligned} & \hline 9511 A=1 \\ & 9512-1 \end{aligned}$ | $\begin{aligned} & \hline 9511 \mathrm{~A}-4 \\ & 9512-1 \end{aligned}$ | $\begin{aligned} & 9511 \mathrm{~A} \\ & 9512 \end{aligned}$ | $\begin{aligned} & \hline 9511 \mathrm{~A}-4 \\ & 9512-1 \end{aligned}$ | $\begin{aligned} & \text { 9511A-4 } \\ & 9512-1 \end{aligned}$ |
| Interrupt Controller | 8259A-5 | $\begin{aligned} & \hline 9519 \mathrm{~A} \\ & 8259 \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \hline 9519 A-4 \\ & 8259 A-5 \end{aligned}$ | $\begin{aligned} & \hline 9519 A \\ & 8259 A \end{aligned}$ | 9519A-1 | 9519A-1 |
| DMA Controlier | $\begin{aligned} & \hline 8089 \\ & 9516 A \\ & 9517 A-5 \end{aligned}$ | 9517A-4 | 9517A-5 | 9517A | $\begin{aligned} & 8016 \\ & 9517 \mathrm{~A}-4 \end{aligned}$ | 8016A |
| Dynamic Memory Controller | $\begin{aligned} & 2964 \mathrm{~B} \\ & 2968 \end{aligned}$ | $\begin{aligned} & \hline 2964 B \\ & 2968 \end{aligned}$ | $\begin{aligned} & 2964 \mathrm{~B} \\ & 2968 \end{aligned}$ | $\begin{aligned} & 2964 \mathrm{~B} \\ & 2968 \end{aligned}$ | $\begin{aligned} & 2964 \mathrm{~B} \\ & 2968 \end{aligned}$ | $\begin{aligned} & 2964 B \\ & 2968 \end{aligned}$ |
| Serial I/O | $\begin{aligned} & \hline 8251 A \\ & 8530 A \\ & 8030 A \end{aligned}$ | $\begin{aligned} & 8251 \mathrm{~A} \\ & 8530 \end{aligned}$ | $\begin{aligned} & 8251 A \\ & 8530 A \end{aligned}$ | 8251A | 8030 | 8030A |
| Parallel I/O | $\begin{aligned} & \text { 8255A-5 } \\ & 8036 \mathrm{~A} \end{aligned}$ | 8255A-5 | 8255A-5 | 8255A | 8036 | 80364. |
| Counter <br> Timer I/O | $\begin{aligned} & \hline 9513 \\ & 8036 \mathrm{~A} \\ & 8073 \end{aligned}$ | $\begin{aligned} & \hline 9513 \\ & 8253-5 \end{aligned}$ | $\begin{aligned} & \hline 9513 \\ & 8253-5 \end{aligned}$ | $\begin{aligned} & 9513 \\ & 8253 \end{aligned}$ | 8073 | 8073 |
| FIFO I/O | 8038 | 8038 | 8038 | 8038 | 8038 | 8038 |
| Data Ciphering Processor | 8068 | 8068 | 8068 | 9518 | 8068 | 8068 |
| Error Detection and Correction | 2960 | 2960 | 2960 | 2960 | 2960 | 2960 |
| Burst Error Processor | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ | $\begin{aligned} & 8065 \\ & 9520 \\ & \hline \end{aligned}$ |
| CRT Controller | $\begin{aligned} & 8275 \\ & 8052 \end{aligned}$ | 8275 | 8275 | 8275 | 8052 | 8052A |
| I/O Processor | 8089 | N/A | N/A | N/A | N/A | N/A |
| RAM I/O | N/A | 8155/6 | 8155/6-2 | N/A | N/A | N/A |
| Memory Management Unit | N/A | N/A | N/A | N/A | 8010 | 8010A |
| Bus Control/ Arbiter | 8288 | N/A | N/A | N/A | N/A | N/A |
| Bus Latches | 29841-6 | 29841-6 | 29841-6 | 29841-6 | 29841-6 | 29841-6 |
| Bus Buffers | 29827/28 | 2958/9 | 2958/9 | 2958/9 | 2958/9 | 2958/9 |
| Bus <br> Transceivers | 29861-4 | 29861-4 | 29861-4 | 29861-4 | 29861-4 | 29861-4 |
| EDC Buffers | 2961/2 | 2961/2 | 2961/2 | 2961/2 | 2961/2 | 2961/2 |
| RAM Drivers | 2965/6 | 2965/6 | 2965/6 | 2965/6 | 2965/6 | 2965/6 |


|  | Microprocessor Components |
| :---: | :---: |
| Part Number | Description |
| SINGLE-CHIP MICROCOMPUTERS |  |
| 8031 | 8-Bit Microcomputer |
| 8051 | 8-Bit Microcomputer with On-Board ROM |
| PERIPHERALS ADVANCED SYSTEM COMPONENTS |  |
| Am9511A | Arithmetic Processor |
| Am9512 | Arithmetic Processor |
| Am9513/A | System Timing Controller |
| Am9516 | Data Transfer Controller |
| Am9517A | DMA Controller |
| Am9518/68 | Data Ciphering Processor |
| Am9519A | Universal Interrupt Controller |
| Am9520 | Burst Error Processor |
| Am9521 | 32-, 35-Bit Burst Error Processor |
| Am9551 | Serial I/O USART |
| DISPLAY PRODUCTS |  |
| Am8052 | CRT Controller |
| Am8152 | Video System Controller |
| Am8153 | Video System Controller |
| IAPX86 FAMILY SYSTEM COMPONENTS |  |
| 8231A/9511A | Arithmetic Processor |
| 8232/9512 | Arithmetic Processor |
| 8237A/9517A | DMA Controller |
| 8251 | Serial I/O USART |
| 8251A | Serial I/O USART |
| 8253 | Counter/Timer |
| 8255A | Programmable Peripheral Interface |
| 8259A | Interrupt Controller |
| 8284A | Clock Generator |
| 8286 | Octal Transceiver |
| 8287 | Octal Transceiver |
| 8288 | Bus Controller |
| AmZ8530 | Serial Communications Controller |
| 8155/H | RAM with I/O Ports |
| 8156/H | RAM with I/O Ports |
| AmZ8536 | Counter Timer and Parallel I/O Unit |
| Z8001/2 FAMILY SYSTEM COMPONENTS |  |
| AmZ8016 | Data Transfer Controller |
| Z8030 | Serial Communication Controller |
| Z8031 | Asynchronous Serial Communications Controller |
| Z8036 | Counter 1/O |
| Z8038 | FIFO I/O Interface |
|  |  |



| Part Number | Description |
| :--- | :--- |
| Bipolar Support Circuits |  |
| 25 LS244 | Octal Buffer |
| 25 LS2521 | Octal Comparator |
| 25 LS2536 | Octal Address Decoder |
| 25 LS2548 | Octal Decoder with ACK |
| $29821-6$ | High Performance Bus Registers |
| 2925 | Clock Generator |
| $29861-4$ | High Performance Bus Transceiver |
| $2948 / 49$ | Octal Bus Transceiver |
| 2960 | 16-Bit Error Detection and Correction |
| $2961 / 62$ | EDC Buffers |
| $2964 B$ | Dynamic Memory Controller |
| $2965 / 66$ | RAM Drivers |
| $29841-6$ | High Performance Bus Latches |



VOLTAGE COMPARATORS

| Am685 | 5ns Propagation Delay, ECL Output <br> Am686 <br> Am687 |
| :--- | :--- |
| 12ns Propagation Delay, TTL Output <br> 8ns Propagation Delay, Dual 685, <br> ECL Output |  |
| Am1500/ | Dual Precision <br> LH2111 <br> LM111/311 <br> LM119 |
| High Accuracy, Low Cost <br> Dual High Speed, $\pm 5 \mathrm{~V}$ to $\pm 15 \mathrm{~V}$ <br> Supply |  |
| LM139 | Quad, Low Power, High Accuracy |

## OPERATIONAL AMPLIFIERS

| LF155/156 | FET-Input, High Slew Rate and Fast <br> Setting Time |
| :--- | :--- |
| LM108 | Low Power, $\pm 2 \mathrm{~V}$ to $\pm 20 \mathrm{~V}$ Supply |
| LM118 | High Speed, 15MHz Bandwidth |
| LM148 | Quad, Low Power 741 |

## CROSS REFERENCE

| AMD | National | Fairchild | Signetics | PMI | Motorola | Raytheon | Analog Devices |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { DAC-08AQ } \\ & \text { DAC-08HQ } \\ & \text { DAC-08HN } \end{aligned}$ | $\begin{aligned} & \text { DAC0800LAJ } \\ & \text { DAC0802LCJ } \\ & \text { DAC0802LCN } \end{aligned}$ | $\mu$ A0801ADM $\mu$ A0801HDC $\mu$ A0801HPC | SE5009F NE5009F NE5009N | $\begin{aligned} & \text { DAC-08AQ } \\ & \text { DAC-08HQ } \\ & \text { DAC-08HP } \end{aligned}$ | $\begin{aligned} & \text { DAC-08AQ } \\ & \text { DAC-08HQ } \\ & \text { DAC-08HP } \end{aligned}$ | DAC-08ADM DAC-08HDM DAC-08HBM | ADDAC-08AD ADDAC-08HD - |
| $\begin{aligned} & \hline \text { DAC-08Q } \\ & \text { DAC-08EQ } \\ & \text { DAC-08EN } \end{aligned}$ | $\begin{aligned} & \text { DAC0800LJ } \\ & \text { DAC0800LCJ } \\ & \text { DAC0800LCN } \end{aligned}$ | $\mu \mathrm{A} 0801 \mathrm{DM}$ $\mu$ A0801EDC $\mu$ A0801EPC | SE5008F <br> NE5008F <br> NE5008N | $\begin{aligned} & \hline \text { DAC-08Q } \\ & \text { DAC-08EQ } \\ & \text { DAC-08EP } \end{aligned}$ | $\begin{aligned} & \text { DAC-08Q } \\ & \text { DAC-08EQ } \\ & \text { DAC-08EP } \end{aligned}$ | DAC-08DM DAC-08EDM DAC-08EBM | ADDAC-08D <br> ADDAC-08ED <br> - |
| $\begin{aligned} & \text { DAC-08CQ } \\ & \text { DAC-08CN } \end{aligned}$ | $\begin{aligned} & \text { DAC0801LCJ } \\ & \text { DAC0801LCN } \end{aligned}$ | $\mu A 0801$ CDC $\mu$ A0801CPC | NE5007F <br> NE5007N | DAC-08CQ DAC-08CP | DAC-08CQ DAC-08CP | DAC-08CDM DAC-08CBM | ADDAC-08CD |
| AM1508L8 AM1408L8 AM1408N8 | DAC0808LJ <br> DAC0808LCJ <br> DAC0808LCN | $\mu$ A0802DM $\mu$ A0802ADC $\mu$ A0802APC | MC1508-8F MC1408-8F MC1408-8N | - | MC1508L8 MC1408L8 MC1408P8 | - | AD1508-8D AD1408-8D $\qquad$ |
| AM1408L7 AM1408N7 | $\begin{array}{\|l\|} \hline \text { DAC0807LCJ } \\ \text { DAC0807LCN } \\ \hline \end{array}$ | $\mu$ A0802BDC $\mu$ A0802BPC | $\begin{array}{\|l\|} \hline \text { MC1408-7F } \\ \text { MC1408-7N } \\ \hline \end{array}$ | - | MC1408L7 MC1408P7 | - | AD1408-7D |
| AM140BL6 AM1408N6 | $\begin{aligned} & \text { DAC0806LCJ } \\ & \text { DAC0806LCN } \end{aligned}$ | $\mu$ A0802CDC $\mu$ A0802CPC | MC1408-6F MC1408-6N | - | MC1408L6 MC1408P6 | - | - |
| $\begin{aligned} & \text { SSS1508A-8Q } \\ & \text { SSS1408A-8Q } \\ & \text { SSS1408A-7Q } \\ & \text { SSS1408A-6Q } \end{aligned}$ |  |  | - | $\begin{aligned} & \text { SSS1508A-8Q } \\ & \text { SSS1408A-8Q } \\ & \text { SSS1408A-7Q } \\ & \text { SSS1408A-6Q } \end{aligned}$ | - | - | - |
| AM6012ADM AM6012ADC AM6012APC AM6012DM AM6012DC AM6012PC | - |  | - | DAC312BR DAC312FR | - | - | - <br> - <br> - |
| AM6070ADM AM6070ADC AM6070DM AM6070DC | - - - | - | - | DAC-76BX <br> DAC-76EX <br> DAC-76X <br> DAC-76CX | - | - | - |
| $\begin{aligned} & \text { AM6072DM } \\ & \text { AM6072DC } \end{aligned}$ | - | - | - | DAC-86EX | - | - | - |
| AM6080 AM6081 | $\text { DAC0830/1/2 } \dagger$ | - | NE5018/19† | $\text { DAC-808/888 } \dagger$ | - | - | AD558 $\dagger$ |
| AM6688 | - | - | - | - | MC6108 | - | - |
| AM6108 | ADC0820 $\dagger$ | - | - | - | - | - | AD570 $\dagger$ AND <br> AD7574 $\dagger$ |
| AM6148 | ADC0820 $\dagger$ | - | - | - | - | - |  |
| LF198 | LF198 | $\mu \mathrm{AF} 198$ | NE5537 | - | - | - | - |

$\dagger$ Functional equivalent only


## General Information Index

Guidelines on Testing Am2900 Family Devices ..... 13-2
IMOX ${ }^{\text {TM }}$ Reliability Report Advanced Micro Devices ..... 13-6
Gate Counts and Die Sizes by Device ..... 13-11
Thermal Characterization of
Packaged Devices APPLICATIONS NOTE by J.L. Hayward ..... 13-15
Package Outlines ..... 13-18
Ordering Information ..... 13-29

# INFORMATION ON MILITARY DEVICES 

Advanced Micro Devices is currently updating its parts listing to identify those devices which are fully compliant with MIL-STD-883, Revision C, Notice 2. For further information, including a current listing of military flows, and to answer questions regarding specific AMD parts, please contact your local AMD sales representative.

# Guidelines on Testing Am2900 Family Devices 

## I. INTRODUCTION

The Am2900 Family represents a major step forward in bipolar technology, in that each device contains a number of MSI-type functions interconnected on one chip. The gate counts in the parts comprising the Am2900 Family are around 10-100 times the gate count of MSI functions. While this produces a number of advantages for manufacturing, such as reduced component count and lower costs, it complicates the incoming-inspection problem because test programs tend to be long and complex and must be carefully designed to insure that all bad parts are rejected and most good parts are accepted. While stating these two criteria is simple, reducing them to practice is not. LSI devices are not as "forgiving" of simplifications in test patterns and assumptions about forcing functions and noise levels, as their simpler counterparts. These notes are intended to point out some common areas of difficulty and their solutions.

## II. THE PURPOSE OF TESTING

Testing is performed at most facilities during an inspection of purchased material. The reason, of course, is that it is much less expensive to screen parts then, than it is to troubleshoot and repair completed boards. Ideally, all the parts passed by incoming inspection will work in the system. This is insured through a specification which defines the way the part must behave in the system, and the incoming test should confirm that devices received meet the specification. The incoming test should not reject devices which meet the specification. When test programs are too tight or test for conditions not contained in the specification, delays in shipments occur and significant costs are incurred by both the vendor and the buyer trying to resolve "correlation problems."

## III. GUARANTEEING THAT THE PARTS WORK

One step in testing devices is to perform DC parametric tests: $\mathrm{I}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{OH}}, \mathrm{V}_{\mathrm{OL}}$ and the like. These tests on bipolar LSI are not really different from those performed on simpler TTL devices, except that the number of pins involved is greater, and more complex set-ups may be required to put outputs in the proper state for testing. Another step is functional testing, and for bipolar LSI, function tests are significantly different than for MSI. The function tests must first insure that the device is capable of working, i.e., it's hooked up correctly inside. These kinds of tests can be described as 'stuck-at-one, stuck-at-zero' tests, because they are designed to exercise each gate in the part. Even for a part as complex as the Am2901, the "stuck-at" tests can be performed quickly. Less than 400 test patterns must be applied to the part to exercise every gate.
But, "stuck-at' tests make an assumption: if a gate works, then it works regardless of the state of other gates in the circuit. Each gate is treated independently, but, in the integrated circuit, no gate is an island. The performance of one gate can, in fact, depend on the states of surrounding
gates, because they share common inputs or common ground lines.

These possible faults are often not tested by '"stuck-at" tests, because they are not independent of the state of surrounding logic. These potential faults depend on the physical and logical construction of the circuit. They are usually called "pattern sensitivities." Pattern-sensitive faults, like the two described above, are not something new. All digital products exhibit pattern sensitivities - even SSI. But, on simpler parts, either traditional 'stuck-at' tests happen to find most of them, or the parts are easy enough to test that all possible data patterns are generated during testing. Neither of these circumstances is true for bipolar LSI. A special effort must be made to apply many data patterns to the devices to check for pattern-sensitive faults. This has been done for years with RAM patierns such as GALPAT. It must now be done with logic functions as well.
In the devices in the Am2900 Family, as with RAMs, testing all possible data patterns is not practical, but, the various MSI kinds of functions in the devices (register, ALU, multiplexer, etc.) can generally be logically isolated, and each of those functions should be checked independently for all possible data patterns. This principle works because (1) as a rule, it is possible to control the MSI functions in a 2900 part with some degree of independence, and (2) the MSI functions are usually physically separated on the die, so that a data pattern within one MSI block will not exhibit pattern sensitivity dependent on the data in another MSI block.
In the Am2901, for example, ALU tests using the two RAM ports as data sources are unlikely to be affected by the state of the data inputs or the Q register. The shift multiplexer at the input of the RAM is unlikely to be affected by the $Q$ register or the ALU source-select multiplexers. The control logic for the ALU source multiplexers should not be affected by anything in the ALU. By applying these kinds of principles intelligently, function tests can be constrained to a few thousand tests which provide a very high confidence level that the part is not subject to patternsensitive faults within its operating range.
As an example of the test philosophy used on these parts, the function tests for the Am2901 are described below.

## Am2901 FUNCTION TEST DESCRIPTION

The following describes the function tests performed on the Am2901. The $\overline{\mathrm{OE}}$ pin is low during the entire function tests and each test gets one clock pulse.

## A-Port GALPAT via ALU

These are tests in which the A-address of the 2-port RAM is tested for Galloping "ones" in a field of "zeros." During these tests, the B-address is the same as the A-address and OP code 337 is used for a write operation, while OP code 134 is used for a read operation. The four shiftoperation pins, $\mathrm{Q}_{0}, \mathrm{Q}_{3} \mathrm{RAM}_{0}$ and $\mathrm{RAM}_{3}$, are ignored.


THE Am2901 4-BIT MICROPROCESSOR SLICE

## B-Port GALPAT via ALU

These are tests in which the B-address of the 2-port RAM is tested for Galloping "ones" in a field of "zero." During these tests, the A-address is the inverse of the B-address and OP code 337 is used for a write operation while OP code 133 is used for a read operation. The four shift-operation pins, $Q_{0}, Q_{3}$ $R^{2} M_{0}$ and $R A M_{3}$, are ignored.

## A-Port GALPAT Bypass ALU

These are tests. in which the A-address of the 2-port RAM is tested for Galloping "ones'" in a field of 'zeros." During these tests, the B-address is the inverse of the A-address and OP code 337 is used for a write operation while OP code 233 is used for a read operation. The four shift-operation pins, $Q_{0}, Q_{3}$, $R A M_{0}$ and $R A M_{3}$, are ignored.

Repeat 1 above by inverting the Data and $Y$ output information on $D_{3-0}$ and $Y_{3-0}$. All other outputs are ignored. This performs Galloping 'zeros" in a field of "ones' for the A-Port via ALU.

Repeat item 2 above by inverting the Data and $Y$ output information on $D_{3-0}$ and $Y_{3-0}$. All other outputs are ignored. This performs Galloping "zeros" in a field of "ones" for the A-Port via ALU.

Repeat item 3 above by inverting Data and $Y$ output information on $D_{3-0}$ and $Y_{3-0}$. All the other outputs are ignored. This is Galloping "zeros" in a field of "ones" for A-Port bypass ALU.

## ALU Source Code

During these tests, the A- and B-addresses are at word locations preloaded with known values. The $Q$ register is also preloaded. Then, with the ALU destination OP code $=1$ (NoOP) and the ALU function code $=6$ (exclusive OR), the source code is cycled through from 0-7. The function code is then modified to 7 (exclusive NOR) and the source code sequence is cycled through once more.

## ALU Function Code

During these tests, the memory is preloaded with content equal to the address. In other words, word 0 is loaded with 0 , word 1 with 1 , and so on. Then; with A-address = B-address, a destination OP code of 1 (No OP), and a source OP code of 1 (A\&B Port selected), the ALU function code is cycled through. the sequence of $7,5,4,0,1,3,2,6$ for every set of A\&B address. This whole sequence is then repeated with $A$ address equal to the inverse of the B-address.

## Arithmetic Operation \& Carry Generation

During these tests, the memory is preloaded with content address. With OP code 105, whereby D input is added to the A-Port of the memory, the tester cycles through every possible D input added to every word in memory with carry in being both one and zero.

## Q Register Operation

During these tests, the $Q$ register is first loaded with all zeros. Then, with $\mathrm{Cn}=$ LOW and with OP code 006, whereby Q register is loaded with the sum of data input and Q-register content on every clock cycle, the device is clocked through all possible data inputs. The Cn input is then changed to a HIGH, and with OP code 016 whereby $Q$ register is loaded with the difference of Q-D. The device is clocked through all possible data input again. This checks both the add and subtract modes of the ALU, the internal-carry-lookahead circuitry and the Q-register operation.

## Q Register Shifting

During these tests, a unique string of data (11100001 010011011110 ) is shifted into the appropriate shift inputs. OP codes used in this group of tests are 432 for shift left, 532 for no shift, 632 for shift right and 732 for no shift.

## RAM Shifting

During these tests, A - and B -addresses are at word 0 . A string of data (11100001010011011110) is shifted into the appropriate shift inputs. OP codes used are 434 and 533 for left shift, 634 and 733 for right shift.

## IV. AVOIDING THE REJECTION OF GOOD DEVICES

Discrepancies in testing results between the vendor and the buyer result in much irritation and substantial costs for both. Some of the common sources of these discrepancies are discussed below.

## Testing for Unspecified or "don't care' Conditions

The data sheet (or purchase specification) defines the characteristics of the part. It is hard enough to test for everything specified without adding additional tests for unspecified parameters. If the state of an output is not specified under certain conditions, then it should not be tested.

## Noise

Many testing problems result from noise produced by the interactions of the device being tested and the test system. Typical test fixtures have lead inductances several times that of a PC board socket. This inductance, especially in the device ground path, is the source of these problems.
When the inputs to the device are changed there is a sequence of rapid changes in the device's ground current as signals propagate through internal gates to the outputs. These appear as changes in the voltage drop across the device ground lead. This voltage drop can be as much as 2 volts across a few inches of wire. Rise times are on the order of 1 nsec and pulse widths range from 2 to 10 nsec. Output transient current during switching may be 50 to 100 mA . The test systems input and output reference voltages are set with respect to tester ground and are not affected by these transients. Consequently the effective input voltages to the device will vary. If the ground pin goes up 1 volt, all the inputs effectively go down 1 volt.
This must be considered in selecting levels for $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{IH}}$. The device data sheet says $\mathrm{V}_{\mathrm{IL}}$ must be less than 0.8 V and $\mathrm{V}_{1 H}$ more than 2.0V. But this is as measured at the device package pins, between input and ground. This means that if the ground varies $\pm 0.5$ volt the input levels must be $\mathrm{V}_{\mathrm{IL}} \leqslant 0.3 \mathrm{~V}$ and $V_{i H} \leqslant 2.5 \mathrm{~V}$. If this is not done, a noise pulse could, for example, make the clock input effectively go high in the middle of the clock low time, causing an extra clock pulse. A similar situation exists at the device outputs, requiring $\mathrm{V}_{\mathrm{OL}}$ to be set higher, and $V_{O H}$ lower, than the data sheet numbers. AMD uses $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2 \mathrm{~V}$ for functional tests.

Proper observations are important to the understanding and control of these problems. Small changes in timing, bypass capacitors, etc. will have large effects on the noise. An oscilloscope of 200 MHz or greater bandwidth is essential. Noise voltage should be measured at the device ground pin (at the device package edge, not the bottom of the test socket). Connect the probe ground to the tester chassis. In order to see the peak noise voltage, cycle the tester through a long
pattern. Trigger the scope internally from the noise waveform. Turn the trigger level slowly up until the trace is almost lost. The peak noise voltage will appear at the left side of the screen. Sweep speed should be about $10 \mathrm{nsec} / \mathrm{div}$. Repeat for the peak of the opposite polarity.
Another useful technique is to identify a particular test pattern location which causes significant noise. Sync the oscilloscope to this test cycle. Using a two channel scope, connect one channel to an input pin and the other channel to the device ground pin. Invert the channel on the ground pin and add the two channels. The waveform will show the effective input levels.
An additional problem is introduced by I/O pins. When output load circuits are connected to these pins the tester must drive the load and the device when the pins are inputs. If the tester has a driver impedance of 50 ohms and the load supplies 16 mA into $\mathrm{V}_{\mathrm{OL}}$, the input level produced will be 0.8 V too high. This must be compensated by further reducing the programmed $\mathrm{V}_{\mathrm{K}}$ for only the I/O pins. Some devices are sensitive to input voltages below ground.

## Guidelines

If the tester does not provide suitable alternate driver supplies, it may be necessary to provide resistor pullups for input-only pins.
The same ground lead inductance problems causes difficulties in DC testing. Many DC tests require some functional sequence to produce the correct device state. The input levels must be such to avoid false clocks, etc. DC tests may be used to verify input threshold levels. To do this, an output test such as $\mathrm{V}_{\mathrm{OL}}$ or $\mathrm{V}_{\mathrm{OH}}$ is selected where the outputs combinatorally depend on the inputs. Using non-threshold levels the appropriate input conditions are applied. The input levels are then reprogrammed to threshold levels. The outputs are then measured for $\mathrm{V}_{\mathrm{OL}}$ or $\mathrm{V}_{\mathrm{OH}}$. It is not possible to do the functional set-up with threshold levels, even if it is only a single line, as oscillations may occur. Switching between alternate driven supplies also may generate sufficient noise to cause problems.

## AC Testing

Many modern testers allow switching tests to be performed during the application of complex test sequences. The switching and function tests can then occur together. Unfortunately, this blurs the distinction between functional failure and switch-ing-speed failure when a device is rejected, so, it is a good idea to do some preliminary function testing with 'loose" AC limits before trying to do everything at once. When function and AC testing are combined, it is important to consider the driving conditions under which the AC parameters are tested. Switching measurements on Bipolar ICs are usually made with input levels switching between 0 V and 3.0 V (sometimes 0.4 V and 2.4 V are used). The output transition is measured at 1.5 V (sometimes at 1.3 V ).
They are never specified at threshold levels $(0.8 \mathrm{~V}$ and 2.0 V$)$ because of noise problems.
Realistic AC tests require sequencing through many lines of test patterns to include a variety of data patterns. Unfortunate-
ly the AC accuracy of most modern logic testers is not as good as memory testers. There are often significant differences between different waveform formats. The position of an edge may depend on whether adjacent pins are switching and whether they are going up or down. This limits the accuracy of testing, especially for such parameters as hold times, where tester error usually exceeds the difference between device typical and data sheet maximum. This may be observed on an oscilloscope by cycling the tester and synchronizing the scope to a repetitive pulse, such as the device clock pin.* Do not trigger the scope on any particular tester cycle. Observing a device input on the second scope channel will show many overlapping transitions, positive and negative. The width of this band must be added to other error sources to determine tester accuracy.

## Temperature Testing

Integrated circuits are specified to operate over either the commercial range of $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ or the military range of $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$. Standard screening procedures (from MIL-STD-883) call for $100 \%$ testing at $25^{\circ} \mathrm{C}$ followed by sample testing at the high and low temperature. Many users duplicate this test sequence in their incoming inspection, and some test $100 \%$ at temperature.

Testing problems are rarely encountered at low temperatures, if care is taken to prevent ice formation on the test socket. At high temperature, difficulties may arise because of the difficulty in creating a test environment which is representative of the thermal conditions found in the system.
High temperature testing with a controlled ambient temperature is very difficult because the thermal coefficient between the package and the surrounding environment depends on humidity, rate of air flow, package color, connections to package pins, and position of surrounding devices. For testing purposes, only the case temperature can really be controlled. (Most systems' thermal engineering is also designed to control case temperatures.)

## V. INCOMING INSPECTION AND TESTING SUPPORT PRODUCTS

AMD provides several products to assist in the development of incoming inspection testing for most Am2900 LSI devices. See the table on the following page for specifics by device.

## Sentry Test Programs

These are complete data sheet function, DC and AC parameter programs. They run on a Fairchild Sentry VII with low voltage test heads, 4K local memory and SPM. Complete load board documentation is included. Programs are supplied on magnetic tape in TDX format. Source files in ASCII code on magnetic tape can be provided for those who wish to generate test programs for other testers. Test programs require a licensing agreement.

## Correlation Kit

This consists of two devices and datalog from AMD's characterization program.

## ORDERING INFORMATION

| Order Code | Description |
| :--- | :--- |
| AM29XX-SEN | Sentry Test Program |
| AM29XX-KIT | Correlation Kit |

Advanced Micro Devices

## SUMMARY

This report is a comprehensive summary of reliability test data accumulated on AMD's IMOX process. IMOX is an acronym for ion-IMplanted/micro-OXide isolation. AMD presently uses this wafer fabrication process on all new Bipolar products, including Bipolar Memory, Interface, Logic and Microprocessor devices. We present not only the statistical data, but also discuss the process itself, typical failure mechanisms, and the test methodology behind the
data. The results show experimental and statistical proof that the AMD IMOX process ensures system designers of long life and highly reliable Bipolar devices.

In line with Advanced Micro Devices' commitment to provide customers with high quality, high performance devices, we will continue to evaluate devices for reliability through ongoing HTOL (high temperature operating life) testing. This report will be updated at regular intervals as new reliability data is accumulated.

## PROCESS

The IMOX process utilizes ion-implanted transistors, oxide isolation and dual-layer metal to create fast, high performance Bipolar devices that consume less power as well.

IMOX processing allows for reduction of transistor geometries and the amount of unused space surrounding a transistor, which means that individual transistors can be built significantly smaller and closer together. Since decreased geometries are obtained without a reduction in photolithographic line width, no increase in the process sensitivity occurs. Speed is one of the most vital characteristics of a Bipolar device. With the tighter layout and reduced capacitances of IMOX processing, we have improved the speed on many devices by as much as $25-30 \%$. Tighter layouts have also allowed us to utilize previously unavailable die space for increased complexity. This is represented in two new AMD Bipolar VLSI devices, the Bipolar Microprocessor, Am29116 and the $16 \times 16$ Parallel Multiplier, Am29517.

## FAILURE MECHANISMS

Failures in integrated circuits are frequently categorized by the phase of manufacturing or the component of the part's structure that is associated with the determined failure mechanism. Failure distributions often are presented as pie charts with slices of the pie named for these categories (see Figures 1 and 2). The failure category distribution percentages are roughly those expected for Bipolar IMOX devices. Each of these categories may contain several distinct failure mecha-nisms-the basic physical or chemical process that results in a failure. The external indicators of a failure (the failure mode) are generally electrical in nature: opens, shorts, non-functional or parametric anomalies. There may be different mechanisms indicated by a single failure mode. The following is a discussion of the commonly observed failure mechanisms in integrated circuits.


RF000100
Key: Failure type distribution for STTL/LSI Integrated Circuits (data derived from Reliability Analysis Center study, 'Microcircuit Screening Effectiveness,' 1978-Order No. TRS-1, 78). Data based on field failure information available to RAC, not life test data.

Figure 1. Normalized Distributions of STTL/LSI Malfunctions

## DIFFUSION

Diffusion-related mechanisms generally cause marginal device parameters which affect the performance of the device in certain operationally extreme situations. Electrical stresses induced during operation at elevated temperatures are effective in screening marginal diffusion problems. The activation energy associated with this general mechanism is difficult to assign without knowing more about the exact process, but it can be assumed to be 1.0 eV for other than the dielectric breakdown.

## OXIDE

Oxide-related faults can be found in the thermally grown oxide regions or in the deposited passivation layers. Defects in the latter sometimes lead to chemical attack of the underlying layers if corrosive elements are present. Activation energies for these types of defects are very large ( $>1.0 \mathrm{eV}$ ). Metal-to-


RF000200
Key: Failure percentages are averages based on past failure analysis studies performed by engineers at AMD.

Figure 2. AMD Observed Distributions of STTL/ LSI Malfunctions
metal or metal-to-semiconductor breakdown can also occur. These are often caused by pinholes, contaminants in the oxide or with photolithographic defects. Though the time dependence for oxide failure is more voltage than temperature related, life-tests are effective in electrically stressing oxide imperfections.

## BULK

Bulk (silicon) defects are those associated with the silicon wafer or die itself, such as crystal imperfections, resistivity gradients, expitaxial layer defects, damage to the die, and foreign material precipitates. These defects in themselves do not change with time at even the highest die operating temperatures, but they can become part of the active region of the device when built-in charge changes occur. This failure mode is very rare. Of the total failure rate percentage, this type of failure occurs less than $1 \%$ of the time.

## SURFACE

lonic-contamination-induced inversion and channeling are the most frequently detected surface related mechanisms. At elevated temperatures, ions become mobile in or on the oxide covering the die. If the device is powered, the ions will be attracted to high field regions that exist near reverse biased junctions. This accumulation of charge can indúce a surface layer (channel) of a conduction type opposite to that of the adjacent region (inversion), i.e., an N -type channel on a P-type region. Additional modes of failure are altered parasitic device characteristics, parasitic capacitance and "leaky" bipolar junction characteristics. The effects of built-in charge may be very slow in appearing, showing up only after many hours under bias at elevated temperatures. The activation energy associated with charge migration in silicon dioxide has been found to be 0.5 to 1.0 eV .

## METALLIZATION

A familiar mechanism of metallization-related failures is metal migration. When high current densities on the order of hundreds of thousands of amps per square centimeter occur at elevated temperatures, the metal (aluminum) atoms are carried aiong by the electron flow, causing migration of the metallization opposite to the direction of current flow which results in wear out. This may be in the form of disconnects, breaks, metal lead opens, etc. AMD's design rules for a metallization stripe cross section provide for a maximum current density of 200,000 amperes per square centimeter, well within the MIL-M-38510 maximum allowable current density for glassivated aluminum conductors. The activation energy of electromigration has been determined to be 0.5 to 1.0 eV .

Open metallization detected in failed devices may be due to metal migration. The high current condition required to cause metal migration is often found to be the result of a defective circuit element. Photolithographic or masking defects sometimes result in reduction of metallization cross-section which is sufficient to allow metal migration to occur. The mechanism by which a severely scratch-damaged metal stripe opens in a very localized area is probably metal migration. Open or short conditions will be easily detected during internal visual inspection. Subtle defects, such as reduced cross-sectional area, can be detected by a dynamic life test at high temperature.

## INTERCONNECT, WIREBOND AND PACKAGE SEAL/LEAD DEFECTS

The interconnect category includes failures that result from the "flying" lead being damaged by nicking, by work-stressing during bonding and by handling subsequent to the wirebond operation. The wirebond category includes all types of bond failures, including intermetallic formation. The package seal/ lead defect category includes hermeticity failures and hermet-icity-related failures such as corrosion. None of these failure types are found in a life-test program. They are controlled by material selection, receiving inspection, and extensive control of the assembly process. The success at these controls is verified by examining the results of quality conformance testing for military and "Hi-Rel" customers, specifically, the group B and group D tests (MIL-STD-883, method 5005). The group B test (lot acceptance test) includes a wirebond strength test. The group $D$ test is a pure-package quality conformance test and includes tests for lead integrity, resistance to thermal shock, temperature cycling, moisture resistance, mechanical shock, vibration, centrifuge, and salt atmosphere exposure. Group B and D testing is periodically performed by AMD and is available for inspection

## ACCELERATED TESTING

Semiconductor devices fail as a consequence of certain physical, metallurgical and chemical processes, all of which have temperature-dependent rates. The rates may also be potential or current dependent, but these dependencies are generally second-order effects. Users of electronic components are aware of the thermal effect and have frequently borrowed the organic chemist's rule of thumb, that reaction rates double for a $10^{\circ} \mathrm{C}$ temperature rise, to estimate the effects of high temperature life testing. This procedure does not provide the proper acceleration factor if applied for more than a decade or two of temperature and is quite inaccurate in estimating a $70^{\circ} \mathrm{C}$ equivalence for a $125^{\circ} \mathrm{C}$ life test.

For most processes causing semiconductor failures, the Arrhenius equation enables us to determine realistic failure rates. Temperature variations and their corresponding reaction rates can also be calculated for semiconductor devices. The following equation can be used over the entire temperature range:

$$
\lambda(T)=C_{1} \exp \left(-E_{a} / K T\right)
$$

where:
$\lambda(T)=$ device failure rate (temperature-dependent)
$T=$ absolute temperature ( ${ }^{\circ} \mathrm{K}$ )
$\mathrm{K}=$ Boltzmann's constant ( $8.62 \times 10^{-5} \mathrm{eV} /{ }^{\circ} \mathrm{K}$ )
$\mathrm{E}_{\mathrm{a}}=$ activation energy of the individual device failure mechanisms (eV)
$\mathrm{C}_{1}=\mathrm{a}$ constant

The temperatures used are junction temperatures, and the ability to use higher temperatures to achieve acceleration is constrained by the maximum permissible junction temperature under bias. Junction temperatures can be computed using power dissipation and package thermal characteristics. The following equation shows how those temperatures were derived:

$$
T_{J}=T_{A}+\theta_{\mathrm{JA}}\left[\left(I_{\mathrm{Cc}_{\text {max }}}\right)\left(\mathrm{V}_{\mathrm{Cc}_{\text {max }}}\right)\right]
$$

To determine the acceleration factor for temperature, $\mathrm{T}_{2}$, with reference to another temperature, $\mathrm{T}_{1}$, simply divide the failure rate equations for the two temperatures:

$$
\text { A.F. }=\frac{\lambda\left(T_{1}\right)}{\lambda\left(T_{2}\right)}=\exp \left[\frac{E_{a}}{K}\left(\frac{1}{T_{2}}-\frac{1}{T_{1}}\right)\right]
$$

where:

$$
\begin{array}{ll}
\text { A.F. } & =\text { acceleration factor } \\
\lambda\left(T_{1}\right) / \lambda\left(T_{2}\right) & =\text { ratio of reaction rates (failure) }
\end{array}
$$

This equation contains one constant whose value is not known from physical theory: the activation energy, $\mathrm{E}_{\mathrm{a}}$. Activation energy reflects the temperature dependence of a particular failure mechanism or group of mechanisms. It has been determined experimentally for some specific processes. Various investigators disagree as to the exact value of $\mathrm{E}_{\mathrm{a}}$ because such experiments are difficult to conduct and spurious failures occur to cloud the results. Table 1 shows the range of these values as determined by experimentation.

TABLE 1.
ACTIVATION ENERGIES FOR CERTAIN PROCESSES

| Surface Contamination | $1.2-1.40 \mathrm{eV}$ |
| :--- | ---: |
| Electromigration | $0.5-1.00 \mathrm{eV}$ |
| Oxide Defects (dielectric breakdown) | $0.3-0.40 \mathrm{eV}$ |
| Corrosion | $0.3-0.60 \mathrm{eV}$ |
| Intermetallic Growth (gold aluminum) | $1.0-1.05 \mathrm{eV}$ |
| Slow Trapping | 1.30 eV |

## RELIABILITY TEST STUDY

The approach used in this report for evaluating reliability involves the concept of failure rates as a function of time. Life
expectancy of devices can be categorized into three distinct intervals:
a. Infant Mortality
b. Operating Range
c. Old Age Mortality

An example of this distribution is shown in Figure 4. The results of this study are from long-term life tests. These tests are performed for 1000 hours or more without an initial burn-in. Therefore, 'Infant Mortalities' are included in the failure rates of the units tested. With the inclusion of a burn-in process, the failure rates of the IMOX devices are expected to be less than the failure rates calculated in this report.


An Arrhenius plot may be used to predict the effect of temperature shift for a particular population at a given average activation energy. This plot has been set up around a 1000 -hour test at $125^{\circ} \mathrm{C}$ for two activation energies, 1.0 eV and 0.466 eV . Equivalent test times of other temperatures may be determined for either a 1.0 eV or a 0.466 eV process. For example, an equivalent test time for 0.466 eV at any temperature may be determined by simply picking an appropriate temperature and reading the number of hours corresponding to the intersection of the temperature and the 0.466 eV line.

Figure 3. Arrhenius Plot


Figure 4. Life Expectancy of Devices

Table 2 shows that units were subjected to HTOL (High Temperature Operating Life) testing at $125^{\circ} \mathrm{C}$ and $150^{\circ} \mathrm{C}$ per MIL-STD-883, method 1005 and 1015, conditions C and D. For an example of an HTOL circuit, see Figure 5. Data was collected on the SN54LS374A and the Am27S184/185 (cerdip and plastic) devices. The testing yielded $10,864,000$ device hours worth of data. In total, 20 failures were recorded indicating a failure rate range (at $60 \%$ confidence level) of $0.183-0.50$ per 1000 hours at $125^{\circ} \mathrm{C}$ using the chi-squared distribution.

This table also includes corresponding calculated failure rates at lower temperatures using an activation energy level of 1.0 eV . The failure rate for the IMOX processed SN54LS374A is less than $.0025 \%$ per Khr at $70^{\circ} \mathrm{C}$ (cerdip) and less than .0045 per Khr at $70^{\circ} \mathrm{C}$ (plastic). The failure rate for the

Am27S184/185 is less than .0120 per khr. The lower temperatures $\left(70^{\circ} \mathrm{C}\right.$ and $\left.25^{\circ} \mathrm{C}\right)$ are chosen to give users reliability predictions at the high end of the commercial operating temperature range and at the average "room temperature" operating temperature of a commercial system.
Other IMOX Bipolar devices which are presently undergoing HTOL testing are: Am2901C, Am29116 and Am29516. After recently completing 1000 cumulative hours of dynamic life testing (condition D) at $125^{\circ} \mathrm{C}$, the 94 -piece lot of Am2901C's resulted in a zero reject rate. Preliminary data has been gathered on each device type. At this time, statistically calculated rates would not accurately reflect the products' failure rate. After further testing is complete, failure rates will be calculated for each product and supplied in an addendum to this report.

TABLE 2. IMOX RELIABILITY OPERATING LIFE TEST DATA SUMMARY

| Device | Number of Units | Device Khrs | Number of Rejects | \%Fall Per Khr | $\lambda 125^{\circ} \mathrm{C}$ | $\lambda 70^{\circ} \mathrm{C}$ | $\lambda 25^{\circ} \mathrm{C}$ | Fits |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | $70^{\circ} \mathrm{C}$ | $25^{\circ} \mathrm{C}$ |
| 54LS374A Cerdip Plastic | $\begin{aligned} & 1435 \\ & 1110 \end{aligned}$ | $\begin{aligned} & 6856 \\ & 3825 \end{aligned}$ | $\begin{array}{r} 11 \\ 9 \end{array}$ | $\begin{aligned} & 0.160 \\ & 0.235 \end{aligned}$ | $\begin{aligned} & 0.183 \\ & 0.274 \end{aligned}$ | $\begin{aligned} & 0.002 \\ & 0.003 \end{aligned}$ | $\begin{aligned} & .00001 \\ & .000015 \end{aligned}$ | $\begin{aligned} & 17 \\ & 26 \end{aligned}$ | $\begin{aligned} & 0.1 \\ & 0.15 \end{aligned}$ |
| 27S184/185 | 263 | 183 | 0 | 0 | 0.50 | 0.0046 | . 000028 | 46 | 0.28 |
| 29116 |  |  |  | Life Test in Progress |  |  |  |  |  |
| 29516 THE DATA FROM 29116 CAN BE APPLIED |  |  |  |  |  |  |  |  |  |
| IMOX Total | 2808 | 10864 | 20 | 0.184 | 0.20 | 0.0018 | . 0000114 | 18 | 0.114 |

Notes: 1. All calculated failure rates and Fits Nos. used the Arrhenius Equation with 1.0 VeV activation energy.
2. Fits $=$ Failure in $10^{9}$ hrs at $70^{\circ} \mathrm{C}$ and $25^{\circ} \mathrm{C}$ using a $60 \%$ confidence level.

## SUMMARY

This report summarizes the actual reliability testing of AMD's proprietary process, IMOX. The statistical data and charts are presented to provide accurate comparative information. The demonstrated failure rates of the devices at $70^{\circ} \mathrm{C}$ reflect the high reliability of IMOX processed products. The design rules for IMOX processing are the same for all Bipolar products. Therefore, similar testing performed on other Bipolar devices, i.e., Am29116, would also result in very low failure rates as seen in this study.

Analysis of the various failures have shown that the device failures were of a random mode and their degree of occurrence was inconsistent. No inherent process failure mechanism has been found in the IMOX process. In conclusion, IMOX is the superior method for Bipolar water fabrication and for building high reliability into AMD devices.


POWER SUPPLY SETTINGS

| Supply No. | Signal | Voltage |
| :---: | :---: | :---: |
| 1 | $\mathrm{~V}_{\mathrm{BB}}$ | $+5.0 \mathrm{~V} \pm$ |
| 2 | $\mathrm{~V}_{\mathrm{CC}}$ | $+5.0 \mathrm{~V} \pm$ |
| Conditions: | 1. <br>  <br>  <br> 2. Pin $10:$ Device Ground <br> High levels: $+3.0 \mathrm{KHz} \pm$ <br> Low lo $+10 \%$ <br> Lovels: -0.2 V to 1.2 V |  |

MIL-STD-883 Method 1015 Condition C
C - Steady state, power and reverse bias.
Inputs reverse biased.
This circuit was used for testing the SN54LS374A.

Figure 5. HTOL Circuit Configuration

## References

IMOX Reliability Report by Beverly Henry. In preparation of this report, Chris King, Wisty Olsson, Ann Rosser, Chris Schmidt and Pauline Seales provided valuable assistance.

## Gate Counts and Die Sizes by Device

The following data is useful for hybrid design and for MIL-STD reliability calculations. The gate counts are only an approximation for LSI devices because the circuit implementation often uses multi-level gates and unique logic structures, not just NAND and NOR gates.

| Part Number | Equivalent Number of Gates (Approximate) | Die Area $\text { In Mils }{ }^{2}=.001 \times .001 \text { in.) }$ | Die Dimensions (In Mils = . 001 in.) |
| :---: | :---: | :---: | :---: |
| Am25S05 | 86 | 9680 | $88 \times 110$ |
| Am25LS07 | 26 | 6300 | $75 \times 84$ |
| Am25S07 | 26 | 5810 | $70 \times 83$ |
| Am25LS08 | 18 | 4575 | $75 \times 61$ |
| Am25S08 | 18 | 4891 | $67 \times 73$ |
| Am25LS09 | 30 | 4575 | $75 \times 61$ |
| Am25S09 | 30 | 4891 | $67 \times 73$ |
| Am25S10 | 29 | 3696 | $56 \times 66$ |
| Am25LS14 | Replaced by Am25LS14A |  |  |
| Am25LS14A | 167 | 7980 | $84 \times 95$ |
| Am25LS15 | 92 | 9025 | $95 \times 95$ |
| Am25S18 | 30 | 6083 | $77 \times 79$ |
| Am25LS22 | 82 | 10,752 | $96 \times 112$ |
| Am25LS23 | 88 | 10,752 | $96 \times 112$ |
| Am25S557 | 1115 | 28,215 | $171 \times 165$ |
| Am25S558 | 1115 | 28,215 | $171 \times 165$ |
| Am25LS2513 | 33 | 6970 | $82 \times 85$ |
| Am25LS2517 | 89 | 9828 | $91 \times 108$ |
| Am25LS2518 | 30 | 8217 | $83 \times 99$ |
| Am25LS2519 | 59 | 8217 | $83 \times 99$ |
| Am25LS2520 | 84 | 8880 | $80 \times 111$ |
| Am25LS2521 | 26 | 4662 | $63 \times 74$ |
| Am25LS2535 | 52 | 7920 | $80 \times 99$ |
| Am25LS2536 | 66 | 8316 | $84 \times 99$ |
| Am25LS2537 | 42 | 7776 | $81 \times 96$ |
| Am25LS2538 | 34 | 7776 | $81 \times 96$ |
| Am25LS2539 | 38 | 7776 | $81 \times 96$ |
| Am25LS2548 | 18 | 7776 | $81 \times 96$ |
| Am25LS2568 | 87 | 8549 | $87 \times 103$ |
| Am25LS2569 | 79 | 8549 | $87 \times 103$ |


| Part Number | Equivalent Number of Gates (Approximate) | $\begin{gathered} \text { Die Area } \\ \text { (In Mils }{ }^{2}=.001 \times .001 \mathrm{in} \text {.) } \end{gathered}$ | Die Dimensions (In Mils = . 001 in .) |
| :---: | :---: | :---: | :---: |
| Am26S02 | N/A | 4402 | $62 \times 71$ |
| Am26S10 | 9 | 4425 | $59 \times 75$ |
| Am26S11 | 13 | 4425 | $59 \times 75$ |
| Am26S12 | 9 | 5112 | $71 \times 72$ |
| Am26S12A | 9 | 5112 | $71 \times 72$ |
| Am26LS27 | In development |  |  |
| Am26LS28 | In development |  |  |
| Am26LS29 | 6 | 6580 | $70 \times 94$ |
| Am26LS30 | 6 | 6580 | $70 \times 94$ |
| Am26LS31 | 10 | 5628 | $67 \times 84$ |
| Am26LS32 | 6 | 4704 | $56 \times 84$ |
| Am26LS32B | 6 | 4704 | $56 \times 84$ |
| Am26LS33 | 6 | 4704 | $56 \times 84$ |
| Am26LS34 | 6 | 4704 | $56 \times 84$ |
| Am26LS38 | 72 | 6208 | $64 \times 97$ |
| Am2900 |  |  |  |
| Part Number | Equivalent Number of Gates (Approximate) | Die Area $\text { (in Mils }{ }^{2}=.001 \times .001 \mathrm{in} . \text { ) }$ | Die Dimensions (in Mils $=.001 \mathrm{in}$.) |
| Am2901 | Replaced by Am2901B and Am2901C |  |  |
| Am2901A | Replaced by Am2901B and Am2901C |  |  |
| Am2901B | 538 | 14,976 | $117 \times 128$ |
| Am2901C | 550 | 15,990. | $130 \times 123$ |
| Am2902 | Replaced by Am2902A |  |  |
| Am2902A | 19 | 4154 | $62 \times 67$ |
| Am2903 | 630 | 32,111 | $163 \times 197$ |
| Am2903A | 752 | 36,808 | $172 \times 214$ |
| Am2904 | 283 | 22,540 | $140 \times 161$ |
| Am2905 | 49 | 10,400 | $80 \times 130$ |
| Am2906 | 56 | 10,400 | $80 \times 130$ |
| Am2907 | 52 | 9064 | $88 \times 103$ |
| Am2908 | 52 | 9064 | $88 \times 103$ |
| Am2909 | Replaced by Am2909A |  |  |
| Am2909A | 225 | 6831 | $69 \times 99$ |
| Am2910 | 736 | 32,980 | $170 \times 194$ |
| Am2910A | In development |  |  |
| Am2911 | Replaced by Am2911A |  |  |
| Am2911A | 221 | 6664 | $68 \times 98$ |
| Am2912 | 9 | 4425 | $59 \times 75$ |
| Am2913 | 33 | 6970 | $82 \times 85$ |
| Am2914 | 335 | 24,871 | $133 \times 187$ |
| Am2915A | 49 | 9620 | $74 \times 130$ |
| Am2916A | 56 | 9620 | $74 \times 130$ |
| Am2917A | 52 | 9620 | $74 \times 130$ |
| Am2918 | 30 | 6083 | $77 \times 79$ |
| Am29LS18 | 30 | 8217 | $83 \times 99$ |
| Am2919 | 59 | 8217 | $83 \times 99$ |
| Am2920 | 84 | 8880 | $80 \times 111$ |
| Am2921 | 34 | 7776 | $81 \times 96$ |
| Am2922 | 52 | 7920 | $80 \times 99$ |
| Am2923 | 18 | 4288 | $64 \times 67$ |
| Am2924 | 17 | 4550 | $65 \times 70$ |
| Am2925 | 120 | 11,834 | $97 \times 122$ |
| Am2926 | 10 | 5278 | $58 \times 91$ |
| Am2927 | 72 | 12,096 | $87 \times 144$ |
| Am2928 | 95 | 12,096 | $87 \times 144$ |
| Am2929 | 10 | 5278 | $58 \times 91$ |


| Part Number | Equivalent Number of Gates (Approximate) | Die Area $\text { (in Mils }{ }^{2}=.001 \times .001 \text { in.) }$ | Die Dimensions (in Mils = . 001 in.) | Q D D |
| :---: | :---: | :---: | :---: | :---: |
| Am2930 | 548 | 26,600 | $133 \times 200$ | ? |
| Am2932 | 521 | 26,600 | $133 \times 200$ | $\bigcirc$ |
| Am2940 | 415 | 32,037 | $177 \times 181$ | $5$ |
| Am2942 | 415 | 32,037 | $177 \times 181$ | $\cdots$ |
| Am2946 | 18 | 6141 | $69 \times 89$ | き |
| Am2947 | 18 | 6141 | $69 \times 89$ | 0 |
| Am2948 | 18 | 6141 | $69 \times 89$ | 믕 |
| Am2949 | 18 | 6141 | $69 \times 89$ | (1) |
| Am2950 | 175 | 14,766 | $107 \times 138$ | $\stackrel{0}{N}$ |
| Am2950A | In development |  |  | N |
| Am2951 | 175 | 14,766 | $107 \times 138$ | 0 |
| Am2951A | In development |  |  | 5 |
| Am2952 | 102 | 14,873 | $107 \times 139$ | $\square$ |
| Am2952A | In development |  |  | $\stackrel{1}{5}$ |
| Am2953 | 102 | 14,873 | $107 \times 139$ | $\stackrel{\square}{8}$ |
| Am2953A | In development |  |  | (1) |
| Am2954 | 50 | 7968 | $96 \times 83$ |  |
| Am2955 | 50 | 7968 | $96 \times 83$ |  |
| Am2956 | 50 | 7854 | $66 \times 119$ |  |
| Am2957 | 50 | 7854 | $66 \times 119$ |  |
| Am2958 | 10 | 5369 | $59 \times 91$ |  |
| Am2959 | 10 | 5369 | $59 \times 91$ |  |
| Am2960 | 450 | 13,056 | $102 \times 128$ |  |
| Am2960A | In development |  |  |  |
| Am2961 | 82 | 8874 | $102 \times 87$ |  |
| Am2962 | 74 | 8874 | $102 \times 87$ |  |
| Am2964B | 170 | 22,308 | $156 \times 143$ |  |
| Am2965 | 10 | 5640 | $94 \times 60$ |  |
| Am2966 | 10 | 5640 | $94 \times 60$ |  |
| Am2968 | In development |  |  |  |
| Am2969 | In development |  |  |  |
| Am2970 | In development |  |  |  |
| Am29112 | In development |  |  |  |
| Am29116 | 2500 | 78,061 | $251 \times 311$ |  |
| Am29116A | In development |  |  |  |
| Am29203 | 752 | 36,808 | $172 \times 214$ |  |
| Am29501 | 1000 | 64,158 | $289 \times 222$ |  |
| Am29510 | In development |  |  |  |
| Am29516 | 2100 | 55,500 | $250 \times 222$ |  |
| Am29516A | In development |  |  |  |
| Am29517 | 2100 | 55,500 | $250 \times 222$ |  |
| Am29517A | In development |  |  |  |
| Am29520 | 362 | 15,327 | $117 \times 131$ |  |
| Am29521 | 362 | 15,327 | $117 \times 131$ |  |
| Am29526 | N/A | N/A | N/A |  |
| Am29527 | N/A | N/A | N/A |  |
| Am29528 | N/A | N/A | N/A |  |
| Am29529 | N/A | N/A | N/A |  |
| Am29540 | 1125 | N/A | N/A |  |
| Am29705 | 258 | 13,056 | $102 \times 128$ |  |
| Am29705A | 206 | 9984 | $104 \times 96$ |  |
| Am29707 | 207 | 9984 | $104 \times 96$ |  |
| Am29803A | N/A | N/A | N/A |  |
| Am29806 | 42 | 6468 | $66 \times 98$ |  |
| Am29809 | 42 | 6468 | $66 \times 98$ |  |
| Am29811A | N/A | N/A | N/A |  |
| Am29818 | 152 | 11,328 | $96 \times 118$ |  |
| Am29821 | 72 | 5376 | $64 \times 84$ |  |
| - |  |  |  |  |


| Part Number | Equivalent Number of Gates (Approximate) |  |  | $$ |  |  | Die Dimensions (in Mils = . 001 in .) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Am29822 | 72 |  |  | 5376 |  |  | $64 \times 84$ |  |
| Am29823 | 68 |  |  | 5376 |  |  | $64 \times 84$ |  |
| Am29824 | 68 |  |  | 5376 |  |  | $64 \times 84$ |  |
| Am29825 | 61 |  |  | 5376 |  |  | $64 \times 84$ |  |
| Am29826 | 61 |  |  | 5376 |  |  | $64 \times 84$ |  |
| Am29827 | 11 |  |  | N/A |  |  | N/A |  |
| Am29828 | 11 |  |  | N/A |  |  | N/A |  |
| Am29833 | In development |  |  |  |  |  |  |  |
| Am29834 | In development |  |  |  |  |  |  |  |
| Am29841 | 52 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29842 | 52 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29843 | 49 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29844 | 49 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29845 | 44 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29846 | 44 |  |  | 5376 |  |  | $84 \times 64$ |  |
| Am29853 | In development |  |  |  |  |  |  |  |
| Am29854 | In development |  |  |  |  |  |  |  |
| Am29861 | 22 |  |  | N/A |  |  | N/A |  |
| Am29862 | 22 |  |  | N/A |  |  | N/A |  |
| Am29863 | 20 |  |  | N/A |  |  | N/A |  |
| Am29864 | 20 |  |  | N/A |  |  | N/A |  |
| 8XXX MOS MPU Support |  |  |  |  |  |  |  |  |
| Part Number | Equivalent Number of Gates (Approximate) |  |  | Die Area$\text { (In Mils }{ }^{2}=.001 \times .001 \mathrm{in} \text {.) }$ |  |  | Die Dimensions (In Mils = . 001 in .) |  |
| Am8120 | 84 |  |  | 8880 |  |  | $80 \times 111$ |  |
| Am8127 | 135 |  |  | 8624 |  |  | $98 \times 88$ |  |
| Am8163 | 350 |  |  | 28,860 |  |  | $185 \times 156$ |  |
| Am8167 | 350 |  |  | 28,860 |  |  | $185 \times 156$ |  |
| Am8212 | N/A |  |  | 10,192 |  |  | $91 \times 112$ |  |
| Am8216 | 10 |  |  | 5940 |  |  | $66 \times 90$ |  |
| Am8224 | 47 |  |  | 7140 |  |  | $85 \times 84$ |  |
| Am8226 | 10 |  |  | 5940 |  |  | $66 \times 90$ |  |
| Am8228 | N/A |  |  | 14,960 |  |  | $110 \times 136$ |  |
| Am8238 | N/A |  |  | 14,960 |  |  | $110 \times 136$ |  |
| Package Material Configurations |  |  |  |  |  |  |  |  |
|  |  | Multilayer Ceramic |  |  | Ceramic |  | Plastic |  |
|  |  | Brazed Packages |  | Chip Carrier | Cerdip |  |  |  |
| Package Body Material |  | 90\% Alumina (Min) |  | 90\% Alumina (Min) | 90\% Alumina (Min) |  | Novolac Epoxy |  |
| Die Attach Pad Metallization |  | Gold |  | Gold | Gold | Silver Palladium | Gold | Silver |
| Die Attach Material |  | Gold/Silicon |  | Gold/Silicon | Gold/ Silicon | Gold | Gold/ Silicon | Silver Epoxy |
| Die Attach Temperature |  | $440^{\circ} \mathrm{C}$ Max |  | $440^{\circ} \mathrm{C}$ Max | $440^{\circ} \mathrm{C}$ Max |  | $440^{\circ} \mathrm{C}$ Max | $\begin{array}{\|l\|} \hline 200^{\circ} \mathrm{C} \\ \text { (Curing Temp) } \\ \hline \end{array}$ |
| Bond Finger Metallization |  | Gold |  | Gold | Aluminum |  | Gold or Silver |  |
| Bonding Wire |  | Aluminum/1\% Silicon |  | Aluminum/1\% S Silicon | Aluminum/1\% Silicon |  | Gold |  |
| Bonding Method |  | Ulitrasonic |  | Ulitrasonic | Ulitrasonic |  | Ball-bonding |  |
| Seal Ring Metallization |  | Gold |  | Gold | None |  | N/A |  |
| Seal Material |  | Gold/Tin | Lead/Tin/ <br> Silver | Gold/Tin | Vitreous Glass |  | N/A |  |
| Lid Material |  | Alloy 42 (Gold Plated) | Alloy 42 (Tin Plated) | Alloy 42 (Gold Plated) | 90\% Alumina (Min) |  | N/A |  |
| Seal Temperature $370^{\circ} \mathrm{C}$ Max |  |  |  | $370^{\circ} \mathrm{C}$ Max | $470^{\circ} \mathrm{C}$ Max |  | $175^{\circ} \mathrm{C}$ Max(Mold Temperature) |  |
| Seal Ambient Nitrogen |  |  |  | Nitrogen $\quad$ Air |  |  | $N / A$ |  |
| Lead Material Alloy 42 |  |  |  | N/A | Alloy 42 |  | Alloy 42 | Copper |
|  |  |  |  | N/A | Tin |  | Solder |  |

# Thermal Characterization of Packaged Devices 

APPLICATION NOTE<br>by J.L. Hayward

## DEFINITION OF THERMAL RESISTANCE

The reliability of an integrated circuit is largely dependent on the maximum temperature which the device will attain during operation. Because the stability of a semiconductor junction declines with increasing temperature, knowledge of the thermal properties of the packaged device becomes an important factor during device design. In order to increase the operating lifetime of a given device, the junction temperatures must be minimized. This demands knowledge of the thermal resistance of the completed assembly and specification of the conditions in which the device will function properly. As devices become both smaller and more complex and the requirement for high speed operation becomes more important, heat dissipation will become an ever more critical parameter.

Thermal resistance is defined as the temperature rise per unit power dissipation above some referenced condition The unit of measure is typically ${ }^{\circ} \mathrm{C} /$ watt. The relationship between junction temperature and thermal resistance is given by:

$$
\begin{equation*}
T_{j}=T_{x}+P_{d} R_{\theta J x} \tag{1}
\end{equation*}
$$

where: $T_{j}=$ junction temperature
$T_{X}=$ reference temperature
$P_{d}=$ power dissipation
$\mathrm{R}_{\theta \mathrm{Jx}}=$ thermal resistance
$X \quad=$ some defined test condition
In general, one of three conditions is defined for measurement of thermal resistance:

| $\mathrm{R}_{\theta \mathrm{JC}}$ | - thermal resistance measured with respect <br> to the temperature at some specified point |
| :--- | :--- |
| on the package surface. |  |
| $\mathrm{R}_{\theta \mathrm{JA}}$ <br> (still air)$\quad$thermal resistance measured with respect <br> to the temperature of a specified volume of <br> still air. |  |
| $\mathrm{R}_{\theta \mathrm{JA}}$ <br> (moving air) |  |
| - thermal resistance measured with respect <br> to the temperature of air moving at a <br> specified velocity. |  |

The relationship between $R_{\theta J C}$ and $R_{\theta C A}$ is

$$
R_{\theta J A}=R_{\theta J C}+R_{\theta C A}
$$

Where $R_{\theta C A}$ is a measure of the heat dissipation due to natural convection (still air) or forced convection (moving air) and the effect of heat radiation and mounting techniques. $R_{\theta J c}$ is dependent solely on material properties and package geometry; $R_{\theta J A}$ includes the influence of the surface area of the package and environmental conditions. Each of these definitions of thermal resistance is an attempt to simulate some manner in which the package device may be used.

The thermal resistance of a packaged device, however measured, is a summation of the thermal resistances of the individual components of the assembly. These in turn are functions of the thermal conductivity of the component materials and the geometry of the heat flow paths. Like
other material properties, thermal conductivity is usually temperature dependent. For alumina and silicon, two common package materials, this dependence can amount to a $30 \%$ variation in thermal conductivity over the operating temperature range of the device. The thermal resistance of a component is given by

$$
\begin{equation*}
R_{\theta}=\frac{L}{K(T) A} \tag{2}
\end{equation*}
$$

where: $L \quad=$ length of the heat flow path
A = cross sectional area of the heat flow path
$K(T)=$ thermal conductivity as a function of temperature -
and the overall thermal resistance of the assembly (discounting convective effects) will be:

$$
R_{\theta}=\Sigma R_{\theta n}=\Sigma \frac{L}{K_{n} A}
$$

But since the heat flow path through a component is influenced by the materials surrounding it, determination of $L$ and $A$ is not always straightforward.

A second factor that affects the thermal resistance of a packaged device is the power dissipation level and, more particularly, the relationship between power level and die geometry, i.e., power distribution and power density. By rearrangement of equation 1 to

$$
\begin{equation*}
P_{d}=\frac{1}{R_{\theta J x}}\left(T_{j}-T_{x}\right)=\frac{1}{\Sigma R_{\theta n}}\left(T_{j}-T_{x}\right) \tag{3}
\end{equation*}
$$

the relationship between $P_{d}$ and $T_{j}$ can be more clearly seen. Thus, to dissipate a greater quantity of heat for a given geometry, $T_{j}$ must increase and, since the individual $R_{\theta n}$ will also increase with temperature, the increase in $T_{j}$ will not be a linear function of increasing power levels.

A third factor of concern is the quality of the material interfaces. In terms of package construction, this relates specifically to the die attach bond, and for those packages having a heatsink, the heatsink attach bond. The quality of the die attach bond will most severely influence the package thermal resistance as this is the area which first impedes the transfer of heat out of the silicon die. Indeed, it seems likely that the initial thermal response of a powered device can be directly related to the quality of the die attach bond.

## EXPERIMENTAL METHOD

The technique for measurement of thermal resistance involves the identification of a temperature-sensitive parameter on the device and monitoring this parameter while the device is powered. For bipolar integrated circuits the forward voltage of the substrate isolation diode provides a
convenient parameter to measure and has the advantage of a linear dependence on temperature. MOS devices which do not have an accessible substrate diode present greater measurement difficulties and may require simulation through use of a specially designed thermal test die. Choice of the parameter to be measured must be made with some care to insure that the results of the measurement are truly representative of the thermal state of the device being investigated. Thus measurement of the substrate isolation diode which is generally diffused across the area of the die yields a weighted average of the condition of the individual junctions across the die surface. Measurement of a more local source would yield a less generalized result.

For those MOS devices for which no useful parameter is available, simulation is accomplished using the thermal test die. The basis for this test die is a 25 mil square cell containing an isolated diode and a $1 \mathrm{~K} \Omega$ resistor. The resistors are interconnected from cell to cell on the wafer before it is cut into multiple arrays of the basic unit cell. In use the device is powered via the resistors with voltage or current adjusted for the proper level and the voltage drop of the individual diodes is monitored as in the case of actual devices.

Prior to the thermal resistance test, the diode voltage/ temperature calibration must be determined. This is done by measuring the forward voltage at 1 mA current level at two different temperatures. The diode calibration factor is then:

$$
\begin{equation*}
\mathrm{K}_{\mathrm{f}}=\frac{\mathrm{T}_{2}-\mathrm{T}_{1}}{\mathrm{~V}_{2}-\mathrm{V}_{1}}=\frac{\Delta \mathrm{T}}{\Delta \mathrm{~V}} \tag{4}
\end{equation*}
$$

in units of ${ }^{\circ} \mathrm{C} / \mathrm{mV}$. For most diodes used for this test the voltage/temperature relationship is linear and these two measurement points are sufficient to determine the calibration.

The actual thermal resistance measurement has two alternating phases: measurement and power on. (See Figure 1.) The device under test is pulse powered with an ON duty cycle of $99 \%$ and a repetition rate of $<100 \mathrm{~Hz}$. During the brief OFF states the device is reverse-biased with a 1 mA current and the voltage drop is measured. The series of voltage readings are averaged over short periods and compared to the voltage reading obtained before the device was first powered ON. The thermal resistance is then computed as:

$$
\begin{equation*}
R_{\theta J x}=\frac{K_{f}\left(V_{f}-V_{i}\right)}{V_{H} I_{H}}=\frac{K_{f} \Delta V}{P_{d}} \tag{5}
\end{equation*}
$$

where: $\mathrm{K}_{\mathrm{f}}=$ calibration factor
$V_{i}=$ initial forward voltage value
$V_{f}=$ current forward voltage value
$V_{\mathrm{H}}=$ heating voltage
$I_{H}=$ heating current
The pulsing measurement is continued until the device has reached thermal equilibrium and the final value measured is the equilibrium thermal resistance of the device under test.

When the end result desired is $\mathrm{R}_{\theta \mathrm{JA}}$ (still air), the device and the test fixture (typically a standard burn-in socket) are enclosed in a box containing approximately 1 cubic foot of air. For $R_{\theta \mathrm{JC}}$ measurements the device is attached to a large metal heatsink. This insures that the reference point on the device surface is maintained at a constant temperature. Through the use of heaters attached to the metal fixture, the "case" temperature may be maintained at any specified value above ambient. The requirements for measurement of $R_{\theta J A}$ (moving air) are rather more complex. They involve the use of a small wind tunnel with capability for monitoring air pressure, temperature and velocity in the area immediately surrounding the device tested. Standardization of this last test requires much careful attention.

Figure 1. Waveforms for Pulsed Thermal Resistance Test


THERMAL CHARACTERIZATION DATA FOR CERDIPS ${ }^{1}$

| Lead <br> Count | Width <br> (Inches) | Approximate <br> $\mathbf{R}_{\theta \mathrm{JA}}$ Range <br> ( $\mathrm{C} / \mathrm{W}$ ) | Approximate <br> $\mathbf{R}_{\theta \mathrm{Jc}}$ Range <br> ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: | :---: |
| 16 | 0.300 | $66-89$ | 22 |
| 20 | 0.300 | $68-78$ | N/A |
| 24 | 0.300 | $55-57$ | $13-14$ |
| 24 | 0.600 | 49 | 11 |
| 28 | 0.600 | 29 | N/A |
| 40 | 0.600 | $36-37$ | $7-9$ |

THERMAL CHARACTERIZATION DATA FOR PLASTIC DIPs ${ }^{1}$

| Lead <br> Count | Width <br> (Inches) | Approximate <br> $\mathbf{R}_{\theta \mathrm{JAA}}$ Range <br> ( $\mathbf{C} / \mathrm{W}$ ) | Approximate <br> $\mathbf{R}_{\theta \mathrm{Jc} \text { Range }}{ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: | :---: |
| 16 | 0.300 | $110^{*}$ | $\mathrm{~N} / \mathrm{A}$ |
| 20 | 0.300 | $81-123^{*}$ | $32^{*}$ |
| 24 | 0.600 | $99-115^{*}$ | $43-57^{*}$ |
| 28 | 0.600 | $85^{*}$ | $\mathrm{~N} / \mathrm{A}$ |
| 40 | 0.600 | $62-73^{*}$ | $27-34^{*}$ |

*In 1983 AMD introduced copper-lead-frame versions of all plastic packages. The copper-lead-frame versions have better thermal characteristics than the current plastic packages measured above.

THERMAL CHARACTERIZATION DATA FOR SIDE-BRAZE AND TOP-BRAZE PACKAGES ${ }^{1}$

| Lead Count | Type | Approximate $\mathrm{R}_{\theta \mathrm{JA}}$ Range ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) | Approximate $\mathrm{R}_{\text {өJc }}$ Range ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: | :---: |
| 40 | Side-Braze | 27-35 | 6-7 |
| 48 | Side-Braze | 37 | 10 |
| 52 | Top-Braze with Heat-Spreader | 19 | 4 |
| 64 | Top-Braze with Heat-Spreader | 20 | 7 |

THERMAL CHARACTERIZATION DATA FOR LEADLESS CHIP CARRIERS (JEDEC TYPE C) ${ }^{1}$

| Lead <br> Count | Approximate $\mathbf{R}_{\text {©JA }}$ <br> Range ( ${ }^{\circ} \mathbf{C} / \mathrm{W}$ ) | Approximate $\mathbf{R}_{\theta \mathrm{JC}}$ <br> Range ( ${ }^{\circ} \mathbf{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: |
| 20 | $66-72^{*}$ | N/A |
| 28 | $69^{*}$ | N/A |
| 44 | $52-57^{*}$ | N/A |
| 52 | $44^{*}$ | N/A |

*The $\mathrm{R}_{\theta \mathrm{JA}}$ values listed for leadless chip carriers were measured with the chip carriers mounted in the appropriate burn-in sockets. This restricts convection of heat from the package and results in $\theta$ values higher than might be expected in actual use.

## THERMAL CHARACTERIZATION DATA FOR

 CERPAKS AND FLATPACKS ${ }^{1}$| Lead <br> Count | Type | Approximate <br> $\mathbf{R}_{\theta J A}$ Range <br> ($\left.{ }^{\circ} \mathrm{C} / \mathrm{W}\right)$ | Approximate <br> $\mathbf{R}_{\text {RJJ }}$ Range <br> ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: | :---: |
| 16 | Cerpak | $113-159$ | $10-17$ |
| 20 | Cerpak | 119 | N/A |
| 24 | Cerpak | 99 | 8 |
| 42 | Brazed <br> Flatpack | 63 | 8 |

Note 1. This data, while derived from actual measurements done on specific packaged devices, is only approximate and cannot be guaranteed because of the wide variation of die sizes and device power levels.

## Package Outlines





Note. Standard lead finish is tin plate or solder dip.

## HERMETIC DUAL IN-LINE PACKAGES



PO001071

D-14-1


PO001101


D-14-2





HERMETIC DUAL IN-LINE PACKAGES (Cont.)
D-52-3



FLAT PACKAGES

F-10-1


F-10-2


PO000940





## Ordering Information

All Advanced Micro Devices' products listed are stocked locally and distributed nationally by Franchised Distributors. See back of this book for the location nearest you. Please consult them for the latest price revisions. For direct factory orders, call local AMD Sales Office or Sales Representative. See the back of this book for the location nearest you.

## Proprietary Product Ordering, Package and Temperature Range Codes

The following scheme is used to identify Advanced Micro Devices' proprietary products.

## Minimum Order

The minimum direct factory order is $\$ 100.00$ for a standard product. The minimum direct factory order for burn-in product is $\$ 250.00$.


| Package Style | Temperature Range | Additional Procedures |
| :--- | :---: | :--- |
| D - Hermetic DIP | $\mathrm{C}-$ Commercial | Blank - Standard processing |
| F - Flat Package | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $\mathrm{B}-\mathrm{Burn}$-in |
| P - Molded DIP | $\mathrm{M}-$ Military |  |
| L - Leadless Chip Carrier | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| X - Dice |  |  |

## Second Source Product Ordering, Package and Temperature Range Codes

An order number and marking system identical to the original manufacturer's is used for the Advanced Micro Devices' pin-for-pin and electrically equivalent circuit.

The following example is the ordering scheme for Advanced Micro Devices' second source to Texas Instruments' products.


## Package Style

$J$ - Hermetic DIP
N - Molded DIP
W - Flat Package
X - Dice

## Temperature Range

C-Commercial
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
M - Military
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

## U.S. AND CANADIAN SALES OFFICES

## 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) 2.24-5193
Advanced Micro Devices
(Canada) Ltd.
AMD
4019 Carling \# 301
Kanata, Ottawa
Canada K2K2A3
Advanced Micro Devices
290 Elwood Davis Road
Suite 316
Liverpool, New York 13088
Tel: (315) 457-5400
MID ATLANTIC AREA

## Advanced Micro Devices

Gateways
1000 Woodbury Road
Woodbury, New York 11797
Tel: (516) 364-8020
FAX: 516-496-3756
Advanced Micro Devices
Waterview Plaza, Suite 303
2001 U.S: Route \#46
Parsippany, New Jersey 07054
Tel: (201) 299-0002
Advanced Micro Devices
110 Gibralter Road \#110
Horsham, Pennsylvania 19044
Tel: (215) 441-8210
TWX: 510-665-7572

## Advanced Micro Devices

Commerce Plaza
5100 Tilghman Street, Suite 320
Allentown, Pennsylvania 18104
Tel: (215) 398-8006
FAX: 215-398-8090

Advanced Micro Devices
205 South Avenue
Poughkeepsie, New York 12601
Tel: (914) 471-8180
TWX: 510-248-4219
Advanced Micro Devices
10 Main Street South
Southbury, Connecticut 06488
Tel: (203) 264-7800
Advanced Micro Devices
7223 Parkway Drive \#203
Dorsey, Maryland 21076
Tel: (301) 796-9310
FAX: 796-2040

## SOUTHEAST AREA

Advanced Micro Devices
4740 North State Road \#7 Suite 202
Ft. Lauderdale, Florida 33319
Tel: (305) 484-8600
Advanced Micro Devices
15351 Roosevelt Boulevard \#201
Clearwater, Florida 33520
Tel: (813) 530-9971
Advanced Micro Devices
478 Ballard Drive \#14
Melbourne, Florida 32935
Tel: (305) 254-2915
FAX: 305-254-2993
Advanced Micro Devices
701 East Altamonte Drive
Altamonte Springs, Florida 32701
Tel: (305) 834-3333
Advanced Micro Devices
15 Technology Parkway \#200
Norcross, Georgia 30092
Tel: (404) 449-7920
Advanced Micro Devices
8 Woodlawn Green, Suite 220
Woodlawn Road
Charlotte, North Carolina 28210
Tel: (704) 525-1875
Advanced Micro Devices
303 Williams Avenue Southwest
Suite 118
Huntsville, Alabama 35801
Tel: (205) 536-5505

Advanced Micro Devices
6501 Six Forks, Suite 150
Raleigh, North Carolina 27609
Tel: (919) 847-8471
MID AMERICA AREA
Advanced Micro Devices
500 Park Boulevard, Suite 940
Itasca, Illinois 60143
Tel: (312) 773-4422
Advanced Micro Devices
5726 Professional Circle \#205G
Indianapolis, Indiana 46241
Tel: (317) 244-7207
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
16985 West Blue Mound Road, Suite 201
Brookfield, Wisconsin 53005
Tel: (414) 782-7748
FAX: (414) 782-8041
NORTHWEST AREA
Advanced Micro Devices
1245 Oakmead Parkway
Suite 2900
Sunnyvale, California 94086
Tel: (408) 720-8811
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-CALIF AREA

Advanced Micro Devices
360 N. Spulveda, Suite 2075
El Segundo, California 90245
Tel: (213) 640-3210
Advanced Micro Devices
21600 Oxnard Street, Suite 675
Woodland Hills, California 91367
Tel: (213) 992-4155

## SOUTHERN CALIF AREA

Advanced Micro Devices
5000 Birch Street
Suite 6000
Newport Beach, California 92660
Tel: (714) 752-6262
Advanced Micro Devices
9619 Chesapeake Drive \#210
San Diego, California 92123
Tel: (619) 560-7030

## MOUNTAIN WEST AREA

Advanced Micro Devices
14755 Preston Road, Suite 700
Dallas, Texas 75240
Tel: (214) 934-9099
Advanced Micro Devices
8240 MoPac Expressway
Two Park North, Suite 385
Austin, Texas 78759
Tel: (512) 346-7830
Advanced Micro Devices
2925 Briar Park \#410
Houston, Texas 77042
Tel: (713) 785-9001
Advanced Micro Devices
1873 South Bellaire Street Suite 920
Denver, Colorado 80222
Tel: (303) 691-5100
Advanced Micro Devices
40 W. Baseline Road \#206
Tempe, Arizona 85283
Tel: (602) 242-4400
Advanced Micro Devices
1955 W. Grant Road \#125
Tucson, Arizona 85745
Tel: (602) 792-1200

## INTERNATIONAL SALES OFFICES

## BELGIUM

Advanced Micro Devices
Belgium S.A. - N.V.
Avenue de Tervueren, 412, bte 9
B-1150 Bruxelles
Tel: (02) 7719993
TELEX: 61028
FAX: 7623712
FRANCE
Advanced Micro Devices, S.A.
Silic 314, Immeuble Helsinki
74, rue d'Arcueil
F-94588 Rungis Cedex
Tél: (01) 687.36 .66
TELEX: 202053
FAX: 686.21 .85

## GERMANY

Advanced Micro Devices GmbH
Rosenheimer Strasse 143B
8000 Munchen 80 ,
West Germany
Tel: 498941140
TELEX: 05-23883
FAX: 406490

## GERMANY

Advanced Micro Devices GmbH
Feuerseeplatz 4/5
D-7000 Stuttgart 1
Tel: (0711) 623377
TELEX: 07-21882
FAX: 625187
Advanced Micro Devices GmbH
Zur Worth 6
D-3108 Winsen/Aller
Tel: (05143) 5362
TELEX: 925287
FAX: 5553

## HONG KONG

Advanced Micro Devices
Room 1602 World Finance Centre
South Tower
Harbour City
17 Canton Road
Tsimshatsui, Kowloon
Tel: (852) 3695377
TELEX: 50426
FAX: (852) 1234276

ITALY
Advanced Micro Devices S.r.L.
Centro Direzionale
Via Novara, 570
l-20153 Milano
Tel: (02) 3533241
TELEX: 315286
FAX: (39) 3498000

## JAPAN

Advanced Micro Devices, K.K.
Shinjuku Kokusai Building
6-6-2 Nishi-Shinjuku
Shinjuku-ku, Tokyo 160
Tel: (03) 345-8241
TELEX: 24064
FAX: 03 342-5196

## SWEDEN

Advanced Micro Devices AB
Box 7013
Rissneleden 144, 5 tr
S-172 07 Sundbyberg
Tel: (08) 7330350
TELEX: 11602
FAX: 7332285

UNITED KINGDOM
Advanced Micro Devices (U.K.) Ltd.
A.M.D. House,

Goldsworth Road,
Woking,
Surrey GU21 1JT
Tel: Woking (04862) 22121
TELEX: 859103
FAX: 22179
Advanced Micro Devices (U.K.) Ltd.
The Genesis Centre
Garrett Field
Science Park South
Birchwood
Warrington WA3 7BH
Tel: Warrington (0925) 828008
TELEX: 628524
FAX: 827693

## The International Standard of

 Qualityguarantees the AQL on all electrical parameters. AC and DC, over the entire operating range.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 | 901 Thompson Place | (408) 732-2400 | (C) 1984 Advanced Micro Devices, Inc. |
| :--- | :--- | :--- | :--- |
| MICRO | P.O. BOX 3453 | TWX: $910-339-9280$ | Printed in U.S.A. |
| DEVICES | Sunnyvale, California 94088 | TELEX: 34-6306 |  |
|  |  |  | TOLLFREE: $(800) 538-8450$ |

TWX: 910-339-9280
TOLL FREE: (800) 538-8450

C 1984 Advanced Micro Devices, Inc Printed in U.S.A.

DEVICES

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


[^0]:    *This information was provided by Microtec. AMD is not associated with Microtec,
    and does not guarentee their products.

[^1]:    Notes: INV = Invalid operation flag
    OVF = Overflow flag
    UNF = Underflow flag
    INE $=$ Inexact flag
    ZER = Zero flag
    NAN = NAN flag
    L $=$ LOW
    $\mathrm{H}=\mathrm{HIGH}$

    - $\quad=$ State of flag
    depends on the
    input operands
    and the operation performed

[^2]:    2. At air velocity of _ linear feet per minute.
[^3]:    *AC performance over the operating temperature range is guaranteed by testing defined in Group $A$, Subgroup 9.

[^4]:    + = Plus; - = Minus; v=OR; ^=AND; $\nabla=$ EX-OR

[^5]:    *Switching Characteristics' performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

[^6]:    Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ ambient and maximum loading.
    2. For conditions shown as MIN or MAX, use the appropriate value specified under Operating Ranges for the applicable device type.
    3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second.

[^7]:    Note: $t_{\text {pwL }}$ is the Clock LOW Time. Both Set-up times must be met.

[^8]:    Am2915A
    
    $\stackrel{\text { B Screening Option }}{ }$
    Blank - Standard processing B - Burn-in
    Temperature (See Operating Range)
    C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
    Package
    D-24-pin CERDIP
    F-24-pin flatpak
    P - 24-pin plastic DIP
    $X$ - Dice
    Device type
    Quad 3-state Bus Transceiver

[^9]:    Am2916A
    

    ## $L_{\text {Screening Option }}$

    Blank - Standard processing B - Burn-in
    Temperature (See Operating Range) C - Commercial $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

    - Package

    D-24-pin CERDIP
    F-24-pin flatpak P-24-pin plastic DIP $X$-Dice

    Device type
    Quad 3-state Bus Transceiver

[^10]:    ```
    Am2917A
    |
    ```


    ## Device type

    ```
    Quad 3-state Bus Transceiver
    Am2917A
    ```

    

    ```
    \(\stackrel{B}{L}\) Screening Option
    Blank - Standard processing B - Burn-in
    Temperature (See Operating Range)
    C - Commercial \(\left(0^{\circ} \mathrm{C}\right.\) to \(\left.+70^{\circ} \mathrm{C}\right)\)
    M - Military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) )
    Package
    D-20-pin CERDIP
    F-20-pin flatpak
    P - 20-pin plastic DIP X - Dice
    ```

[^11]:    Am2946/2947
    

    - Screening Option

    Blank - Standard processing B - Burn-in
    Temperature (See Operating Range)
    C - Commercial ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
    M - Military $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
    Package
    D-20-pin CERDIP
    X- Dice
    Device type
    Bidirectional Bus Transceivers

[^12]:    Parity $=\mathrm{F}_{3} \nabla \mathrm{~F}_{2} \nabla \mathrm{~F}_{1} \nabla \mathrm{~F}_{0} \mathrm{SIO}_{3}$
    $\nabla=$ Exclusive OR
    $L=L O W$
    $\mathrm{H}=\mathrm{HIGH}$
    $\mathrm{Hi}-\mathrm{Z}=\mathrm{High}$ Impedance

[^13]:    U = Update
    NC = No Change
    $0=$ Reset
    $1=$ Set
    $i=0$ to 15 when not specified

[^14]:    Note: Please refer to Guidelines for Testing Am2900 Family Devices in Section 13 of this data book.

[^15]:    ${ }^{*}$ Multibus is a registered trademark of Intel Corporation.

[^16]:    *Enable is used as strobe for the latch in sampled operation.

[^17]:    *For Am29853/54 replace CLK with EN.

[^18]:    Am25LS09 used to store a word from either data bus A or data bus B.

[^19]:    *AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

[^20]:    3-State Priority Encoder

[^21]:    *AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

[^22]:    *AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

[^23]:    *AC performance over the operating temperature range is guaranteed by testing defined in Group A, Subgroup 9.

[^24]:    *PAL is a registered trademark of Monolithic Memories, Inc.
    IMOX is a trademark of Advanced Micro Devices, Inc.

