## Signetics

## PLHS5O1 Application Notes <br> Vol. 2

## Designing <br> With PML

$\checkmark$ Micro Channel
$\checkmark$ NuBus
$\checkmark$ VMEBUS
/ Bus Parity
$\checkmark$ Flip-Flop Merging

Signetics reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Signetics assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified. Applications that are described herein for any of these products are for illustrative purposes only. Signetics makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.
LIFE SUPPORT APPLICATIONS
Signetics Products are not designed for use in life support appliances, devices, or systems where malfunction of a Signetics Product can reasonably be expected to result in a personal injury. Signetics customers using or selling Signetics' Products for use in such applications do so at their own risk and agree to fully indemnify Signetics for any damages resulting from such improper use or sale.

Signetics registers eligible circuits under the Semiconductor Chip Protection Act.

© Copyright 1989 Signetics Company a division of North American Philips Corporation

## PLHS501

## APPLICATION NOTES

Vol 2

## IMPORTANT NOTICE

Signetics reserves the right to make changes without notice, in the products including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Signetics assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products or processes, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified. Applications that are described herein for any of these products are for illustrative purposes only. Signetics makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

## LIFE SUPPORT POLICY

SIGNETICS PRODUCTS ARE NOT FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT EXPRESS WRITTEN APPROVAL OF AN OFFICER OF SIGNETICS CORPORATION. As used herein:
o Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
o A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

PAL is a registered trademark of AMD/MMI
Micro Channel is a trademark of IBM Corporation
NuBus is a trademark of Texas Instruments, Inc.
Macintosh is a registered trademark of Apple Computer, Inc.

## PLHS501 Application Notes Vol 2.

## TABLE OF CONTENTS

Section 1
Introduction ..... 1-1
Section 2
PLHS501 Review ..... 2-1
Section 3
Flip-Flop Basics ..... 3-1
3.1 Notation ..... 3-1
3.2 Flip-Flop Merging ..... 3-7
Section 4
VME Bus Examples ..... 4-1
4.1 Omnibyte VSBC20 Mailbox Interrupt Structure ..... 4-1
4.2 VME Bus EPROM Interface ..... 4-9

## TABLE OF CONTENTS [continued]

Section 5
Micro Channel Interface ..... 5-1
Section 6
NuBus Interface ..... 6-1
Section 7
Nuggets ..... 7-1
7.1 Data Bus Parity ..... 7-1
7.2 Data Bus Operations ..... 7-10

## LIST OF FIGURES

2-1. PLHS501 Logic Diagram ..... 2-2
2-2. An Internal NAND Logic Equivalent ..... 2-3
3-1. Single D-Latch (Enable Active-High) ..... 3-3
3-2. D Flip-Flop (Negative Edge-Triggered) ..... 3-4
3-3. D Flip-Flop With Reset ..... 3-5
3-4. J-K Flip-Flop With Set and Reset ..... 3-6
3-5. Flip-Flop Merging ..... 3-8
4-1. Portion of Omnibyte VSBC20 Highlighting PLHS501 Usage ..... 4-4
4-2. PLHS501 Pinlist for VSBC20 Interrupt Structure ..... 4-5
4-3. VSCBC20IS .BEE File ..... 4-8
4-4. VME - EPROM Interface ..... 4-10
4-5. Edge-Triggered D Flip-Flop (DFFS) ..... 4-11
4-6. 4-Bit Shifter (7495) ..... 4-11
4-7. VMEEXP and FULLEXP ..... 4-12
4-8. VMEEXP PLHS501 Pinlist ..... 4-13
4-9. VMEEXP PLHS501 .BEE File ..... 4-15
4-10. FULLEXP Pinlist ..... 4-16
4-11. FULLEXP PLHS501 .BEE File ..... 4-18
5-1. Block Diagram of Basic POS Implementation in PLHS501 ..... 5-3
5-2. Latches used in MCA Interface ..... 5-4
5-3. PLHS501 MCPOSREG Pinlist ..... 5-5
5-4. PLHS501 MCPOSREG .BEE File ..... 5-8
6-1. Simplified NuBus Diagram ..... 6-2
6-2. Adapter Card Schematic ..... 6-3
6-3. Timing Diagram ..... 6-4
6-4. Decoding and Latch Circuitry ..... 6-5
6-5. Internal Flip-Flops and Latches ..... 6-6
6-6. AMAZE Listing ..... 6-9

## LIST OF FIGURES [continued]

7-1. Complementary Input Levels ..... 7-3
7-2. Four Variable EX-ORs ..... 7-4
7-3. 16 Input Even Parity Generation ..... 7-5
7-4. PARITET PLHS501 Pinlist ..... 7-6
7-5. PARITET PLHS501 .BEE File ..... 7-7
7-6. PLHS501 Pinlist for 16-Bit Comparator ..... 7-8
7-7. Compare PLHS501 .BEE File ..... 7-10
7-8. Basic Cell Structure ..... 7-11

## PLHS501 Application Notes Vol 2.

## LIST OF TABLES

2-1. PLHS501 Gate Count Equivalents ..... 2-4
3-1. Internal Fold Back NAND Gate ..... 3-2
$7-1$. Even Parity Functions ..... 7-2
7-2. Data Operations ..... 7-10

## 1. Introduction

This document is written assuming the reader is familiar with Signetics PLHS501. As well, we shall assume familiarity with the predecessor document "Designing with PML" and some exposure to Signetics AMAZE software. The goal of this document (i.e., Part Two) is to expand on the original ideas and present some cookbook solutions to some useful design problems. Part Two also reflects nearly a year of experience through the multitude of design-ins achieved with the PLHS501. In fact, several of the design solutions presented here were contributions from our customers through our field applications organization. Designs we have encountered fell into a couple of interesting categories. First, many users view the part as a natural step in eliminating extraneous board "glue" (10 or more chips) or eliminating multiple programmable array logic devices (usually 3 to 5 units). Others recognized the PLHS501 capabilities of extremely wide logic functions and still others chose to invent their own solutions to standard bus interfaces. Commercially available bus interfaces often "miss the mark" and creative designers wish to implement exactly the functions they need in a concise, effective manner. To date, we have seen PLHS501 interfaces to the VME Bus II, FAST Bus, NuBus, GPIB and the IBM Micro Channel for the PS/2 system.

Before presenting these solutions however, it is appropriate to review the PML basics and expand on a number of issues which have been found to be important but which were previously treated lightly.

## 2. PLHS501 Review

The PLHS501 is a $52-$ pin, bipolar programmable logic device with a very powerful architecture. Unlike classic and/or based architectures, its basic building block is the NAND function which is configured in a foldback programming array. By cascading successive NAND functions through the array, both combinational and sequential structures may be obtained. The PLHS501 has 24 dedicated inputs, 16 outputs (with several varieties) and eight bidirectional pins. The internal NANDs may be cascaded to any depth needed, to achieve effective solutions using logic structures such as muxes, decoders and flip-flops without going off chip and wasting I/O pins to achieve cascading. To use the PLHS501 effectively, the designer should attempt to fold in function and remain within the chip as much as possible before exiting.

Figure 2-1 shows the PLHS501 architecture and illustrates several of the timing paths for internal signals to give the designer a feeling for maximum time delay within the part. These numbers are worst case maximums, regardless of switching directions, so the user may be assured that in general, the PLHS501 will be faster than these numbers.

The shorthand notation of Figure 2-1 hides something which many designers have been impressed with in the PLHS501, the wide input NAND gates. Figure 2-2 shows just how wide the internal NANDs are, from a logical viewpoint. Each NAND can accommodate up to 32 external inputs and 72 internal inputs. Hence, the part is ideal for wide decoding of 32 -bit address and data busses. With 72 copies of the wide NAND, the PLHS501 is often compared against low end gate arrays. While flattering, this gives no usable method to determine the degree to which functions can be fit into the device. As a rule of thumb, the PLHS501 can accommodate three or more PLA devices and usually four to five PAL ${ }^{\circledR}$ devices.

For any particular design, the user should refer to Table 2-1 and evaluate his design incrementally, tallying against a 72 gate budget. This is a ballpark estimation against the NAND capacity of the core of the part. The clever designer will find additional function by correctly exploiting the output logic.


Figure 2-1 PLHS501 Logic Diagram


Figure 2-2 An Internal NAND Logic Equivalent


TABLE 2-1 PLHS501 Gate Count Equivalents

## 3. Flip-Flop Basics

Most designers view flip-flops as black boxes with data inputs and outputs as well as additional control inputs. Some flip-flops are designed as primitive transistor structures, but in the past, gate array designers used their elementary building block, the NAND gate, to make flip-flops. Because the PLHS501 is also largely structured from NANDs, we can draw upon years of well known NAND-based flip-flop designs to readily implement flip-flops within the PLHS501.

Figure 3-1, 3-2, 3-3 and 3-4 give single sheet summaries of several flip-flop configurations. It should be noted that the transparent latch is recommended for data capturing, but not for state machines due to potential glitching. The edge triggered D -type is a convenient building block. Although external gates are saved with the $\mathrm{J}-\mathrm{K}$ structure, it is at the expense of additional NANDs within the $\mathrm{J}-\mathrm{K}$ flip-flop itself.

### 3.1 Notation

The delay of a NAND gate is most often designated as $t_{\text {PLH }}$ or $t_{\text {PHL }}$, indicating that the gate output makes a high to low ( $\mathrm{t}_{\mathrm{PHL}}$ ) or low to high ( $\mathrm{t}_{\mathrm{PLH}}$ ) transition. For the flip-flops transition, the high-to-low ID is D0 and the low-to-high ID is D1. This also holds true for structures fully contained within the foldback core, because input and output time delays will differ and change the performance. Knowing the basic concepts, the designer can expand these structures to include I/O pins and generate flip-flops wrapped around the part - but, he must derate his parameters accordingly to reflect the slower paths.

Because it will be lengthy to explain all of the flip-flop configurations given, we will show only one in some detail. The interested reader can verify the rest by manual analysis or by digital simulation. The following table gives the typical and worst case values for an internal foldback NAND gate.


| SYMBOL | PARAMETER |  | LIMITS |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | To | From | Min | Max |  |
|  | (Output) | (Input) |  |  |  |
| tPHL |  |  | 5.5 | 6.5 |  |
| tPLH |  | ANY | 6.5 | 8.0 | ns |

TABLE 3-1 Internal Fold Back NAND Gate
The single D -latch with enable Active-High can be described in terms of the propagation delay formula given in Figure 3-1. For instance, the first propagation is for D to Q where the Q output transitions from High-to-Low (i.e., $\mathrm{t}_{\text {PDO }}$ ). To do this, assume Q is High so the /Q term is Low. To switch the state, /Q must be flipped first. Hence, the logic variable enters G2, then passes though G7, G4 and finally G3. This presents four transitions, two from Low-to-High (G2 \& G4 outputs) and two from High-to-Low (G1 \& G3 outputs). Hence, the formula reflects $2(\mathrm{~d} 1 \& \mathrm{~d} 0)$ which, using the previous table, gives $2(8+6.5)=29 \mathrm{nsec}$.

This is a worst case value, using typicals will give a value of $2(5.5+6.5)=24 \mathrm{nsec}$.

Switching in the other direction is a little different. Assuming $\mathrm{t}_{\mathrm{PD1}}$ goes from $\mathrm{Q}=0$ to $\mathrm{Q}=1$, the / Q signal must be initially 1 . Hence, G 3 is armed for immediate transition. Hence, the time delay is simply traversing G2 and G3. One of them will go High-to-Low (G2) and the other Low-to-High (G3). The formula reflects the sum of the two transitions: $t_{P D 1}=d 1+d 0$. From the table, this is $14.5 n s e c$ (worst case) or 12 nsec (typical). The rest of the formula must be similarly analyzed, but the method is straightforward.

LOAIC SYMBOL


PROPAGATION DELAY FORMULAS:

| FROM | T0 | FORMULAS |
| :---: | :---: | :---: |
| 0 | 0 | TPDO $=d 1+d 0 \times 2$ |
|  |  | $t P D 1=d 1+d 0$ |
| D | $\bar{\square}$ | tPDO $=d 1+2 \times d 0$ |
|  |  | $t P D 1=2 \times d 1+d 0$ |
| E | 0 | tPDO $=d 1+2 \times d 0$ |
|  |  | $t P D 1=d 1+d 0$ |
| E | $\overline{0}$ | tPDO $=d 1+2 \times d 0$ |
|  |  | $t P D 1=d 1+d 0$ |
| SETUP TIME <br> HOLD TIME <br> ENABLE PULSE |  | $=d 1+2 X d 0$ |
|  |  | $=0$ |
|  |  | $=E$ TO Q tPDO |

TIMINQ WAVEFORMS:


Notes:
Spikes can occur on $\bar{Q}$ during the propegetion delay of $E$ to $\overline{0}$.

NAND CATE DIAGRAM


FUNCTION (TRUTH) TABLE

| Opereting mode | $E$ | $D$ | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| Date enebled | 1 | 0 | 0 | 1 |
|  | 1 | 1 | 1 | 0 |
| Data latched | 0 | $x$ | 0 | 0 |
|  | $0-1$ | $n-1$ |  |  |

Notes:

1. When input Enable (E) is High, dota enters tha latch ot "D" and appears at outputs "O" and "T": the "Q" output follows the data as long as $E$ is High. Dne setup time before the High-to-Low trensition of $E$, $D$ is stored in the latch; the latched outputs remain stable os long os E is Low.
2. $\mathrm{O}_{n-1}=$ state before High-to-Low transition of $E$.
3. $X=$ don't cara.

PROPACATION DELAY8:

| PARAMETER | FROM | T0 | DELAY in ns |
| :---: | :---: | :---: | :---: |
|  | 0 | 0 |  |
|  | D | ए |  |
|  | E | 0 |  |
|  | E | ए |  |
|  | D | 0 |  |
|  | D | ए |  |
|  | E | 0 |  |
|  | E | ए |  |
| D (SETUP TIME) <br> D (hold Time) ENABLE PULSE WIDTH |  |  |  |

Figure 3-1 Single D-Latch (Enable Active-High)

LOCIC SYMBOL


PROPACATION DELAY FORMLLAS:

| FROM | то | FORMULAS |
| :---: | :---: | :---: |
| C | 0 | tPD $=2 \times d 1+d 0$ |
|  |  | tPDO $=2 \times d 1+2 \times d 0$ |
| C | $\bar{\square}$ | tPD1 $=2 \times d 1+d 0$ |
|  |  | tPDO $=2(\mathrm{~d} 1+\mathrm{d} \mathrm{d})$ |
| o(setup time) <br> o (hold Time) <br> CLOCK PULSE WIDTH |  | = ISL2 do |
|  |  | $=\mathrm{ISL1} 1 \mathrm{~d} 1+\mathrm{do}$ |
|  |  | $=2 \times d 0+d 1$ |

TIMING WAVEFORAS:


Notes:
Splkes can occur on $\overline{\mathrm{a}}$ during the propagotion deloy of $E$ to $\bar{Q}$.

## NAND CATE DIAGRAM



FUNCTION (TRUTH) TABLE

| $c$ | 0 | 0 <br> $n+1$ | 0 <br> $n+1$ |
| :---: | :---: | :---: | :---: |
| $\square$ | 0 | 0 | 1 |
| $\square$ | 1 | 1 | 0 |

Notes:

1. Data is transferred to the outputs on the negativegoing edge of the clock.
2. $0 n+1=$ stote ofter High-to-Low transition of $C$.

PROPACATION DELAY8:

| PRRAMETER | FROM | T0 | DELAY in ns |
| :---: | :---: | :---: | :---: |
|  | C | 0 |  |
|  | C | 0 |  |
| tPD1 | C | 0 |  |
|  | C | 0 |  |
| D(SETUP TIME) <br> D(HOLD TIME) <br> CLOCK WIDTH | ns Min <br> ne Min <br> ns Min |  |  |

Figure 3-2 D Flip-Flop (Negative Edge-Triggered)


NAND CATE DIAGRAM

PROPACATION DELAY FORMULAS:

| FROM | TO | FORMULAS |
| :---: | :---: | :---: |
| C | 0 | tPD1 $=2 d 1+d 0$ |
|  |  | tPDE $=2(d)+d \theta)$ |
| C | $\overline{0}$ | $t P D 1=2 d 1+d 0$ |
|  |  | $t P D 1=2(d)+d Q)$ |
| RR | $\begin{aligned} & 0 \\ & \overline{\mathrm{Q}} \end{aligned}$ | $t P D 0=d 1+d 0$ |
|  |  | $\mathrm{tPD1}=\mathrm{dl}$ |
| D(SETUP TIME) |  | $=d 0$ |
| D (HOLD TIME) |  | $=d 1+d 0$ |
| $\begin{gathered} \mathrm{CL} \text { WIDTH } \\ (\mathrm{HIGH}) \\ \hline \end{gathered}$ |  | $=d 1+2 d 0$ |
| $\begin{gathered} \text { AESET WIDTH } \\ (L O W) \end{gathered}$ |  | $R \rightarrow 0$ |

FUNCTION (TRUTH) TABLE


| $C$ | $D$ | 0 <br> $n+1$ | 0 <br> $n+1$ |
| :---: | :---: | :---: | :---: |
|  | 0 | 0 | 1 |
|  | 1 | 1 | 0 |
|  | 0 | 0 | 1 |
|  | 1 | 1 | 0 |

Notes:

1. Data is transferred to the outputs on the negotive going edge of the clock: reset "R" (active-low) is osynchronous and independent of
2. $\mathrm{On}_{\mathrm{n}} \mathrm{l}=$ state ofter High-to-Low transition of $C$.
3. $X=$ don't care

## TIMINO WAVEFORMS:



PROPACATION DELAYs:

| PARAMETER | FROM | T0 | DELAY |
| :---: | :---: | :---: | :---: |
| tPD1 | $\begin{aligned} & \mathrm{C} \\ & \mathrm{C} \\ & \mathrm{~A} \end{aligned}$ | $\frac{0}{0}$ |  |
|  | C C R | $\frac{\overline{0}}{\frac{0}{0}}$ |  |
| DISETUP TIME) | ns Min |  |  |
| D (HOLD TIME) | ns Min |  |  |
| $\begin{aligned} & \text { MINTMUM } \\ & \text { CLOCKWIOTH } \end{aligned}$ | ns |  |  |
| $\begin{aligned} & \text { MINIMUM R } \\ & \text { WIDTH } \end{aligned}$ | ns |  |  |

Figure 3-3 D Flip-Flop With Reset

LOCTC SYMBOL


PROPACATION DELAY FORMLLASE

| FROM | to | FORMULAS |
| :---: | :---: | :---: |
| c | $0, \overline{0}$ | tPDO $=3 \mathrm{dO}+2 \mathrm{di}$ |
|  |  | tPD1 $=3(d 1+d 0)$ |
| S | 0 | tPD1 $=\mathrm{d} 1$ |
| R | 0 | tPD1 $=\mathrm{dl}$ |
| S | 0 | $\begin{aligned} & \text { IFC }=0 \\ & \text { tPDO }=d 1+d 0 \end{aligned}$ |
| R |  | $\begin{aligned} & \text { IfC }=1 \\ & \text { tPDO }=2(d)+d \theta \end{aligned}$ |
| J-K SETUP time |  | 0 |
| J-K hold time |  | = do |
| $\begin{aligned} & \text { PULSE HIDTH } \\ & \text { C (MIN) } \end{aligned}$ |  | $=d 1+d 0$ |
| S.R (MIN) |  | $=(d 1+d 0)$ |

timana waverormse


NAND CATE DLACRNM


FUNCTION (TRUTH) TABLE

| C | J | K | 5 | R | $\stackrel{0}{n+1}$ | $\overbrace{n}^{6}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 75 | 0 | 0 | 1 | 1 | Qn | वn |
| $\square$ | 1 | 0 | 1 | 1 | 1 | 0 |
| 15 | 0 | 1 | 1 | 1 | 0 | 1 |
| - | 1 | 1 | 1 | 1 | 0 | $\square$ |
| C | 」 | K | 5 | R | 0 | $\square$ |
| X | X | X | 1 | 0 | 0 | 1 |
| X | X | X | 0 | 1 | 1 | 0 |

Nates:

1. Moster/slove dato is pulse-trig when the clock (C) goes Low; the ontered dotals transferred to the outputs on the positive going edge inputs are osynchronous, independent signols ond, when either is active-
low, the J-K and C inputs are
overridden.
2. $\mathrm{On}_{\mathrm{n}} 1=$ next state of Q .
3. $X=d^{\prime}$ ' $t$ care

PROPACATION DELAYE

| PARAMETER | FROM | T0 | OELAY |
| :---: | :---: | :---: | :---: |
| tPDO | $\begin{aligned} & \mathrm{C} \\ & \mathrm{~S} \\ & \mathrm{~S} \\ & \mathrm{R} \\ & \mathrm{R} \end{aligned}$ | $\begin{aligned} & \frac{080}{0} \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ |  |
| ${ }^{\text {tPD1 }}$ | C S R | 080 0 0 |  |
| J-K SETUP TIME | 0 |  |  |
| J-K hold time | 2 Min |  |  |
| TMINIMUAPTULSE | 20 |  |  |
| MINIMUM PULSE <br> WIDTH SAP (LOW) | 16 |  |  |

Figure 3-4 J-K Flip-Flop With Set and Reset

## PLHS501 Application Notes Vol 2.

### 3.2 Flip-Flop Merging

Figure 3-5(a) shows the positive edge triggered D FF structure. By putting a 2-level AND/OR structure in front of the data input, the D FF can be steered from state to state.

Figure 3-5(b) shows such an input structure realized from a 2 -level NAND gate section.

Figure 3-5(c) shows this "AND-OR" structure rolled inside of the flip-flop. The gating was merged with the flip-flop inwards to make a faster, composite function. Whereas this may appear as a trick to the uninitiated, this degree of flexibility allowed gate array designers to merge a multitude of logic into a fixed foundation. For highest efficiency, similar thinking allows the designer to break up decoders and multiplexors into their building blocks and generate only the pieces needed.


Figure 3-5 Flip-Flop Merging

## 4. VME Bus Examples

### 4.1 Omnibyte VSBC20 Mailbox Interrupt Structure

One of the more popular uses for the PLHS501 is interfacing with 32-bit microprocessors. This section illustrates some of the ways the part has been used with the popular VME Bus. The Omnibyte Corporation manufactures many VME Bus products (as well as others) and was kind enough to release a portion of their VSBC20 board design as an example of using the PLHS501 in a very flexible, user configurable interrupt generation device. The VSBC20 employs two PLHS501 parts, as shown in Figure 4-1. One device is used largely as an address decoder, the other, which is the object of this Section, is the configurable interrupt generator. The target microprocessor here is a 25 MHz 68020 and the application is interrupt generation. The explanation is in the words of Glenn Case, the designer:
"Following the design philosophy of giving the user as much flexibility as possible, the local interrupt structure of the VSBC20 is implemented in a PLD. It is impossible to "optimize" the assignment of the local interrupts to the interrupt levels of the processor since they are application specific. One system may want the Serial I/O and Parallel I/O to have higher levels than the Omnimodule Interrupts while yet another, using a SCSI Omnimodule, may want it to have higher level interrupts. Arbitrarily assigning and hard wiring these levels would unnecessarily constrain the use of the VSBC20 for any given application. By using the Signetics PLHS501, the entire logic to implement the interrupt structure fits into one PLD. Furthermore, the AMAZE software to program the part is available free from Signetics. The PLHS501 can be reprogrammed until the unused feedback gates are all used. So, the user can get the software free and change the interrupt levels a couple of times before having to replace the PLHS501 with a new part. This appendix describes how the PLHS501 is used and how to change the interrupt levels.

There are a total of 17 possible interrupt sources to the processor on the VSBC20. There are up to seven possible VMEbus interrupts, nine possible local interrupts, and a Front Panel Non-Maskable interrupt. The local interrupts include: ACFAIL*, SYSFAIL*, parity error, mailbox interrupt, two Omnimodule interrupts, 24 bit timer interrupt, Parallel I/O, and Serial I/O interrupts. Although ACFAIL*, SYSFAIL* and mailbox interrupts are generated by VMEbus, they are referred to as local interrupts because they are acknowledged locally. That is, no VMEbus IACK cycle takes place. The local interrupts are latched during an IACK cycle to "freeze" the state of the interrupts. This allows the correct acknowledgment of the interrupts. The ACFAIL*, SYSFAIL* and Front Panel Non-Maskable Interrupt are assigned to Level 7. The Front Panel NMI has the highest priority followed by ACFAIL*, parity error, and SYSFAIL*. The front Panel interrupt is acknowledged by an autovector while the other three generate a vector that is encoded as described in the Error Interrupt Vector CSR. The local interrupts for the mailbox interrupt, Omnimodule Interrupt 0, Omnimodule Interrupt 1, 24 bit timer interrupt, Parallel I/O Interrupt, and Serial I/O Interrupt have been assigned to levels 6-1 respectively. These interrupts are intended to be assigned by the user to the level best suited for the user's application. The mailbox interrupt uses the auto vector while the others provide interrupt acknowledge vectors. However, these may also be changed to generate autovectors. For example, if a unique Omnimodule is designed by the user and there is not enough room to provide an interrupt vector on the module, the PLD can be changed to issue an autovector instead of generating an IACK cycle to the Ominmodule. It is also possible to have two interrupts share the same level, although this seems unnecessary, since there are enough available interrupt levels.

## PLHS501 Application Notes Vol 2.

The following examples illustrate how easy it is to change the local interrupt levels."

## Example 1:

Put the P10 interrupt in level 4 and the Omnimodule 0 interring on level 2.

```
LIRQ4 = /LIRQPIO;
LIRQ2 = /LIRQ0OM;
IACKOOM = /(/LIRQOM*/A3*A2*/Al*//IACK*/BAS);
IACKPIIO = /(/LIRQPIO*A3*/A2*/AI*/IACK*/BAS);
    |>
<-| equations to
<-1
```


## Example 2:

Make both the Omnimodule Interrupt Autovectored instead of bus-vectored. (LITRQ0OM uses level 4 and LIRQIOM uses level 5.

```
AUTOVECTOR = [/FPNMIRQ*A3*A2*Al*/IACK*/BAS*RESET]
    + [/LIRQMBOX*A2*A2*/Al*/IACK*/BAS*RESET]
    + [/LIRQ0OM*A3*/A2*/Al*/IACK*/BAS*RESET] <-- ADD
    + [/LIRQIOM*A3*/A2*Al*/IACK*/BAS*RESET] <-- ADD
    + [AUTOVECTOR* /BAS*RESET];
```

IACKIOM $=/(0)$; $<--\quad$ change
IACKOOM $=/(0)$; $<-$ equation


INTERRUPT CONTROLLER

Figure 4-1 Portion of Omnibyte VSBC20 Highlighting PLHS501 Usage

File Name : vsbc20is
Date : 9/13/1988
Time : 9:4:2
\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\# P I N L I S T \#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#

Left
LABEL ** FNC **PIN
VCC ** +5V ** 8-
VIRQ1 ** I ** 9-
VIRQ2 ** I ** 10-
VIRQ3 ** I ** ll-
VIRQ4 ** I ** 12-
VIRQ5 $\quad$ ** I $\quad$ ** $13-$
VIRQ6 $\quad$ ** I $\quad$ ** $14-$
BRDFAIL ** I ** 15-
RESET ** I ** 16-
FPNMIIN ** I ** 17-
VIRQ7 ** I ** 18-

| N/C | ** | O | ** | $19-1$ |
| :--- | :--- | :--- | :--- | :--- |
| GND | ** | OV | ** | $20-1$ |

$$
\begin{aligned}
& \text { Right } \\
& \text { PIN** FNC ** LABEL } \\
& \text { |-46 ** +5V **VCC } \\
& \left\lvert\, \begin{array}{lll}
-45 & * * & I \\
-44 & * * & \text { A } 1 \\
-4 * A 2
\end{array}\right. \\
& -43 \text { ** I **A3 } \\
& \text {-42 ** I **BAS } \\
& \text { H } \quad-41 \text { ** I } \quad \text { **IACK } \\
& \text { S } \quad-40 * * / 0 \quad * * \text { IACKF } \\
& 5 \quad-39 * * / 0 \quad * * N / C \\
& 0 \quad \mid-38 \quad * * / 0 \quad * * N / C \\
& 1 \quad \mid-37 \quad * * / 0 \quad * * N / C \\
& \text { - }-36 \text { ** O **IPL2 } \\
& \left\lvert\, \begin{array}{lll}
-35 & \text { ** } 0 & \text { **IPLI } \\
-34 & \text { ** } & \text { OV } \\
\text { **GND }
\end{array}\right.
\end{aligned}
$$

Bottom
LABEL ** FNC **PIN N/C ** O ** 21DSACKO ** O ** 22N/C ** O ** 23-1
IACKOOM **/O ** 24- IACKIOM ** $/ 0$ ** 25IACKTMR **/0 ** 26IACKPIO ** /O ** 27-
D24 ** O ** 28-

| D25 | ** | 0 | ** | $29-1$ |
| :--- | :--- | :--- | :--- | :--- |
| IACKSIO | ** | 0 | t* | $30-1$ |

$$
\begin{array}{lllll|}
\text { OFFBRDIACK } & \text { ** } & 0 & \text { ** } & 31-1 \\
\text { AUTOVEC } & \text { } * & 0 & * * & 32-1
\end{array}
$$

$$
\text { IPL0 } \quad \text { ** } 0 \quad \text { ** } 33-1
$$

Top

|  | PIN** FNC | ** LABEL |
| :---: | :---: | :---: |
|  | - 7 ** I | **LIRQSIO |
|  | - 6 ** I | **LIRQPIO |
|  | - 5 ** I | **LIRQTMR |
| P | - 4 ** I | **LIRQ0OM |
| L | - 3 ** I | **LIRQ1OM |
| H | - 2 ** I | **LIRQMBX |
| S | - 1 ** I | **LIRQPE |
| 5 | -52 ** I | **LACFAIL |
| 0 | -51 ** I | **LSYSFAIL |
| 1 | -50 ** I | **N/C |
|  | -49 ** I | **ACFM |
|  | -48 ** I | **SYSFM |
|  | -47 ** I | **PERRM |

Figure 4-2 PLHS501 Pinlist for VSBC20 Interrupt Structure

## PLHS501 Application Notes Vol 2.

```
@DEVICE TYPE
PLHS501
@DRAWING ll55
@REVISION A
@DATE 9-9-88
@SYMBOL
@COMPANY OMNIBYTE CORP.
@NAME GLENN CASE
@DESCRIPTION VSBC2O INTERRUPT STRUCTURE PLD
@INTERNAL NODE
LIRQ7 ALLIRQ7 AHIACKF AHFPNMIRQ AUTOVECTOR FPNMIRQ
@COMMON PRODUCT TERM
LIRQ6 = /LIRQMBX; "LIRQ6 goes high when LIRQMBX goes low"
LIRQ5 = /LIRQlOM;
LIRQ4 = /LIRQ0OM;
LIRQ3 = /LIRQTMR;
LIRQ2 = /LIRQPIO;
LIRQl = /LIRQSIO;
@I/O DIRECTION
DB4 = 0;
DB5 = 0;
DB6 = 0;
DB7 = 0;
XEO = /IACKF;
XE1 = l;
XE2 = l;
XE3 = l;
OEl = /IACKF;
OE2 = l;
OE3 = l;
@I/O STEERING
@LOGIC EQUATION
```



```
ALLIRQ7 = /[/[/LACFAIL * ACFM]
    * /[/LSYSFAIL * SYSFM * BRDFAIL]
    * /[/LIRQPE * PERRM]];
AHFPNMIRQ = [/FPNMIIN */IACK * RESET]
    + [AHFPNMIRQ */IACK * RESET]
```

```
    + [AHFPNMIRQ * IACK * BAS * RESET]
    + [AHFPNMIRQ * IACK * /BAS * /Al * RESET]
    + [AHFPNMIRQ * IACK * /BAS * /A2 * RESET]
    + [AHFPNMIRQ * IACK * /BAS * /A3 * RESET]
+ [AHFPNMIRQ * IACK * /BAS * A3 * A2 * Al * /AUTOVECTOR * RESET];
FPNMIRQ = /(AHFPNMIRQ);
IPL0: XRI=/VIRQ7
    + LIRQ7
    +/FPNMIRQ
    +/LIRQ7 * /LIRQ6 * VIRQ7 * VIRQ6 * LIRQ5
    +/LIRQ7 * /LIRQ6 * VIRQ7 * VIRQ6 * /VIRQ5
    +/LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * VIRQ7 * VIRQ6 * VIRQ5 * VIRQ4
    * LIRQ3
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * VIRQ7 * VIRQ6 * VIRQ5 * VIRQ4
    * /VIRQ3
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * /LIRQ3 * /LIRQ2 * VIRQ7 * VIRQ6
    * VIRQ5 * VIRQ4 * VIRQ3 * VIRQ2 * LIRQ1
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * /LIRQ3 * /LIRQ2 * VIRQ7 * VIRQ6
    * VIRQ5 * VIRQ4 * VIRQ3 * VIRQ2 * /VIRQ1;
XR2 = 1;
IPLI: XRI = /VIRQ7
    + LIRQ7
    + /FPNMIRQ
    + /LIRQ7 * VIRQ7 * LIRQ6
    +/LIRQ7 * VIRQ7 * /VIRQ6
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * VIRQ7 * VIRQ6 * VIRQ5 * VIRQ4
        * LIRQ3
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 * VIRQ7 * VIRQ6 * VIRQ5 * VIRQ4
        * /VIRQ3
    +/LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 */LIRQ3 * VIRQ7 * VIRQ6 * VIRQ5
        * VIRQ4 * VIRQ3 * LIRQ2
    +/LIRQ7 * /LIRQ6 * /LIRQ5 * /LIRQ4 */LIRQ3 * VIRQ7 * VIRQ6 * VIRQ5
        * VIRQ4 * VIRQ3 * /VIRQ2;
XR2 = 1;
```

IPL2: XRI $=$ NIRQ7
+ LIRQ7
$+/$ FPNMIRQ
+ /LIRQ7 * VIRQ7 * LIRQ6
+ /LIRQ7 * VIRQ7 * /VIRQ6
+ /LIRQ7 * /LIRQ6 * VIRQ7 * VIRQ6 * LIRQ5
+ /LIRQ7 * /LIRQ6 * VIRQ7 * VIRQ6 * /VIRQ5
+/LIRQ7 * /LIRQ6 * /LIRQ5 * VIRQ7 * VIRQ6 * VIRQ5 * LIRQ4

```
    + /LIRQ7 * /LIRQ6 * /LIRQ5 * VIRQ7 * VIRQ6 * VIRQ5 * /VIRQ4;
XR2 = l;
```

```
IACKF = /([A3 * A2 * Al * FPNMIRQ * /LACFAIL * IACK * /BAS]
```

IACKF = /([A3 * A2 * Al * FPNMIRQ * /LACFAIL * IACK * /BAS]
+ [A3 * A2 * Al * FPNMIRQ * /LSYSFAIL * IACK * /BAS]
+ [A3 * A2 * Al * FPNMIRQ * /LSYSFAIL * IACK * /BAS]
+ [A3 * A2 * Al * FPNMIRQ * /LIRQPE * IACK * /BAS]);
+ [A3 * A2 * Al * FPNMIRQ * /LIRQPE * IACK * /BAS]);
OFFBRDIACK:XRl=/LIRQ7 * A3 * A2 * Al * IACK * /BAS * FPNMIRQ * /AUTOVECTOR
+ /LIRQ6 * A3 * A2 * /Al * IACK * /BAS
+ /LIRQ5 * A3 * /A2 * Al * IACK * /BAS
+ /LIRQ4 * A3 * /A2 * /Al * IACK * /BAS
+ /LIRQ3 * /A3 * A2 * Al * IACK * /BAS
+/LIRQ2 * /A3 * A2 * /Al * IACK * /BAS
+ /LIRQ1 * /A3 * /A2 * Al * IACK * /BAS;
XR2 = 1;
AUTOVECTOR = [/FPNMIRQ * A3 * A2 * Al * IACK * /BAS * RESET]
+ [/LIRQMBX * A3 * A2 * /Al * IACK * /BAS * RESET]
+ [ AUTOVECTOR * /BAS * RESET];
AUTOVEC: XRI = AUTOVECTOR;
XR2 = l;
D24: XRI = /LACFAIL * ACFM
+ /LIRQPE * PERRM;
XR2 = 1;
D25: XRI = /LACFAIL * ACFM
+ LIRQPE * PERRM * /LSYSFAIL * SYSFM
+ /PERRM * /LSYSFAIL * SYSFM;
XR2 = 1;
IACKIOM = /(/LIRQlOM * A3 * /A2 * Al * IACK * /BAS);
IACKOOM = /(/LIRQOOM * A3 * /A2 * /Al * IACK * /BAS);
IACKTMR = /(/LIRQTMR * /A3 * A2 * Al * IACK * /BAS);
IACKPIO = /(/LIRQPIO * /A3 * A2 * /Al * IACK * /BAS);
IACKSIO = /(/LIRQSIO * /A3 * /A2 * Al * IACK * /BAS);
DSACKO = BAS;

```

Figure 4-3 VSCBC20IS .BEE File

\subsection*{4.2 VME Bus EPROM Interface}

The idea for this VMEbus EPROM board came from WIRELESS WORLD CIRCUIT IDEAS, January, 1988. The implementation was done by a Philips' FAE, John McNally.

The board contains two banks of EPROMs. Each bank consists of either two 27128 's or two 27256 's; each of which can be enabled by comparing the address location of the board. Decoding three other address bits selects which of the banks is accessed. A 4-bit shift register combined with four jumpers provide wait states.

The circuit drawing was entered on to a PC using FutureNet Dash, a schematic capture package (Figures \(4-4,4-5\) and \(4-6\) ). It was then converted to logic equations using AMAZE (Figure 4-9) and then assembled into a PLHS501.

This application, which needs eight ICs, used forty-four of the available seventy-two NAND Foldback Terms and forty of the available fifty-two pins. As the PLHS501 contains no registers, an edge triggered D type Flip-Flop was designed using NAND gates and this is used as a soft macro in order to implement the shift register function (Figure 4-6).

As suggested in the original article the circuit could be expanded to access up to eight ROM banks (Figure 4-8). This was achieved by editing the logic equation file and adding extra equations (Figure 4-9). Modifying the drawing, although fairly easy to do, was not considered necessary as the object was to design with PML and not TTL. The expanded circuit would require another three TTL IC packages, bringing the total to eleven. The number of foldback terms increased to fifty-five, with the number of pins rising to fifty. Figure \(4-10\) shows the pinout of both versions.



Figure 4-5 Edge-Triggered D Flip-Flop (DFFS)


Figure 4-6 4-Bit Shifter (7495)
a banks as original circuit. REPLACES 8 PACKAGES - USES 46 FOLDBACK TERMS


EXPANDED TO 8 ROM BANKS
REPLACES 11 PACKAGES - USES 55 FOLDBACK TERMS


Figure 4-7 VMEEXP and FULLEXP
```

File Name : VMEEXP

```

Date : 2/13/1988
Time : 10:23:5
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|c|}{Left} \\
\hline LABEL & ** FNC & **PIN \\
\hline VCC & ** +5V & ** 8- \\
\hline A21 & ** I & ** 9- \\
\hline A22 & ** I & ** 10- \\
\hline A23 & ** I & ** 11- \\
\hline /DS0 & * I & ** 12- \\
\hline /DSl & ** I & ** 13- \\
\hline R-WN & ** I & ** 14- \\
\hline Q0 & ** 0 & ** 15- \\
\hline Q1 & ** 0 & ** 16- \\
\hline Q2 & ** 0 & ** 17- \\
\hline Q3 & ** 0 & ** 18- \\
\hline /ROMOLO & ** 0 & ** 19- \\
\hline GND & ** OV & ** 20- \\
\hline
\end{tabular}

LABEL ** FNC **PIN

Bottom
LABEL
\begin{tabular}{lllll|} 
/ROMOHI & \(* *\) & 0 & \(* *\) & \(21-1\) \\
/ROMlLO & \(* *\) & 0 & \(* *\) & \(22-1\) \\
/ROMIHI & \(* *\) & 0 & \(* *\) & \(23-1\) \\
N/C & \(* *\) & 10 & \(* *\) & \(24-1\) \\
N/C & \(* *\) & \(/ 0\) & \(* *\) & \(25-1\) \\
N/C & \(* *\) & \(/ 0\) & \(* *\) & \(26-1\) \\
N/C & \(* * / 0\) & \(* *\) & \(27-1\) \\
ENADD & \(* *\) & 0 & \(* *\) & \(28-1\) \\
ENDATLO & \(* *\) & 0 & \(* *\) & \(29-1\) \\
ENDATHI & \(* *\) & 0 & \(* *\) & \(30-1\) \\
N/C & \(* *\) & 0 & \(* *\) & \(31-1\) \\
N/C & \(* *\) & 0 & \(* *\) & \(32-1\) \\
N/C & \(* *\) & 0 & \(* *\) & \(33-1\)
\end{tabular}

Figure 4-8 VMEEXP PLHS501 Pinlist

File Name: VMEEXP
Date: 2/13/1988
Time: 10:23:41
@DEVICE TYPE PLHS501
@DRAWING
VMEEXP. DWG
@REVISION
@DATE
2/12/1988
@SYMBOL
@COMPANY
@NAME
VMEEXP
@DESCRIPTION
@INTERNAL NODE
RO3 SO3 DO3 RO2 SO2
DO2 QO RO1 SOl DO1
ROO SOO DOO
@I/O DIRECTION
DB5 = 1 ;
DB6 = 1 ;
DB7 = 1 ;
OEO = 1 ;
OEl = 1 ;
@I/O STEERING
@LOGIC EQUATION
RO3 \(=(/((/\) MASEL \() *\) SO3 \(*\) CK8MZ \(*\) DO3 \()) ;\)
SO3 = (/(CKBMZ*(/(SO3*DO3*(//MASEL))))) ;
DO3 = (/(Q2*RO3)) ;
RO2 \(=(/((/\) MASEL \() * S O 2 *\) CKBMZ*DO2 \())\);
SO2 = (/(CKBMZ*(/(SO2*DO2 (//MASEL))))) ;
DO2 = (/(Ql*RO2)) ;
RO1 \(=(/((/ /\) MASEL \() * S O 1 *\) CKBMZ \(*\) DOL \())\);
SOl \(=(/(\) CKBMZ*(/(SOl*DOl*(//MASEL))))) ;
DO1 = (/(QO*rol)) ;
ROO = (/((/MASEL)*SOO*CKBMZ*DOO)) ;
SOO = (/(CKBMZ*(/(SOO*DOO*(//MASEL))))) ;
DOO = ( \(\left./\left(\mathrm{Q}^{\star} \mathrm{ROO}\right)\right)\);
/ROMOLO \(=(/ \mathrm{DSO} 0+(/ / \mathrm{Al} 6 * / 0 * 1 * / /\) MASEL \()))\);
/ROMOHI = (/DSl+(/(/Al6*/0*l*//MASEL))) ;
\(/\) ROM1LO \(=(/ \mathrm{DSO} 0+(/(\mathrm{Al6} * / 0 * 1 * / /\) MASEL \()))\);
/ROM1HI = (/DSl+(/(Al6*/0*l*//MASEL))) ;
Q0 = (/( / (ROO*QO))*SOO*(//MASEL))) ;
Ql \(=(/((/(R O 1 * Q 1)) * S O l *(/ /\) MASEL \()))\);
Q2 \(=(/((/(\mathrm{RO} 2 * \mathrm{Q} 2)) * S O 2 *(/ /\) MASEL \()))\);
```

Q3 = (/((/(RO3*Q3))*SO3*(//MASEL))) ;
/MASEL =/(/([/((Al7*Sl7+/Al7*/Sl7)*(Al8*Sl8+/Al8*/Sl8)*(Al9*Sl9+
/Al9*/S19)*(A20*S20+/A20*/S20)*(A21*S21+/A21*/S21)*
(A22*S22+/A22*/S22)*(A23*S23+/A23*/S23)*//A5)])) ;
/DTACK = /((/(/MASEL+WAIT))*R-WN) ;
DTACK = /(/DTACK) ;
/R-W = /(R-WN) ;
ENADD = (//A5) ;
ENDATLO = ((/R-W+/MASEL)+/DSO) ;
ENDATHI = (/DSl+(/R-W+/MASEL)) ;

```

Figure 4-9 VMEEXP PLHS501 .BEE File

File Name: FULLEXP
Date : 2/13/1988
Time : 10:11:28
********************* P I N
Left
LABEL ** FNC **PIN
\begin{tabular}{|c|c|c|}
\hline VCC & ** +5V & ** 8- \\
\hline A21 & ** I & ** 9- \\
\hline A22 & ** I & ** 10- \\
\hline A23 & ** I & ** ll- \\
\hline /DS0 & ** I & ** 12- \\
\hline /DSI & ** I & ** 13- \\
\hline R-WN & ** I & ** 14- \\
\hline REG & ** 0 & ** 15- \\
\hline ENADD & ** 0 & ** 16- \\
\hline ENDATLO & ** 0 & ** 17- \\
\hline ENDATHI & ** 0 & ** 18- \\
\hline /ROMOLO & ** 0 & ** 19- \\
\hline GND & ** OV & ** 20- \\
\hline
\end{tabular}

Bottom
LABEL
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|c|}{Bottom} \\
\hline LABEL & & \\
\hline /ROMOHI & ** 0 & ** 21- \\
\hline /ROM1LO & ** 0 & ** 22- \\
\hline /ROM1HI & ** 0 & ** 23- \\
\hline /ROM1LO & ** 10 & ** 24- \\
\hline /ROM1HI & ** \(/ 0\) & ** 25- \\
\hline /ROM3LO & ** 10 & ** 26- \\
\hline /ROM3 \({ }^{\text {RI }}\) & ** 10 & ** 27- \\
\hline /ROM4LO & ** 0 & ** 28- \\
\hline /ROM4HI & & ** 29- \\
\hline /ROM5L0 & ** 0 & ** 30- \\
\hline /ROM5HI & ** 0 & ** 31- \\
\hline /ROM6LO & ** 0 & ** 32- \\
\hline /ROM6HI & ** 0 & ** 33-1 \\
\hline
\end{tabular}

L I S T *********************
Right
LABEL
\begin{tabular}{|c|c|c|}
\hline |-46 & ** +5v & **VCC \\
\hline -45 & ** I & **W0 \\
\hline -44 & ** I & **W1 \\
\hline -43 & ** I & **CKBMZ \\
\hline -42 & ** I & **N/C \\
\hline -41 & ** I & **N/C \\
\hline -40 & ** 10 & **/R-W \\
\hline -39 & ** 10 & **DTAK \\
\hline -38 & ** 10 & **/DTACK \\
\hline -37 & ** 10 & **/MASEL \\
\hline -36 & ** 0 & **ROM7HI \\
\hline -35 & ** 0 & **ROM7L0 \\
\hline -34 & ** OV & **GND \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & & Top \\
\hline & & LABEL \\
\hline & 1-7** I & **A20 \\
\hline & 1-6 ** I & **A19 \\
\hline & 1-5 ** I & **A18 \\
\hline P & 1-4 ** I & **A17 \\
\hline L & 1-3 ** I & **Al6 \\
\hline H & 1-2 ** I & **/A5 \\
\hline S & - 1 - ** I & **S17 \\
\hline 5 & -52 ** I & **S18 \\
\hline 0 & -51 ** I & **S19 \\
\hline 1 & -50 ** I & **S20 \\
\hline & -49 ** I & **S21 \\
\hline & -48 ** I & **S22 \\
\hline & -47 ** I & **S23 \\
\hline
\end{tabular}

Figure 4-10 FULLEXP Pinlist

File Name : FULLEXP
Date: 2/13/1988
Time: 10:ll:30
@DEVICE
PLHS501
@DRAWING
VMEEXP.DWG
@REVISION
@DATE
2/12/1988
@SYMBOL
@COMPANY
@NAME
VMEEXP
@DESCRIPTION
@INTERNAL NODE
RO3 SO3 DO3 RO2 SO2
DO2 RO1 SOl DO1 ROO
SOO DOO
QO Q1 Q2 Q3
@I/O DIRECTION
DB4 = l ;
DB5 = 1 ;
DB6 = 1 ;
DB7 = 1 ;
\(\mathrm{OEO}=1\);
OE1 = 1 ;
\(\mathrm{OE} 2=1\);
OE3 = 1 ;
\(\mathrm{XEO}=1\);
XE1 = 1 ;
\(\mathrm{XE} 2=1\);
XE3 = 1 ;
@STEERING
\(\mathrm{SO}=\mathrm{Q}\);
Sl \(=Q\);
\(\mathrm{S} 2=\mathrm{Q}\);
S3 \(=\mathrm{Q}\);
@LOGIC EQUATION
RO3 \(=(/((/ / M A S E L) * S O 3 * C K B M Z * D O 3)) ;\)
SO3 = (/(CKBMZ*(/(SO3*DO3*(//MASEL))))) ;
DO3 \(=(/(\mathrm{Q} 2 * \mathrm{RO} 3))\);
RO2 \(=(/((/ /\) MASEL \() *\) SO2*CKBMZ*DO2 \())\);
SO2 \(=(/(\) CKBMX* \((/ S O 2 * D O 2 *(/ /\) MASEL \()))))\);
\(\mathrm{DO} 2=(/(\mathrm{Q} * \mathrm{RO} 2))\);
```

ROI = (/((//MASEL)*SOl*CKBMZ*DOl)) ;
SOl = (/(CKBMZ*(/(SOl*DOl*(//MASEL))))) ;
DOl = (/(QO*ROl)) ;
ROO = (/((//MASEL)*SOO*CKBMZ*DOO)) ;
SOO = (/(CKBMZ*(/SOO*DOO*(//MASEL))))) ;
DOO = (/(Q*ROO)) ;
/ROMOLO = (/DOO+/(/Al6*/Al7*/Al8*//MASEL)) ;
/ROMOHI = (/DSl+/(/Al6*/Al7*/Al8*//MASEL)) ;
/ROM1LO = (/DSO+/(Al6+/Al7*/Al8*//MASEL)) ;
/ROMlHI = (/DSl+/(Al6*/Al7*/Al8*//MASEL)) ;
/ROM2LO = /(/(/DS0+/(/Al6*Al7*/Al8*//MASEL))) ;
/ROM2HI = /(/(/DSl+/(/Al6*Al7*/Al8*//MASEL))) ;
/ROM3L0 = /(/(/DS0+/(Al6*Al7*/Al8*//MASEL))) ;
/ROM3HI = /(/(/DSl*/(Al6*Al7*/Al8*//MASEL))) ;
/ROM4LO = (/DSO+/(Al6*/Al7*Al8*//MASEL)) ;
/ROM4HI = (/DSl+/(Al6*/Al7*/Al8*//MASEL)) ;
/ROM5LO = (/DSO+/(Al6*/Al7(Al8*//MASEL)) ;
/ROM5HI = (/DSl+/(Al6*/Al7*Al8*//MASEL)) ;
/ROM6LO = (/DSO+/(Al6*Al7*Al8*//MASEL)) ;
/ROM6HI = (/DSl+/(Al6*Al7*Al8*//MASEL)) ;
/ROM7LO = (/DSO+/(Al6*Al7*Al8*//MASEL)) ;
/ROM7HI = (/DSl+/(Al6*Al7*Al8*//MASEL)) ;
ENADD = (//A5) ;
ENDATLO = ((/R-W+/MASEL)+/DSO) ;
ENDATHI = (/DSl+(/R-W+/MASEL)) ;
QO = /((/(ROO*QO))*SOO*(//MASEL)) ;
Q1 = /((/(ROl*Ql))*SOl*(//MASEL)) ;
Q2 = /((/(RO2*Q2))*SO2*(//MASEL)) ;
Q3 = /((/(RO3*Q3))*SO3*(//MASEL)) ;
/MASEL =/(/([/((Al7*Sl7+/Al7*/Al7*/Sl7*(Al8*Sl8+/Al8*/Sl8)
*(Al9*Sl9+/Al9+/Sl9*(A20*S20*/S20*(A2l*S2l
+/A21*/S21)*(A22*S22+/A22*/S22)*(A23**S23
+(A23*S23)*//A5)])) ;
/DTACK = /((/(/MASEL+/((/QO*WO*/Wl)+(/Ql*WO*/Wl)+(/Q2*/WO*Wl)
+(/Q3*W0*Wl))))*R-WN) ;
DTAK = /(DTACK) ;
/R-W = /(R-WN) ;
REG = QO*Q1*Q2*Q3 ;

```

Figure 4-11 FULLEXP PLHS501 .BEE File

\section*{5. Micro Channel Interface}

IBM's new Micro Channel Architecture (MCA) bus implements new features not found on the XT/AT bus. One new requirement for adapter designers is that of Programmable Option Select (POS) circuitry. It allows system software to configure each adapter card upon power on, thereby eliminating option select switches or jumpers on the main logic board and on adapter cards.

Each adapter card slot has its own unique -CDSETUP signal routed to it. This allows the CPU to interrogate each card individually upon power up. By activating a card's -CDSETUP line along with appropriate address and control lines two unique 8 bit ID numbers are first read from the adapter. Based upon the ID number, the system then writes into the card's option latches configuration information that had been stored in the system's CMOS RAM. The CPU also activates POS latch address 102 h bit 0 , which is designated as a card enable bit.

If a new card is added to the system, an auto-configuration utility will be invoked. Each adapter card has associated with it a standardized Adapter Description File with filename of @XXXX.ADF, where XXXX is the hex ID number of the card. The configuration utility prompts the user according to the text provided in the .ADF file and updates the card's latches and the system's CMOS RAM.

IBM reserves 8 addresses for byte-wide POS latches, however, depending on the card's function, not all addresses need to be used. In addition, of those addresses that are used, only the bits used need to be latched. The first two addresses which are reserved for reading the ID bytes, and bit 0 of the third address, which is defined as a card enable bit, are mandatory. Some of the remaining bits of the third address are suggested by IBM to be used as inputs to an IO or memory address comparator to provide for alternate card addresses. Many adapter cards will not use more than these three POS locations.

\section*{PLHS501 Application Notes \\ Vol 2.}

The following example describes an implementation of POS circuitry realized in a PLHS501. It uses only 56 of the possible 72 internal foldback NAND gates and only a portion of the device pins, allowing additional circuitry to be added. Figure 5-1 shows a block diagram of the circuit, and Figure 5-3 and 5-4 are the AMAZE files. Pins labeled D0O-D7O must be connected externally to pins D0I-D7I. They also must be connected through a 74 F 245 transceiver to the Micro Channel. External transceiver direction and enable control is provided for by circuitry within the PLHS501. The external transceiver may also be used by other devices on the adapter card.

In this application, edge triggered registers are not required and therefore should not be used as transparent latches use fewer NAND gates to implement. Figure 5-2 shows the various latch circuits described by the AMAZE equations. POS byte 2 was made using four of the \(/ \mathrm{B}\) device pins and four of the B pins. Notice however, from Figure 5-2(B) that the bits on the /B pins used the complement of the input pin, thereby implementing a noninverting latch. Also, all 8 bits of this byte were brought to output pins. If some of the bits are not used by external circuitry, then the specific bit latch may not be needed or may be constructed entirely from foldback NAND gates freeing additional pins.

An external F521 may by added to provide for IO address decoding. As the MCA bus requires all 16 bits of the IO address to be decoded, 8 bits may be assigned to the F521 and 8 bits to the 501 . Bit fields decoded in the 501 may be done so in conjunction with bits from POS byte 2 to provide for alternate IO addressing. Additionally, some of the available 501 outputs may be used as device enables for other devices on the card.


Figure 5-1 Block Diagram of Basic POS Implementation in PLHS501


Figure 5-2 Latches used in MCA Interface

File Name : MCPOSREG
Date : 5/31/1988
Time : 11:50:2

Left
LABEL ** FNC **PIN VCC \(\quad * *+5 \mathrm{~V}\) ** \(8-1\) N/C ** I ** 9-1 N/C ** I ** 10-1 N/C ** I ** 11N/C ** I ** 12N/C ** I ** 13-
N/C ** I ** 14-
/L4 ** O ** 15-
/L5 ** O ** 16-
/L6 ** O ** 17-
/L7 \(7 * 0\) ** 18-
N/C \(\quad\) ** \(0 \quad\) ** \(19-1\)
GND ** OV ** 20-|

Right
PIN** FNC ** LABEL
\begin{tabular}{|c|c|c|}
\hline -46 & ** +5V & **VCC \\
\hline -45 & ** I & **D4I \\
\hline -44 & ** I & **D3I \\
\hline -43 & ** I & **D2I \\
\hline -42 & ** I & **D1I \\
\hline -41 & ** I & **DOI \\
\hline -40 & ** 10 & **L3 \\
\hline -39 & ** 10 & **L2 \\
\hline -38 & ** 10 & **Ll \\
\hline -37 & ** 10 & **LO \\
\hline -36 & ** 0 & **D70 \\
\hline -35 & ** 0 & **D60 \\
\hline -34 & ** OV & **GND \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{3}{|c|}{Bottom} & & \multicolumn{4}{|c|}{Top} \\
\hline LABEL & ** FNC & **PIN & & PIN** & FNC & ** & LABEL \\
\hline BUFEN & ** 0 & ** 21-1 & & - 7 ** & I & **SS1 & \\
\hline N/C & ** 0 & ** 22-1 & & - 6 ** & I & **SS0 & \\
\hline N/C & ** 0 & ** 23-1 & & - 5 ** & I & **SETUP & \\
\hline IOWB & ** 10 & ** 24-1 & P & - 4 ** & I & **CMD & \\
\hline N/C & ** 10 & ** 25-1 & L & -3 ** & I & **A2 & \\
\hline N/C & ** 10 & ** 26- & H & - 2 ** & I & **Al & \\
\hline N/C & ** 10 & ** 27-1 & S & - 1 ** & I & **AO & \\
\hline D00 & ** 0 & ** 28-1 & 5 & -52 ** & I & **MIO & \\
\hline Dlo & ** 0 & ** 29-1 & 0 & -51 ** & I & **ADL & \\
\hline D20 & ** 0 & ** 30-1 & 1 & -50 ** & I & **RST & \\
\hline D30 & ** 0 & ** 31-1 & & -49 ** & I & **D7I & \\
\hline D40 & ** 0 & ** 32-1 & & -48** & & **D6I & \\
\hline D50 & ** 0 & ** 33-1 & & -47 ** & I & **D5I & \\
\hline
\end{tabular}

Figure 5-3 PLHS501 MCPOSREG Pinlist

File Name : MCPOSREG
Date : 5/31/1988
Time : 11:50:17
@DEVICE TYPE PLHS501
@DRAWING
@REVISION
@DATE
@SYMBOL
@COMPANY
@NAME
@DESCRIPTION
Basic Programmable Option Select circuitry for a Micro Channel Adaptor card
@INTERNAL NODE
/setupl,/miol,a01,all,/a2l,ss0l,ssll;
/en,outen,/iow;
@COMMON PRODUCT TERM
read0 \(=(\) setupl*/ssll*ss0l*miol*/cmd*a2l*/all*/a01);
readl \(=(\) setupl*/ssll*ss01*miol*/cmd*a2l*/all* a01);
read2 \(=(\) setupl*/ssll*ss0l*miol*/cmd*a2l* all*/a01);
NOTE: In the above equations, setupl, miol and a2l all should be preceded by a slash (/). The slash was omitted to correct for a mapping error in AMAZE 1.65 when using active low internal node definitions in common product terms.
```

b7h = 0; " Define high ID byte "
b6h = l; " (POS byte \#l)
b5h = l; " 7E hex
b4h = l;
b3h = l;
b2h = 1;
blh = l;
bOh = 0;
b7l = l; " Define low ID byte "
b6l = l; ", (POS byte \#0) "
b5l = l; " FF hex
b4l = 1;
b31 = 1;
b2l = l;
bll = l;
bOl = l;

```
```

@I/O DIRECTION
"3-state output control of d7o-d0o"
xe0 = (/setupl*/ssll*ss0l*/miol*/cmd*/a2l*outen);
xel = (/setupl*/ssll*ss0l*/miol*/cmd*/a2l*outen);
xe2 = (/setupl*/ssll*ss01*/miol*/cmd*/a2l*outen);
xe3 = (/setupl*/ssll*ss01*/miol*/cmd*/a2l*outen);

```

\section*{@I/O STEERING}
@LOGIC EQUATION
" 7-Bit Input Latch for Control Signals "
```

/setupl = /setup*/adl + /setupl*adl;
/miol = /mio */adl + /miol *adl;
ssll = ssl */adl + ssll *adl;
ss0l = ss0 */adl + ss0l *adl;
/a2l = /a2 */adl + /a2l *adl;
all = al */adl + all *adl;
a01 = a0 */adl + a0l *adl;

```
" Option Select Octal Data Latch (POS byte \#2)"
" lo is to be used as a card enable signal"
/en \(=/[/ s e t u p l * / s s 01 * s s l l * / m i o l * / c m d * / a 2 l * a l l * / a 01] ;\) "write to latch"
```

/l7 = /[/d7i * en] * /[17 * /en] * [/rst];
/l6 = /[/d6i * en] * /[l6 * /en] * [/rst];
/l5 = /[/d5i * en] * /[15 * /en] * [/rst];
/l4 = /[/d4i * en] * /[l4 * /en] * [/rst];
13 = /(/[ d3i * en * /rst] * /[l3 * /en * /rst]);
l2 = /(/[ d2i * en * /rst] * /[l2 * /en * /rst]);
ll = /(/[ dli * en * /rst] * /[ll * /en * /rst]);
l0 = /(/[ dOi * en * /rst] * /[l0 * /en * /rst]);

```
" Octal 3 to 1 Multiplexer "
" This multiplexer selects between reading POS[0], POS[1] or POS[2] onto the data bus"
```

d7o = (b7h*readl + b7l*read0 + /l7*read2);
d6o = (b6h*readl + b6l*read0 + /l6*read2);
d5o = (b5h*readl + b5l*read0 + /l5*read2);
d4o = (b4h*readl + b4l*read0 + /l4*read2);
d3o = (b3h*readl + b3l*read0 + l3*read2);
d2o = (b2h*readl + b2l*read0 + l2*read2);
dlo = (blh*readl + bll*readO + ll*read2);
d0o = (bOh*readl + bOl*readO + l0*read2);
"3-State output control for d7o-d0o"
outen =/[all*a0l];
"External F245 transceiver control"
iowb = /(/a2l * /setupl * /miol * ssll * /ssOl);
/iow = /(/a2l * /setupl * /miol * ssll * /ss0l);
bufen = cmd * /iow;

```

Figure 5-4 PLHS501 MCPOSREG .BEE File

\section*{6. NuBus Interface}

In Apple Computer's book* "Designing Cards and Drivers for Macintosh II and Macintosh \(\mathrm{SE}^{\prime \prime}\), an application was described for interfacing an 8-bit I/O controller to the NuBus. The controller used was a SCSI controller of the type used on the main Macintosh logic board. Seven devices (three of which were PAL architecture) were used as control circuitry interfacing the SCSI controller and two RAM chips to the bus.

This example of using the PLHS501 shows a method of interfacing the same SCSI controller and RAM chips to the NuBus using only three parts. The adapter card schematic is shown in Figure 6-2 and the AMAZE listing is in Figure 6-6. Although the AMAZE listing may seem confusing at first glance, the circuitry fused into the PLHS501 can be broken down into small blocks of latches, flip-flops, and schematically in Figure 6-4 and 6-5. Circuit timing is shown in Figure 6-3.

Referring to Figure 6-4 and Figure 6-5, the circuitry starts a transaction by first detecting a valid address in either the slot or super slot range. The detection is accomplished by two wide-input NAND gates, and controlled by the /CLK signal. Following each NAND gate is an S-R latch to hold the signal until near the end of the cycle. The two S-R latch signals are combined into one signal named ST0 such that if either NAND gate output was low, then some delay time after the rising edge of /CLK, ST0 will go low. The next rising edge of /CLK will cause signal ST1 to go low. This sets signal DE2 low, which is an input to an external flip-flop to cause ST2 to go low at the next rising /CLK edge terminating the cycle. An external flip-flop was necessary to achieve a high-speed /CLK to /IOR and /ACK transition. Also, an external FI25 buffer was added to meet the soon to be approved IEEE P1196 specification requirement of \(60 \mathrm{~mA} \mathrm{I}_{\mathrm{o}}\) for signal /NMRQ and

\footnotetext{
*Designing Cards and Drivers for Macintosh II and Macintosh SE, Addison-Wesley Publish Company, Inc. 1987.
}
\(24 \mathrm{~mA} \mathrm{I}_{0}\) for signals /TM0/TM1 and /ACK. Figure 6-5(b) shows an easily implemented latch which controls interrupts generated by the SCSI controller passing onto the bus. Upon /RESET the latch is put into a known state. Under software control, by writing to a decoded address, the latch may be set or reset thereby gating or blocking the interrupt signals.


Figure 6-1 Simplified NuBus Diagram


Figure 6-2 Adapter Card Schematic


Figure 6-3 Timing Diagram


Figure 6-4 Decoding and Latch Circuitry




(a) Four internal Flip-Flops constructed from NAND gates.

(b) Interrupt enoble control lateh Internal Flip-Flops and Latches

Figure 6-5 Internal Flip-Flops and Latches

Left
LABEL ** FNC **PIN VCC ** +5V ** 8/ID2 ** I ** 9/ID3 ** I ** 10DRQ ** I ** llIRQ ** I ** 12ST2 ** I ** 13N/C ** I ** 14N/C ** O ** 15-
N/C ** O ** 16-
N/C ** O ** 17-
N/C ** O ** 18-
N/C ** O ** 19-
GND ** OV ** 20-

Bottom
LABEL ** FNC **PIN
\begin{tabular}{lllll|} 
N/C & \(* *\) & 0 & \(* *\) & \(21-1\) \\
N/C & \(* *\) & 0 & \(* *\) & \(22-1\) \\
ACLK & \(* *\) & 0 & \(* *\) & \(23-1\) \\
/ROMCS & \(* *\) & OO & \(* *\) & \(24-1\) \\
/RAMCS & \(* *\) & /O & \(* *\) & \(25-1\) \\
N/C & \(* *\) & /O & \(* *\) & \(26-1\) \\
/NMRQ & \(* *\) & /O & \(* *\) & \(27-1\) \\
DE2 & \(* *\) & 0 & \(* *\) & \(28-1\) \\
/RESETB & \(* *\) & 0 & \(* *\) & \(29-1\) \\
/SCSI & \(* *\) & 0 & \(* *\) & \(30-1\) \\
/DACK & \(* *\) & 0 & \(* *\) & \(31-1\) \\
/IORR & \(* *\) & 0 & \(* *\) & \(32-1\) \\
/IOW & \(* *\) & 0 & \(* *\) & \(33-1\)
\end{tabular}

Right
PIN** FNC ** LABEL
\begin{tabular}{|c|c|c|}
\hline -46 & ** +5V & **VCC \\
\hline -45 & ** I & **D1 \\
\hline -44 & ** I & **D0 \\
\hline -43 & ** I & **A19 \\
\hline -42 & ** I & **A18 \\
\hline -41 & ** I & **A9 \\
\hline -40 & ** / 0 & **ST0 \\
\hline -39 & ** 10 & **N/C \\
\hline -38 & ** 10 & **N/C \\
\hline -37 & ** 10 & **N/C \\
\hline -36 & ** 0 & **N/C \\
\hline -35 & ** 0 & **N/C \\
\hline -34 & ** OV & **GN \\
\hline
\end{tabular}

Top
PIN** FNC ** LABEL
\begin{tabular}{|c|c|c|}
\hline 1-7 & ** I & **/IDl \\
\hline 6 & ** I & **/ID0 \\
\hline 5 & ** I & **/RESET \\
\hline 4 & ** I & **/TM1 \\
\hline - 3 & ** I & **/ACK \\
\hline - 2 & ** I & **/START \\
\hline 1 & ** I & **/CLK \\
\hline -52 & ** I & **D7 \\
\hline -51 & ** I & **D6 \\
\hline -50 & ** I & **D5 \\
\hline -49 & ** I & **D4 \\
\hline -48 & ** I & **D3 \\
\hline -47 & ** I & **D2 \\
\hline
\end{tabular}
```

@DEVICE TYPE
PLHS501
@DRAWING
@REVISION
@DATE
@SYMBOL
@COMPANY
@NAME
@DESCRIPTION
SCSI-NuBus Interface
@INTERNAL NODE
/sl,/sp,/SLOT,/SUPER;
snl,sn2,rnl,rn2;
sn3,rn3,stl;
sn4,rn4,tmll,tmlln;
CMP3a,CMP2a,CMP1a,CMP0a;
CMP3b, CMP2b,CMP1b, CMP0b;
/slt,/sup,stln,adclk;
setad,rstad,inten;
slotn,supern;
@COMMON PRODUCT TERM
@I/O DIRECTION
@I/O STEERING
@LOGIC EQUATION
"Address Decode"
cmp0a = (d0*id0+/d0*/id0);
cmpla = (dl*idl+/dl*/idl);
cmp2a = (d2*id2+/d2*/id2);
cmp3a = (d3*id3+/d3*/id3);
cmpOb = (d4*id0+/d4*/id0);
cmplb = (d5*idl+/d5*/idl);
cmp2b = (d6*id2+/d6*/id2);
cmp3b = (d7*id3+/d7*/id3);
/sl = /(d7*d6*d5*d4*cmp0a*cmpla*cmp2a*cmp3a*start*/ack*clk);
/sp = /(cmp0b*cmplb*cmp2b*cmp3b*start*/ack*clk);
"latch slot signal"
/slt = /(/reset*st2*/[/sl*/slt]);
"latch super signal"
/sup = /(/reset*st2*/[/sp*/sup]);
"Let /slt or /sup through only
until after the rising edge
of /clk"
st0 = /(/[/slt*/sup*/clk] * /[st0*clk] * /[/slt*/sup*st0] * /reset);

```
"Slot signal D-type Flip Flop"
```

snl = /(/clk*/slt*(/[snl*/reset*/super*(/[st0*rnl*/slt])]));

```
rnl \(=/(/ c l k * s n l *(/[s t 0 * r n l * / s l t])) ;\)
/slot \(=/(/\) reset*/super*snl*slotn);
slotn \(=/(/\) slot*rnl*/slt);
    "Super signal D-type Flip Flop"
sn2 \(=/(/ c l k * / s u p *(/[s n 2 * / r e s e t * / s l o t *(/[s t 0 * r n 2 * / s u p])])) ;\)
rn2 \(=/\left(/ \mathrm{clk} * \mathrm{sn}^{2 *}(/[\right.\) st0*rn2*/sup]) \()\);
/super \(=/(/\) reset*/slot*sn2*supern);
supern = /(/super*rn2*/sup);
    "State l D-type Flip Flop"
sn3 \(=/(/ \mathrm{clk}\) * \((/[\operatorname{sn} 3 * / \operatorname{reset} *(/[s t 0 * r n 3])])\) );
rn3 \(=/(/ c l k * \operatorname{sn} 3 *(/[s t 0 * r n 3]))\);
stl \(=/(/\) reset*sn3*stln);
stln= /[stl*rn3];
    "output to external flop"
de2 = /(stln * st2);
    "address latch clock"
adclk \(=\) clk*st0*stl;
aclk \(=c l k * s t 0 * s t l ;\)
    "latch tml signal for \(r / w\) info"
sn4 \(=\) /(adclk*/reset*(/[sn4*(/[/tml*rn4*/reset])]));
rn4 \(=\) /(adclk*sn4*(/[/tml*rn4*/reset]));
tmll \(=/(\operatorname{sn} 4 * t m l l n) ;\)
tmlln= /(rn4*/reset*tmll);
    tmll \(\rightarrow\) l read, 0 write
    tmlln \(\rightarrow 0\) read, 1 write
    "
    "straight decode stuff"
/iorr \(=/(\) st0*tmll \(\quad\) * /reset);
/iow \(=/(\) tmlln*/st0 */reset);
/scsi \(=/(\) slotn*/al9*/al8*/a9 */reset);
/dack \(=/(\) slotn*/al9*/al8* a9 */reset);
/romcs= /(slotn* al9* al8 * /reset);
/ramcs= /(supern */reset);
/resetb= /reset;
    "interrupt control latch"
setad \(=/(t m l l n * / s t 0 * s l o t n * ~ a l 9 * / a l 8 * ~ a 9) ; ~\)
rstad \(=/(\) tmlln*/st0*slotn* al9*/al8*/a9);
inten \(=/(\) setad* \((/[\) inten*rstad*/reset]));
/nmrq \(=/(i n t e n * d r q+i n t e n * i r q) ;\)

Figure 6-6 AMAZE Listing

\section*{7. Nuggets}

Much current focus for microprocessor design is on the address bus. Typically, most designers assume the processor will handle the data manipulation and the data bus is assumed to be a straight, clean path to and from the memory. Data transformations may be accomplished for specific purposes when the application requires it. For instance, a classic transformation from the early 70's was the bit reversal required to address operands for a Fast Fourier Transformation. When designers implemented bit reversal as a separate hardware process, the whole system improved. Likewise for hardware multipliers.

Also, a hidden "transformation" is the appending of parity and the calculation of E.C.C. polynominals. Clearly, when the designer recognizes that significant performance improvement can be achieved by realizing the payoff attainable with a special purpose hardware device, he should design it. For example, let's consider parity generation:

\subsection*{7.1 Data Bus Parity}

The PLHS501 can span 32-bits of input data. It has four output EX-OR gates, and the ability to generate literally any function of the inputs. It would seem that there must be some "best" way to generate and detect parity. Recall that the PLHS501 can generate both deep logic functions (lots of levels) and wide logic functions (lots of inputs). The best solution would require the fewest gates and the fewest number of logic levels. Let's review the basics, first. Table 7-1(a) shows the parity function for two variables and Table 7-2(b) shows it for three variables. The EX-OR function generates even parity.
\begin{tabular}{cc|ccc}
\(A\) & \(B\) & \(A\) & \(\oplus\) & \(B\) \\
\hline 0 & 0 & 0 & \\
0 & 1 & & 1 & \\
1 & 0 & & 1 & \\
1 & 1 & & 0
\end{tabular}

Table 7-1(a)
\begin{tabular}{ccc|c}
\(A\) & \(B\) & \(C\) & \(A \oplus B \oplus C\) \\
\hline 0 & 0 & 0 & 0 \\
0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 \\
0 & 1 & 1 & 0 \\
1 & 0 & 0 & 1 \\
1 & 0 & 1 & 0 \\
1 & 1 & 0 & 0 \\
1 & 1 & 1 & 1
\end{tabular}

Table 7-1(b)

\section*{TABLE 7-1 Even Parity Functions}

It is noticeable that there are precisely \(50 \%\) logical 1 entries in the truth tables. This yields the famous checkerboard Karnaugh Maps. With a checkerboard K-map, no simplification of EX-OR functions is possible by Boolean simplification. The two variable EX-OR has two ones (implying 3 gates to generate), the 3 variable has four ones (implying 5 gates to generate). In general, \(2^{n-1}+1\) product terms could generate EX_OR functions in two levels of NAND gates (assuming complementary input variables exist). You must have an unlimited number of gate inputs for this to hold.

The PLHS501 could do this for 7 input variables in two levels \(\left(2^{6}+1=65\right)\), but cannot support \(8\left(2^{7}+1=129\right)\). Hence, it is appropriate to seek a cascaded solution, hopefully taking advantage of the available output EX-OR functions. Let's solve a 16 input EX-OR function, by subpartitioning. First, consider Figure 7-1(a) where two literals are exclusive-ORed to generate an intermediate EX-OR function. This requires available complementary inputs and generates even parity in two levels. Figure \(7-1\) (b) also does this (by factoring), requiring 3 gate levels, but does not require complementary inputs.



Figure 7-1(b)

Figure 7-1 Complementary Input Levels

Assuming inputs must get into the PLHS501 through the pin receivers, it is best to generate as wide of an initial EX-OR as possible, so a structure like Figure 7-1(a) expanded is appropriate. Figure 7-1 shows a 2 -level 4 input EX-OR function which may be viewed as a building block. This structure may be repeated four times, across four sets of four input bits generating partial intermediate parity values which may then be treated through two boxes similar to Figure 7-1(b). These outputs are finally combined through an output EX-OR at a PLHS501 output pin. Figure 7-3 shows the complete solution which requires 44 NANDs plus one EX-OR.


Figure 7-2 Four Variable EX-ORs


Figure 7-3 16 Input Even Parity Generation
Two examples follow which were supplied by one of our European Sales Engineers, Nils Lindgren. The first, called "paritet", calculates even and odd parity for 24 input literals. Several output options are available and the design uses a cascade with a different partitioning than just previously discussed.

The second example "compare" implements, a 16-bit comparator over 32 input bits. The design generates outputs for conditions representing the classic "EQUAL", "AGTB" ( \(\mathrm{A}>\mathrm{B}\) ) and BGTA ( \(\mathrm{B}>\mathrm{A}\) ). The long, triangularized equation for T42 suggests that Nils found a clever editing approach to accurately enter a relatively long design equation, into Signetics AMAZE.

File Name : PARITET
Date : 5/31/1988
Time : 10:26:22
\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\# P I N L I S T \#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#

Left
\begin{tabular}{|c|c|c|}
\hline IABEL & ** FNC & **PIN \\
\hline VCC & ** +5V & ** 8-1 \\
\hline A & ** I & ** 9- \\
\hline B & ** I & ** 10- \\
\hline C & ** I & ** 11- \\
\hline D & ** I & ** 12- \\
\hline E & ** I & ** 13- \\
\hline F & ** I & ** 14- \\
\hline N/C & ** B & ** 15- \\
\hline N/C & ** B & ** 16- \\
\hline N/C & ** B & ** 17- \\
\hline N/C & ** B & ** 18- \\
\hline N/C & ** 0 & ** 19- \\
\hline GND & ** OV & ** 20-1 \\
\hline
\end{tabular}

Bottom
LABEL ** FNC **PIN
\begin{tabular}{|c|c|c|c|}
\hline N/C & ** 0 & ** & 21- \\
\hline N/C & ** 0 & ** & 22- \\
\hline ODD_OC & ** 0 & ** & 23- \\
\hline ODD & ** 10 & ** & 24- \\
\hline EVEN & ** / 0 & ** & 25- \\
\hline EVEN_OC & ** / 0 & ** & 26- \\
\hline N/C & ** 10 & ** & 27- \\
\hline N/C & ** 0 & ** & 28- \\
\hline N/C & ** 0 & ** & 29- \\
\hline N/C & ** 0 & ** & 30- \\
\hline N/C & ** 0 & ** & 31- \\
\hline N/C & ** 0 & ** & 32- \\
\hline N/C & ** 0 & ** & 33- \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|}
\hline & & & & \\
\hline & PIN** & FNC & ** & LABEL \\
\hline & 1-7 ** & I & **Y & \\
\hline & 1-6 ** & I & **X & \\
\hline & - 5 ** & I & **V & \\
\hline P & 1-4 ** & I & **U & \\
\hline L & - 3 ** & I & **T & \\
\hline H & 1-2 ** & I & **S & \\
\hline S & - 1 ** & I & **R & \\
\hline 5 & -52 ** & I & **Q & \\
\hline 0 & -51 ** & I & **P & \\
\hline 1 & -50 ** & I & **O & \\
\hline & -49 ** & I & **N & \\
\hline & -48 ** & I & **M & \\
\hline & -47 ** & I & **L & \\
\hline
\end{tabular}

Figure 7-4 PARITET PLHS501 Pinlist
```

File Name : PARITET
@DEVICE TYPE
PLHS501
@DRAWING
@REVISION
@DATE
1988
@SYMBOL
@COMPANY
Philips
@NAME
Nils Lindgren
@DESCRIPTION
2 4 ~ b i t ~ p a r i t y ~ c i r c u i t
@INTERNAL NODE
J0 Jl J2 J3 J4 J5 J6 J7 J8 J9 T0 Tl T2 T3
@COMMON PRODUCT TERM
@I/O DIRECTION
OEl=T2*T3*/OEN;
OE2=/OEN;
OE3=T0*Tl*/OEN;
@I/O STEERING
@LOGIC EQUATION
"FIRST LEVEL: 'EVEN' FROM GROUPS OF THREE INPUTS"
J0 =/A*/B*/C + /A*B*C + A*/B*C + A*B*/C;
Jl=/D*/E*/F + /D*E*F + D*/E*F + D*E*/F;
J2=/G*/H*/I + /G*H*I + G*/H*I + G*H*/I;
J3=/J*/K*/L +/J*K*L + J*/K*L + J*K*/L;
J4=/M*/N*/O +/M*N*O +M*/N*O + M*N*/O;
J5=/P*/Q*/R +/ P*Q*R + P*/Q*R + P*Q*/R;
J6=/S*/T*/U + /S*T*U + S*/T*U + S*T*/U;
J7=/V*/X*/Y + /V*X*Y + V*/X*Y + V*X*/Y;
"SECOND LEVEL: 'EVEN' FROM FOUR GROUPS AT A TIME"
J8=/J0*/Jl*/J2*/J3 + /J0*/Jl*J2*J3 + J0*Jl*/J2*/J3 + /J0*Jl*J2*J3
+ J0*/Jl*/J2*J3 + /J0*Jl*/J2*J3 + J0*/Jl*J2*/J3 + J0*Jl*J2*J3;
J9=/J4*/J5*/J6*/J7 +/J4*/J5*J6*J7 + J4*J5*/J6*/J7 +/J4*J5*J6*/J7
+ J4*/J5*/J6*J7 + /J4*J5*/J6*J7 + J4*/J5*J6*/J7 + J4*J5*J6*J7;
T0=/(J8*J9);
Tl=/(/J8*/J9);
T2=/(J8*/J9);
T3=/(/J8*J9);
ODD=/(T2*T3);
EVEN=/(TO*Tl);
ODD_OC=O;
EVEN_OC=/(l);

```

Figure 7-5 PARITET PLHS501 .BEE File

File Name : compare
Date : 5/31/1988
Time : 10:25:29
\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\# P I N L I S T \#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#\#

Left
LABEL ** FNC **PIN
VCC ** +5V ** 8-1
\begin{tabular}{|c|c|c|}
\hline A0 & ** I & ** 9- \\
\hline Al & ** I & ** 10- \\
\hline A2 & ** I & ** 11- \\
\hline A3 & ** I & ** 12- \\
\hline A4 & ** I & ** 13- \\
\hline A5 & ** I & ** 14- \\
\hline A6 & ** I & ** 15- \\
\hline A7 & ** I & ** 16- \\
\hline A8 & ** I & ** 17- \\
\hline A9 & ** I & ** 18- \\
\hline N/C & & ** 19- \\
\hline GND & ** OV & ** 20- \\
\hline
\end{tabular}

Right
PIN** FNC ** LABEL
\begin{tabular}{|c|c|c|}
\hline -46 & ** +5V & **VCC \\
\hline -45 & ** I & **B2 \\
\hline -44 & ** I & **B1 \\
\hline -43 & ** I & **B0 \\
\hline -42 & ** I & **AF \\
\hline -41 & ** I & **AE \\
\hline -40 & ** I & **AD \\
\hline -39 & ** I & **AC \\
\hline -38 & ** I & **AB \\
\hline -37 & ** I & **AA \\
\hline -36 & ** 0 & **N/C \\
\hline -35 & ** 0 & **N/C \\
\hline -34 & ** OV & **GND \\
\hline
\end{tabular}

Bottom
LABEL ** FNC **PIN
EQUAL ** O ** 21-1
AGTB ** O ** 22-
BGTA ** O ** 23-
N/C ** /O ** 24-
N/C ** /O ** 25-
N/C ** /O ** 26-
N/C ** /O ** 27-
N/C ** O ** 28-
N/C ** O ** 29-1
N/C ** O ** 30-
N/C ** O ** 31-1
N/C ** O ** 32-1
N/C ** O ** 33-1

Top
PIN** FNC ** LABEL \(\left\lvert\, \begin{array}{llll}-7 & * * & \mathrm{I} & * * \mathrm{BF} \\ -6 & * * & \mathrm{I} & * * \mathrm{BE} \\ -5 & * * & \mathrm{I} & * * \mathrm{BD} \\ -4 & * * & \mathrm{I} & * * \mathrm{BC} \\ -3 & * * & \mathrm{I} & * * \mathrm{BB} \\ \mid-2 & * * & \mathrm{I} & * * \mathrm{BA} \\ -1 & * * & \mathrm{I} & * * \mathrm{~B} 9 \\ -52 & * * & \mathrm{I} & * * \mathrm{~B} 8 \\ \mid-51 & * * & \mathrm{I} & * * \mathrm{~B} 7 \\ -50 & * * & \mathrm{I} & * * \mathrm{~B} 6 \\ \mid-49 & * * & \mathrm{I} & * * \mathrm{~B} 5 \\ -48 & * * & \mathrm{I} & * * \mathrm{~B} 4 \\ -47 & * * & \mathrm{I} & * * \mathrm{~B} 3\end{array}\right.\)

Figure 7-6 PLHS501 Pinlist for 16-Bit Comparator
```

File Name : compare
Date : 5/31/l988
Time : 10:25:43
@DEVICE TYPE
PLHS501
@DRAWING
@REVISION
@DATE
@SYMBOL
@COMPANY
PHILIPS
@NAME
NILS LINDGREN
@DESCRIPTION
16 BIT COMPARATOR WITH THREE OUTPUTS:
EQUAL,AGTB (A>B), AND BGTA (B>A)
@INTERNAL NODE
Tl T2 T3 T4 T5 T6 T7 T8
T9 Tl0 Tll Tl2 Tl3 Tl4 Tl5 Tl6
Tl7 T18 T19 T20 T21 T22 T23 T24
T25 T26 T27 T28 T29 T30 T31 T32
T41 T42
@COMMON PRODUCT TERM
@I/O DIRECTION
@I/O STEERING
@LOGIC EQUATION
Tl=/(AF*/BF); T2=/(/AF*BF);
T3=/(AE*/BE); T4=/(/AE*BE);
T5=/(AD*/BD); T6=/(/AD*BD);
T7=/(AC*/BC); T8=/(/AC*BC);
T9=/(AB*/BB); Tl0=/(/AB*BB);
Tll=/(AA*/BA); Tl2=/(/AA*BA);
Tl3=/(A9*/B9); Tl4=/(/A9*B9);
T15=/(A8*/B8); Tl6=/(/A8*B8);
T17=/(A7*/B7); Tl8=/(/A7*B7);
T19=/(A6*/B6); T20=/(/A6*B6);
T2l=/(A5*/B5); T22=/(/A5*B5);
T23=/(A4*/B4); T24=/(/A4*B4);
T25=/(A3*/B3); T26=/(/A3*B3);
T27=/(A2*/B2); T28=/(/A2*B2);
T29=/(Al*/B2); T30=/(/Al*B1);
T31=/(A0*/B0); T32=/(/A0*B0);
T4l=Tl*T2*T3*T4*T5*T6*T7*T8*T9*Tl0*Tll*Tl2*Tl3*Tl4*Tl5*Tl6*Tl7*
T18*T19*T20*T21*T22*T23*T24*T25*T26*T27*T28*T29*T30*T31*T32;
T42=


#### Abstract

/T3*T2+ /T5*T4*T2+ /T7*T6*T4*T2+ /T9*T8*T6*T4*T2+ /Tll*Tl0*T8*T6*T4*T2+ /T13*T12*T10*T8*T6*T4*T2+ /T15*T14*T12*T10*T8*T6*T4*T2+ /T17*T16*T14*T12*T10*T8*T6*T4*T2+ /T19*T18*T16*T14*T12*T10*T8*T6*T4*T2+ /T21*T20*T18*T16*T14*T12*T10*T8*T6*T4*T2+ /T23*T22*T20*T18*T16*T14*T12*T10*T8*T6*T4*T2+ $/ \mathrm{T} 25 * \mathrm{~T} 24 * \mathrm{~T} 22 * \mathrm{~T} 20 * \mathrm{~T} 18 * \mathrm{~T} 16 * \mathrm{~T} 14 * \mathrm{~T} 12 * \mathrm{~T} 10 * \mathrm{~T} 8 * \mathrm{~T} 6 * \mathrm{~T} 4 * \mathrm{~T} 2+$ $/ \mathrm{T} 27 * \mathrm{~T} 26 * \mathrm{~T} 24 * \mathrm{~T} 22 * \mathrm{~T} 20 * \mathrm{~T} 18 * \mathrm{~T} 16 * \mathrm{~T} 14 * \mathrm{~T} 12 * \mathrm{Tl} 10 * \mathrm{~T} 8 * \mathrm{~T} 6 * \mathrm{~T} 4 * \mathrm{~T} 2+$ /T29*T28*T26*T24*T22*T20*T18*T16*T14*T12*T10*T8*T6*T4*T2+ /T31*T30*T28*T26*T24*T22*T20*T18*T16*T14*T12*T10*T8*T6*T4*T2; ```EQUAL=T41; AGTB=T42; BGTA=/(T4l+T42);```


Figure 7-7 Compare PLHS501 .BEE File

### 7.2 Data Bus Operations

The following is basically an academic example, posed for the sake of illustration. Suppose some special data bus operations are desirable. For the purpose of illustration, let's label the microprocessor bus output side as ODAT0-ODAT15 and the output of our PLHS501 as D0-D15. Basically, the microprocessor will output straight data and the PLHS501 will alter it according to some plan.

We will replicate multiple identical cells, but they need not be identical in practice. Table $7-2$ shows the operations to be done (just about any could be chosen, provided they meet the gate budget).

| $I_{2}$ | $I_{1}$ | Dout |  |
| :--- | :--- | :--- | :--- |
| 0 | 0 | ODATI | (pass) |
| 0 | 1 | ODATI | (complement) |
| 1 | 0 | SWITCH |  |
| 1 | 1 | DOUBLE | SHIFT |

TABLE 7-2 Data Operations

The basic cell will require a structure as follows:


Figure 7-8 Basic Cell Structure
It may be observed that in one mode, the data passes directly, it complements in another, switches bits in another and rotates right in the last. Four input gates per bit are required to map the bits, and one output gate. Clearly, the straight PLHS501 NAND outputs can be judiciously used, but care must be taken when using other output functions. A 16 -bit data bus requires 16 cell configuration where each cell is essentially identical to Figure $7-8$ but, its internal structure may be altered to account for the particular output pins logic function.

## Signetics <br> a division of North American Philips Corporation

Signetics Company 811 E. Arques Avenue P.O. Box 3409 Sunnyvale, California 94088-3409 Telephone 408/991-2000

