### INTERNATIONAL CMOS TECHNOLOGY, INC.



# PEEL<sup>™</sup> Software and Applications Handbook

1989

Table of Contents and Introduction

PEEL Device Software Overview

Getting Started with the Software

A Step-By-Step Guide

**APEEL Language Reference** 

**Application Primer and Examples** 

Appendix

**ICT Sales Network** 

8

#### Trademarks

PEEL<sup>™</sup> and APEEL<sup>™</sup> are trademarks of International CMOS Technology Inc. PAL® and PALASM® are registered trademarks of Monolithic Memories Inc GAL® is a registered trademark of Lattice Semiconductor Corp. ABEL<sup>™</sup> is a trademark of Data I/O Corporation CUPL<sup>™</sup> is a trademark of Assisted Technology Wordstar® is a registered trademark of MicroPro International Corporation

#### PEEL<sup>™</sup> Software and Applications Handbook Copyright

This document is copyrighted. All rights are reserved. This document may not, in whole or in part, be copied, photocopied, reproduced, translated or reduced to any electronic medium or machine readable form without prior written consent from International CMOS Technology Inc.

©1989 International CMOS Technology Inc. 2125 Lundy Avenue San Jose, CA 95131

## **TABLE OF CONTENTS**

## 1.0 Introduction

| The PEEL Software and Applications Handbook |  | .1 | - | 1 |
|---------------------------------------------|--|----|---|---|
|---------------------------------------------|--|----|---|---|

### 2.0 Software Overview

| The PEEL Device Software                 | .2-1 |
|------------------------------------------|------|
| Key Features of the PEEL Device Software | .2-2 |
| PEEL Device Development Process          | .2-3 |
| APEEL Logic Assembler                    | .2-5 |
| JEDEC File Translator                    | .2-6 |

## 3.0 Getting Started with the Software

| System Requirements     |           | <br> | <br>3-1 |
|-------------------------|-----------|------|---------|
| Software Initialization |           | <br> | <br>3-2 |
| The "Main Menu"         | • • • • • | <br> | <br>3-4 |

### 4.0 A Step-by-Step Guide

| Assemble/Simulate an APEEL File4-1                  |
|-----------------------------------------------------|
| Translate a PLD File to a PEEL Device4-5            |
| Translate a PLD File to a PEEL Device (from DOS)4-8 |
| Read a JEDEC File from Disk4-11                     |
| Write (Save) a JEDEC File to Disk                   |
| Download/Upload JEDEC File via COM Port4-13         |
| Display/Print a Formatted PEEL JEDEC File           |
| Using the Built-in Editor4-17                       |
| Using the File/Directory Utilities4-19              |
| Select New Drive, Directory or Mask                 |
| Using the VT Emulator                               |
| Using the Setup Utility4-25                         |

### 5.0 APEEL<sup>™</sup> Language Reference

| Using the APEEL <sup>™</sup> Logic Assembler   | 5-1 |
|------------------------------------------------|-----|
| Elements of the APEEL <sup>™</sup> Source File | 5-2 |
| APEEL Syntax                                   | 5-8 |
| Creating New APEEL Source Files5               | -17 |

### 6.0 Application Primer and Examples

| APEEL Applications Primer                               | .6-2 |
|---------------------------------------------------------|------|
| Basic Gates (18CV8)                                     | 6-14 |
| Basic Registers and Latches (18CV8)                     | 6.20 |
| Clock Divider and Address Decoder (18CV8)               | 6-24 |
| Bus Programmable 8 to 1 Multiplexer (18CV8)             | 6-28 |
| Expandable 8-bit (or dual 4-bit)Comparator (18CV8)      | 6-31 |
| 8-Bit Counter with Function Controls (18CV8)            | 6-34 |
| 4-Bit Change-of-State Port with Interrupt (18CV8)       | 6-38 |
| 8-Bit Loadable Up/Down Counter (22CV10)                 | 6-43 |
| 8-Bit Change-of-State Port with Interrupt (22CV10Z)     | 6-49 |
| 16 to 4 Priority Encoder (173)                          | 6-55 |
| 8-Bit Greater-Than/Less-Than Magnitude Comparator (273) | 6-59 |
| 10-Bit Expandable Equality Comparator (273)             | 6-63 |
|                                                         |      |

### Appendix

| Appendix A: Editor Command Reference         | .A-1 |
|----------------------------------------------|------|
| Appendix B: Programming Support              | .B-1 |
| Appendix C: PEEL Development System (PDS-1)  | C-1  |
| Appendix D: PEEL Device Logic Array Diagrams | D-1  |

### **ICT Sales Network**

North American Sales Representatives Distributor Network World-wide Sales Representatives

## **1.0 Introduction**

#### The PEEL Software and Applications Handbook

Welcome to the PEEL Software and Applications Handbook from International CMOS Technology, Inc. (ICT). This handbook is designed to be used in conjunction with PEEL Device Software included on two floppy diskettes (System diskette and Applications diskette). PEEL Device data sheets may also be useful for reference. Please check to see if you have these items, if not, contact your local ICT sales representative listed in the last section of this manual.

Before using the software, read through chapter 2.0 of the handbook for an overview of the features and operation of the software. Once familiar with its operation, chapter 3.0 contains information for getting started with the software, including installation procedures. To assist in using the software quickly, chapter 4.0 offers a step-by-step guide for executing common functions.

For designing with the APEEL Logic Assembler, chapter 5.0 contains a complete language reference guide, and chapter 6.0 provides an APEEL applications primer as well as several application examples of APEEL source files that are included on the Applications Diskette. Additionally, the Appendix includes useful reference information for using the software and programming PEEL devices.

Please note that although this book deals exclusively with PEEL device software from ICT, PEEL designs can also be implemented using popular third party software products such as ABEL from Data I/O Corporation and CUPL from Logical Devices. Many of the examples and techniques covered in this book will serve as a useful reference when using these software packages with PEEL Devices.

We at ICT hope you find the PEEL Software and Applications Handbook a valuable tool for designing with the PEEL device family. Thank you for your interest in PEEL Devices.

## 2.0 Software Overview

#### The PEEL Device Software

The PEEL Device Software provides a PC-based tool for designing with the PEEL Device family of Programmable, Electrically-Erasable Logic devices from International CMOS Technology, Inc. (ICT). Created to serve as a "personal PLD workstation", the PEEL software allows easy access to all operations, from initial design entry to program and test using the PEEL Development System (PDS-1, see appendix B) or by using third-party programmers via the serial port download utility.

The Software consists of:

- A System diskette which contains the PEEL system and installation files.
- An Applications diskette containing several APEEL example files, one PEEL Translator example file, and the PEEL Editor system files.



#### Key Features of the PEEL Device Software

Key features include:

- APEEL<sup>™</sup> Boolean Logic Assembler
  - Supports all advanced features of PEEL devices
  - "PALASM®-like" sum-of-products equations
  - "ABEL®-like" macro cell definitions
  - Logic Simulation
- JEDEC file translators for sixty-nine Standard PLDs
- Built-in File Editor
  - To edit source, JEDEC, or test-vector files
  - Interacts with APEEL when assembly errors are found
- Upload/download JEDEC files via the serial port 1 or 2
- Video Terminal Emulator to control third-party programmers within the PEEL software environment
- Expandable and Accessable
  - New features and devices supported with software updates
  - No copy protection

#### **PEEL Device Development Process**

The PEEL Device Software includes two unique tools for designing with PEEL devices:

- The APEEL Logic Assembler
- JEDEC File Translator

Figure 2-1 illustrates the PEEL development process using the APEEL Logic Assembler or the JEDEC file translator.

The **APEEL Logic Assembler** can be used to create new designs specifically for PEEL devices. The software includes a screen editor for entering and editing your design files. APEEL software then assembles the design file and creates a JEDEC file which can be used to program PEEL devices.

The **JEDEC file translator** allows logic functions created for other PLDs to be programmed into PEEL devices. That is, if you have used some other logic assembler or compiler to develop a design for one of the PLDs which PEEL devices emulate, you can use the translator to program the same function into a PEEL device. The translator reads a PLD JEDEC file and produces a new JEDEC file which can be used to program a PEEL device.

Once a PEEL JEDEC file has been created, a PEEL device can be programmed and secured by using ICT's PEEL Development System (see Appendix B) or by using third-party programmers via the serial port utility.

#### Figure 2-1. The PEEL Device Development Process



#### **APEEL Logic Assembler**

The APEEL Logic Assembler is used to create new designs specifically for PEEL devices. Using the software's built-in text editor or another word processor, APEEL logic equations and test vectors are entered and saved as an APEEL input file (refer to the APEEL Language Reference chapter for a detailed description of APEEL).

Once the design is entered and saved, APEEL software can assemble the file. During assembly APEEL software checks for syntax errors. If errors are found, the APEEL assembler will interact with the editor to open the file and move the editor's cursor to the error (highlighted) location. A brief description of the type of error will also be displayed on the upper right corner of the editor's screen.

When the input file is successfully assembled, its logic functions may be simulated if user-defined test vectors are provided. If simulation errors are found, APEEL will specify the test vector where the error occurred. If there are no simulation errors, a PEEL JEDEC (\*.JED) file can be created, or optionally, fault grading may be performed.

Fault grading provides the means for measuring how well the test vectors for the APEEL file cover all possible logic conditions. The fault grader exhaustively exercises the inputs of the simulated files to check for "stuck-at-1" and "stuck-at-0" fault conditions. It then compares the vectors required to do this with the APEEL vectors provided. The final grading is given in percentage of faults covered. The better the percentage of coverage the more likely the test vectors will have tested all possible logic conditions. A report of low fault coverage is an indication to improve the APEEL file test vectors. Because fault grading can be very time consuming, it is optional and recommended only for those who wish to use it.

Once the assembly (simulation and fault grading are optional) is completed, a PEEL device JEDEC file is created and saved to disk. This JEDEC file is now ready to be used for programming a PEEL device. A step-by-step procedure for assembling and simulating an APEEL design file is described in the chapter titled "A Step-By-Step Guide".

#### These PEEL devices are supported by APEEL V3.30

| PEEL18CV8 | PEEL20CG10 | PEEL22CV10 | PEEL22CV10Z |
|-----------|------------|------------|-------------|
| PEEL153   | PEEL173    | PEEL253    | PEEL273     |

#### **JEDEC File Translator**

The JEDEC-file translation utility of the PEEL Device Software translates JEDEC files created for programming other PLDs to JEDEC files used for programming PEEL devices. The translated JEDEC file will program a PEEL device to be a pin-for-pin replacement for the original PLD. The utility translates JEDEC files that have been written on a disk. If a disk file is not available, the pattern may be read from a master device with ICT's PEEL Development System or a third-party programmer. When a third-party programmer is used, the software will allow the file to be uploaded through a serial port and written to a file.

The translated PEEL JEDEC file is given the name of the original file with the ".JED" extension modified to ".JEX". The ".JEX" file can then be used to program your PEEL devices. The complete procedure for translating a PLD file to a PEEL device is described in the section titled "A Step-By-Step Guide".

| These devices c | can be | translated to | the | PEEL180 | SV8 | (V3.30) |
|-----------------|--------|---------------|-----|---------|-----|---------|
|-----------------|--------|---------------|-----|---------|-----|---------|

| PAL16L8 | PAL16R8  | PAL16R6  | PAL16R4  |
|---------|----------|----------|----------|
| PAL16P8 | PAL16RP8 | PAL16RP6 | PAL16RP4 |
| PAL10L8 | PAL12L6  | PAL14L4  | PAL16L2  |
| PAL10H8 | PAL12H6  | PAL14H4  | PAL16H2  |
| PAL16H8 | PAL16LD8 | PAL16HD8 | PAL18P8  |
| GAL16V8 | EP310    | EP320    | 5C031    |
| 5C032   |          |          |          |

These devices can be translated to the PEEL20CG10, PEEL22CV10, and PEEL22CV10Z (V3.30)

| PAL20L8   | PAL20R8  | PAL20R6  | PAL20R8  |
|-----------|----------|----------|----------|
| PAL20L10  | PAL20L2  | PAL18L4  | PAL16L6  |
| PAL14L8   | PAL12L10 | PAL22V10 | PAL20G10 |
| GAL 201/8 |          |          |          |

The PAL22V10 is JEDEC file compatible with PEEL22CV10, so no translation is actually performed by the software in this case.

These devices can be translated to the PEEL273 (V3.30)

PLS173 PAL20L10 PAL20L8

These devices can be translated to the PEEL173 (V3.30)

- PAL20L10 PAL20L8
- The PLS173 is JEDEC file compatible with PEEL173, so no translation is actually performed by the software in this case.

These devices can be translated to the PEEL253 (V3.30)

PLS153

I

l

l

These devices can be translated to the PEEL153 (V3.30)

- PLS153
- The PLS153 is JEDEC file compatible with PEEL153, so no translation is actually performed by the software.



## 3.0 Getting Started

#### System Requirements

The following computer system configuration is required for operating the PEEL Device Software:

- IBM PC, XT, AT or compatible
- Minimum 384 K-bytes RAM space
- Monochrome or Color Display
- Two 360K floppy-disk drives, or one floppy disk drive and a hard disk
- · DOS version 2.1 or greater



- Although the minimum RAM requirement is specified at 384 Kbytes, the PEEL software can still be executed with only 256 Kbytes of RAM. When using the software on a system with only 256 K-bytes of RAM, certain features (listed below) must be executed from DOS by typing the specific file name.
  - PEEL Translator (PEELXLT.EXE).
  - PEEL Editor (PEELEDIT.COM).

#### Software Initialization

#### **Floppy-Disk Based Systems**

If you are using a computer with only two floppy disk drives, the following procedure must be used the first time you use your PEEL Device Software, or whenever you move your PEEL Device Software to a different computer:

- > Turn computer on and boot-up with DOS 2.1 or greater
- > Make sure you have a back-up of the original diskettes.
- Insert the system diskette into drive A: and the applications diskette into drive B:
- > At the A: prompt, type INIT and press [ENTER].
- Answer the set-up questions for system-type, color, and sound. Be sure to select B for dual floppy-disk operation when prompted for system-type.
- > The software is now ready for operation.

Once initialized for your computer, the software is re-entered with the following procedure:

- > Turn computer on and boot-up with DOS 2.1 or greater.
- Insert the system diskette into drive A: and the Applications diskette into drive B:
- ➤ At the A: prompt, type PEEL and press [ENTER]. Note, press [ENTER] twice to bypass the PEEL software boot-up messages.
- > The software is now ready for operation.
- The system diskette must remain in drive A If you wish to access a file from another diskette, use drive B: (see "Select New Drive, Directory, or Mask" in Step-By-Step Chapter for instructions on changing the file selection screen to select drive B:)

#### Hard-Disk Based Systems

If you are using a computer with a hard disk, the following procedure must be used the first time you use your PEEL Device Software, or whenever you move your PEEL Device Software to a different computer.

- > Turn computer on and boot-up with DOS 2.1 or greater
- > Make sure you have a back-up of the original disk diskettes.
- Insert the system diskette into drive A:
- Type A:INSTALHD and press [ENTER]. This creates a "PEEL" directory on your hard disk and copies into it all the files from both the diskettes.
- A prompt will instruct your to insert the PEEL Applications diskette into the drive. Do so and press [ENTER]. After copying the files, the PEEL software will boot-up automatically.
- Answer the set-up questions for system-type, color, and sound. Be sure to select A for hard disk operation.
- The software is now ready for operation. After exiting the software, you can leave the PEEL directory by typing CD\ and pressing [ENTER].

Once the PEEL Device software is installed in your hard disk, the software can be started with the following procedure:

- ➤ Turn computer on and boot-up with DOS 2.1 or greater.
- Change to the PEEL directory by typing CD\PEEL and pressing [ENTER].
- Type PEEL and press [ENTER]. Note, press [ENTER] twice to bypass the PEEL software boot-up messages.
- The software is now ready for operation. After exiting the the software, you can leave the PEEL directory by typing CD\ and pressing [ENTER].

#### The "Main Menu"

The first screen to appear after the initialization and sign-on messages will be the "Main Menu" which contains the majority of the commands used with the PEEL Device Software Kit.

```
ICT PEEL DEVICE SOFTWAREVersion 3.30DEVICE [PEEL18CV8]JEDEC FILE [R8CNTR.JEX]UTILITIESL = LoadR = Read from diskH = HelpP = ProgramW = Write to diskS = SetupV = VerifyC = COM Transmit/receiveF = File/directoryT = TestD = Display/printE = EditU = aUxiliaryX = TranslateA = APEELK = checKsum [A8A0]Z = VT EmulationQ = Quit to DOSEnter Selection >
```

The main menu is divided into three command sections: **DEVICE**; **JEDEC FILE**; and **UTILITIES**.

The **DEVICE** section controls all operations pertaining to the PEEL device programmer module. The commands include: **Load**; **Program**; **Verify**; **Test**; and other auxiliary functions. These commands are provided only to illustrate the capabilities of the PEEL Development System.

The JEDEC FILE section controls the primary operations used for working with JEDEC files. These functions include: Read from disk; Write to disk; COM transmit/receive; Display/print; Translate; and Check sum.

The UTILITIES section allows access to the functions: Help; Setup; File/directory; Edit; APEEL; VT Emulation; and Quit to DOS.

#### **Command Selection**

To select a command from the main menu, simply press the letter that corresponds to its adjacent command word. Some commands will have secondary command menus or prompts which must be followed to complete the original command.

#### "H" is for Help!

When in doubt about the operation of a command, press H for help. This will display an on-line help file that contains a complete list of the PEEL Device Software commands, each with a brief description of its operation. After selecting H, any command letter can be pressed to get help on that specific command, or press H to present the entire help file.

#### Exiting And Re-entering The Software

Exiting the PEEL software is done from the main menu by pressing **Q** for **Quit to DOS**. Doing this will cause a prompt to appear asking you to confirm that you wish to quit. If you respond by entering **Y**, the software will terminate and the DOS prompt will appear.

To re-enter the software from DOS, simply type **PEEL** and press **[ENTER]**. (Press **[ENTER]** twice to bypass the PEEL software boot-up messages.)

## 4.0 A Step-by-Step Guide

In this section, the step-by-step procedures illustrate how to use some of the major main menu commands. Please note that you must begin each of the step-by-step procedures at the main menu prompt.

#### Assemble/Simulate an APEEL File

|                    | TCT PEEL DEVICE SOFTWARE | Version 3.30                  |
|--------------------|--------------------------|-------------------------------|
|                    |                          |                               |
| DEVICE [PEEL18CV8] | JEDEC FILE [R8CNTR.JEX]  | UTILITIES                     |
| L = Load           | R = Read from disk       | H = Help                      |
| P = Program        | W = Write to disk        | S = Setup                     |
| V = Verify         | C = COM Transmit/receive | F = File/directory            |
| T = Test           | D = Display/print        | E = Edit                      |
| U = aUxiliary      | X = Translate            | $\mathbf{A} = \mathbf{APEEL}$ |
|                    | K = checKsum [A8A0]      | Z = VT Emulation              |
|                    |                          | Q = Quit to DOS               |
| Enter Selection >  |                          |                               |
|                    |                          |                               |
|                    |                          |                               |
|                    |                          |                               |
|                    |                          |                               |
|                    |                          |                               |

#### 1. Press "A" for APEEL

The "Assemble File" selection screen will appear. Several demonstration APEEL (.APL) files provided on the Applications diskette will appear. Use the arrow keys followed by [ENTER] to select the APEEL (.APL) file you wish to assemble. If you don't see the file you wish to assemble, refer to "Select New Drive, Directory, or Mask" found later in this section.



Use V8GATES.APL if this is the first time you are using the assembler.

#### 2. Watch the Assembly Process

A description of the assembly process which converts the APEEL file to the PEEL JEDEC file will be displayed. Also, this description which includes the macro cell definitions (if applicable to the PEEL device), pin assignments, and product term assignments is written to a file with the same file name as the source file but with an ".OUT" extension.

By pressing [Ctrl] S, you can start or stop the scrolling of the display. Additionally, pressing [Ctrl] C will terminate the assembly (or simulation) process.

If a syntax error is found, the assembly will stop and the APEEL file line number with the error will be displayed. The editor may then be entered to correct the file. Press [space bar] to enter the editor, or press Q to terminate the assembly and return to the main menu. Once the editor has opened the file, the cursor automatically goes to the error line which will also be highlighted. A brief description of the error and its location is also displayed in the upper right corner of the screen. When you return from the editor, the PEEL software will prompt you to re-assemble the file.

**If no syntax errors are found**, the assembly will conclude and the following prompt will appear:

Assembly Completed...S=Simulation...Q=Quit..any other key to continue

Note: Simulation is performed only if the APEEL file has test vectors.

If you press Q (for Quit) after assembly, simulation or fault grading, the APEEL process will terminate and the PEEL JEDEC file will not be created nor saved to disk. If you want the JEDEC file to be created and saved to disk but do not want simulation, you must press any key other than "S" or "Q" (such as the space bar).

#### 3. Press the "S" for Simulation (optional)

If there are no test vectors present in the file, APEEL will omit the simulation and fault grading. However if test vectors are provided, they can be used to verify the function of the APEEL design through simulation. If simulation is selected, each vector will be displayed one at a time.

If a simulation error is found, an error message will appear prior to the vector that fails. An example of the error message is shown below.

ERROR! vector# 8 pin=19 sim=L vec=H

The above error message means that the vector 8 in the APEEL file has a simulation error on pin 19. The simulated level for this output is a LOW, but the expected output level (specified in the file) is a HIGH.

**If no simulation errors are found**, simulation will conclude and the following prompt will appear:

Simulation Completed..F=Fault Grade..Q=Quit..any other key to continue

The prompt shown above assumes that the Fault Grade mode has been turned ON (the default condition is OFF) in the Setup utility. If you wish to perform fault grading, press **S** (for Setup) at main menu prompt. Then, press **F** to set the Fault Grade mode to ON.

#### 4. Press "F" for Fault Grade Test Vectors (optional)

Fault grading provides the means for measuring how well the test vectors for the APEEL file cover all possible logic conditions. The final grading is given as a percentage of Stuck-At-One (SA1) and Stuck-At-Zero (SA0) faults covered. The higher the percentage of coverage the more likely the vectors will have tested all possible logic conditions. A very low percentage is an indication that the test vectors need to be improved.

Fault grading can be very time consuming. You can press the space bar during the fault-grading process to get a report on the progress of the fault grading, or you can press **Q** to terminate the process.

#### 5. Press any key to continue

Regardless of whether simulation or fault grading was used, pressing any key after proper assembly will allow the JEDEC file to be created and saved to disk. The JEDEC file will then be displayed and loaded into memory. This JEDEC file will be given the same name as the APEEL source file but with the extension changed to ".JED". The JEDEC file can then be used to program a PEEL device.

During assembly, simulation, or fault grading, a description of the execution process is displayed. For APEEL designs which many product terms, the time consumed for displaying this execution process can be significant. There is a feature in the Setup utility which will turn off the display mode and speed-up the assembly process. Press **S** (for Setup) at main menu prompt. Then, press **B** to set the Brief mode to ON (default condition is OFF).

#### Translate a PLD File to a PEEL Device

|                    | ICT PEEL DEVICE SOFTWARE | Version 3.30       |
|--------------------|--------------------------|--------------------|
| DEVICE [PEEL18CV8] | JEDEC FILE [R8CNTR.JEX]  | UTILITIES          |
| L = Load           | R = Read from disk       | H = Help           |
| P = Program        | W = Write to disk        | S = Setup          |
| V = Verify         | C = COM Transmit/receive | F = File/directory |
| T = Test           | D = Display/print        | E = Edit           |
| U = aUxiliary      | X = Translate            | A = APEEL          |
|                    | K = checKsum [A8A0]      | Z = VT Emulation   |
|                    |                          | Q = Quit to DOS    |
| Enter Selection >  |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |

#### 1. Press "X" for Translate JEDEC file

A prompt will appear on the screen:

```
D = translate Device loaded in memory
F = translate File on disk
Q = Quit
Enter Selection >
```

#### 2. Press "F" to translate File on disk

The "Translate File" selection screen will appear showing the files found in the directory currently specified. If you don't see the file you wish to translate, refer to "Select New Drive, Directory, or Mask" found later in this section.

(Note: the selection "D = translate Device loaded in memory" is used when translating programming patterns that have been loaded directly from master devices with the PEEL Development System hardware.)

#### 3. Use the arrow keys to select the file to be translated

Note that a translation demonstration file, **R8CNTR.JED**, is provided on the PEEL Applications Diskette. **R8CNTR.JED** is a PAL16R8 JEDEC file for an 8-bit counter.

#### 4. Press the [ENTER] key to select file

A list of the target PEEL devices for the translation will appear:

A = 18CV8 B = 253 F = 153 C = 273 G = 173 D = 22CV10Z H = 22CV10 E = 20CG10 Select target PEEL device >

Note that you can terminate the translation process and return to the main menu by pressing **[Esc]**.

#### 5. Press the letter of target PEEL device

If you are translating the demonstration file, **R8CNTR.JED**, be sure to type **A** to select the PEEL18CV8.

#### 6. Press the letter of source PLD

A list of PLDs that can be translated to the selected target PEEL device will appear. If translating the demonstration file, **R8CNTR.JED**, select the letter **B** for 16R8. Otherwise, select the letter corresponding to the part number of the PLD JEDEC file being translated.

Once you have made your selection, a prompt will appear to confirm your choice of the target PEEL device and source PLD.

| Source JEDEC File: R8CNTR.JED    |                            |
|----------------------------------|----------------------------|
| Source Device<br>PAL16R8         | Target Device<br>PEEL18CV8 |
| Do you want to change the device | type? (Y/N) >              |

If you press **Y**, you will be asked to repeat steps 5 and 6. If you do not need to change your selection, press any other key.

#### 7. Watch the translation process

The translated and formatted PEEL JEDEC file will then be displayed on the screen, updated in memory, and written to the currently selected drive. The file written will have the same name as the original JEDEC file with the extension modified to ".JEX" to designate a translated file. The ".JEX" file can then be used to program a PEEL device.

Turning on the Brief mode (default condition is off) in the Setup utility will turn the display function off to speed-up the translation process.

#### Translate a PLD File to a PEEL Device (from DOS)

When running the PDK-1 software on a system with only 256 Kbytes of RAM the translator utility cannot be used within the PEK-1 environment. However, the translator utility can be executed directly from DOS. The PEEL device translator program is contained in a file called PEELXLT.EXE on the program diskette. When using PEELXLT.EXE, you must specify a PLD source file name, a source PLD type, and a target PEEL device type.

#### Type "PEELXLT source\_filename source\_PLD target\_PEEL\_device"

You need not specify the extension for the PLD source file name because it is assumed to have a ".JED" extension. The source PLD and target PEEL device types recognized by the translator are listed below.

An example of the PEEL Translator command format is:

PEELXLT R8CNTR 16R8 18CV8

Here, the JEDEC file "R8CNTR.JED" is used in the translation from the PAL16R8 to the PEEL18CV8 device, and in the process creates the PEEL device JEDEC file "R8CNTR.JEX".

#### When translating to the PEEL18CV8

#### Target PEEL device: 18CV8 Source PLDs:

| 16L8  | 16R8  | 16R6  | 16R4  |      |
|-------|-------|-------|-------|------|
| 16H8  | 16P8  | 16RP8 | 16RP6 |      |
| 16RP4 | 16LD8 | 16HD8 | 18P8  |      |
| 16L2  | 16H2  | 14L4  | 14H4  |      |
| 12L6  | 12H6  | 10L8  | 10H8  |      |
| 310   | 320   | 5C031 | 5C032 | 16V8 |

When translating to the PEEL20CG10, PEEL22CV10, or PEEL22CV10Z

Target PEEL device: 20CG10, 22CV10, or 22CV10Z Source PLDs:

| 20R8  | 20R6  | 20R4  | 20L8 |
|-------|-------|-------|------|
| 20L10 | 20L2  | 18L4  | 16L6 |
| 14L8  | 12L10 | 20G10 | 20V8 |

22V10 (20CG10 and 22CV10Z only)

No translation is necessary for PAL22V10 to PEEL22CV10 because they are JEDEC-file compatible.

When translating to the PEEL273

Target PEEL device: 273 Source PLDs:

PLS173 20L10 20L8

When translating to the PEEL173

PEEL device: 173 Source PLDs:

20L10 20L8

No translation is necessary for PLS173 to PEEL173 because they are JEDEC-file compatible.

When translating to the PEEL253

Target PEEL device: 253 Source PLD:

**PLS153** 



The translator program also provides the capability of translating multiple PLD JEDEC files to different types PEEL device JEDEC files through the application of a DOS batch file. Here is an example of the batch file (PAL2PEEL.BAT).

PEELXLT R8CNTR 16R8 18CV8 PEELXLT DECODE 20L10 22CG10

Typing **PAL2PEEL** followed by **[ENTER]** will automatically translates the R8CNTR.JED and DECODE.JED to their respective target PEEL device JEDEC files (R8CNTR.JEX and DECODE.JEX).

#### Read a JEDEC File from Disk

```
ICT PEEL DEVICE SOFTWARE
                                Version 3.30
  DEVICE [PEEL18CV8]
             JEDEC FILE [R8CNTR.JEX]
                              UTILITIES
          L = Load
P = Program
P = Flog_{1}
V = Verify
T = Test
U = aUxiliary X = Translate
                           A = APEEL
Z = VT Emulation
            K = checKsum [A8A0]
                              Q = Quit to DOS
Enter Selection >
           _____
           _____
```

#### 1. Press "R" to Read JEDEC File

The "Read File" selection screen will appear showing the files found in the current directory with the specified file mask.

#### 2. Use the arrow keys to locate the JEDEC file

If the file you wish to read is not displayed, refer to "Select New Drive, Directory, or Mask" found later in this section.

#### 3. Press [ENTER] to read the selected file

The PEEL device JEDEC file will be read and displayed on the screen. When you respond to the prompt "any key to continue", the PEEL software will display the name of the file that has been read and the PLD or PEEL device type that has been selected for this JEDEC file. If the selection is correct, press **C** to continue and the main screen will appear. If you press any other key, you will be asked to choose a new device type. The main screen appears once a new device has been selected.

#### Write (Save) a JEDEC File to Disk

|                    | ICT PEEL DEVICE SOFTWARE | Version 3.30       |
|--------------------|--------------------------|--------------------|
| DEVICE [PEEL18CV8] | JEDEC FILE [R8CNTR.JEX]  | UTILITIES          |
| L = Load           | R = Read from disk       | H = Help           |
| P = Program        | W = Write to disk        | S = Setup          |
| V = Verify         | C = COM Transmit/receive | F = File/directory |
| T = Test           | D = Display/print        | E = Edit           |
| U = aUxiliary      | X = Translate            | A = APEEL          |
|                    | K = checKsum [A8A0]      | Z = VT Emulation   |
|                    |                          | Q = Quit to DOS    |
| Enter Selection >  |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |
|                    |                          |                    |

#### 1. Press "W" to Write JEDEC File

The "Write File" selection screen will appear showing the files found in the directory with the file mask currently specified.

#### 2. Use the arrow keys to locate the JEDEC file (for over-writing only)

If you wish to over-write an existing file and this file is not displayed, refer to "Select New Drive, Directory, or Mask" found later in this section.

If you wish to enter a new file name, press **W** and then type in the new file name followed by **[ENTER]**. After the file has been written to disk, the PEEL software will return to the main menu (bypassing step 3).

#### 3. Press [ENTER] to over-write to the selected file

The PEEL software will prompt you to confirm over-writing to the selected file. Press Y to over-write the selected file (press N to cancel the command).

#### Download/Upload JEDEC File via the COM Port

```
ICT PEEL DEVICE SOFTWAREVersion 3.30DEVICE [PEEL18CV8]JEDEC FILE [R8CNTR.JEX]UTILITIESL = LoadR = Read from diskH = HelpP = ProgramW = Write to diskS = SetupV = VerifyC = COM Transmit/receiveF = File/directoryT = TestD = Display/printE = EditU = aUxiliaryX = TranslateA = APEELK = checKsum [A8A0]Z = VT EmulationQ = Quit to DOSEnter Selection >
```

This feature allows you to transfer PEEL device JEDEC files between the PC and a third-party programmer.

#### 1. Press "C" to select COM transmit/receive mode

The COM port parameter selection screen shown below will appear.

| C = COM Port      | : COM1 | X = Transmit JEDEC to COM  |
|-------------------|--------|----------------------------|
| B = Baud-rate     | : 4800 | R = Receive JEDEC from COM |
| D = Data size     | : 8    | Q = Quit to main menu      |
| S = Stop bits     | : 1    |                            |
| P = Parity        | : NONE |                            |
| T = Timeout       | : 30   |                            |
|                   |        |                            |
| Enter Selection > |        |                            |

#### 2. Set the port parameters by pressing the appropriate letters

The port parameter value selection is made by pressing each letter corresponding to the port parameters continuously until the desired parameter value appears.

## 3. To upload a PLD JEDEC file from a third-party programmer to memory:

#### 3a. Press "R" to Receive JEDEC FILE

The PEEL software will wait for the third-party programmer to transmit the JEDEC file. If no JEDEC file is transmitted within the period specified by the timeout value (in seconds), the COM Receive mode will terminate.

You can terminate the JEDEC file reception or transmission any time by pressing **[Esc]**.

#### 3b. Set the third-party programmer to Transmit JEDEC file

When transmission is complete, the PEEL software will display the name of the file (COM.JED) that has been read and the PLD or PEEL device type that has been selected for this JEDEC file. If the selection is correct, press C to continue and the main menu will appear. If you press any other key, you will be asked to choose a new device type. The main menu appears once a new device has been selected.

The uploaded JEDEC file resides in the memory only and has not been saved to disk yet.

## 4. To download a JEDEC file from memory to a third-party programmer:

#### 4a. Set the third-party programmer to Receive mode

The PEEL software is equipped with a video terminal emulator (refer to "Using The VT Emulator" found later in this section) so that you can set your third-party programmer to "receive" mode without exiting the software. (Be sure to set your third-party programmer to the correct PEEL device type.)

#### 4b. Press "X" to Transmit JEDEC file to COM

If the transmission is successful, press any key to return to the main menu.



- COM port parameters incorrectly set.
- Incompatible PEEL device type between the PEEL software and the third-party programmer.

#### **Display/Print a Formatted PEEL JEDEC File**

```
ICT PEEL DEVICE SOFTWAREVersion 3.30DEVICE [PEEL18CV8]JEDEC FILE [R8CNTR.JEX]UTILITIESL = LoadR = Read from diskH = HelpP = ProgramW = Write to diskS = SetupV = VerifyC = COM Transmit/receiveF = File/directoryT = TestD = Display/printE = EditU = aUxiliaryX = TranslateA = APEELK = checKsum [A8A0]Z = VT EmulationQ = Quit to DOSEnter Selection >
```

With this feature, you can display or print the JEDEC file that currently resides in memory. If you want to display or print a file from disk, you must first read the file into memory (refer to "Read a JEDEC file from disk").

The default setting for the printer port is LPT1. To select a different printer port, use the Setup utility. Press **S** at the main menu prompt, and then press **P** to change the printer port.

#### 1. Press "D" to Display/print the JEDEC file

A prompt will appear on the screen:
```
D = list JEDEC to Display
P = list JEDEC to Printer
Q = Quit to main menu
Enter Selection >
```

## 3. If "D" is pressed

The currently loaded PEEL device JEDEC file will be displayed on the screen, 24 lines at a time. To display the next full screen, press the space bar or any key other than "D" or "Q". To exit the display mode, press **Q**. To display the entire file without pausing, press **D** again.



## 4. If "P" is pressed

The currently loaded PEEL device JEDEC file will be output to the printer port. Make sure your printer is on-line and ready to receive data. The main menu will appear when printing is complete.

# Using The Built-in File Editor

```
ICT PEEL DEVICE SOFTWAREVersion 3.30DEVICE [PEEL18CV8]JEDEC FILE [R8CNTR.JEX]UTILITIESL = LoadR = Read from diskH = HelpP = ProgramW = Write to diskS = SetupV = VerifyC = COM Transmit/receiveF = File/directoryT = TestD = Display/printE = EditU = aUxiliaryX = TranslateA = APEELK = checKsum [A8A0]Z = VT EmulationQ = Quit to DOSEnter Selection >
```

## 1. Press "E" for Edit

The "Edit File" selection screen will appear. Use the arrow keys to select the file you wish to edit and then press **[ENTER]**. (If the file you wish to edit is not displayed, refer to "Select New Drive, Directory, or Mask" found later in this section.) The selected file is loaded into the editor which appears on the screen. Notice the command window in the upper right corner. The command window will display how and when to enter or exit the pull-down menu.

## 2. Press the [F10] key, then [ENTER] for pull-down menu

The first pull-down command menu will appear. Use the right and left arrow keys to select the command type. You can use the up and down arrow keys to select the specific command, then press **[ENTER]** to invoke the command.

## 3. Press the [Esc] key twice to exit pull-down menu

This will cause the pull-down windows to disappear and return the editor to edit mode. When in the edit mode, the standard cursor key functions and WordStar®-type [CTRL] commands can be used. For further information on the editor commands, refer to Apendix A or any reference book for the WordStar-type editors.

## 4. To exit Editor, press [F10], then "F", then "Q"

If any changes were made, a prompt will appear for saving changes. If you wish not to save the edits, press N . The main menu will then appear.

You can also use [CTRL] K [CTRL] Q (during edit mode only) to exit the editor.

# **Using The File/Directory Utilities**

```
ICT PEEL DEVICE SOFTWARE
                                                               Version 3.30
   DEVICE [PEEL18CV8]
                          JEDEC FILE [R8CNTR.JEX]
                                                           UTILITIES
L = Load R = Read from disk H = Help

P = Program W = Write to disk S = Setup

V = Verify C = COM Transmit/receive F = File/directory

T = Test D = Display/print E = Edit

U = aUxiliary X = Translate A = APEEL

K = checKsum [A8A0] Z = VT Emulation
                                                           Q = Quit to DOS
Enter Selection >
                      _____
                      _____
```

## 1. Press "F" for File/directory

The "File/directory" selection screen will appear. The create directory, rename directory, rename file, and erase file commands are located in the upper left corner of the screen. (Please refer to "Select New Drive, Directory, or Mask" found later in this section for changing directory or file mask.)

If you are erasing or renaming a file, use the arrow keys to select the file, and then go to step 3.

## 2. Press "C" to create a directory, or press "R" to remove a directory

The PEEL software will prompt you to enter the directory name. You might need to use the [Back Space] key to delete the file or directory name selected by the file selection screen cursor. If the operation is successful, you will be returned to the "File/directory" selection screen. Error messages will be displayed if the operation is unsuccessful.



The directory created or removed must be a sub-directory of the current directory. Please refer to "Select New Drive, Directory, or Mask" for changing the directory.

#### 3. Press "E" to erase a file, or press "N" to rename a file

If you press E to erase a file, a prompt for you to enter the file name appears. Most probably, a file name (selected from the file selection screen cursor) has already been typed in at this prompt. If the file name is correct, press [ENTER]. If the file name is incorrect, use the [Back Space] key to delete the file name, and then enter the correct file name followed by [ENTER]. A confirmation prompt will appear.

If you press **N** to rename a file, the file name selected from the file selection screen cursor appears at the "old file" prompt. If the file name is correct, press **[ENTER]**. If the file name is incorrect, use the **[Back Space]** key to delete the file name, and then enter the correct file name followed by **[ENTER]**. When the "new file" prompt appears, type in the new file name followed by **[ENTER]**.

If the operation is successful, the PEEL software returns you to the "File/directory" file selection screen. Error messages will be displayed if the operation is unsuccessful.

## Select New Drive, Directory, or Mask

The file selection screen which shows the files of the current directory with the specified file mask is used by the Read from disk, Write to disk, Translate (from file on disk), File/directory, Edit, and APEEL utilities. A menu of file selection options appears in the upper right corner of the screen.

#### Press "D" to change drives.

If you wish to display a different drive, press **D**. Type in the letter of the new drive (do not press **[ENTER]** after the drive letter).

## Press "I" to specify a different directory

If you wish to display the files of a different directory, press I. Backspace over the current directory name and type the new name followed by [ENTER]. For example, typing PEEL\DESIGNS would select the sub-directory DESIGNS in the directory PEEL.

You may have noticed that all sub-directories in the current directory are displayed with a "/" at the beginning of each directory name. You can actually change directory by moving the file selection cursor to directory and then press [ENTER]. The "/." and "/.." represents the root and the next higher directory respectively. So, you can change your directory to the root directory if you select "/." and then press [ENTER].

## Press "M" for change file mask

During file selection, the PEEL software uses a mask to control which files will be displayed. If you wish to change the mask, press **M**, then backspace over current mask and type the new mask to be used. Note that a " \* " is a wild card. For instance, a " \*.JE\* " will show all files with extensions that consist of the " .JE " (i.e., .JED and .JEX files). A " \*.\* " overrides the mask and shows all files. The mask defaults to " \*.A\* " in the Edit and APEEL directories in order to select the APEEL (\*.APL) files.

#### Select File

Once the desired drive, directory, and mask is set, the file can now be selected. Use the arrow keys to highlight the desired file and press [ENTER].

## 6. Press "Q" for Quit

If you wish not to select a file for read, write, translate, and etc., press **Q** to return to the main menu.

# Using The VT Emulator

```
ICT PEEL DEVICE SOFTWAREVersion 3.30DEVICE [PEEL18CV8]JEDEC FILE [R8CNTR.JEX]UTILITIESL = LoadR = Read from diskH = HelpP = ProgramW = Write to diskS = SetupV = VerifyC = COM Transmit/receiveF = File/directoryT = TestD = Display/printE = EditU = aUxiliaryX = TranslateA = APEELK = checKsum [A8A0]Z = VT EmulationQ = Quit to DOSEnter Selection >
```

This feature allows you to exercise a video terminal emulation so that you can control the functions of your third-party programmer (if applicable). Programming features such as program, load, and verify can then be initiated without exiting the PEEL software.

## 1. Press "Z" to select VT Emulation

The COM port parameter selection screen (similar to that of the COM transmit/receive utility) will appear.

```
C = COM Port : COM1

B = Baud-rate : 4800 T = Terminal Emulation

D = Data size : 8 Q = Quit to main menu

S = Stop bits : 1

P = Parity : NONE

T = Timeout : 30

Enter Selection >
```

#### 2. Press the letter corresponding to the port parameters

The port parameter value selection is made by pressing each letter corresponding to the port parameters continuously until the desired parameter value appears.

Changing the port parameter values here will affect the port parameter values set in the COM transmit/receive utility, and visa versa.

#### 3. Press "T" to start terminal emulation

You can terminate the terminal emulation any time by pressing **[Esc]**. When you press **[Esc]** to abort, the ASCII character for the [Esc] key would not be sent to the COM port. Some third-party programmers will end terminal or remote mode if they receive the [Esc] ASCII character. In this way, you can exit the terminal emulation mode without terminating your third-party programmer's terminal or remote mode. One application example is the downloading of the PEEL device JEDEC file from memory to your third-party programmer via the COM port. Here, you use the terminal emulation to set the programmer to receive mode and then return to the main menu to execute the COM Transmit utility.

# **Setup Utilities**

```
ICT PEEL DEVICE SOFTWARE
                                                         Version 3.30
  DEVICE [PEEL18CV8]
                       JEDEC FILE [R8CNTR.JEX]
                                                      UTILITIES
L = Load R = Read from disk H = Help

P = Program W = Write to disk S = Setup

V = Verify C = COM Transmit/receive F = File/directory

T = Test D = Display/print E = Edit

U = aUxiliary X = Translate A = APEFT

K = chc-T
                      x = TranslateA = APEELK = checKsum [A8A0]Z = VT Emulation
                                                     Q = Quit to DOS
Enter Selection >
                    ______
```

Additional features of the PEEL Device Software can be found under the Setup utility heading.

## 1. Press "S" for Setup Utility

Allows you to configure the operation of the system to suit your preferences or the requirements of your computer. Note that most the Setup configurations are saved to the "PEEL.SAV" file. Every time you call the PEEL software by typing PEEL followed by [ENTER], the previous Setup configuration will be implemented. If you type [INIT], the default configuration will be implemented.

Q = Quit to last menu Enter Selection >

```
C = Color mode is ONS = Sound mode is ONT = Timer is OFFB = Brief mode is OFFD = Directory sort is ONV = Vector trace mode is OFFF = Fault Grade is OFFA = APEEL output file mode is ONR = Reset Program CounterP = Printer Port is LPT1
```

#### Color Mode

Pressing  $\mathbf{C}$  will toggle the color mode from ON to OFF, and visa versa. Turn color mode on for color monitors. Turn color mode off for monochrome monitors or to display in black and white on color monitors.

#### Sound Mode

Pressing **S** will toggle the sound mode from ON to OFF, and visa versa. When the sound mode is on, your PC will produce various sounds as different functions are executed. When the sound mode is off, no sounds will be produced.

#### Timer Mode

Pressing T will toggle the timer mode from ON to OFF, and visa versa. During programming, when the timer mode is on, the system will measure and report on the time it took to program, verify, and test the PEEL device (applicable only for PEEL Development System). The default condition is OFF.

#### **Brief Mode**

Pressing **B** will toggle the brief mode from ON to OFF, and visa versa. When brief mode is off, the system will display the JEDEC or APEEL file being read, translated, or assembled. Turning brief mode on will disable this display feature and speed up the operation of the function. The default condition is OFF.

## **Directory Sort**

Pressing **D** will toggle the directory sort mode from ON to OFF, and visa versa. When directory sort is on, files displayed in the file selection screen will be sorted in alphabetical order. This sorting process could take up to 2-3 seconds if there are a lot of files in the directory. The default condition is ON.

#### Vector Trace Mode

Pressing V will toggle the vector trace mode from ON to OFF, and visa versa. When vector trace mode is on, the simulator will report in detail the results of each pass for each vector through

the simulator. A vector pass is similar to a vector state. The default condition is OFF.

## Fault Grade Mode

Pressing **F** will toggle the fault grade from ON to OFF, and visa versa. The default condition is OFF.

## APEEL Output File Mode

Pressing **A** will toggle the APEEL output file mode from ON to OFF, and visa versa. When the APEEL output file mode is on, the description displayed on your screen during the APEEL process will be written to a file with the same name as your source file but with a ".OUT" extension. This is useful when you need a print-out copy of you simulation errors. The default condition is ON.

## Reset Program Counter Mode (PEEL Development System only)

Pressing **R** will reset the program counter.

## **Printer Port Selection**

Pressing **P** will allow you to select any one of these printer ports: LPT1, LPT2, and LPT3. The default port is LPT1.

# 5.0 APEEL<sup>™</sup> Language Reference

## Using the APEEL<sup>™</sup> Logic Assembler

The APEEL logic assembler is used for creating custom logic functions for implementation in PEEL devices. Logic designs are specified as Boolean equations with additional statements specifying the desired configurations of the I/O macrocells. Input files may be created with most any text editor or word processor, including in the APEEL software package is a builtin word processor which is driven by familiar keyboard commands and convenient pull-down menus.

APEEL software operates in an interactive manner during assembly. It assembles the input file while checking for syntax errors. If errors are found, the APEEL assembler will interact with the PEEL editor to open the input file and moves the cursor to the line with the error (this line is highlighted). A brief description of the error and its location is also displayed in the upper right corner of the editor screen. When the input file is successfully assembled, user-defined test vectors may be used to simulate the logic function created by the design. Simulation errors are reported and identified to aid in debugging. APEEL software can also provide fault grading of the test vectors.

When the design is successfully assembled, APEEL software creates a JEDEC fusemap with JEDEC-formatted test vectors (if applicable). The JEDEC file can then be used by the PEEL Development System programmer or downloaded to a third-party programmer via the COM tramsmit/receive utility for programming PEEL devices.

For more information on using the APEEL logic assembler, refer to chapter 4.0, "A Step-By-Step Guide".

## Elements of the APEEL<sup>™</sup> Source File

#### APEEL<sup>™</sup> Source File Template

You can create APEEL source files with any word processor or text editor that produces ASCII files. The elements of an APEEL source file are shown in the Figure 5-1. In the figure, lines which begin with double quotes are comments and are ignored by the APEEL assembler. The expressions in **bold type** are the APEEL reserved words which must be included in the file. The expressions in *italic type* are strings that you would replace with the appropriate pin name, logic expression, etc. The application examples in chapter 6 further illustrate the elements of an APEEL source file.

| TITLE                       | title of design'                                                                     |
|-----------------------------|--------------------------------------------------------------------------------------|
| " device                    | declaration                                                                          |
|                             | PEEL_device_number                                                                   |
| ZERO_<br>AUTO_              | POWER "only applicable for PEEL22CV10Z<br>SECURE "Sets security bit automatically    |
| " pin an                    | d node assignments                                                                   |
|                             | name PIN pin_#                                                                       |
|                             | name NODE node_#                                                                     |
| EQUAT                       | IONS                                                                                 |
|                             | name = Sum-of-Product expression                                                     |
| ENA                         | BLE name = Product expression                                                        |
| TEST_V                      | VECTORS                                                                              |
| (input1<br>input1<br>input1 | input2 -> output1 output2)<br>input2 -> output1 output2<br>input2 -> output1 output2 |

Figure 5-1. APEEL Source File Template

The elements of an APEEL source file are:

TITLE – The title is optional and is used to describe the source file. The title will be printed as a header when printing the JEDEC programming file and is useful for documenting the design. The title statement consists of the keyword TITLE followed by a string enclosed by single quotes ('), where the string is the desired title of the design. The maximum length of the title is 240 characters ( 3 lines with 80 characters wide).

**DEVICE DECLARATION** – The device declaration identifies the target PEEL device for the assembler. Use the ICT PEEL part number as the device identifier, eg. **PEEL18CV8**, or **PEEL173**, etc.

**ZER0-POWER** - If the Zero-Power option which is applicable only for PEEL22CV10Z is desired, you must enter the reserved word **ZER0\_POWER** after the device declaration but prior to pin and node assignments.

**AUTO\_SECURE** - This feature allows the security bit to be automatically set when the JEDEC file is created this reserved word must be specified after the device declaration but prior to pin and node assignments.

**PIN AND NODE ASSIGNMENTS** – This section defines the pins and nodes of the PEEL device with identifiers used in the source file. User-defined names are assigned to each pin and the configurations of the I/O macro cells are defined. Refer to the APEEL Syntax section for more details.

Note that node assignment statements are only applicable for devices which have Asynchronous Clear or Synchronous Preset (or both) product terms.

**EQUATIONS** – This section contains the Boolean equations that describe the logic design. Refer to the APEEL syntax section for details on the Equations section of the source file.

**TEST VECTORS** – Contains the optional user-defined test vectors. Test vectors can be used by the APEEL assembler's logic simulation function to verify the functionality of the logic design. The vectors are also used by the PEEL Development System or third-party programmers to exercise the PEEL device after it has been programmed. Listing 5-1 is the APEEL source file for the Basic Registers and Latches application of the PEEL18CV8. This file is called "V8REGS.APL" and is found on the PEEL Device Software Applications Disk. Please study this listing carefully as it contains numerous information on the APEEL assembler.

#### Elements of the APEEL<sup>™</sup> Source File

5.0 APEEL<sup>™</sup> Language Reference

```
TITLE 'APEEL FILE: 18CV8 BASIC REGISTERS and LATCHES,
DESIGNER: Robin Jigour, ICT
DATE: 8/16/87'
PEEL18CV8
"Inputs"
CLK
            pin 1
                                          "register and latch inputs
           pin 2
D
т
           pin 3
J
          pin 4
           pin 5
Κ
R
           pin 6
          pin 7
S
          pin 8
LAT
                                           "gated latch
          pin 9
LEN
                                           "enable for gated latch
          pin 11
SRES
                                           "synchronous reset
          pin 12
SSET
                                           "synchronous set
ARES
          pin 13
                                          "asynchronous reset
"Outputs and Macro Cell definitions
Q GL
                                          "Latch outputs
         pin 14 = pos com feed_or
  "(internal feedback)
Q SL pin 15 = neg com feed pin
Q_SR pin 16 = pos reg feed_reg
Q_JK pin 17 = pos reg feed_reg
Q_T pin 18 = pos reg feed_reg
Q_D pin 19 = pos reg feed_reg
                                         "Register outputs"
"Internal Nodes"
 AC
          node 21
                                         "Asynchronous Clear node"
 SP
           node 22
                                         "Synchronous Preset node"
EOUATIONS
SP = SSET
                                     "Synchronous Preset
AC = ARES
                                     "Asynchronous Clear
```

Listing 5-1 APEEL Source File For V8REGS.APL

```
Q D := !SRES & D
                             "D register
Q_T := !SRES & T & !Q_T #
                              "T register
      ISRES & IT & QT
Q JK := !SRES & J & !K #
                             "JK register
      !SRES & !J & !K & Q_JK #
!SRES & J & K & !Q_JK
Q SR := !SRES & S & !R #
                             "SR register (clocked)
      ISRES & IS & IR & Q SR
Q SL = ! ( R # !S & !Q SL )
                             "SR latch"
     \uparrow = This '!' is actually ignored by the APEEL. The inversion
...
          is performed by the output's NEG polarity.
Q GL = LEN \& LAT #
                             "Gated latch"
     LEN & Q_GL #
                           "fix hazard when Q_GL=1"
      LAT & Q GL
TEST VECTORS "D Register"
( CLK D SRES SSET ARES -> Q_D )
   0 0 0 0 1 ->
                            Х
   0 0 0 0
                  1 ->
                            L
  Н
                            L
                            Н
                            L
                            Н
                            \mathbf{L}
   C 1
         0 0
                  0 ->
                            Н
TEST VECTORS "T Register"
( CLK T SRES SSET ARES -> Q_T )
            0 1
     0
        0
   0
                      ->
                             L
   C 0 0 1
                  0 ->
                            Н
```

Listing 5-1 APEEL Source File For V8REGS.APL

## APEEL Syntax

| ( CLK                                                        | JUKS 1                                              | SRES                                         | SSET                                           | ARES   | ->   | O JK         | ) |
|--------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------|------------------------------------------------|--------|------|--------------|---|
| 0                                                            | 0 0                                                 | 0                                            | 0                                              | 1      | ->   | L L          | , |
| C                                                            | 0 0                                                 | 0                                            | 1                                              | 0      | ->   | Н            |   |
| С                                                            | 0 0                                                 | 1                                            | 0                                              | 0      | ->   | L            |   |
| С                                                            | 0 0                                                 | 1                                            | 1                                              | 0      | ->   | Н            |   |
| С                                                            | 0 0                                                 | 0                                            | 0                                              | 0      | ->   | Н            |   |
| С                                                            | 0 1                                                 | 0                                            | 0                                              | 0      | ->   | $\mathbf{L}$ |   |
| С                                                            | 1 0                                                 | 0                                            | 0                                              | 0      | ->   | Н            |   |
| С                                                            | 1 1                                                 | 0                                            | 0                                              | 0      | ->   | L            |   |
| С                                                            | 0 0                                                 | 0                                            | 0                                              | 0      | ->   | L            |   |
| C                                                            |                                                     | 0                                            | 0                                              | 0      | ->   | н            |   |
| C                                                            | 1 1                                                 | 0                                            | 0                                              | 0      | ->   | ц<br>Ц       |   |
| C                                                            | 1 1                                                 | 0                                            | U                                              | v      | -    |              |   |
| TEST VE                                                      | CTORS "                                             | SR Reas                                      | ister                                          | (cloc) | (ed) |              |   |
| ( CLK                                                        | SRES                                                | SR                                           | -> Ç                                           | SR )   |      |              |   |
| С                                                            | 0                                                   | 0 0                                          | ->                                             | _x     |      |              |   |
| С                                                            | 0                                                   | 1 0                                          | ->                                             | Н      |      |              |   |
| С                                                            | 0                                                   | 0 0                                          | ->                                             | Н      |      |              |   |
| С                                                            | 0                                                   | 0 1                                          | ->                                             | L      |      |              |   |
| С                                                            | 0                                                   | 0 0                                          | ->                                             | L      |      |              |   |
| C                                                            | U                                                   | 1 1                                          | -/                                             | Ц      |      |              |   |
| ( S R<br>0 0<br>1 0<br>0 0<br>0 1<br>0 0<br>1 1              | -><br>-><br>-><br>-><br>-><br>->                    | Q_SL<br>X<br>H<br>L<br>L<br>L<br>L           | )                                              |        |      |              |   |
| TEST_VE                                                      | CTORS "                                             | Gated I                                      | atch"                                          |        |      |              |   |
| ( T. T. C.                                                   |                                                     | -> Ç                                         | GL )                                           |        |      |              |   |
| ( LAT                                                        | DEN .                                               | _ >                                          | v                                              |        |      |              |   |
| ( LAT<br>0<br>0                                              | 0                                                   | -><br>->                                     | X                                              |        |      |              |   |
| ( LAT<br>0<br>0<br>0                                         | 0 · · · · · · · · · · · · · · · · · · ·             | -><br>-><br>->                               | X<br>L<br>L                                    |        |      |              |   |
| ( LAT<br>0<br>0<br>0<br>1                                    | 0 · · · · · · · · · · · · · · · · · · ·             | -><br>-><br>->                               | X<br>L<br>L<br>L                               |        |      |              |   |
| ( LAT<br>0<br>0<br>0<br>1<br>0                               | 0<br>1<br>0<br>0                                    | -><br>-><br>-><br>->                         | X<br>L<br>L<br>L<br>L                          |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1                               | 0                                                   | -><br>-><br>-><br>-><br>->                   | X<br>L<br>L<br>L<br>L<br>H                     |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1<br>1                          | 0                                                   | -><br>-><br>-><br>-><br>->                   | X<br>L<br>L<br>L<br>H<br>H                     |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1<br>1<br>0<br>0                | 0<br>1<br>0<br>1<br>1<br>1<br>0<br>1                | -><br>-><br>-><br>-><br>-><br>->             | X<br>L<br>L<br>L<br>H<br>H<br>H<br>H           |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1<br>1<br>0<br>0<br>0<br>0<br>0 | 0                                                   | -><br>-><br>-><br>-><br>-><br>-><br>-><br>-> | X<br>L<br>L<br>L<br>H<br>H<br>H<br>L<br>L      |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1<br>1<br>0<br>0<br>0<br>0<br>0 | 0<br>1<br>0<br>1<br>1<br>0<br>1<br>0<br>0<br>1<br>0 | -><br>-><br>-><br>-><br>-><br>-><br>-><br>-> | X<br>L<br>L<br>L<br>H<br>H<br>H<br>L<br>L      |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>0      | 0<br>1<br>0<br>1<br>1<br>0<br>1<br>0<br>0<br>1<br>0 | -><br>-><br>-><br>-><br>-><br>-><br>->       | X<br>L<br>L<br>L<br>H<br>H<br>H<br>H<br>L<br>L |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>1<br>0<br>1<br>1<br>0<br>0<br>0      | 0<br>1<br>0<br>0<br>1<br>1<br>0<br>0                | -><br>-><br>-><br>-><br>-><br>-><br>-><br>-> | X L L L L H H H L L                            |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>0      | 0<br>1<br>0<br>1<br>1<br>1<br>0<br>0<br>1<br>0      | -><br>-><br>-><br>-><br>-><br>->             | X L L L H H H H L L                            |        |      |              |   |
| ( LAT<br>0<br>0<br>1<br>0<br>1<br>1<br>0<br>0<br>0<br>0      | 0<br>1<br>0<br>0<br>1<br>1<br>0<br>0                | -><br>-><br>-><br>-><br>-><br>->             | X L L L L H H H H L L                          |        |      |              |   |

Listing 5-1 APEEL Source File For V8REGS.APL

# APEEL Syntax

This section describes the minimum elements and syntax required to create a file which can be assembled by APEEL software. In the sections that follow, *italics will be used to identify fields in which the user would enter identifiers, such as pin names, etc.* 

## **Basic APEEL File Structure**

The basic structure of an APEEL input file is shown below: Title

Declarations: Device Type Zero\_Power (if applicable) Auto\_Secure ( if applicable) Input Pin Assignments Output Pin Assignment and Macro Definitions Node Assignments (if applicable) Boolean Equations Test Vectors (optional)

The examples given in this section are taken from the example application file V8REGS.APL (refer to chapter 6) which is found on PEEL Device Software Applications Disk.

## Identifiers

Identifiers are names that identify devices, device pins, nodes, and input or output signals.

The rules governing all identifiers are:

1. Identifiers may use only alphanumeric and underscore characters.

2. Spaces cannot be used in an identifier. To create identifiers which consist of two words, connect them with an underscore character.

Example: Q\_GL

3. Identifiers are not case sensitive. Uppercase and lowercase letters are treated the same. Thus, the output pin name **Q\_GL** and **Q\_gI** will be considered to be the same identifier

#### **Reserved Identifiers**

Reserved identifiers are part of the APEEL language and cannot be used to name pins, nodes, or signals. Reserved identifiers are shown below:

| PIN     | NODE                                                          | ZERO_POWER                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENABLE  | TEST_VECTORS                                                  | AUTO_SECURE                                                                                                                                                                                                               |
| P18CV8  | PEEL20CG10                                                    | P20CG10                                                                                                                                                                                                                   |
| P22V10  | PEEL22CV10Z                                                   | P22CV10                                                                                                                                                                                                                   |
| F153    | F82S153                                                       | PEEL253                                                                                                                                                                                                                   |
| PEEL173 | F173                                                          | F82S173                                                                                                                                                                                                                   |
| F273    |                                                               |                                                                                                                                                                                                                           |
|         | PIN<br>ENABLE<br>P18CV8<br>P22V10<br>F153<br>PEEL173<br>F2273 | PIN         NODE           ENABLE         TEST_VECTORS           P18CV8         PEEL20CG10           P22V10         PEEL22CV10Z           F153         F82S153           PEEL173         F173           F273         F173 |

#### **Basic Syntax**

In an APEEL source-code file, identifiers must be separated from each other by a space, a comma, or by an operator.

Example: CLK pin 1 Q\_SL pin 15 = neg com feed\_pin Q\_D = !SRES & D 0 0 0 0 1 -> X

#### Comments

The liberal use of comments will make your source file easy to understand. Comments explain what is not readily apparent from the source code itself. Comments do not affect the meaning of the code.

Comments begin with a double quotation mark character (") and end with either another double quotation mark or the end of line character.

Example: "INPUTS"

"Latch outputs internal feedback"

#### Title

The file begins with an optional declaration of the name of the design. The maximum length of the title is 240 characters (3 lines with 80 characters wide).

Format: TITLE '*Title\_of\_design*' Example: TITLE 'PEEL 18CV8 Basic Registers and Latches DESIGNER: Robin Jigour DATE: 8/16/87'

#### Device Type

The target device of the design is declared by simply entering the ICT PEEL device name:

 PEEL18CV8
 P18CV8

 PEEL22CV10
 P22V10

 PEEL153
 F153

 F253
 PEEL173

 PEEL273
 F273

PEEL20CG10 PEEL22CV10Z F82S153 F173 P20CG10 P22CV10Z PEEL253 F82S173

**Input Pin Assignments** 

Here, names are assigned to the input pins. You can include the "!" or "/" at the beginning of the pin names to implement "Active Low" inputs.

**Format:** *Pin\_Name* PIN *Pin\_Number* 

Example: D pin 2

I/O Pin Assignments and Macrocell Configurations

**Format:** *Pin\_Name* **PIN** *Pin\_# = Macrocell\_Configuration* where Macrocell\_Configuration is specified by the following string

Format: Polarity Output Type Feedback Path

You can include a "!" or "/" at the beginning of the pin name of the macrocell assignment (you do not need to specify the macrocell configuration for input definitions) to implement an "Active Low" input or feedback path. If it is an output, the output's polarity will remain in the polarity as specified by the macrocell polarity attribute.

Example: !A = neg reg feed\_reg (Macrocell Pin Definition) A = I (Eguation 1 - Output A is "Active Low") B = A (Equation 2 - Feedback A is "Active Low")

If you omit "!" or "/" in your pin name and specify "NEG" for your polarity attribute, you will get an "Active Low" output but an "Active High" feedback path.

Please refer to "Boolean Equations and Logical Operators" (described later in this section) for more information on the effects of feedback signals.

The options available for specifying Polarity, Output Type, and Feedback Path shown in the table below:

| Attribute    | Identifier                        | Definition                                                                                                              | PEEL Devices                                          |
|--------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| Polarity:    | POS<br>NEG                        | (positive),<br>(negative)                                                                                               | All PEEL devices                                      |
| Output Type: | COM<br>REG                        | (combinatorial),<br>(registered)                                                                                        | PEEL18CV8,<br>PEEL20CG10<br>PEEL22CV10<br>PEEL22CV10Z |
| Feedback Pa  | th:FEED_PIN<br>FEED_OR<br>FEED_RE | <ul> <li>(bi-directional I/O),</li> <li>(feedback from the OR gate)</li> <li>G (feedback from the flip-flop)</li> </ul> | PEEL18CV8<br>PEEL20CG10<br>PEEL22CV10Z                |

Note that some macrocell attributes are not applicable to some of the PEEL devices. An assembling syntax error will occur if the PEEL devices use an invalid attribute. The PEEL devices which the attribute is applicable to are listed under the "PEEL Devices" column in the previous table.

# If you do not specify the macrocell configuration, APEEL will default the configuration to:

- "POS COM FEED\_PIN" for PEEL18CV8, PEEL20CG10, and PEEL22CV10Z.
- "POS COM" for PEEL22CV10
- "POS" for PEEL153, PEEL253, PEEL173, and PEEL273.



| Configuration # |  | PEEL18CV8, PEEL20CG10<br>PEEL22CV10Z | PEEL22C | V10 PEEL153, PEE<br>PEEL173, PEE | PEEL153, PEEL253<br>PEEL173, PEEL273 |  |   |                    |         |       |  |
|-----------------|--|--------------------------------------|---------|----------------------------------|--------------------------------------|--|---|--------------------|---------|-------|--|
| 1               |  |                                      |         |                                  |                                      |  |   | .NEG REG FEED_PIN  | N/A     | N/A   |  |
| 2               |  |                                      |         |                                  |                                      |  |   | .POS REG FEED PIN  | N/A     | N/A   |  |
| 3               |  |                                      |         |                                  |                                      |  |   | . NEG COM FEED_PIN | NEG COM | A NEG |  |
| 4               |  |                                      |         |                                  |                                      |  |   | . POS COM FEED_PIN | POS CON | A POS |  |
| 5               |  |                                      |         |                                  |                                      |  |   | .NEG REG FEED_OR   | N/A     | N/A   |  |
| 6               |  |                                      |         |                                  |                                      |  |   | .POS REG FEED_OR   | N/A     | N/A   |  |
| 7               |  |                                      |         |                                  |                                      |  |   | .NEG COM FEED_OR   | N/A     | N/A   |  |
| 8               |  |                                      |         |                                  |                                      |  |   | .POS COM FEED_OR   | N/A     | N/A   |  |
| 9               |  |                                      |         |                                  |                                      |  |   | .NEG REG FEED_REG  | NEG REG | a N/A |  |
| 10              |  |                                      |         |                                  |                                      |  |   | . POS REG FEED_REG | POS REG | à N/A |  |
| 11              |  |                                      |         |                                  |                                      |  |   | .NEG COM FEED_REG  | N/A     | N/A   |  |
| 12              |  | •                                    | •       |                                  |                                      |  | • | . POS COM FEED_REG | N/A     | N/A   |  |

N/A = Not Applicable

## Figure 5-2. APEEL Macrocell Configuration Definitions

### Node Assignments

Some PEEL devices have product terms assigned to control the **Asynchronous Clear** and **Synchronous Preset** of the registers. To allow control of these special functions, nodes are assigned to these product terms.

Format: Node\_Name NODE Node\_Number

The table below shows the node number assignments for the PEEL devices.

| PEEL Devices | Node Number        |                    |  |  |  |
|--------------|--------------------|--------------------|--|--|--|
| -            | Asynchronous Clear | Synchronous Preset |  |  |  |
| PEEL18CV8    | 21                 | 22                 |  |  |  |
| PEEL20CG10   | 25                 | 26                 |  |  |  |
| PEEL22CV10   | 25                 | 26                 |  |  |  |
| PEEL22CV10Z  | 25                 | 26                 |  |  |  |

#### **Boolean Equations and Logic Operators**

#### **Equation Format**

The logic function to be implemented at each output pin is expressed as a Boolean equation in the **sum-of-products** form. The equations **must** be preceded by the statement **EQUA-TIONS** 

**Format:** *Pin\_Name = Sum-Of-Products\_Expression* 

**Example:**  $Q_SL = !(R \# !S \& !Q_SL)$ 

The above equation has a "!" just prior to the parenthesis. This "!" character is actually **ignored** by APEEL (otherwise, the expression of the right side of the "=" symbol is not in a sum-ofproducts form). The inversion of the expression is actually done by setting the output "Q\_SL" to NEG polarity (in the macrocell configuration). The reason for inserting the "!" is to make the equation appears logical without refering back to the macrocell configuration assignment statements.

If the "!" or "/" is inserted to the beginning of the output pin name (on the left side of the "=" symbol of the equation), it will also be **ignored** by APEEL. This means that the polarity of the output is solely controlled by setting the macrocell polarity attribute (NEG or POS). However, you can include the "!" or "/" on your output pin names (only in the boolean equations) to match the pin names in your design.

- Note, the "=" operator may be used for specifying both combinatorial and registered functions, as the type of output is explicitly defined in the macrocell definition. However, the ":=" operator commonly used by other logic assemblers and compilers to specify registered functions may also be used in APEEL.

## **Logic Operators**

The APEEL assembler allows the use of logic operators that are compatible with either ABEL or PALASM. The designer may choose whichever format is more familiar.

| (ABEL) | (PALASM) | Logic Description |
|--------|----------|-------------------|
| &      | *        | AND               |
| #      | +        | OR                |
| !      | /        | NOT               |

## **Output Feedback**

Below is an example of an APEEL boolean equation with feedback.

Example:

 $Q_{SL} = !(R # !S \& !Q_{SL})$ 

| Output Q       | _SL        | FeedBack Q_SL | Feedback Logical Level |       |  |  |
|----------------|------------|---------------|------------------------|-------|--|--|
| Previous State | Next State | Level         | Q-SL                   | IQ-SL |  |  |
| X              | L          | X             | X                      | X     |  |  |
| L              | н          | L             | 0                      | 1     |  |  |
| н              | н          | Н             | 1                      | 0     |  |  |

The macrocell definition for the output Q SL was:

Q SL pin 15 = neg com feed pin

Because the "!" or "/" has been omitted in the pin name of the macrocell definition statement, the feedback signal Q SL has the same voltage level but not the same logical level as the previous output level, regardless of the output's polarity or feedback type. In this case, the output is "Active Low" but the feedback is "Active High".

If the "!" or "/" was included in the pin name, then both output and feedback has the same logical level (i.e. "Active Low"). Please refer to the "I/O Pin Assignments and Macrocell Configurations" section described earlier.

In conclusion, the feedback signal assumes an "Active Low" or "Active High" polarity depending on whether a "!" or "/" was included in the pin name of the macrocell definition statement. This definition is consistent with the input pin definition.

#### **Output Enable Operator**

To control the programmable output enable function, the following format is used:

Format: Enable I/O Pin Name = Product Expression

Enable I/O Pin Name = 1 (output enabled unconditionally)

Example:

Enable HZ BUF = OE

The output will be enabled when Product Expression is TRUE. This example can be found in the file V8GATES.APL.

If you do not specify the "Enable" statement, the output is enabled automatically. All unused outputs are disabled automatically.

#### Test Vectors

Test vectors are defined in the input file for logic simulation and function testing. The vectors are automatically converted to the JEDEC format and incorporated in the JEDEC programming file. Test vectors **must** be preceded by the statement TEST VECTORS. The identifiers and format for defining test vectors in APEEL are described below.

#### **Input transitions:**

| Symbol           | Function                                                      |
|------------------|---------------------------------------------------------------|
| C<br>1<br>0<br>X | Clock (LOW-HIGH-LOW)<br>Input HIGH<br>Input LOW<br>Don't Care |
|                  |                                                               |

#### **Output transitions:**

| Sym | bol | Function             |
|-----|-----|----------------------|
| н   |     | Output expect HIGH   |
| L   |     | Output expect LOW    |
| Z   |     | Output expect High-Z |
| Х   |     | Don't examine output |
|     |     |                      |

A set of test vectors may include a subset of the total number of input and output pins, and multiple vector sets may be included in one file. When multiple functions are implemented in a single device, it is often convenient to group vectors for each function separately (see the application examples for an illustration). Note that each set of vectors must be preceded by the **TEST\_VECTORS** statement.

## Format

The labels of the pins being described are separated by spaces or commas and are enclosed by parenthesis as shown:

(Input\_Pins -> Output\_Pins)

Below the pin label, list the desired input and expected output transitions. Separate the input transitions with spaces or commas and do likewise with the output transitions, but do not add parenthesis. If feedbacks are used, the associated outputs must be declared as output pins (not input pins).

```
Example:
```

(S R -> Q\_SL) 0 0 -> X 1 0 -> H 0 0 -> H

If you have specified the output pin name with a "!" or "/" on the macrocell definition statement to implement an "Active Low" feedback path, you must include the "!" or "/" in the output pin name on test vector pin label statement. Please refer to the "I/O Pin Assignments and Macrocell Configurations" and "Boolean Equations and Logic Operators" (under Output Feedback) sections for additional information.

| Example: | !A pin | 19 = | neg reg | feed_reg (Macrocell Pin Definition) |
|----------|--------|------|---------|-------------------------------------|
|          | (I X Y | Z -: | • !A B) | (Test_Vector pin name label)        |
|          | 0 1 0  | 1 -> | ΗL      | (Test_Vector data)                  |

## **Creating New APEEL Source Files**

APEEL template files for each PEEL device are included on the APEEL Applications Diskette. These files provide the structure for writing a new APEEL design. To use the template files, simply:

- Select the specific template file for the PEEL device you wish to design with.
- Build the source file around the template, following the syntax rules presented in this section, by adding the specific pin names, macro definitions, equations, test vectors, and comments needed for your design.
- Save the newly edited file with a new file name (using the Save As command) in order to preserve the template file.

#### APEEL Template Files Included on the Applications Diskette

#### PEEL Device

## APEEL Template File

PEEL18CV8 PEEL173 PEEL273 PEEL153 PEEL253 PEEL20CG10 PEEL22CV10 PEEL22CV10Z ANEWV8.APL ANEW173.APL ANEW273.APL ANEW153.APL ANEW253.APL ANEWV10.APL ANEWV10.APL ANEWV10Z.APL This page is blank

# 6.0 Application Primer and Examples

A number of application examples for PEEL devices have been provided in the form of APEEL input files which can be found on the Applications diskette (disk# 2). These files show some of the possible applications for PEEL devices and provide an example of the format used to create APEEL input files. These examples and the APEEL applications primer in section 6.1 can be used to familiarize yourself with the capabilities of the APEEL software and designing with PEEL device architectures.

## **Application Directory**

APEEL source files for the PEEL applications listed below may be found on the PEEL Device Applications Diskette.

6.1 APEEL Applications Primer

| EL18CV8 Applications                       | File Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Basic Logic Gates                          | V8GATES.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Basic Registers and Latches                | V8REGS.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Clock Divider and Address Decod            | V8CLKADD.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Bus Programmable 8 to 1 Multiple           | V8BUSMUX.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Expandable 8-bit (or Dual 4-bit) Comparate | orV8COMP.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8-bit Counter with Function Controls       | V8FCNTR.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4-bit Change-of-State Port with Interrupt  | V8CPORT.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EL 22CV10 and 22CV10Z Applicati            | ons File Name.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8-bit Loadable Up/Down Counter             | V10CNT8.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8-bit Change-of-State Port with Interrupt  | V10ZPORT.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EL173 Applications                         | File Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16 to 4 Priority Encoder                   | PRI173.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| EL273 Applications                         | File Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2 8-bit Greater/Less-Than Mag. Comparato   | r MAG23.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3 10-Bit Expandable Equality Comparator .  | EQU273.APL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                            | EL18CV8 Applications         Basic Logic Gates         Basic Registers and Latches         Clock Divider and Address Decod         Bus Programmable 8 to 1 Multiple         Expandable 8-bit (or Dual 4-bit) Comparato         8-bit Counter with Function Controls         4-bit Change-of-State Port with Interrupt         EL 22CV10 and 22CV10Z Applicati         8-bit Loadable Up/Down Counter         0         8-bit Change-of-State Port with Interrupt         EL173 Applications         1         16 to 4 Priority Encoder         2         8-bit Greater/Less-Than Mag. Comparato         3         10-Bit Expandable Equality Comparator |

# 6.1 APEEL Application Primer

If programmable logic devices are new to you, this section will give you a brief overview of the how design concepts can be described by APEEL design files which are then assembled into JEDEC programming files.

- Your Design Concepts
- □ The Basics of an APEEL file
- PEEL Device Architectures
- □ The JEDEC File

## Your Design Concepts

In digital circuits, there are various ways to describe a logic design but probably the most familiar method is by schematic (or gate) form. However, like most logic assemblers APEEL requires logic to be described in equation form. Before converting your design conceptualized in schematic form into APEEL equations, you must first choose the right PEEL device for your specific application. Some of the basic issues when selecting a PEEL device for your design are:

- The speed (tpD, combinatorial propagation delay from input to output), power and cost considerations
- The number of input and I/O pins required
- The complexity of your design in terms of the number of product and sum-of-product functions to be implemented
- The use of output registers (flip-flops)

Most of the above issues can be better understood after reading through the following section on the PEEL device architectures, reviewing the PEEL device data sheets, and experiencing a few APEEL designs. Figure 6.1a gives you a brief summary of the features of all the devices in the PEEL family, but please note that you should refer to the product data sheets for the latest specifications.



|                         | Architecture |        |      |           |                  |                 |                        | Speed*      |                               | Power*                     |
|-------------------------|--------------|--------|------|-----------|------------------|-----------------|------------------------|-------------|-------------------------------|----------------------------|
| Superset<br>Replacement | Pins         | Inputs | I/Os | Registers | Macro<br>Configs | Prog.<br>Arrays | Product /<br>Sum Terms | Prop<br>tco | Delay (ns)<br>t <sub>PD</sub> | Supply Current<br>Icc (mA) |
| PEEL18CV8               | 20           | 10     | 8    | 8         | 12               | AND             | 74                     | 15-25       | 25-35                         | 20 + 0.7/MHz               |
| PEEL18CV8-15            | 20           | 10     | 8    | 8         | 12               | AND             | 74                     | 12          | 15                            | 80 + 0.5/MHz               |
| PEEL20CG10              | 24           | 12     | 10   | 10        | 12               | AND             | 92                     | 15-20       | 20-35                         | 55 + 0.5/MHz               |
| PEEL22CV10Z             | 24           | 12     | 10   | 10        | 12               | AND             | 132                    | 15-20       | 20-35                         | 55 + 0.5/MHz†              |
| PEEL253                 | 20           | 8      | 10   | 0         | 2                | AND/OR          | 42/20                  | N/A         | 30-40                         | 35 + 1.0/MHz               |
| PEEL273                 | 24           | 12     | 10   | 0         | 2                | AND/OR          | 42/20                  | N/A         | 30-40                         | 35 + 1.0/MHz               |
| Direct<br>Replacement   | Pins         | Inputs | I/Os | Registers | Macro<br>Configs | Prog.<br>Arrays | Product /<br>Sum Terms | Prop<br>tco | Delay (nS)<br>tpp             | Supply Current<br>Icc (mA) |
| PEEL22CV10              | 24           | 12     | 10   | 10        | 4                | AND             | 132                    | 12-20       | 20-35                         | 55 + 0.5/MHz               |
| PEEL153                 | 20           | 8      | 10   | 0         | 2                | AND/OR          | 42/10                  | N/A         | 30-40                         | 35 + 1.0/MHz               |
| PEEL173                 | 24           | 12     | 10   | 0         | 2                | AND/OR          | 42/10                  | N/A         | 30-40                         | 35 + 1.0/MHz               |

† User-programmable "zero-power" standby mode: ICC = approx.200μA

Figure 6.1a Pin Configurations and Features Summary of PEEL Devices \*Please refer to latest PEEL Device data sheets for more detailed and updated AC and DC specifications. Higher speed versions of all devices are scheduled for late 1989-1990.

## The Basics of an APEEL file

Once a PEEL device is selected, the process of transferring your conceptualized design into APEEL design file is segmented into three main steps.

- Input and I/O pin assignments
- Macro cell configuration declarations
- Logic equations

Figure 6.1b illustrates a simple exclusive NOR design in schematic form converted to an APEEL design file for the PEEL18CV8 device. First, the input signal names "I1" and "I2" are assigned to input pins 1 and 2 respectively. Next, the output signal "OUT" is assigned to an I/O pin which macro cell is configured as: positive polarity output (POS); combinatorial output (COM); and feedback from the pin (FEED\_PIN). In this case, the feedback is actually not being used but it should be specified anyway. Finally, the equivalent equation for the logic function is expressed. Note that the "!" equals the NOT function, "&" equals the AND function, and "#" equals the OR function.



Three other similar examples are shown in figures 6.1c (2-to-4 Bit Decoder), 6.1d (4-Bit Shifter), and 6.1e (2-Bit Counter). For a more detailed description of the APEEL language, please refer to section 5.0 and the APEEL application examples found later in this chapter




#### **PEEL Device Architectures**

The following section describes PEEL Device Architectures. Although helpful, a detailed understanding of PEEL Device architecture is not always necessary to sucessfully design with PEEL Devices. Many PEEL logic designers, armed with a minimum knowledge of macrocell configurations, pin functions and number of product terms are able to create effective PEEL designs for their specific applications.

### The Logic Array

Probably the most basic thing about programmable logic devices is the logic array diagram of the device. The two types of logic structures in the PEEL Device family are the programmable-AND/fixed-OR and programmable-AND/programmable-OR structures. The PEEL18CV8 logic array which utilizes the programmable-AND/fixed-OR structure is shown on Figure 6.1i. Other PEEL devices with this logic structure include PEEL22CV10, PEEL20CG10, PEEL22CV10Z (see Appendix D). As shown in the diagram, the 36 (0-35) input lines which run vertically are derived from true and complement of the 18 possible input pins. The product terms, drawn as horizontal lines, serve as AND functions (denoted by the AND gate symbol at the end of each product term) with a maximum of 36 inputs for each product term. The 74 product terms are made up of: one synchronous preset term; one asynchronous clear term; eight output enable terms; and 64 terms divided into groups of eight, with each group feeding into an OR function. The area where the input lines and the product terms intersect is known as the AND array. At each intersection of the input line and product





Figure 6.1j PEEL273 Logic Array Diagram (Programmable-AND/Programmable-OR)

term is an EEPROM cell which determines whether the intersection is connected or open. A connection allows an input line to become a logical input of the intersected product term (AND gate). Hence, logic functions are performed by merely connecting the input lines to the product terms. By connecting specific inputs or I/O macrocell feedbacks to the product terms, complex sum-of-product logic functions can be created. In the PEEL18CV8 device, each sum feeds into its associated I/O macrocell where the logic function can be further controlled for output to an I/O pin and/or feedback into the array. To graphically illustrate the logic functions in the logic array diagram, X's are used to mark the intersection in which the input lines are connected to the product terms (refer to the V8GATES design in section 6.2).

The other logic array structure in the PEEL devices (PEEL153, PEEL253, PEEL173, and PEEL273) is the programmable-AND/programmable-OR structure (see Figure 6.1j and Appendix D). This logic structure is ideal for combinatorial applications such comparitors, priority encoders, etc. which utilize many product terms. Unlike the PEEL18CV8's fixed OR array, the programmable OR array allows user-specified product terms to be connected to the sum terms (drawn as horizontal lines) which are propagated to the I/O pin, output enable buffer, or back to the AND array as feedbacks. This sharing of product terms minimizes product term redundancy and avoids wasting unused terms of fixed-OR arrays.

# A Closer Look at the Logic Array

Figure 6-1k illustrates how a logic function (specifically the two-input exclusive NOR design described earlier) is implemented in the PEEL18CV8 array. Note that if all true and complement inputs of a product term are left open, the output of the AND gate will be a logical true (HIGH). If both true and complement of one or more inputs are connected to a product term, the output of the AND gate is forced to a logical false (LOW). Frequently, you will find that the unused product terms are connected to both true and complement of all the possible inputs in the device, creating product terms with JEDEC 0's. Most logic assembler or compiler (including APEEL) omit these unused product terms not specified in the JEDEC file are assumed to be unused.





# The Macro Cell

In the PEEL18CV8 device, there is a macro cell associated with each I/O pin. This macro cell allows you to configure the architecture of each output independently into one of twelve possible configurations. This flexiblity makes it possible to customize the architecture to your design requirements. PEEL devices with similar macro cell capabilities include PEEL20CG10, PEEL22CV10, and PEEL22CV10Z. Macro cells in PEEL devices such as PEEL153, PEEL253, PEEL173 and PEEL273 provide for output polarity control only. Please refer to 5-12 of this handbook for more information describing the different PEEL macro cell configurations.

As shown in figure 6.1i, the PEEL18CV8 I/O macro cell consists of a D-type flip-flop and two signal-select multiplexers. The configuration of each macrocell is determined by the four EEPROM bits (A,B,C,D) controlling these multiplexers. These bits determine: output polarity; output type (registered or nonregistered); and input/feedback path (bi-directional I/O, combinatorial feedback, or register feedback). Figure 6.1j shows the equivalent circuits of the PEEL18CV8 twelve macro cell configurations.

# **Output Type**

The signal from the OR array can be fed directly to the output pin (combinatorial function) or latched in the D-type flip-flop (registered function). The D-type flip-flop latches data on the rising edge of the clock and is controlled by the global preset



Figure 6.1i PEEL18CV8 Macro Cell

and clear terms. When the synchronous preset term is satisfied, the Q output of the register will be set HIGH at the next rising edge of the clock input. Satisfying the asynchronous clear term will set Q LOW, regardless of the clock state. If both terms are satisfied simultaneously, the clear will override the preset.

# **Output Polarity**

Each macrocell can be configured to implement active-high or active-low logic. Programmable polarity eliminates the need for external inverters.

# Output Enable

The output of each I/O macrocell can be enabled or disabled under the control of its associated programmable output enable product term. When the logical conditions programmed on the output enable term are satisfied, the output signal is propagated to the I/O pin. Otherwise, the output buffer is driven into the high-impedance state. Under the control of the output enable term, the I/O pin can function as a dedicated input, output, or a bi-directional I/O.

# Input/Feedback Select

The I/O macrocell also provides control over the feedback path. The input/feedback signal associated with each I/O macrocell may be obtained from three different locations: from the I/O pin (bi-directional I/O); directly from the Q output of the flip-flop (registered feedback); or directly from the OR gate (combinatorial feedback).



Figure 6.1j PEEL18CV8 macro cell configurations

# **Bi-directional I/O**

The input/feedback signal is taken from the I/O pin when using the pin as a dedicated input or as a bi-directional I/O. (Note that it is possible to create a registered output function with bi-directional I/O.)

# **Combinatorial Feedback**

The signal-select multiplexer gives the macrocell the ability to feedback the output directly from the OR gate, regardless of whether the output function is registered or combinatorial. This feature allows the creation of asynchronous latches, even when the output must be disabled.

## **Registered Feedback**

Feedback also can be taken from the register, regardless of whether the output function is registered or combinatorial. When implementing a combinatorial output and registered feedback configuration (configurations number 11 and 12 in figure 6.1j), the register can be used for internal latching of data while leaving the external output free for combinatorial functions.

### The JEDEC File

As mentioned earlier, the APEEL assembler outputs a JEDEC file which can be uploaded into a programmer to program the PEEL device. Referencing to the logic array diagram with the V8GATES application example on section 6.2, the X's which mark the connected inputs to the product term are represented by 0's in the JEDEC file.

After the PEEL device is erased (electrically), all EEPROM cells are set to a JEDEC "1" which open all logical connections. The device is then configured to perform the user-defined function by programming selected connections (JEDEC "0") in the AND array. Please refer to the JEDEC pattern of the V8GATES.APL design. Note that only used product terms are specified.

The JEDEC file is the output of the APEEL assembler (and all other PLD logic compilers). This JEDEC file which is a standard data transfer format for programmable logic devices between the development systems and programmer defines that the data "1" and "0" represent an open and short connection. For more information on the JEDEC standard, you can contact:

> Electronic Industries Association Engineering Department 2001 Eye Street N.W. Washington, D.C. 20006.

#### 6.2 Basic Gates



This PEEL18CV8 application example implements several basic logic gates. The logic gates include an inverter, four-input AND, OR, NAND, and NOR gates, a four-input AND-OR- IN-VERT gate, a two- input XOR gate and a high-impedance buffer. Each gate uses one or more of the (A,B,C and D) inputs. Additionally, the high-impedance buffer uses the /HZ input for impedance control. The truth table for these gates can be examined in the test vectors. Note, the remaining unused input pins can be used as additional inputs into the gates.



Figure 6.2a – Pinout for V8GATES.APL





#### 6.2 Basic Gates

TITLE 'APEEL FILE: PEEL18CV8 BASIC GATES DESIGNER: Robin Jigour DATE: 8/16/87' PEEL18CV8 "Inputs" Ά pin 1 "A, B, C, and D are gate inputs. В pin 2 С pin 3 D pin 4 !OE "The '!' is only used to indicate an pin 9 "active low output "enable for HZ BUF. This character "is NOT part of the pin name. "Outputs and Macro Cell definitions pin 12 = pos com feed\_pin "High Impedence Buffer. HZ BUF XOR pin 13 = pos com feed pin "Exclusive OR. AOI pin 14 = neg com feed\_pin "AND-OR-Invert. NOR pin 15 = neg com feed pin OR pin 16 = pos com feed pin NAND pin 17 = neg com feed pin AND pin 18 = pos com feed pin NOT pin 19 = pos com feed pin "Inverter. EQUATIONS NOT = !A "Note macro cell polarity for each output. = A & B & C & D AND NAND = ! (A & B & C & D) "Here, the '!' (which is actually ignored "by APEEL) is to make the equation "appears logically correct. This output's "macro cell which is set to NEG polarity is "actually doing the inversion. A # B # C # D OR -

6

NOR "Again, the '!' is ignored by APEEL. = ! (A # B # C # D) AOI = ! (A & B # C & D) "Same as above. A & !B # !A & B XOR ----HZ BUF = A Enable HZ BUF = OE"OE controls output enable. "Outputs without the 'ENABLE' statements are "enabled unconditionally. TEST VECTORS ( D C B A OE -> NOT AND NAND OR NOR AOI XOR HZ BUF ) 0 0 0 L 0 1 -> H L Н L Н Н L 0 0 0 1 1 -> L Н Н L Н Н Н L 0 0 1 0 -> H Ζ 0 Η Н Н Н L  $\mathbf{L}$ -> L Н 0 0 1 1 0 Н z L L  $\mathbf{L}$ L 0 1 0 0 Х -> X L Н Х Х Н  $\mathbf{L}$ Н -> X 0 1 0 1 L Н Х Н  $\mathbf{L}$ Н Х Х 0 1 0 -> X 1 Х Н L Н L Н х Х 0 1 1 1 Х -> X  $\mathbf{L}$ Н Н Х Х  $\mathbf{L}$ L -> X 0 0 0 1 Х Н Н Х Х L Н  $\mathbf{L}$ 0 0 1 -> X 1 х Х Х L Н Н L Н 1 0 1 0 Х -> X L Н Н Х Х Н L 1 1 -> X 1 0 Х L Н Η L  $\mathbf{L}$ Х Х -> X 0 0 1 1 Х L Н Н L  $\mathbf{L}$ Х Х 1 1 0 1 Х -> X L Н Н L L Х Х L Н 1 1 1 0 Х -> X Н L L Х Х 1 1 1 1 х -> X Н Н L L Х х L

6



ment of input pin 1.



#### **V8GATES JEDEC File**

<STX>ICT APEEL(tm) V3.30. Tue 3-21-1989 18:17:11 APEEL FILE: PEEL18CV8 BASIC GATES DESIGNER: Robin Jigour DATE: 8/16/87 \*DF PEEL \*DD 18CV8 \*DM ICT \*OP20 \*OF2696 \*F0 \* N Output Pin 19 \* N Output Pin 18 \* N Output Pin 17 \* N Output Pin 16 \* \* \* \* \* N Output Pin 15 \* \* \* \* N Output Pin 14 \* \* \* N Output Pin 13 \* \* \* N Output Pin 12 \* 

6

| N Out <sub>E</sub><br>L2304 | out E<br>1111 | nable<br>1111 | 19,18<br>1111 | 3 <b>,</b> :<br>1111 | l2 *<br>1111 | 1111  | 1111  | 1111  | 1111 | * |  |
|-----------------------------|---------------|---------------|---------------|----------------------|--------------|-------|-------|-------|------|---|--|
| L2340                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2376                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2412                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2448                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2484                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2520                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1111 | * |  |
| L2556                       | 1111          | 1111          | 1111          | 1111                 | 1111         | 1111  | 1111  | 1111  | 1011 | * |  |
| N Sync                      | > Pre         | set, A        | Async         | Clear                | c, Ma        | croce | 11 19 | ,18,. | 12   | * |  |
| L2592                       | 0000          | 0000          | 0000          | 0000                 | 0000         | 0000  | 0000  | 0000  | 0000 | * |  |
| L2628                       | 0000          | 0000          | 0000          | 0000                 | 0000         | 0000  | 0000  | 0000  | 0000 | * |  |
| L2664                       | 0011          | 0011          | 1011          | 0011                 | 1011         | 1011  | 0011  | 0011  | *    |   |  |
| V0001                       | 0000          | XXXX01        | IXLLH         | HLHLHN               | 1 *          |       |       |       |      |   |  |
| V0002                       | 10002         | XXXXO         | ахннна        | LHHLLN               | 1 *          |       |       |       |      |   |  |
| V0003                       | 01002         | XXXX1         | IXZHHI        | CHHTH                | 1 *          |       |       |       |      |   |  |
| V0004                       | 11002         | XXXX1         | IXZTTI        | CHHTT                | 1 *          |       |       |       |      |   |  |
| V0005                       | 00102         | XXXXX         | 1XXXH         | CHHLXN               | 1 *          |       |       |       |      |   |  |
| V0006                       | 10102         | XXXXX         | 1XXXH]        | THHTX                | 1 *          |       |       |       |      |   |  |
| V0007                       | 01102         | XXXXX         | 1XXXH         | CHHTX                | 1 *          |       |       |       |      |   |  |
| V0008                       | 11103         | XXXXX         | 1XXXT]        | LHHLXN               | 1 *          |       |       |       |      |   |  |
| V0009                       | 00012         | XXXXX         | IXXXHI        | THHTX                | 1 *          |       |       |       |      |   |  |
| V0010                       | 10012         | XXXXX         | 1XXXH]        | LHHLXN               | 1 *          |       |       |       |      |   |  |
| V0011                       | 01012         | XXXXX         | 1XXXH]        | LHHLXN               | 1 *          |       |       |       |      |   |  |
| V0012                       | 11012         | XXXXXI        | VXXXL1        | LHHLXI               | v *<br>• •   |       |       |       |      |   |  |
| V0013                       | 10111         | XXXXXI        | IXXXI.        |                      | · ·          |       |       |       |      |   |  |
| V0014                       | 10111         | VVVVVN        |               |                      | ч ~<br>т +   |       |       |       |      |   |  |
| V0015                       | 11111         | VVVVVN        | IVVVII        |                      | л "<br>л ж   |       |       |       |      |   |  |
| 10010                       | T T T T T     | ~~~~          |               | JUTUUVI              | •            |       |       |       |      |   |  |
| C6C41                       | *             |               |               |                      |              |       |       |       |      |   |  |
| <etx>(</etx>                | 0000          |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |
|                             |               |               |               |                      |              |       |       |       |      |   |  |

# 6.3 Basic Registers and Latches

DEVICE: PEEL18CV8 FILE NAME: V8REGS.APL

This application examples demonstrates the implementation of several basic registers and latches within a PEEL18CV8. Four register types are included, D, T, JK, and SR, all of which are clocked by the CLK input. All registers can be synchronously reset, set, and asynchronously reset using the SRES, SSET and ARES inputs respectively. Besides the registers, an SR latch and a Gated Latch circuit show how independent asynchronous storage elements can be implemented. Only the Q outputs of these registers and latches are provided at the output pins. The /Q outputs could easily be accessed by inverting the macro cell output polarity. Truth table operation can be referenced via the test vectors.



TITLE 'APEEL FILE: 18CV8 BASIC REGISTERS and LATCHES, DESIGNER: Robin Jigour, ICT DATE: 8/16/87' PEEL18CV8 "Inputs" CLK pin l pin 2 "register and latch inputs D Т pin 3 pin 4 J pin 5 K pin 6 R pin 7 S LAT pin 8 "gated latch "enable for gated latch LEN pin 9 pin 11 "synchronous reset SRES "synchronous set pin 12 SSET ARES pin 13 "asynchronous reset "Outputs and Macro Cell definitions Q\_GL pin 14 = pos com feed or "Latch outputs "(internal feedback) Q\_SL pin 15 = neg com feed\_pin Q\_SRpin 16 = pos reg feed\_reg"Register outputs"Q\_JKpin 17 = pos reg feed\_regQ\_Tpin 18 = pos reg feed\_regQ\_Dpin 19 = pos reg feed\_reg "Internal Nodes" node 21 AC "Asynchronous Clear node" SP node 22 "Synchronous Preset node" EQUATIONS SP = SSET"Synchronous Preset AC = ARES"Asynchronous Clear

```
"D register
Q D := !SRES & D
Q T := !SRES & T & !Q T #
                               "T register
      ISRES & IT & Q T
Q_JK := !SRES & J & !K #
                               "JK register
      SRES & J & K & Q_JK #
      ISRES & J & K & IQ_JK
Q SR := !SRES & S & !R #
                               "SR register (clocked)
      ISRES & IS & IR & Q_SR
Q SL = ! (R # !S \& !Q SL)
                              "SR latch"
      \uparrow = This '!' is actually ignored by the APEEL. The inversion
11
...
          is performed by the output's NEG polarity.
                       "Gated latch"
Q GL = LEN & LAT #
     !LEN & Q GL #
                            "fix hazard when Q_GL=1"
      LAT & Q GL
TEST VECTORS "D Register"
( CLK D SRES SSET ARES
                        ->
                            Q_D )
   0
      0
         0 0
                   1 ->
                              Х
   0
     0
          0
              0
                    1
                        ->
                              L
     0 0 1
   С
                   0
                        ->
                             Н
                  0 ->
   С
     0 1 0
                             L
   C 0 1 1
                   0 ->
                              Н
   C 0 0 0
                   0 ->
                              \mathbf{L}
   C 1 0 0
                   0 ->
                              Н
   C 0 0 0
                   0 ->
                              T.
   С
      1
          0
              0
                   0
                        ->
                              Н
TEST VECTORS "T Register"
( CLK T SRES SSET ARES
                        ->
                             Q_T )
   0
      0
         0
              0
                   1
                        ->
                              L
   С
     0
          0
              1
                    0
                        ->
                              Н
     0
   С
         1
             0
                   0
                        ->
                              L
     0
             1
   С
         1
                    0
                        ->
                              Н
         1
              1
   С
     0
                    0
                        ->
                              Н
         0
      1
   С
              0
                    1
                        ->
                              \mathbf{L}
         0
   С
              0
                   0
      0
                        ->
                              \mathbf{L}
          0
   С
      1
              0
                    0
                         ->
                              Н
```

| , 01                             | K J                                                                            | K                                                                  | SRES                                | SSET                                                    | ARES  | ->             | Q_JK         | ) |
|----------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------|-------|----------------|--------------|---|
| 0                                | . 0                                                                            | 0                                                                  | 0                                   | 1                                                       | 1     | ->             | 上<br>11      |   |
| C                                | : 0                                                                            | 0                                                                  | 1                                   | 1                                                       | 0     | ->             | н<br>Т.      |   |
| c                                | ÷ 0                                                                            | õ                                                                  | 1                                   | 1                                                       | õ     | ->             | H            |   |
| С                                | 0                                                                              | 0                                                                  | 0                                   | 0                                                       | 0     | ->             | Н            |   |
| С                                | 0                                                                              | 1                                                                  | 0                                   | 0                                                       | 0     | ->             | $\mathbf{L}$ |   |
| С                                | : 1                                                                            | 0                                                                  | 0                                   | 0                                                       | 0     | ->             | Н            |   |
| С                                | . 1                                                                            | 1                                                                  | 0                                   | 0                                                       | 0     | ->             | $\mathbf{L}$ |   |
| С                                | . 0                                                                            | 0                                                                  | 0                                   | 0                                                       | 0     | ->             | L            |   |
| C                                | . 1                                                                            | 1                                                                  | 0                                   | 0                                                       | 0     | ->             | H            |   |
| c                                | 1                                                                              | 1                                                                  | 0                                   | 0                                                       | 0     | ->             | Н            |   |
| <b>— — — —</b>                   | 1100001                                                                        |                                                                    |                                     |                                                         |       | , <u>, , .</u> |              |   |
| TEST_                            | VECTOR                                                                         | KS "SR                                                             | Regs                                | -> 0                                                    | (CTOC | kea)"          |              |   |
| ( CI                             |                                                                                | 0 0                                                                | 0                                   | -> 2                                                    | /     |                |              |   |
| c                                | : (                                                                            | )<br>1                                                             | Ō                                   | ->                                                      | Н     |                |              |   |
| С                                | ; (                                                                            | 0 (                                                                | 0                                   | ->                                                      | Н     |                |              |   |
| С                                | : (                                                                            | 0 C                                                                | 1                                   | ->                                                      | L     |                |              |   |
| С                                | . (                                                                            | 0 0                                                                | 0                                   | ->                                                      | L     |                |              |   |
| TEST_<br>( S<br>0<br>1<br>0<br>0 | VECTOR<br>R -<br>0 -<br>0 -<br>1 -<br>1 -<br>1 -                               | <pre></pre>                                                        | Lato<br>SL<br>X<br>H<br>L<br>L<br>L | ch"<br>)                                                |       |                |              |   |
| 0                                |                                                                                |                                                                    | ted I                               | atch"                                                   |       |                |              |   |
| 0<br>1<br>TEST_                  | VECTOR                                                                         | RS "Ga<br>J ->                                                     |                                     | GT. N                                                   |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0                                                         | RS "Ga<br>N -><br>->                                               | ç                                   | GL )<br>X                                               |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>0 1                                                  | RS "Ga<br>N -><br>-><br>->                                         | ç                                   | j_GL )<br>X<br>L                                        |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>0 1<br>0 0                                           | <pre>{S "Ga"</pre>                                                 | ç                                   | E_GL )<br>X<br>L<br>L                                   |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>1 0<br>1 0                                           | RS "Ga<br>-><br>-><br>-><br>-><br>->                               | ç                                   | )_GL )<br>X<br>L<br>L<br>L                              |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>0 1<br>0 0<br>1 0<br>0 1                             | RS "Ga<br>-><br>-><br>-><br>-><br>->                               | ç                                   | E_GL )<br>X<br>L<br>L<br>L<br>L                         |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>0 1<br>0 0<br>1 0<br>0 1<br>1 1<br>1 0               | RS "Ga<br>-><br>-><br>-><br>-><br>-><br>-><br>->                   | ç                                   | GL )<br>X<br>L<br>L<br>L<br>L<br>H                      |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>0 0<br>0 1<br>0 0<br>1 0<br>0 1<br>1 1<br>1 0<br>0 0                 | RS "Ga<br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>->       | ç                                   | ) GL )<br>X<br>L<br>L<br>L<br>L<br>H<br>H               |       |                |              |   |
| 0<br>1<br>TEST_<br>( LA          | VECTOR<br>T LEN<br>0 0<br>1 0<br>0 1<br>1 0<br>0 1<br>1 1<br>1 0<br>0 0<br>0 1 | RS "Ga<br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-> | ç                                   | EGL )<br>X<br>L<br>L<br>L<br>L<br>H<br>H<br>H<br>H<br>L |       |                |              |   |

6

## 6.4 Clock Divider and Address Decoder

DEVICE: PEEL18CV8 FILE NAME: V8CLKADD.APL

This application uses the PEEL18CV8 for two common microprocessor system functions: a clock divider and a memory mapped address decoder The clock divider provides divide 2, 4 and 8 clock outputs. The SET input sets all clock outputs high. The address decoder decodes the processor address lines to select one of five memory or I/O devices. The chip select for these devices are active low. The memory map over a 64K boundary is shown below.

Memory Map for Address Decoder



TITLE 'APEEL FILE: PEEL18CV8 CLOCK DIVIDER AND ADDRESS DECODER DESIGNER: Robin Jigour, ICT DATE: 9/20/87' PEEL18CV8 "PIN ASSIGNMENTS "Inputs CLK pin 1 SET pin 2 80A pin 3 A09 pin 4 pin 5 A10 pin 6 A11 pin 7 A12 pin 8 A13 pin 9 A14 A15 pin 11 "Outputs and Macro Cell definitions pin 12 = neg com feed\_pin "5 Combinatorial outputs. SRAM pin 13 = neg com feed\_pin PORT UART pin 14 = neg com feed\_pin "Pins 12-16 have active low outputs. EEPROM pin 15 = neg com feed\_pin EPROM pin 16 = neg com feed pin CLK8 pin 17 = pos reg feed\_reg "3 Registered outputs. CLK4 pin 18 = pos reg feed\_reg CLK2 pin 19 = pos reg feed reg "Internal Nodes node 21 "Asynchronous Clear - not used. AC SP node 22 "Synchronous Preset.

EQUATIONS "Clock Divider SP = SET"If SET=1 set all CLK outputs high. CLK2 := !CLK2 "CLK divided by 2. CLK4 := !CLK4 & CLK2 # "CLK divided by 4. CLK4 & !CLK2 CLK8 := !CLK8 & CLK4 & CLK2 # "CLK divided by 8. CLK8 & !CLK4 # CLK8 & !CLK2 "Address Decoder (active low outputs) /SRAM = !A15 & !A14 & !A13 "The '/' is actually ignored by APEEL. "Here, the '/' is inserted to: ... (1) indicate that the output is active п LOW, and " (2) allow the user to match the output ... signal name with what's on his/her ... design. "Note: '/' can be used instead of '!'. /PORT = !A15 & A14 & !A13 & !A12 & !A11 & !A10 & !A09 & !A08 = !A15 & A14 & !A13 & !A12 & !A11 & !A10 & !A09 & A08 /UART /EEPROM = !A15 & A14 & !A13 & A12 & !A11 /EPROM = A15

6.0 Application Examples

6

| TEST_VI<br>( CLK<br>C C<br>C C<br>C C<br>C C<br>C C<br>C C | ECTORS<br>SET<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | "for<br>->C<br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-><br>-> | Clov<br>LK8<br>H<br>L<br>L<br>L<br>H<br>H<br>H<br>H<br>H | ck Di<br>CLK4<br>H<br>L<br>H<br>H<br>L<br>L<br>H<br>H<br>L<br>L<br>H | Lvid<br>1 C                              | er"<br>LK2<br>H<br>L<br>H<br>L<br>H<br>L<br>H<br>L<br>H<br>L | )                                        |                                |                                 |                                    |                                    |                                    |   |
|------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------|------------------------------------------|--------------------------------|---------------------------------|------------------------------------|------------------------------------|------------------------------------|---|
| TEST_VI<br>( A15 2<br>0<br>0<br>0<br>0<br>1                | CTORS<br>A14 A1<br>0 0 1<br>1 0<br>1 0<br>1 0<br>1 1<br>X X          | "for<br>3 A12<br>X<br>0<br>1<br>0<br>X                            | L<br>Add.<br>A11<br>X<br>X<br>0<br>0<br>0<br>X<br>X<br>X | ress<br>Al0<br>X<br>0<br>0<br>X<br>X<br>X<br>X                       | Dec<br>A09<br>X<br>0<br>0<br>X<br>X<br>X | oder"<br>A08<br>X<br>X<br>0<br>1<br>X<br>X<br>X<br>X         | -> -> -> -> -> -> -> -> -> -> -> -> -> - | EPROM<br>H<br>H<br>H<br>H<br>L | EEPROM<br>H<br>H<br>L<br>H<br>H | UART<br>H<br>H<br>H<br>H<br>H<br>H | PORT<br>H<br>H<br>H<br>H<br>H<br>H | SRAM<br>L<br>H<br>H<br>H<br>H<br>H | ) |
|                                                            | T                                                                    |                                                                   |                                                          |                                                                      |                                          |                                                              |                                          |                                |                                 |                                    |                                    |                                    |   |

### 6.5 Bus Programmable 8 to 1 Multiplexer

DEVICE: PEEL18CV8 FILE NAME: V8BUSMUX.APL

This application implements an 8 to 1 multiplexor that can be interfaced to a  $\mu$ P bus. Any one of the 8 inputs (I0-7) can be selectively routed to the output (OUT) by writing (/WR and /CS =0) a 3-bit binary value to the data inputs (DI0-2). The value is stored into a 3-bit latch that controls the multiplexer selection. Because the latch utilizes internal asynchronous feedback (macro configuration #8), the value can also be enabled onto the data outputs (DO0-2). The DI and DO (0-2) pins should be tied together for write/read bus operation. The truth table for the mux is depicted via the test vectors.





| TITLE //<br>DESIGNEN<br>DATE: 9. | APEEL FILE: PEEL18CV<br>R: Robin Jigour<br>/13/87′ | 8 BUS PROGRAMMBLE 8 TO 1 MUX            |
|----------------------------------|----------------------------------------------------|-----------------------------------------|
| DEET 18C                         | 78                                                 |                                         |
|                                  |                                                    |                                         |
| ייזר ואדפיי                      |                                                    |                                         |
| FIN DE                           | INTIONS                                            |                                         |
| "Inputs                          | n                                                  |                                         |
| IO                               | pin l                                              |                                         |
| I1                               | pin 2                                              |                                         |
| 12                               | pin 3                                              |                                         |
| 13                               | pin 4                                              |                                         |
| 14                               | pin 5                                              |                                         |
| DIU                              | pin 6                                              |                                         |
| DII                              | pin /                                              |                                         |
|                                  | pin 8                                              |                                         |
| INR                              | pin 9                                              |                                         |
| 100                              | pin II                                             | "Hee as inputs only                     |
| 1 KU<br>1 7                      | pin iz                                             | "Ding 12 17-19 magne configurations are |
| 16                               | pin 18                                             | "defaulted to 'pos com feed pin'        |
| 15                               | pin 19                                             | defudiced to pos com feed_pin .         |
|                                  | P 111 10                                           |                                         |
| "Output:                         | s and Macro Cell def                               | initions                                |
| D02                              | pin 13 = pos com                                   | feed_or "Internal feedback from the     |
| D01                              | pin 14 = pos com                                   | feed_or "input of the D flip-flop.      |
| D00                              | pin 15 = pos com                                   | feed_or                                 |
| MOUT                             | pin 16 = pos com                                   | feed_pin                                |
| EQUATIO                          | NS                                                 |                                         |
| DO0 = D:                         | IO & WR & CS #                                     | "Set D0 latch from bus write.           |
| DO                               | 00 & !WR #                                         | "Hold when not selected.                |
| DO                               | 00 & !CS #                                         |                                         |
| D                                | IO & DOO                                           | "Prevent hazard.                        |
|                                  | 00 - PD = CC                                       | "Eachle DO output with hus read         |

| 001         | DC<br>DC         | )1 &<br>)1 &                                                 | 1W<br>1C                                | R #<br>S #                                   | 00                                   | n                                                    |                                                |                                                                  | "Hold            | d whe                                                | n no                                          | ot s                                         | sele                                   | cted                                                         | ".                                           |                                                      |             |             |
|-------------|------------------|--------------------------------------------------------------|-----------------------------------------|----------------------------------------------|--------------------------------------|------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------|------------------|------------------------------------------------------|-----------------------------------------------|----------------------------------------------|----------------------------------------|--------------------------------------------------------------|----------------------------------------------|------------------------------------------------------|-------------|-------------|
| Enab        | D]<br>le [       | 1 &<br>001                                                   | DO<br>= R                               | 1<br>D&                                      | cs                                   |                                                      |                                                |                                                                  | "Prev<br>"Enat   | vent<br>ble D                                        | haza<br>1 ou                                  | ard.<br>atpu                                 | it w                                   | ith                                                          | bus                                          | read                                                 | d.          |             |
| D02         | = D]<br>D(       | 12 &<br>2 &                                                  | WR<br>!W                                | &<br>R #                                     | cs                                   | #                                                    |                                                |                                                                  | "Set<br>"Holo    | D2 l<br>d whe                                        | atch<br>n no                                  | n fi<br>ot s                                 | com<br>sele                            | bus<br>ctec                                                  | wri <sup>.</sup>                             | te.                                                  |             |             |
| Enab        | DI<br>DI<br>le D | 12 &<br>12 &<br>002                                          | DO<br>= R                               | 2<br>D&                                      | cs                                   |                                                      |                                                |                                                                  | "Prev<br>"Enat   | vent<br>ble D                                        | haza<br>2 ou                                  | ard.<br>itpi                                 | it w                                   | ith                                                          | bus                                          | read                                                 | d.          |             |
| MOUT        | = ]              | [0 &<br>[1 &<br>[2 &<br>[3 &<br>[4 &<br>[5 &<br>[6 &<br>[7 & | ! D<br>! D<br>! D<br>! D<br>D<br>D<br>D | 02<br>02<br>02<br>02<br>02<br>02<br>02<br>02 | & !<br>& !<br>& !<br>& !<br>& !<br>& | D01<br>D01<br>D01<br>D01<br>D01<br>D01<br>D01<br>D01 | &<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>& | ! D00<br>D00<br>! D00<br>! D00<br>! D00<br>! D00<br>! D00<br>D00 | #<br>#<br>#<br># | "Sel<br>"Sel<br>"Sel<br>"Sel<br>"Sel<br>"Sel<br>"Sel | ect<br>ect<br>ect<br>ect<br>ect<br>ect<br>ect | I0<br>I1<br>I2<br>I3<br>I4<br>I5<br>I6<br>I7 | whe<br>whe<br>whe<br>whe<br>whe<br>whe | n DC<br>n DC<br>n DC<br>n DC<br>n DC<br>n DC<br>n DC<br>n DC | -2<br>-2<br>-2<br>-2<br>-2<br>-2<br>-2<br>-2 | = 0<br>= 1<br>= 2<br>= 3<br>= 4<br>= 5<br>= 6<br>= 7 |             |             |
| TEST        | _VEC             | CTOR                                                         | S "                                     | Tes                                          | t p                                  | rog                                                  | ran<br>T7                                      | nmabl                                                            | e 8 t            | to 1                                                 | mux'                                          | WD                                           | PD                                     | _ \                                                          | 200                                          | DOI                                                  | 000         | MOUT        |
| 1           | 0<br>0           | 0                                                            | 0                                       | 0<br>0                                       | 0                                    | 0                                                    | 0                                              | 012                                                              | 0<br>0<br>0      | 0000                                                 | 1<br>0                                        | 1<br>0                                       | 0<br>0                                 | -><br>->                                                     | Z<br>Z                                       | Z<br>Z                                               | Z<br>Z      | H<br>H      |
| 0<br>1      | 0<br>0           | 0<br>0                                                       | 0<br>0                                  | 0<br>0                                       | 0<br>0                               | 0<br>0                                               | 0<br>0                                         | X<br>X                                                           | X<br>X           | X<br>X                                               | 0<br>1                                        | 0<br>0                                       | 0<br>1                                 | -><br>->                                                     | Z<br>L                                       | Z<br>L                                               | Z<br>L      | L<br>H      |
| 0           | 0<br>0           | 1<br>1<br>0                                                  | 0<br>0                                  | 0<br>0                                       | 0<br>0                               | 0<br>0                                               | 0                                              | 0                                                                | 1<br>1<br>¥      | 0<br>0<br>8                                          | 1<br>0                                        | 1<br>0                                       | 0<br>0                                 | -><br>->                                                     | Z<br>Z                                       | Z<br>Z                                               | Z<br>Z      | H<br>H      |
| 0           | 0                | 1                                                            | 0                                       | 0                                            | 0                                    | 0                                                    | 0                                              | X                                                                | X                | X                                                    | 1                                             | 0                                            | 1                                      | ->                                                           | L                                            | H                                                    | L           | н           |
| 0<br>0<br>0 | 0<br>0<br>0      | 0<br>0<br>0                                                  | 0<br>0<br>0                             | 0<br>0<br>0                                  | 1<br>1<br>0                          | 0<br>0<br>0                                          | 0<br>0<br>0                                    | 1<br>1<br>X                                                      | 0<br>0<br>X      | 1<br>1<br>X                                          | 1<br>0<br>0                                   | 1<br>0<br>0                                  | 0<br>0<br>0                            | -><br>-><br>->                                               | Z<br>Z<br>Z                                  | Z<br>Z<br>Z                                          | Z<br>Z<br>Z | H<br>H<br>L |
| 0           | 0                | 0                                                            | 0                                       | 0                                            | 1                                    | 0                                                    | 0                                              | X<br>1                                                           | X<br>1           | X<br>1                                               | 1                                             | 0                                            | 1                                      | ->                                                           | H<br>7                                       | L                                                    | H           | Н           |
| 0           | 0                | 0                                                            | 0                                       | 0                                            | 0                                    | 0                                                    | 1                                              | 1<br>X                                                           | 1<br>X           | 1<br>X                                               | 0                                             | 0                                            | 0                                      | -><br>->                                                     | Z<br>Z                                       | Z<br>Z                                               | Z           | H<br>L      |
| 0           | U                | υ                                                            | υ                                       | υ                                            | υ                                    | υ                                                    | T                                              | х                                                                | X                | х                                                    | 1                                             | υ                                            | 1                                      | ->                                                           | Н                                            | н                                                    | н           | н           |
|             |                  |                                                              |                                         |                                              |                                      |                                                      |                                                |                                                                  |                  |                                                      |                                               |                                              |                                        |                                                              |                                              |                                                      |             |             |

## 6.6 8-Bit Expandable Comparator

DEVICE: PEEL18CV8 FILE NAME: V8COMP.APL

This application uses the PEEL18CV8 as an expandable 8-bit (or dual 4-bit) comparator. The inputs are organized into four 4bit groups and are labeled A0-A3, B0-B3, C0-C3, and D0-D3. The comparison is done between inputs A and C, and inputs B and D. As an 8-bit comparator, both outputs must be tied together with a resistor pull-up (2-20K depending on system speed requirements). If the comparison is equal, the outputs will disable, allowing the resistor to pull the output high. If the comparison of is not equal an output will be asserted low pulling both outputs low. The application utilizes the individual output enables and internal feedback capability of the 18CV8 macro cell to allow expandability. (configuration 7 in figure 6 of the PEEL18CV8 data sheet). This configuration is used to implement a wired-AND function allowing additional comparators outputs to be tied together. Thus, two 18CV8s could create a 16 bit comparator, three a 24 bit comparator, and so on. A dual 4bit comparator can be achieved by using two pull-up resistors (one resistor for each output). Note, if expandability is not needed, the pull-up resistors can be removed for the dual 4-bit comparator by permanently enabling the outputs.



### 6.6 8-Bit Expandable Comparator

6.0 Application Examples

| DATE: 9/13/87' PEEL18CV8 "PIN DEFINITIONS" "Inputs" A0 pin 1 A1 pin 2 A2 pin 3 A3 pin 4 B0 pin 5 B1 pin 6 B2 pin 7 B3 pin 8 C0 pin 9 C1 pin 11 C2 pin 12 "Use as inputs only. C3 pin 13 "Pins 12-17 macro configurations T0 pin 14 "are defaulted to 'pos com feed_pin' D1 pin 15 D2 pin 16 D3 pin 17 "Outputs Macro Cell definitions A_EQ_C pin 18 = neg com feed_or "Internal feedback. B_EQ_D pin 19 = neg com feed_or EQUATIONS                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>PEEL18CV8 "PIN DEFINITIONS" "Inputs" A0 pin 1 A1 pin 2 A2 pin 3 A3 pin 4 B0 pin 5 B1 pin 6 B2 pin 7 B3 pin 8 C0 pin 9 C1 pin 11 C2 pin 12 "Use as inputs only. C3 pin 13 "Pins 12-17 macro configurations D0 pin 14 "are defaulted to 'pos com feed_pin' D1 pin 15 D2 pin 16 D3 pin 17 "Outputs Macro Cell definitions A_EQ_C pin 18 = neg com feed_or "Internal feedback. B_EQ_D pin 19 = neg com feed_or EQUATIONS</pre>                                                     |
| "PIN DEFINITIONS"<br>"Inputs"<br>A0 pin 1<br>A1 pin 2<br>A2 pin 3<br>A3 pin 4<br>B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS           |
| <pre>"Inputs"<br/>A0 pin 1<br/>A1 pin 2<br/>A2 pin 3<br/>A3 pin 4<br/>B0 pin 5<br/>B1 pin 6<br/>B2 pin 7<br/>B3 pin 8<br/>C0 pin 9<br/>C1 pin 11<br/>C2 pin 12 "Use as inputs only.<br/>C3 pin 13 "Pins 12-17 macro configurations<br/>D0 pin 14 "are defaulted to 'pos com feed_pin'<br/>D1 pin 15<br/>D2 pin 16<br/>D3 pin 17<br/>"Outputs Macro Cell definitions<br/>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br/>B_EQ_D pin 19 = neg com feed_or<br/>EQUATIONS</pre> |
| A0 pin 1<br>A1 pin 2<br>A2 pin 3<br>A3 pin 4<br>B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                            |
| A1 pin 2<br>A2 pin 3<br>A3 pin 4<br>B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                        |
| A2 pin 3<br>A3 pin 4<br>B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                    |
| A3 pin 4<br>B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                |
| B0 pin 5<br>B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                            |
| B1 pin 6<br>B2 pin 7<br>B3 pin 8<br>C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                        |
| <pre>B3 pin 8<br/>C0 pin 9<br/>C1 pin 11<br/>C2 pin 12 "Use as inputs only.<br/>C3 pin 13 "Pins 12-17 macro configurations<br/>D0 pin 14 "are defaulted to 'pos com feed_pin'<br/>D1 pin 15<br/>D2 pin 16<br/>D3 pin 17<br/>"Outputs Macro Cell definitions<br/>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br/>B_EQ_D pin 19 = neg com feed_or</pre>                                                                                                                       |
| C0 pin 9<br>C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                            |
| C1 pin 11<br>C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                        |
| C2 pin 12 "Use as inputs only.<br>C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                     |
| C3 pin 13 "Pins 12-17 macro configurations<br>D0 pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                       |
| DU pin 14 "are defaulted to 'pos com feed_pin'<br>D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                     |
| D1 pin 15<br>D2 pin 16<br>D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                                                                       |
| D3 pin 17<br>"Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                                                                                                 |
| "Outputs Macro Cell definitions<br>A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                                                                                                              |
| A_EQ_C pin 18 = neg com feed_or "Internal feedback.<br>B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                                                                                                                                                 |
| B_EQ_D pin 19 = neg com feed_or<br>EQUATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| EQUATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A_EQ_C = !( !A0 & CO # A0 & !CO # "Compare A0-3 and CO-3,                                                                                                                                                                                                                                                                                                                                                                                                                           |
| !A1 & C1 # A1 & !C1 # "when A does not = C then                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| $!A2 \& C2 \# A2 \& !C2 \# "A_EQ_C is 0.$                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [A3 & C3 # A3 & [C3])                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| "Disable when A does not = C<br>"Disable when A = C.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| En   | abl         | e B    | _EQ    | !B1<br>!B2<br>!B3<br>_D = | &  <br>&  <br>&  <br>!B | D1<br>D2<br>D3<br>_EQ | #<br>#<br>#<br>D | B1 &<br>B2 &<br>B3 & | 4 1 E<br>4 1 E<br>4 1 E | )1<br>)2<br>)3 | #<br>#<br>)   | "When B does not = D then<br>"B_EQ_D is 0<br>"Enable when B does not = D.<br>"Disable when B = D. |
|------|-------------|--------|--------|---------------------------|-------------------------|-----------------------|------------------|----------------------|-------------------------|----------------|---------------|---------------------------------------------------------------------------------------------------|
| тE   | ST '        | VEC    | TOR    | s                         |                         |                       |                  |                      |                         |                |               |                                                                                                   |
| (    | A3          | A2     | A1     | A0                        | С3                      | C2                    | C1               | C 0                  | ->                      | • 7            | A_EQ_C        | )                                                                                                 |
|      | 0           | 0      | 0      | 0                         | 0                       | 0                     | 0                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 0           | 0      | 0      | 1                         | 0                       | 0                     | 0                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 0           | 0      | 1      | 0                         | 0                       | 0                     | 1                | 0                    | ->                      | <b>`</b>       | Z<br>T        |                                                                                                   |
|      | 0           | 1      | U<br>T | 1<br>L                    | 0                       | 1                     | U<br>T           | 0                    | ->                      | ,              | ட<br>7        |                                                                                                   |
|      | 0           | 1      | 0      | 1                         | 0                       | 1                     | 0                | 0                    | ->                      |                | L.            |                                                                                                   |
|      | Ő           | 1      | 1      | ō                         | 0                       | 1                     | 1                | õ                    | ->                      | •              | Z             |                                                                                                   |
|      | 0           | 1      | 1      | 1                         | 0                       | 1                     | 1                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 1           | 0      | 0      | 0                         | 1                       | 0                     | 0                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 1           | 0      | 0      | 1                         | 1                       | 0                     | 0                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 1           | 0      | 1      | 0                         | 1                       | 0                     | 1                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 1           | 1      | 1      | 1                         | 1                       | 1                     | 1                | 0                    | ->                      | •              | 上<br>7        |                                                                                                   |
|      | 1           | 1      | 0      | 1                         | 1                       | 1                     | 0                | 0                    | ->                      | ,              | <u>г</u> .    |                                                                                                   |
|      | 1           | 1      | 1      | ō                         | 1                       | 1                     | 1                | õ                    | ->                      |                | z             |                                                                                                   |
|      | 1           | 1      | 1      | 1                         | 1                       | 1                     | 1                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 1           | 1      | 1      | 1                         | 1                       | 1                     | 1                | 1                    | ->                      | •              | Z             |                                                                                                   |
| m 77 | <u>с</u> п, |        |        | ~                         |                         |                       |                  |                      |                         |                |               |                                                                                                   |
| TE / | BU<br>BU    | R1     | B2     | ь<br>ра                   | D٥                      | נם                    | 2ס               | ъз                   | - `                     | . T            | R FO D        | <b>)</b>                                                                                          |
| `    | 0           | 0      | 0      | 0                         | 0                       | 0                     | 0                | 0                    | ->                      | , '            | ZZ            | ,                                                                                                 |
|      | 0           | 0      | 0      | 1                         | 0                       | 0                     | 0                | 0                    | ->                      | •              | $\mathbf{L}$  |                                                                                                   |
|      | 0           | 0      | 1      | 0                         | 0                       | 0                     | 1                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 0           | 0      | 1      | 1                         | 0                       | 0                     | 1                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 0           | 1      | 0      | 0                         | 0                       | 1                     | 0                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 0           | 1      | 0      | 1                         | 0                       | 1                     | U<br>1           | 0                    | ->                      | •              | 上<br>7        |                                                                                                   |
|      | 0           | 1<br>1 | 1<br>1 | 1                         | 0                       | ⊥<br>1                | 1<br>1           | 0                    | -2                      | ,              | <u></u><br>Т. |                                                                                                   |
|      | 1           | Ō      | Ō      | Ō                         | 1                       | Ō                     | Ō                | õ                    | ->                      |                | Z             |                                                                                                   |
|      | 1           | 0      | 0      | 1                         | 1                       | 0                     | 0                | 0                    | ->                      | •              | L             |                                                                                                   |
|      | 1           | 0      | 1      | 0                         | 1                       | 0                     | 1                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 1           | 0      | 1      | 1                         | 1                       | 0                     | 1                | 0                    | ->                      | •              | $\mathbf{L}$  |                                                                                                   |
|      | 1           | 1      | 0      | 0                         | 1                       | 1                     | 0                | 0                    | ->                      | •              | Z             |                                                                                                   |
|      | 1           | 1      | 0      | 1                         | 1                       | 1                     | 0                | 0                    | ->                      | <b>`</b>       | L<br>7        |                                                                                                   |
|      | 1<br>1      | 1<br>1 | ⊥<br>1 | 0<br>1                    | ⊥<br>1                  | 1<br>1                | ⊥<br>1           | 0                    | ->                      | ,              | Z<br>T        |                                                                                                   |
|      | 1           | 1      | 1      | 1                         | 1                       | 1                     | ⊥<br>1           | 1                    | _`                      |                | ت<br>7        |                                                                                                   |

# 6.7 8-Bit Counter with Function Controls

DEVICE: PEEL18CV8 FILE NAME: V8FCNTR.APL

This application uses the PEEL18CV8 as an 8 bit counter with four control functions: hold, reset, repeat and output enable. The operation of each control listed below. The Synchronous Preset term was utilized to free-up a product term from the eighth bit of the counter. This allowed the hold function to be implemented. SRES (Synchronous Reset) - When SRES is set high the outputs (Q0-7) will go low after the next clock. When SRES is set high the counter will start counting up with each clock. HOLD (Hold Count) - When HOLD is set high the count will hold the present state. When HOLD is low the counter will resume. REP (Repeat Count) - When REP is set high, the counter repeat the count after reaching FF hex. When REP is set low, the counter will stop after one complete count. OE (Output Enable) - When OE is high the outputs will disable to high impedance. When low, the outputs are enabled. (TEST) - This input is used to preload the registers to simplify test vector operation.



TITLE 'APEEL FILE: PEEL18CV8 8-Bit Counter with Function Controls DESIGNER: Robin Jigour and John Birkner DATE: 9/14/87' P18CV8 "PIN ASSIGNMENTS CLK pin 1 pin 2 TEST "For test only, set Q0-Q5 to 1's. HOLD pin 7 SRES pin 8 REP pin 9 !OE pin 11 "Outputs" pin 12 = pos reg feed reg "All positive registered outputs. 07 Q6 pin 13 = pos reg feed reg Q5 pin 14 = pos reg feed reg pin 15 = pos reg feed\_reg
pin 16 = pos reg feed\_reg
pin 17 = pos reg feed\_reg
pin 18 = pos reg feed\_reg 04 Q3 Q2 01 Q0 pin 19 = pos reg feed reg "Internal Nodes" AC node 21 "Asynchronous Clear node. "Synchronous Preset node. SP node 22 EQUATIONS AC = !SRES & !REP & !Q7 & !Q6 & !Q5 & !Q4 & !Q3 & !Q2 & !Q1 & !Q0 "If REP=1 repeat count else stop at count 00 hex. SP = !SRES & Q7 & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & !Q0"Free up product term on Q7. Q0 = !SRES & !HOLD & !Q0 #"Count. SRES & HOLD & QO # "Hold state. SRES & TEST Enable Q0 = OE"Enable output.

6

l

6.0 Application Examples

| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                |                                                                                      |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------|---------------------------------|----------------------------------------------|----------------------|----|---|----|---|----|---|----|---|----|---|--|
| Enable Q1 = OE<br>Q2 = $:SRES \& :HOLD \& :Q2 \& Q1 \& Q0 # \\ :SRES \& :HOLD & Q2 & Q2 & Q1 & Q0 # \\ :SRES \& HOLD & Q2 & Q2 & Q1 & Q0 # \\ :SRES \& HOLD & Q2 & Q2 & Q1 & Q0 # \\ :SRES \& HOLD & Q3 & Q2 & Q1 & Q0 # \\ :SRES \& :HOLD & Q3 & Q2 & Q1 & Q0 # \\ :SRES \& :HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES \& :HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES \& :HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q3 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q4 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q4 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q4 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q4 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q5 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 # \\ :SRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 & # \\ :SRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 & # \\ :SRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 & # \\ :SRES & HOLD & Q6 & Q5 & Q4 & Q4 & Q4 & Q4 & Q4 & Q4 & Q4$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q1 =           | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &                                             | !HOLD<br>!HOLD<br>HOLD<br>TEST                                             | &<br>&<br>&                                                                                 | !Q1<br>Q1<br>Q1                                | &<br>&<br>#                     | Q0<br>!Q0                                    | #<br>#               |    |   |    |   |    |   |    |   |    |   |  |
| $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Enable         | Q1 = OE                                                                              |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Q2 =           | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &                                  | !HOLD<br>!HOLD<br>!HOLD<br>HOLD<br>TEST                                    | &<br>&<br>&<br>&                                                                            | ! Q2<br>Q2<br>Q2<br>Q2                         | &<br>&<br>#                     | Q1<br>!Q1<br>!Q0                             | &<br>#<br>#          | QO | # |    |   |    |   |    |   |    |   |  |
| $\begin{array}{rclcrcl} \mathbb{Q}3 &=& \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{i}\mathrm{Q}3 &\mathrm{\&}\mathrm{Q}2 &\mathrm{\&}\mathrm{Q}1 &\mathrm{\&}\mathrm{Q}0 &\mathrm{#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}3 &\mathrm{\&}\mathrm{i}\mathrm{Q}2 &\mathrm{#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}3 &\mathrm{\&}\mathrm{i}\mathrm{Q}0 &\mathrm{#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}3 &\mathrm{\&}\mathrm{i}\mathrm{Q}0 &\mathrm{#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}3 &\mathrm{\&}\mathrm{i}\mathrm{Q}2 &\mathrm{\&}\mathrm{Q}1 &\mathrm{\&}\mathrm{Q}0 &\mathrm{#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}4 &\mathrm{\&}\mathrm{I}\mathrm{Q}3 &\mathrm{\&}\mathrm{Q}2 &\mathrm{\&}\mathrm{Q}1 &\mathrm{\&}\mathrm{Q}0 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}4 &\mathrm{\&}\mathrm{IQ}3 &\mathrm{\&}\mathrm{Q}2 &\mathrm{\&}\mathrm{Q}1 &\mathrm{\&}\mathrm{Q}0 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}4 &\mathrm{\&}\mathrm{IQ}0 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}5 &\mathrm{\&}\mathrm{IQ}4 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}5 &\mathrm{\&}\mathrm{IQ}4 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}5 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{i}\mathrm{HOLD} &\mathrm{\&}\mathrm{Q}5 &\mathrm{\&}\mathrm{IQ}0 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}3 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{\&}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{S}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{S}\mathrm{IHOLD} &\mathrm{\&}\mathrm{Q}6 &\mathrm{\&}\mathrm{IQ}2 &\mathrm{\#} \\ && \mathrm{i}\mathrm{SRES}\mathrm{IHOLD} &\mathrm{I}\mathrm{Q} &\mathrm{I}\mathrm{I}\mathrm{I}\mathrm{I}\mathrm{I}\mathrm{I}\mathrm{I}\mathrm{I}$ | FUIDIG         | QZ = OE                                                                              |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
| Enable Q3 = OE<br>Q4 = $\frac{1}{3}$ SRES & $\frac{1}{3}$ HOLD & $\frac{1}{6}$ $\frac{1}{2}$ Q4 & $\frac{1}{6}$ $\frac{1}{2}$ $\frac{3}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{3}$ HOLD & $\frac{1}{6}$ $\frac{2}{2}$ $\frac{4}{6}$ $\frac{1}{2}$ $\frac{3}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{3}$ HOLD & $\frac{1}{6}$ $\frac{2}{2}$ $\frac{4}{6}$ $\frac{1}{2}$ $\frac{1}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{3}$ HOLD & $\frac{1}{6}$ $\frac{2}{2}$ $\frac{4}{6}$ $\frac{1}{2}$ $\frac{1}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{6}$ HOLD & $\frac{1}{6}$ $\frac{2}{2}$ $\frac{1}{6}$ $\frac{2}{2}$ $\frac{1}{6}$ $\frac{2}{2}$ $\frac{1}{6}$ $\frac{2}{2}$ $\frac{1}{6}$<br>$\frac{2}{3}$ $\frac{1}{3}$ $\frac{1}{3}$ SRES & $\frac{1}{3}$ HOLD & $\frac{1}{6}$ $\frac{2}{5}$ $\frac{1}{6}$ $\frac{2}{2}$ $\frac{1}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{6}$ HOLD & $\frac{1}{6}$ $\frac{2}{5}$ $\frac{5}{6}$ $\frac{1}{2}$ $\frac{2}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{6}$ HOLD & $\frac{2}{6}$ $\frac{2}{5}$ $\frac{5}{6}$ $\frac{1}{2}$ $\frac{2}{4}$<br>$\frac{1}{3}$ SRES & $\frac{1}{6}$ HOLD & $\frac{2}{6}$ $\frac{2}{5}$ $\frac{5}{6}$ $\frac{2}{2}$ $\frac{2}{6}$ $\frac{2}{1}$ $\frac{6}{6}$ $\frac{2}{6}$ $\frac{2}{6}$ $\frac{2}{1}$ $\frac{2}{6}$ $\frac{2}{6}$ $\frac{2}{1}$ $\frac{2}{6}$ $\frac{2}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Q3 =           | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &                       | !HOLD<br>!HOLD<br>!HOLD<br>!HOLD<br>HOLD<br>TEST                           | &<br>&<br>&<br>&<br>&                                                                       | ! Q3<br>Q3<br>Q3<br>Q3<br>Q3<br>Q3             | &<br>&<br>&<br>&<br>#           | Q2<br>!Q2<br>!Q1<br>!Q0                      | &<br>#<br>#          | Q1 | £ | QO | # |    |   |    |   |    |   |  |
| Q4 = !SRES & !HOLD & 2 !Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & !HOLD & Q4 & !Q2 #<br>ISRES & !HOLD & Q4 & !Q2 #<br>ISRES & !HOLD & Q4 & !Q0 #<br>ISRES & HOLD & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & !HOLD & Q5 & !Q4 #<br>ISRES & !HOLD & Q5 & !Q2 #<br>ISRES & !HOLD & Q5 & !Q2 #<br>ISRES & !HOLD & Q5 & !Q2 #<br>ISRES & !HOLD & Q5 & !Q0 #<br>ISRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & !HOLD & Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>ISRES & !HOLD & Q6 & 1Q2 #<br>ISRES & !HOLD & Q6 & 1Q0 #<br>ISRES & HOLD & Q6 & 1Q0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Enable         | Q3 = OE                                                                              |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
| Enable Q4 = OE<br>Enable Q4 = OE<br>Q5 = $!SRES \& !HOLD \& !Q5 \& Q4 \& Q3 \& Q2 \& Q1 \& Q0 #$<br>!SRES & !HOLD & Q5 & !Q4 #<br>!SRES & !HOLD & Q5 & !Q2 #<br>!SRES & !HOLD & Q5 & !Q2 #<br>!SRES & !HOLD & Q5 & !Q0 #<br>!SRES & !HOLD & Q5 & !Q0 #<br>!SRES & HOLD & Q5 #<br>!SRES & TEST<br>Enable Q5 = OE<br>Q6 = $!SRES \& !HOLD & Q6 \& Q5 \& Q4 \& Q3 \& Q2 \& Q1 \& Q0 #$<br>!SRES & !HOLD & Q6 & !Q5 #<br>!SRES & !HOLD & Q6 & !Q4 #<br>!SRES & !HOLD & Q6 & !Q4 #<br>!SRES & !HOLD & Q6 & !Q3 #<br>!SRES & !HOLD & Q6 & !Q4 #                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q4 =           | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &                       | ! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>HOLD<br>TEST             | &<br>&<br>&<br>&<br>&<br>&                                                                  | 24<br>Q4<br>Q4<br>Q4<br>Q4<br>Q4<br>Q4         | &<br>& &<br>& &<br>#            | Q3<br>!Q3<br>!Q2<br>!Q1<br>!Q0               | &<br>#<br>#<br>#     | Q2 | & | Q1 | & | QO | # |    |   |    |   |  |
| Q5 = ISRES & IHOLD & IQ5 & Q4 & Q3 & Q2 & Q1 & Q0 # $ISRES & IHOLD & Q5 & IQ4 #$ $ISRES & IHOLD & Q5 & IQ2 #$ $ISRES & IHOLD & Q5 & IQ2 #$ $ISRES & IHOLD & Q5 & IQ0 #$ $ISRES & IHOLD & Q5 & IQ0 #$ $ISRES & IHOLD & Q5 #$ $ISRES & IHOLD & Q5 #$ $ISRES & IHOLD & Q6 & IQ0 #$ $ISRES & IHOLD & Q6 & IQ2 #$ $ISRES & IHOLD & Q6 & IQ0 #$ $ISRES & IHOLD & ISRES & IHOLD &$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Enable         | Q4 = OE                                                                              | 1201                                                                       |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
| Enable Q5 = OE<br>Q6 = !SRES & !HOLD & !Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>!SRES & !HOLD & Q6 & !Q5 #<br>!SRES & !HOLD & Q6 & !Q4 #<br>!SRES & !HOLD & Q6 & !Q4 #<br>!SRES & !HOLD & Q6 & !Q2 #<br>!SRES & !HOLD & Q6 & !Q2 #<br>!SRES & !HOLD & Q6 & !Q1 #<br>!SRES & !HOLD & Q6 & !Q0 #<br>!SRES & HOLD & Q6<br>Enable Q6 = OE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q5 =           | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &            | !HOLD<br>!HOLD<br>!HOLD<br>!HOLD<br>!HOLD<br>!HOLD<br>HOLD<br>TEST         | &<br>&<br>&<br>&<br>&<br>&<br>&<br>&                                                        | ! Q5<br>Q5<br>Q5<br>Q5<br>Q5<br>Q5<br>Q5<br>Q5 | &<br>& & & & & & #              | Q4<br>!Q4<br>!Q3<br>!Q2<br>!Q1<br>!Q0        | &<br>#<br>#<br>#     | Q3 | æ | Q2 | & | Q1 | & | QO | # |    |   |  |
| Q6 = !SRES & !HOLD & !Q6 & Q5 & Q4 & Q3 & Q2 & Q1 & Q0 #<br>!SRES & !HOLD & Q6 & !Q5 #<br>!SRES & !HOLD & Q6 & !Q4 #<br>!SRES & !HOLD & Q6 & !Q3 #<br>!SRES & !HOLD & Q6 & !Q2 #<br>!SRES & !HOLD & Q6 & !Q1 #<br>!SRES & !HOLD & Q6 & !Q0 #<br>!SRES & HOLD & Q6<br>Enable Q6 = OE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Enable         | Q5 = OE                                                                              |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Q6 =<br>Enable | !SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>!SRES &<br>Q6 = OE | ! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>! HOLD<br>HOLD | &<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>& | ! Q6<br>Q6<br>Q6<br>Q6<br>Q6<br>Q6<br>Q6<br>Q6 | 8<br>8<br>8<br>8<br>8<br>8<br>8 | Q5<br>!Q5<br>!Q4<br>!Q3<br>!Q2<br>!Q1<br>!Q0 | & # # # #<br># # # # | Q4 | & | Q3 | æ | Q2 | £ | Q1 | Ł | QO | # |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                |                                                                                      |                                                                            |                                                                                             |                                                |                                 |                                              |                      |    |   |    |   |    |   |    |   |    |   |  |

| Q | 7 =    | !SRES<br>!SRES<br>!SRES<br>!SRES<br>!SRES<br>!SRES<br>!SRES<br>!SRES | & ! HC<br>& HC<br>& HC | 4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010     4 010 | !Q7 &<br>Q7 &<br>Q7 &<br>Q7 &<br>Q7 &<br>Q7 &<br>Q7 &<br>Q7 & | 20<br>10<br>10<br>10<br>10<br>10<br>10<br>10 | 5 &<br>5 #<br>5 #<br>1 #<br>8 #<br>2 # | Q5           | &            | Q4 &         | Q3           | ۵.     | Q2 &         | Q1           | æ            | QO |  |
|---|--------|----------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|----------------------------------------|--------------|--------------|--------------|--------------|--------|--------------|--------------|--------------|----|--|
|   | nuore  | 2, (                                                                 |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
| T | EST_VI | ECTORS                                                               |                                                                                    | CDFC                                                                                                                                              | DFD                                                           | 0F                                           | _\                                     | 07           | 06           | 05           | 04           | 03     | 02           | 01           | 00           | 、  |  |
| ( | C      | 0                                                                    | 0                                                                                  | 1                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | x′           | x            | x            | X            | x      | X<br>X       | X            | x            | ,  |  |
|   | C      | 0                                                                    | 0                                                                                  | 1                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | L            | L            | L            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 1                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | $\mathbf{L}$ | L            | Н            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 0                                            | ->                                     | Z            | Z            | Z            | Z            | Z      | Z            | Z            | Z            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | $\mathbf{L}$ | L            | L            | L      | L            | Н            | Н            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 1                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | $\mathbf{L}$ | L            | $\mathbf{L}$ | L            | L      | L            | L            | L            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | L            | $\mathbf{L}$ | L            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 1                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | L            | L            | Н            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | L            | Н            | L            |    |  |
|   | С      | 1                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Ц<br>т       | Ц<br>1       | Н            | H            | H<br>T | н            | H            | H            |    |  |
|   | C      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | ц<br>т       | н            | ц<br>т       | ь<br>        | Ц      | Ц            | Ц            | 1            |    |  |
|   | C      | 1                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ~~                                     | ц<br>11      | н<br>т       | н            | н<br>т       | т      | п            | п            | т            |    |  |
|   | c      | 1                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            |                                        | л<br>U       | Т            | ц<br>Ц       | ы<br>U       | ц      | ц            | ц            | ц            |    |  |
|   | c      | Ô                                                                    | 0<br>0                                                                             | 0                                                                                                                                                 | ñ                                                             | 1                                            | ->                                     | н            | н            | т.           | T.           | T.     | T.           | T.           | T.           |    |  |
|   | č      | 0                                                                    | õ                                                                                  | õ                                                                                                                                                 | õ                                                             | 1                                            | ->                                     | н            | н            | L            | L            | L      | L            | L            | н            |    |  |
|   | c      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | L            | L            | L      | L            | Н            | L            |    |  |
|   | С      | 0                                                                    | 1                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | $\mathbf{L}$ | L            | L      | L            | Н            | L            |    |  |
|   | С      | 0                                                                    | 1                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | L            | $\mathbf{L}$ | L      | $\mathbf{L}$ | Н            | $\mathbf{L}$ |    |  |
|   | С      | 1                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | Н            | Н            | Н      | Н            | Н            | Η            |    |  |
|   | С      | 0                                                                    | 1                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | Н            | Н            | Н      | Н            | Н            | Н            |    |  |
|   | С      | 0                                                                    | 1                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | Н            | Н            | H            | H            | Н      | H            | H            | H            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | L            | L            | L            | L      | L            | L            | L            |    |  |
|   | С      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | 0                                                             | 1                                            | ->                                     | L            | L            | L            | L            | Ц<br>т | L            | L            | L            |    |  |
|   | C      | 0                                                                    | 0                                                                                  | 0                                                                                                                                                 | T                                                             | T                                            | ->                                     | Ц            | Г            | Ц            | Г            | Ц      | Ц            | Ц            | н            |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |
|   |        |                                                                      |                                                                                    |                                                                                                                                                   |                                                               |                                              |                                        |              |              |              |              |        |              |              |              |    |  |

6

# 6.8 Change-of-State Port with Interrupt

DEVICE PEEL18CV8 FILE NAME: V8CPORT.APL

This application uses the PEEL18CV8 as an 8-bit input port of which 4 of its inputs can detect a change-of-state. When detected, the INTR output is set for interrupting a CPU. The state change is latched by four pseudo-buried registers which can be read by the CPU on D0-D3 as listed in the address table below. Once read, unless another change has occurred, the INTR will be reset. The D4 output can be used for status polling of any remaining state change. The I4-7 inputs do not detect state changes but can be read as a standard input port.

| Ad | dres | ss | Data       | Outputs |                             |
|----|------|----|------------|---------|-----------------------------|
| A0 | CS   | RD | D0-3       |         | D4                          |
| Х  | 1    | Х  | Hi-Z       |         | Hi-Z                        |
| Х  | Х    | 1  | Hi-Z       |         | Hi-Z                        |
| 0  | 0    | 0  | Read I0-I3 | Change  | I0-I3 Pending Change Status |
| 1  | 0    | 0  | Read I4-I7 | Inputs  | Don't care                  |







TITLE 'APEEL FILE: PEEL18CV8 CHANGE-OF-STATE INPUT PORT WITH INTERRUPT DESIGNER: Robin Jigour, ICT DATE: 9/4/87' PEEL18CV8 "PIN DEFINITIONS" "Inputs" CLK pin l "Must be connected to pin 14, INTR. "IO-I3 inputs can detect change-of-state. ΙO pin 2 Ι1 pin 3 12 pin 4 pin 5 Τ3 I4 pin 6 "I4-I7 are standard inputs. Τ5 pin 7 I6 pin 8 17 pin 9 Pin 11 ICS pin 12 "Use as inputs only. IRD pin 13 "Default pin 13 "Default macro configuration = pos com feed pin. "Outputs" INTR pin 14 = pos com feed or D4 pin 15 = pos com feed or "Internal feedback. D3 pin 16 = pos com feed\_reg D2 pin 17 = pos com feed reg pin 18 = pos com feed reg D1 D0 pin 19 = pos com feed reg "Pseudo buried registers. EQUATIONS D0 = I0 & !CS # "IO to DO register. IO & CS & !RD # "IO to DO register. D0 & CS & RD & !A0 #"Read D0 register.14 & CS & RD & A0"Read I4.Enable D0 = CS & RD"Enable onto data bus.

D1 = I1 & !CS # "I1 to D1 register. I1 & CS & !RD # D1 & CS & RD & !AO # "Il to Dl register. "Read D1 register. I5 & CS & RD & AO "Read I5. Enable D1 = CS & RD "Enable onto data-bus. D2 = I2 & !CS #"I2 to D2 register. I2 & CS & !RD # "I2 to D2 register. D2 & CS & RD & !A0 # "Read D2 register. I6 & CS & RD & AO "Read I6. Enable D2 = CS & RD "Enable onto data-bus. D3 = I3 & !CS # "I3 to D3 register. I3 & CS & !RD # "I3 to D3 register. "Read D3 register. D3 & CS & RD & !A0 # I7 & CS & RD & AO "Read I7. Enable D3 = CS & RD "Enable onto data-bus. D4 = I0 & !D0 # !I0 & D0 # "Compare IO-3 with DO-3 registers. I1 & !D1 # !I1 & D1 # "D4=1 if IO-3 and DO-3 are not equal. I2 & !D2 # !I2 & D2 # I3 & !D3 # !I3 & D3 Enable D4 = CS & RD "Enable onto data-bus for status. INTR = D4 & !CS # "Latch not-equal status uP interrupt and D4 & !RD # "PEEL clock. Clear interrupt when registers D4 & A0 # "are read and there are no more input state INTR & !CS # "changes, that is, when D4, CS, RD and A0 INTR & !RD # "are all 0. INTR & AO
| TH<br>( | EST_V | ECTC<br>T O | RS<br>T1 | "Te:<br>12 | st (<br>TR | chang<br>∡∩ | e-oi | E-sta<br>RD | te i: | nput<br>no   | t po<br>n1   | ort<br>סי    | 10-<br>D3    | 4 op<br>04   | eratio       | nc"<br>א |  |
|---------|-------|-------------|----------|------------|------------|-------------|------|-------------|-------|--------------|--------------|--------------|--------------|--------------|--------------|----------|--|
| `       | 0     | 10          | 11       | 12         | 13         | X           | 0    | X           | ->    | 20           | 7.           | 7.           | 7.           | 7            | 1016         | ,        |  |
|         | 0     | 0           | õ        | Ő          | õ          | 0           | 1    | 1           | ->    | ž            | x            | x            | x            | õ            | õ            |          |  |
|         | 0     | 1           | 0        | 0          | 0          | x           | ō    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 0        | 0          | 0          | х           | 0    | 0           | ->    | Z            | z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 0        | 0          | 0          | 0           | 1    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 0        | 0          | 0          | 0           | 1    | 1           | ->    | Н            | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{r}$ | $\mathbf{L}$ |          |  |
|         | 0     | 1           | 0        | 0          | 0          | 0           | 1    | 1           | ->    | Н            | L            | L            | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ |          |  |
|         | 0     | 1           | 0        | 0          | 0          | X           | 0    | X           | ->    | Z            | Z            | Z            | Z            | Z            | L            |          |  |
|         | 1     | 0           | 0        | 0          | 0          | X           | 0    | 0           | ->    | Z            | Z            | Z            | Z            | Z<br>7       | н            |          |  |
|         | 1     | 0           | 0        | 0          | 0          | ^           | 1    | 0           | ->    | 2<br>7       | 2            | 2            | 2            | 2            | н<br>ц       |          |  |
|         | 1     | 0           | 0        | Ő          | Ő          | 0           | 1    | 1           | ->    | т.           | Т.           | т.           | T.           | т.           | т.           |          |  |
|         | ō     | 0           | ō        | 0          | õ          | x           | ō    | x           | ->    | Z            | z            | Z            | Z            | Z            | L            |          |  |
|         | 0     | 1           | 0        | 0          | 0          | Х           | 0    | х           | ->    | Z            | Z            | Z            | z            | Z            | н            |          |  |
|         | 1     | 1           | 0        | 0          | 0          | х           | 0    | х           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 1        | 1          | 1          | Х           | 0    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 1        | 1          | 1          | 0           | 1    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 1        | 1          | 1          | 0           | 1    | 1           | ->    | Н            | L            | L            | L            | Н            | L            |          |  |
|         | 0     | 1           | 1        | 1          | 1          | X           | 0    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 1           | 1        | 1          | 1          | 0           | 1    | 1           | ->    | Z<br>U       | 2            | Z<br>U       | Z<br>U       | Z<br>T       | H<br>T       |          |  |
|         | 0     | 1           | 1        | 1          | 1          | x           | 0    | x           | ->    | п<br>7.      | п<br>7.      | л<br>7.      | л<br>7.      | <br>7.       | T.           |          |  |
|         | Ő     | Ō           | ō        | Ō          | Ō          | x           | õ    | x           | ->    | z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 0           | 0        | 0          | 0          | х           | 0    | х           | ->    | z            | Z            | Z            | Z            | Z            | Н            |          |  |
|         | 1     | 0           | 0        | 0          | 0          | 0           | 1    | 1           | ->    | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ | L            | $\mathbf{L}$ |          |  |
|         | 1     | 0           | 0        | 0          | 0          | х           | 0    | х           | ->    | Z            | Z            | Z            | Z            | Z            | $\mathbf{L}$ |          |  |
| TE      | EST V | ECTC        | RS       | "Te:       | st s       | stand       | ard  | inpu        | t po  | rt :         | 14-          | 7 01         | oera         | itior        | ."           |          |  |
| (       | CLK   | I4          | 15       | I6         | 17         | A0          | CS   | RD          | ->    | D0 I         | D1 I         | 22 1         |              | D4           | INTR         | )        |  |
|         | 0     | 1           | 0        | 1          | 0          | 1           | 0    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | х            |          |  |
|         | 0     | 1           | 0        | 1          | 0          | 1           | 1    | 0           | ->    | Z            | z            | Z            | z            | Z            | х            |          |  |
|         | 0     | 1           | 0        | 1          | 0          | 1           | 1    | 1           | ->    | Н            | $\mathbf{L}$ | Н            | L            | Х            | х            |          |  |
|         | 0     | 0           | 1        | 0          | 1          | 1           | 1    | 0           | ->    | Z            | Z            | Z            | Z            | Z            | х            |          |  |
|         | 0     | 0           | 1        | 0          | 1          | 1           | 1    | 1           | ->    | L            | Н            | L            | Н            | X            | X            |          |  |
|         | U     | U           | T        | U          | T          | T           | 0    | 0           | ->    | Z            | Z            | Z            | z            | Z            | х            |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |
|         |       |             |          |            |            |             |      |             |       |              |              |              |              |              |              |          |  |

# 6.9 8-Bit Loadable Up/Down Counter with Carry-out or Borrow-in

| DEVI<br>FILE                    | VICE PEEL22CV10Z<br>E V10CNT8.APL                                                                                                                                                                                   |                             |                                 |                            |                                  |                                                                      |                                 |  |  |  |  |  |  |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------|----------------------------|----------------------------------|----------------------------------------------------------------------|---------------------------------|--|--|--|--|--|--|
| This a<br>Loada                 | his application uses the PEEL22CV10 as an 8-bit Up/Down<br>oadable counter. The four controls are:                                                                                                                  |                             |                                 |                            |                                  |                                                                      |                                 |  |  |  |  |  |  |
| CLR<br>puts (                   | (Synch<br>Q7-Q0                                                                                                                                                                                                     | nronou<br>D and             | us Clea<br>CO_Bl                | r)W<br>) will b            | /hen CLR<br>be set to L          | is set to High<br>ow on next clo                                     | , all out-<br>ock.              |  |  |  |  |  |  |
| UP (L<br>will co<br>Q0 wi       | Ip/Dov<br>ount up<br>II cour                                                                                                                                                                                        | vn cor<br>o on e<br>nt dov  | ntrol)—N<br>ach clo<br>vn.      | When<br>ck. W              | UP is set t<br>hen UP is s       | o High, output<br>set to Low, out                                    | s Q7-Q0<br>puts Q7-             |  |  |  |  |  |  |
| LOAD<br>will fo<br>CO_E         | ) (Loa<br>bllow<br>Bl will                                                                                                                                                                                          | d data<br>the d<br>be set   | a)—Wh<br>ata of<br>t to Low     | en LC<br>D7-D(<br>/.       | )AD is set<br>) on next          | High, output<br>clock and th                                         | s Q7-Q0<br>e output             |  |  |  |  |  |  |
| !OE (<br>Q0 ar<br>all ou        | Outpu<br>nd CO<br>tputs v                                                                                                                                                                                           | t Enat<br>_BI) v<br>will be | ole)—W<br>vill be H<br>e enable | 'hen C<br>High I<br>ed.    | DE is set to<br>mpedance         | high, all outp<br>. When OE is                                       | outs (Q7-<br>set Low,           |  |  |  |  |  |  |
| Note:<br>CO_E<br>the C<br>descr | lote: After counting up 255, the count will go to 0 and the<br>O_BI will be set High on next clock. The High will remain on<br>ne CO_BI pin until LOAD or CLR goes High. The table below<br>escribes the operation: |                             |                                 |                            |                                  |                                                                      |                                 |  |  |  |  |  |  |
|                                 |                                                                                                                                                                                                                     |                             |                                 | Opera                      | tion Table                       |                                                                      |                                 |  |  |  |  |  |  |
| CLK                             | CLR                                                                                                                                                                                                                 | UP                          | LOAD                            | !OE                        | D7—D0                            | Q7Q0                                                                 | C0_BI                           |  |  |  |  |  |  |
| ССССССХ                         | 1<br>0<br>0<br>0<br>0<br>0<br>X                                                                                                                                                                                     | X<br>1<br>0<br>0<br>X<br>X  | X<br>0<br>0<br>0<br>1<br>X      | 0<br>0<br>0<br>0<br>0<br>1 | X<br>X<br>X<br>X<br>DATA IN<br>X | LOW<br>COUNT UP<br>255→0<br>COUNT DOWN<br>0→255<br>DATA IN<br>HIGH-Z | 0<br>0<br>1<br>0<br>1<br>0<br>0 |  |  |  |  |  |  |
| C = Clo                         | ck Puls                                                                                                                                                                                                             | e (0→1)                     | )                               |                            |                                  |                                                                      |                                 |  |  |  |  |  |  |

X = Don't Care



#### 6.9 8-Bit Loadable Up/Down Counter with Carry-out or

TITLE 'APEEL FILE: PEEL22CV10 8-Bit Up/Down Loadable Counter with Carry-Out or Borrow-In. DATE: 6/9/88' DESIGNER: James Khong Peel22CV10 "PIN ASSIGNMENTS CLK pin 1 CLR pin 2 DO pin 3 D1 pin 4 D2 pin 5 D3 pin 6 pin 7 D4 D5 pin 8 D6 pin 9 pin 10 D7 pin 11 UP OE pin 13 "Used as input only. Default macro configuration LOAD pin 23 "is defaulted to 'pos com feed\_pin'. 00 pin 14 = pos reg "All positive registered outputs. Q1 pin 15 = pos reg Q2 pin 16 = pos reg Q3 pin 17 = pos reg Q7 pin 18 = pos reg Q6 pin 19 = pos reg 05 pin 20 = pos reg pin 21 = pos reg 04 CO BI pin 22 = pos reg "Carry-Out / Borrow-In. AC node 25 "Asynchronous Clear node - not used. SP node 26 "Synchronous Preset node. Equations Enable Q7 = !OE Enable Q6 = !OE Enable Q5 = !OE

#### 6.9 8-Bit Loadable Up/Down Counter with Carry-out or

Enable Q4 = !OE Enable Q3 = !OF Enable Q2 = !OE Enable Q1 = !OE = !OE Enable Q0 Enable CO BI = !OE SP = !CLR & !00 & !01 & !02 & !03 & !04 & !05 & !06 & !07 & !UP & !LOAD; Q7 = !CLR & Q0 & Q7 & !UP & !LOAD # "Count Down. !CLR & Q1 & Q7 & !UP & !LOAD # !CLR & Q2 & Q7 & !UP & !LOAD # !CLR & O3 & O7 & !UP & !LOAD # !CLR & 04 & 07 & !UP & !LOAD # !CLR & Q5 & Q7 & !UP & !LOAD # !CLR & Q6 & Q7 & !UP & !LOAD # !CLR & !QO & Q7 & UP & !LOAD # "Count Up. !CLR & !Q1 & Q7 & UP & !LOAD # !CLR & !Q2 & Q7 & UP & !LOAD # !CLR & !Q3 & Q7 & UP & !LOAD # !CLR & !Q4 & Q7 & UP & !LOAD # !CLR & !Q5 & Q7 & UP & !LOAD # !CLR & !Q6 & Q7 & UP & !LOAD # !CLR & QO & Q1 & Q2 & Q3 & Q4 & Q5 & Q6 & !Q7 & UP & !LOAD # !CLR & D7 & LOAD "Load Data. Q6 = !CLR & !Q0 & !Q1 & !Q2 & !Q3 & !Q4 & !Q5 & !Q6 & !UP & !LOAD # !CLR & QO & Q6 & !UP & !LOAD # !CLR & Q1 & Q6 & !UP & !LOAD # 
 !CLR & Q2 & Q6 & !UP & !LOAD #

 !CLR & Q3 & Q6 & !UP & !LOAD #
 !CLR & Q4 & Q6 & !UP & !LOAD # !CLR & Q5 & Q6 & !UP & !LOAD # !CLR & !QO & Q6 & UP & !LOAD # !CLR & !Q1 & Q6 & UP & !LOAD # !CLR & !Q2 & Q6 & UP & !LOAD # !CLR & !Q3 & Q6 & UP & !LOAD # !CLR & !Q4 & Q6 & UP & !LOAD # !CLR & !Q5 & Q6 & UP & !LOAD # !CLR & Q0 & Q1 & Q2 & Q3 & Q4 & Q5 & !Q6 & UP & !LOAD # !CLR & D6 & LOAD Q5 = !CLR & !Q0 & !Q1 & !Q2 & !Q3 & !Q4 & !Q5 & !UP & !LOAD #!CLR & Q0 & Q5 & !UP & !LOAD # !CLR & Q1 & Q5 & !UP & !LOAD #

#### 6.9 8-Bit Loadable Up/Down Counter with Carry-out or

!CLR & Q2 & Q5 & !UP & !LOAD # !CLR & Q3 & Q5 & !UP & !LOAD # !CLR & Q4 & Q5 & !UP & !LOAD # !CLR & !QO & Q5 & UP & !LOAD # !CLR & !Q1 & Q5 & UP & !LOAD # !CLR & !Q2 & Q5 & UP & !LOAD # !CLR & !Q3 & Q5 & UP & !LOAD # !CLR & !Q4 & Q5 & UP & !LOAD # !CLR & Q0 & Q1 & Q2 & Q3 & Q4 & !Q5 & UP & !LOAD # !CLR & D5 & LOAD Q4 = !CLR & !Q0 & !Q1 & !Q2 & !Q3 & !Q4 & !UP & !LOAD # !CLR & QO & Q4 & !UP & !LOAD # !CLR & Q1 & Q4 & !UP & !LOAD # !CLR & Q2 & Q4 & !UP & !LOAD # !CLR & Q3 & Q4 & !UP & !LOAD # !CLR & !00 & 04 & UP & !LOAD # !CLR & !Q1 & Q4 & UP & !LOAD # !CLR & !Q2 & Q4 & UP & !LOAD # !CLR & !O3 & O4 & UP & !LOAD # !CLR & QO & Q1 & Q2 & Q3 & !Q4 & UP & !LOAD # !CLR & D4 & LOAD Q3 = !CLR & !Q0 & !Q1 & !Q2 & !Q3 & !UP & !LOAD # !CLR & QO & Q3 & !UP & !LOAD # !CLR & Q1 & Q3 & !UP & !LOAD # !CLR & Q2 & Q3 & !UP & !LOAD # !CLR & !QO & Q3 & UP & !LOAD # !CLR & !Q1 & Q3 & UP & !LOAD # !CLR & !Q2 & Q3 & UP & !LOAD # !CLR & QO & Q1 & Q2 & !Q3 & UP & !LOAD # CLR & D3 & LOAD Q2 = !CLR & !Q0 & !Q1 & !Q2 & !UP & !LOAD # !CLR & QO & Q2 & !UP & !LOAD # !CLR & Q1 & Q2 & !UP & !LOAD # !CLR & !QO & Q2 & UP & !LOAD # !CLR & !Q1 & Q2 & UP & !LOAD # !CLR & QO & Q1 & !Q2 & UP & !LOAD # !CLR & D2 & LOAD Q1 = !CLR & !Q0 & !Q1 & !UP & !LOAD # !CLR & QO & Q1 & !UP & !LOAD # !CLR & !QO & Q1 & UP & !LOAD # !CLR & Q0 & !Q1 & UP & !LOAD # !CLR & D1 & LOAD

Q0 = !CLR & !Q0 & !LOAD # !CLR & DO & LOAD CO BI = !CLR & !QO & !Q1 & !Q2 & !Q3 & !Q4 & !Q5 & !Q6 & !Q7 & !UP & !LOAD # !CLR & QO & Q1 & Q2 & Q3 & Q4 & Q5 & Q6 & Q7 & UP & !LOAD # !CLR & CO BI & !LOAD "Latch in the previous CO BI Test vectors (CLK CLR UP LOAD D7 D6 D5 D4 D3 D2 D1 D0 OE ->Q7 Q6 Q5 Q4 Q3 Q2 Q1 Q0 CO BI) 0 -> L L С 1 Х Х х Х х х х Х Х х L L LLLL L Х 0 -> L С 0 1 0 Х Х Х Х Х Х Х  $\mathbf{L}$ L L Н  $\mathbf{L}$ L T. L С Ω 1 0 х Х Х Х Х Х Х Х 0 -> L  $\mathbf{L}$  $\mathbf{L}$ L L L Н L L С Х Х 0 -> L 0 1 0 Х Х Х Х Х Х  $\mathbf{L}$ L L  $\mathbf{L}$ Н Н  $\mathbf{L}$  $\mathbf{L}$ 0 -> H С 0 1 0 Н Н Н 1 1 1 1 1 1 1 1 Н Н L Н  $\mathbf{L}$ С Х Х Х х х Х 0 -> H 0 1 0 Х Х Н Н Н Н Н Н L  $\mathbf{L}$ С Х Х Х 0 1 0 Х Х Х Х Х 0 -> H Н Н Η Η Н Н Н  $\mathbf{L}$ Х С 0 1 0 Х Х Х Х Х Х Х 0 -> L L  $\mathbf{L}$ L  $\mathbf{L}$  $\mathbf{L}$ L  $\mathbf{L}$ Н С 0 1 0 Х Х Х Х Х Х Х Х 0 -> L  $\mathbf{L}$  $\mathbf{L}$ L L L L Н Н С 0 0 1 0 1 0 1 0 1 0 1 0 -> L Н L Н  $\mathbf{L}$ Н L Н  $\mathbf{L}$ С 0 1 0 Х Х Х Х Х Х Х Х 0 -> L Н L Н L Н Н L L С 0 0 0 Х Х Х Х Х Х Х Х 0 -> L Н L Н  $\mathbf{L}$ Н Н L  $\mathbf{L}$ С 0 0 0 Х Х Х Х Х Х Х Х 0 -> L L Н L Н Н L L L С 0 0 0 0 0 0 0 0 1 0 0 -> L 1 L L L L L Н L L С 0 0 0 Х Х Х Х Х Х Х Х 0 -> L L L L L L L Н L 0 0 Х х х х С 0 Х х Х Х 0 -> L L L L L L L Τ. Τ. С 0 0 0 х х Х х Х Х х х 0 -> H Н Н Н нннн н С 0 0 0 Х х Х Х Х х х х 0 -> H Н Н н н н г Н Н С 0 0 0 Х х х Х х х Х Х 0 -> H Н Н H H L Н Н Н С 1 1 1 х х х Х ххх Х X -> L L L L LLLL T.

### 6.10 Change-of-State Port with Interrupt





#### 6.10 Change-of-State Port with Interrupt

| TITL<br>DESI<br>DATE                                                    | E 'APEEL FILE: PEEL22CV10Z CHANGE-OF-STATE INPUT PORT WITH INTERRUPT<br>GNER: Robin Jigour, ICT<br>: 5/1/87'                                                                                                                                         |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PEEL                                                                    | 22CV10Z                                                                                                                                                                                                                                              |
| ZERO                                                                    | _POWER "The key word 'ZERO_POWER' is omitted for non zero-power mode.<br>"For zero-power applications, this key word must be specified<br>"after the part number declaration but prior to pin list<br>"definition.                                   |
| "PIN                                                                    | DEFINITIONS"                                                                                                                                                                                                                                         |
| "Inp                                                                    | uts"                                                                                                                                                                                                                                                 |
| CLK<br>I0<br>I1<br>I2<br>I3<br>!RD<br>!CS<br>I4<br>I5<br>I6<br>I7<br>A0 | <pre>pin 1 "Must be connected to pin 18, INTR.<br/>pin 2 "IO-I7 inputs can detect change-of-state.<br/>pin 3<br/>pin 4<br/>pin 5<br/>pin 6<br/>pin 7<br/>pin 8<br/>pin 9<br/>pin 10<br/>pin 11<br/>pin 13</pre>                                      |
| D7<br>D6<br>D5<br>D4<br>INTR<br>NEQ<br>D3<br>D2<br>D1<br>D0             | <pre>pin 14 = pos com feed_reg<br/>pin 15 = pos com feed_reg<br/>pin 16 = pos com feed_reg<br/>pin 17 = pos com feed_or<br/>pin 19 = pos com feed_or<br/>pin 20 = pos com feed_reg<br/>pin 21 = pos com feed_reg<br/>pin 23 = pos com feed_reg</pre> |

| QUATIONS               |                        |  |
|------------------------|------------------------|--|
| 0 = IO & !CS #         | "IO to DO register.    |  |
| IO & CS & !RD #        | "IO to DO register.    |  |
| DO & CS & RD & !AO #   | "Read DO register.     |  |
| IO & CS & RD & AO      | "Read IO.              |  |
| Enable D0 = CS & RD    | "Enable onto data bus. |  |
| 1 = I1 & !CS #         | "Il to Dl register.    |  |
| I1 & CS & !RD #        | "I1 to D1 register.    |  |
| D1 & CS & RD & !A0 #   | "Read D1 register.     |  |
| Il & CS & RD & AO      | "Read I1.              |  |
| Enable D1 = CS & RD    | "Enable onto data-bus. |  |
| 2 = I2 & !CS #         | "I2 to D2 register.    |  |
| I2 & CS & !RD #        | "I2 to D2 register.    |  |
| D2 & CS & RD & !A0 #   | "Read D2 register.     |  |
| I2 & CS & RD & AO      | "Read I2.              |  |
| Enable D2 = CS & RD    | "Enable onto data-bus. |  |
| 3 = I3 & !CS #         | "I3 to D3 register.    |  |
| I3 & CS & !RD #        | "I3 to D3 register.    |  |
| D3 & CS & RD & !AO #   | "Read D3 register.     |  |
| I3 & CS & RD & AO      | "Read I3.              |  |
| Enable $D3 = CS \& RD$ | "Enable onto data-bus. |  |
| 4 = I4 & !CS #         | "I4 to D4 register.    |  |
| I4 & CS & !RD #        | "I4 to D4 register.    |  |
| D4 & CS & RD & !A0 #   | "Read D4 register.     |  |
| 14 & CS & RD & AO      | "Read I4.              |  |
| Enable $D4 = CS \& RD$ | "Enable onto data bus. |  |
| 5 = I5 & !CS #         | "I1 to D5 register.    |  |
| 15 & CS & !RD #        | "Il to D5 register.    |  |
| D5 & CS & RD & !A0 #   | "Read D5 register.     |  |
| 15 & CS & RD & AO      | "Read 15.              |  |
| Enable D5 = CS & RD    | "Enable onto data-bus. |  |
| 6 = I6 & !CS #         | "I6 to D6 register.    |  |
| I6 & CS & !RD #        | "I6 to D6 register.    |  |
| D6 & CS & RD & !A0 #   | "Read D6 register.     |  |
| I6 & CS & RD & AO      | "Read I6.              |  |

D7 = I7 & !CS # "I7 to D7 register. I7 & CS & !RD # "I7 to D7 register. D7 & CS & RD & !A0 # "Read D7 register. "Read I7. I7 & CS & RD & AO Enable D7 = CS & RD"Enable onto data-bus. NEO = IO & !DO # !IO & DO # "Compare IO-7 with DO-7 registers. I1 & !D1 # !I1 & D1 # "NEQ=1 if IO-7 and DO-7 are not equal. I2 & !D2 # !I2 & D2 # I3 & !D3 # !I3 & D3 # I4 & !D4 # !I4 & D4 # I5 & !D5 # !I5 & D5 # I6 & !D6 # !I6 & D6 # I7 & !D7 # !I7 & D7 INTR = NEQ & !CS # "Latch not-equal status for uP interrupt and NEO & !RD # "PEEL clock. Clear interrupt when registers NEQ & AO # "are read and there are no more input state INTR & !CS # "changes, that is, when NEQ, CS, RD and AO INTR & !RD # "are all 0. INTR & AO TEST\_VECTORS "Test change-of-state input port IO-7 operation" (CLK IO I1 I2 I3 I4 I5 I6 I7 AO CS RD -> DO D1 D2 D3 D4 D5 D6 D7 NEQ INTR) 0 0 0 0 0 0 0 0 Ο Х 0 X -> Z 7. Z Ζ Z 7. 7. 7. х Δ 0 0 0 0 0 Ο 0 0 0 0 1 -> X Ω 1 х Х Х Х Х L Х Х Ω 1 Ω 0 Ω Ω 0 0 0 0 -> Z х 0 Z ZZZZ ΖZ Н Н 0 0 0 0 -> Z 1 1 Ο 0 0 0 х 0 ZZZZZ 7. 7.  $\mathbf{L}$ Н 0 0 0 0 0 0 0 0 -> Z 1 1 Ω 1 ZZZZZ ΖZ L Η 0 0 0 0 0 0 1 1 0 1-> H L L L L L L 1  $\mathbf{L}$ L 0 1 0 0 0 0 0 0 0 1 1->HLLLLL L L 0 1 0 0 0 0 0 0 X  $\mathbf{L}$ L Ω 0 0 0 0 0 0 X 0 0 -> Z ZZZZZZZ н н 1 0 0 0 0 0 0 0 X 0 0 -> Z ZZZZZZZ Τ. Η 1 0 0 0 0 0 0 0 0 1  $0 \rightarrow Z Z Z Z Z Z Z Z Z$ L Н 1 0 0 0 0 0 0 0 0 1 1->LLLLLLL T. T. 0 0 0 0 0 0 0 X 0 X -> Z Z Z Z Z Z Z Z 0 L L 0 0 0 0 0 0 X 0 1 н н 0 X ZZZZ 1 1 0 0 0 0 0 0 0 X -> Z ZZZ T. Н 0 -> Z 1 1 1 1 1 1 1 1 X 0 ZZZ Ζ Z ΖZ Н Н 1 0 -> Z 1 1 1 1 1 1 1 1 0 ZZZ ZZZ Н 1 1 Ζ Н 1 1 -> H L L L H L 1 1 1 1 1 1 0 LLL 1 1 1 L 1 X 0 1 1 1 1 1 1 1 0 0 -> Z ZZZZ ZZZ н н 1 1 ZZZ 1 1 1 1 0 -> Z ZZZZ 1 1 1 1 0 L H

| 0 0 0 0 0 0 0 0 X 0 X -> Z Z Z Z Z Z Z Z L L | 0 0 0 0 0 0 0 0 0 X 0 X -> Z Z Z Z Z Z Z Z Z L L | 1       1         1       1         0       0         0       0         0       0         1       1         1       1         1       1         1       1         1       1         0       0         0       0         0       0         0       0         0       0         0       0         0       0 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 1       1       1       0         1       1       1       X         0       0       0       X         0       0       0       X         0       0       0       X         1       1       1       0         1       1       1       X         1       1       1       0         1       1       1       X         0       0       0       X         0       0       0       X         0       0       0       X | $\begin{array}{cccccccccccccccccccccccccccccccccccc$         | H       H       H       H       L         Z       Z       Z       Z       L         Z       Z       Z       Z       L         Z       Z       Z       Z       L         L       L       L       L       L         Z       Z       Z       Z       Z         L       L       L       L       L         Z       Z       Z       Z       Z         L       L       L       L       H         Z       Z       Z       Z       Z       H         Z       Z       Z       Z       Z       L         H       H       H       H       L       L         Z       Z       Z       Z       Z       L         Z       Z       Z       Z       Z       L       L         Z       Z       Z       Z       Z       L       L       L | L<br>L<br>H<br>H<br>L<br>L<br>H<br>H<br>L<br>L<br>H<br>H<br>L |
|----------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|                                              |                                                  | ))))                                                                                                                                                                                                                                                                                                      | 0 0 0<br>0 0 0<br>0 0 0<br>0 0 0                     | 0 0 0 X<br>0 0 0 X<br>0 0 0 0<br>0 0 0 X                                                                                                                                                                                                                                                                                                                                                                        | 0 X -> Z Z Z<br>0 X -> Z Z Z<br>1 1 -> L L L<br>0 X -> Z Z Z | Z       Z       Z       Z       H         Z       Z       Z       Z       Z       L         L       L       L       L       L       L         Z       Z       Z       Z       Z       L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | H<br>H<br>L<br>L                                              |
|                                              |                                                  |                                                                                                                                                                                                                                                                                                           |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                             |
|                                              |                                                  |                                                                                                                                                                                                                                                                                                           |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                               |

## 6.11 16 to 4 Priority Encoder

DEVICE: PEEL173 FILE NAME: PRI173.APL

This PEEL173 application implements a 16 to 4 priority encoder with high-impedance outputs. If any D0-DF input goes low, the GS (group strobe) output will go high and the binary value of the highest priority input will be placed on the E0-E3 (Encoded) outputs when enabled by OE (output enable). The D0 input is highest priority and DF lowest. When the E0-E3 outputs are disabled (a function of OE or IGS) they assume a high-impedance state. This makes it possible to interface the encoded outputs onto a system bus where GS might serve as an interrupt line to a uP and OE as the chip select. The high-impedance control also allows multiple PEEL173 priority encoders to be bussed together for creating wider (32, 48 or 64 bit etc.) priority encoders. To add additional encoders, the highest priority OE must be tied low, and the GS must control the next highest priority OE. The multiple GS can be further encoded to identify which device is driving the E0-E3 lines.



| DATE: 10                                                                                                                                                       | /15/87'                                                                                                                                                       | 101                                  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|
| PEEL173                                                                                                                                                        |                                                                                                                                                               |                                      |  |
| "PIN DEF                                                                                                                                                       | INITIONS"                                                                                                                                                     |                                      |  |
| "Inputs"                                                                                                                                                       |                                                                                                                                                               |                                      |  |
| D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>D8<br>D9<br>DA<br>D8<br>D9<br>DA<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0<br>D0 | pin 1<br>pin 2<br>pin 3<br>pin 4<br>pin 5<br>pin 6<br>pin 7<br>pin 8<br>pin 9<br>pin 10<br>pin 11<br>pin 13<br>pin 14<br>pin 15<br>pin 16<br>pin 17<br>pin 18 | "Pins 14-18, default polarity = pos. |  |
| "Outputs                                                                                                                                                       |                                                                                                                                                               |                                      |  |
| E0<br>E1<br>E2<br>E3<br>GS                                                                                                                                     | pin 19 = pos<br>pin 20 = pos<br>pin 21 = pos<br>pin 22 = pos<br>pin 23 = neg                                                                                  |                                      |  |
|                                                                                                                                                                |                                                                                                                                                               |                                      |  |

#### 6.11 16 to 4 Priority Encoder

6.0 Application Examples

6

```
EOUATIONS
GS = ! (D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9
          & DA & DB & DC & DD & DE & DF)
EO = DO \& !D1 #
     D0 & D1 & D2 & !D3 #
     D0 & D1 & D2 & D3 & D4 & !D5 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & !D7 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & !D9 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & !DB #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & DB & DC
        & !DD #
     DO & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & DB & DC
        & DD & DE
Enable E0 = !OE & GS
E1 = D0 \& D1 \& !D2 #
     DO & D1 & D2 & !D3 #
     DO & D1 & D2 & D3 & D4 & D5 & !D6 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & !D7 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & !DA #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & !DB #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & DB & DC & DD
Enable E1 = !OE & GS
E2 = D0 \& D1 \& D2 \& D3 \& !D4 #
     D0 & D1 & D2 & D3 & D4 & !D5 #
     D0 & D1 & D2 & D3 & D4 & D5 & !D6 #
     D0 & D1 & D2 & D3 & D4 & D5 & D6 & !D7 #
     DO & D1 & D2 & D3 & D4 & D5 & D6 & D7 & D8 & D9 & DA & DB
Enable E2 = !OE & GS
E3 = D0 \& D1 \& D2 \& D3 \& D4 \& D5 \& D6 \& D7
Enable E3 = !OE \& GS
```

6-57

#### 6.11 16 to 4 Priority Encoder

6.0 Application Examples

| TES:<br>(D0<br>1<br>1<br>0<br>1<br>1<br>1<br>1<br>1<br>1 | r_VF<br>D1<br>1<br>1<br>x<br>0<br>1<br>1<br>1<br>1<br>1 | ECTC<br>D2<br>1<br>1<br>X<br>X<br>0<br>1<br>1<br>1<br>1<br>1<br>1 | DRS<br>D3<br>1<br>X<br>X<br>0<br>1<br>1<br>1<br>1<br>1 | D4<br>1<br>1<br>x<br>x<br>x<br>x<br>0<br>1<br>1 | D5<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>0<br>1 | D6<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>0<br>1 | D7<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>0 | D8<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | D9<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DA<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DB<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DC<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DD<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DE<br>1<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | DF<br>1<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X<br>X | OE<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | ->E3<br>->Z<br>->L<br>->L<br>->L<br>->L<br>->L<br>->L<br>->L       | E2<br>Z<br>Z<br>L<br>L<br>L<br>H<br>H<br>H | E1<br>ZZLLHHLLHH | EO<br>Z<br>L<br>H<br>L<br>H<br>L<br>H<br>L<br>H | GS<br>L<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H<br>H | ) |  |
|----------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------|-------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------|------------------|-------------------------------------------------|----------------------------------------------------------------|---|--|
| 1<br>1<br>1<br>1<br>1<br>1<br>1                          | 1<br>1<br>1<br>1<br>1<br>1<br>1                         | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                              | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                   | 1<br>1<br>1<br>1<br>1<br>1<br>1                 | 1<br>1<br>1<br>1<br>1<br>1<br>1                 | 1<br>1<br>1<br>1<br>1<br>1<br>1                      | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                           | 0<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                                          | x 0<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1                                   | X X 0 1 1 1 1 1 1 1 1 1                                   | x x x 0 1 1 1 1 1 1                                                           | x x x x 0 1 1 1 1                                         | x x x x x 0 1 1 1                                                             | X X X X X X X X 1 1                                                      | X X X X X X X X 1                                              |                                                 | ->H<br>->H<br>->H<br>->H<br>->H<br>->H<br>->H<br>->H<br>->H<br>->Z | L<br>L<br>L<br>H<br>H<br>H<br>H<br>Z       | LLHHLLHHZ        | L H L H L H L H Z                               | H<br>H<br>H<br>H<br>H<br>L                                     |   |  |
|                                                          |                                                         |                                                                   |                                                        |                                                 |                                                 |                                                      |                                                                |                                                                                    |                                                                               |                                                           |                                                                               |                                                           |                                                                               |                                                                          |                                                                |                                                 |                                                                    |                                            |                  |                                                 |                                                                |   |  |
|                                                          |                                                         |                                                                   |                                                        |                                                 |                                                 |                                                      |                                                                |                                                                                    |                                                                               |                                                           |                                                                               |                                                           |                                                                               |                                                                          |                                                                |                                                 |                                                                    |                                            |                  |                                                 |                                                                |   |  |

#### 6.12 8-Bit Greater-Than/Less-Than Magnitude Comparator

DEVICE: PEEL273 FILE NAME: MAG273.APL

This application uses the PEEL273 to implement a magnitude comparator that compares two groups of eight inputs (A0-7 and B0-7) to provide both greater-then (AB) and less-then (A) outputs. The comparator can be cascaded by connecting the A GT B and A LT B outputs of up to eight PEEL273s to the An and Bn inputs a next level PEEL273. Thus nine PEEL273s would allow for a 64-bit magnitude comparator. Comparators, especially magnitude comparators use many exclusive-OR functions for testing for equality or inequality. Because of this, the sum-of-product equations for just one output of the magnitude comparator requires 2 to the n-1 product terms per bit. With eight bits that comes to 255 product terms per sum, more then are available with even the PEEL273. However, by using multi-level logic many of the high order exclusive-OR functions (EQ4-EQ7) are first implemented and then used in the final magnitude comparator output equations, thus, reducing product terms to 39.



6-59

| N<br>DESIGNER | AGNITUDE COMPARATOR<br>R: Robin Jigour, ICT                   |
|---------------|---------------------------------------------------------------|
| DATE: 10      | )/11/87'                                                      |
| PEEL273       |                                                               |
| "PIN DEF      | TNITIONS"                                                     |
| "Inputs"      | ,                                                             |
| inpues        |                                                               |
| A0<br>A 1     | pin 1<br>pin 2                                                |
| A2            | pin 2<br>n 3                                                  |
| A3            | pin 4                                                         |
| A4            | pin 5                                                         |
| A5            | pin 6                                                         |
| A 6           | pin 7                                                         |
| A7            | pin 8                                                         |
| B/<br>DC      | pin 9                                                         |
| во<br>85      | pin 10<br>nin 11                                              |
| B4            | pin 13                                                        |
| В3            | pin 14 "Pins 14-17, default polarity = pos.                   |
| B2            | pin 15                                                        |
| B1            | pin 16                                                        |
| 80            | pin 17                                                        |
| "Outputs      | 3                                                             |
| E 4           | pin 18 = NEG "E4-E7 are used to minimize equation product ter |
| E 5           | pin 19 = NEG                                                  |
| E6            | pin $20 = NEG$                                                |
| בו/<br>בית הב | $pin \ 21 = NEG$ $pin \ 22 = POS$                             |
| A GT B        | pin 22 = POS<br>pin 23 = POS                                  |
|               |                                                               |
|               |                                                               |
|               |                                                               |
|               |                                                               |
|               |                                                               |
|               |                                                               |
|               |                                                               |
|               |                                                               |

```
EQUATIONS
Enable A GT B = 1
                    "Enable outputs (unconditionally).
Enable A LT B = 1
Enable E7
            = 1
Enable E6
            = 1
Enable E5
            = 1
Enable E4
            = 1
E7 = !(A7 \& !B7 #
                       "A7=B7 (XNOR)
       !A7 & B7)
E6 = ! (A6 \& !B6 #
                       "A6=B6
                              (XNOR)
       !A6 & B6)
E5 = ! ( A5 & !B5 #
                       "A5=B5
                              (XNOR)
       !A5 & B5)
E4 = !(A4 \& !B4 #
                       "A4=B4 (XNOR)
       !A4 & B4)
A GT B = A7 & !B7 #
    E7 & A6 & !B6 #
    E7 & E6 & A5 & !B5 #
    E7 & E6 & E5 & A4 & !B4 #
    E7 & E6 & E5 & E4 & A3 & !B3 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & A2 & !B2 #
    E7 & E6 & E5 & E4 & A3 & B3 & A2 & !B2 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & !A2 & !B2 & A1 & !B1 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & A2 & B2 & A1 & !B1 #
    E7 & E6 & E5 & E4 & A3 & B3 & !A2 & !B2 & A1 & !B1 #
    E7 & E6 & E5 & E4 & A3 & B3 & A2 & B2 & A1 & !B1 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & !A2 & !B2 & !A1 & !B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & !A2 & !B2 & A1 & B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & A2 & B2 & !A1 & !B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & !A3 & !B3 & A2 & B2 & A1 & B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & A3 & B3 & !A2 & !B2 & !A1 & !B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & A3 & B3 & !A2 & !B2 & A1 & B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & A3 & B3 & A2 & B2 & !A1 & !B1 & A0 & !B0 #
    E7 & E6 & E5 & E4 & A3 & B3 & A2 & B2 & A1 & B1 & A0 & !B0
```

6.0 Application Examples

| A_L1                                                                               | В                                                                                    | = ! 2<br>! 2<br>! 2<br>! 2<br>! 2<br>! 2<br>! 2<br>! 2<br>! 2<br>! 2 | A_G1<br>A_G1<br>A_G1<br>A_G1<br>A_G1<br>A_G1<br>A_G1<br>A_G1 |                                            | ی<br>چ<br>چ<br>چ<br>چ<br>چ<br>چ<br>چ<br>چ  | 1 E 7<br>1 E 6<br>1 E 5<br>1 E 4<br>A 3<br>1 A 3<br>A 2<br>1 A 3<br>A 1<br>1 A 1<br>A 0<br>1 A 0 | #<br>#<br>#<br>& !<br>& !<br>&<br>& !<br>&<br>&<br>! | B3<br>B3<br>B2<br>B1<br>B1<br>B0<br>B0     | # # # # #                        |                                       |                                       |                                            |                             |                                  |                                            |                                               |                                                         |                                              |      |
|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------|----------------------------------|---------------------------------------|---------------------------------------|--------------------------------------------|-----------------------------|----------------------------------|--------------------------------------------|-----------------------------------------------|---------------------------------------------------------|----------------------------------------------|------|
| TEST<br>( A7<br>C<br>C<br>C<br>C<br>C<br>C<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | - VE<br>A6<br>0 0<br>0 0<br>0 0<br>0 0<br>0 0<br>0 0<br>0 1<br>1<br>1<br>1<br>1<br>1 | CTOP<br>A5<br>0<br>0<br>1<br>1<br>0<br>1<br>1<br>1                   | RS<br>A4<br>0<br>0<br>0<br>0<br>0<br>1<br>1<br>1             | A3<br>0<br>0<br>1<br>1<br>0<br>1<br>1<br>1 | A2<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1 | A1<br>0<br>0<br>1<br>1<br>0<br>1<br>1<br>1                                                       | A0<br>0<br>1<br>0<br>0<br>1<br>1<br>1<br>0           | B7<br>0<br>0<br>1<br>0<br>1<br>1<br>1<br>1 | B6<br>0<br>0<br>1<br>0<br>1<br>1 | B5<br>0<br>0<br>1<br>1<br>1<br>1<br>1 | B4<br>0<br>0<br>0<br>1<br>1<br>1<br>1 | B3<br>0<br>0<br>1<br>0<br>1<br>1<br>1<br>1 | B2<br>0<br>0<br>1<br>1<br>1 | B1<br>0<br>0<br>1<br>1<br>1<br>1 | B0<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | ->A<br>-><br>-><br>-><br>-><br>-><br>-><br>-> | _GT_B<br>L<br>L<br>L<br>H<br>L<br>L<br>L<br>L<br>L<br>L | A_LT<br>L<br>H<br>L<br>L<br>H<br>L<br>H<br>H | _B ) |
|                                                                                    |                                                                                      |                                                                      |                                                              |                                            |                                            |                                                                                                  |                                                      |                                            |                                  |                                       |                                       |                                            |                             |                                  |                                            |                                               |                                                         |                                              |      |

### 6.13 10-Bit Expandable Equality Comparator

DEVICE: PEEL273 FILE NAME: EQU273.APL

This application uses the PEEL273 as an equality comparator for two 10-bit values (A0-9 and B0-9). When EXP (expand) is low, the PEEL273 works in a single mode, directly driving the EQU (equal) output high when A=B and low when A=/B. When EXP is high the EQU output simulates an open-drain output allowing expansion to multiple PEEL273 comparators with EQU outputs tied in parallel with a pull-up resistor (not to exceed 625 ohms). Thus, using two PEEL273s, a 20-bit equivalency comparator could be achieved. When using multiple comparators the EQU line will pull high only when all A and B inputs of each comparator are equal. The truth table is listed below:



6.0 Application Examples

| PEEL273  | 3                                            |  |
|----------|----------------------------------------------|--|
| "PIN DE  | EFINITIONS"                                  |  |
| "Inputs  | 5"                                           |  |
| A0       | pin 1                                        |  |
| A1       | pin 2                                        |  |
| A2       | pin 3                                        |  |
| AJ<br>AA | pin 4<br>Din 5                               |  |
| Δ5       | pin 5                                        |  |
| A6       | pin 7                                        |  |
| A7       | pin 8                                        |  |
| A8       | pin 9                                        |  |
| Α9       | pin 10                                       |  |
| В9       | pin 11                                       |  |
| B8       | pin 13                                       |  |
| B/       | pin 14 "Pins 14-22, default polarity = pos.  |  |
| B0<br>B5 | pin 15<br>nin 16                             |  |
| B4       | pin 17                                       |  |
| В3       | pin 18                                       |  |
| B2       | pin 19                                       |  |
| B1       | pin 20                                       |  |
| BO       | pin 21                                       |  |
| EXP      | pin 22                                       |  |
| "Output  | ts                                           |  |
| EQU      | pin 23 = neg                                 |  |
| EQUATIO  | DNS                                          |  |
| EQU      | = !(A0 & !B0 # !A0 & B0 # "Compare A to B.   |  |
|          | Al & !Bl # !Al & Bl # "If A /= B, EQU=0.     |  |
|          | A3 & $!B3 \# !A3 \& B3 \#$ "If A = B, EQU=1. |  |
|          | A4 & !B4 # !A4 & B4 #                        |  |
|          |                                              |  |
|          |                                              |  |

| Enab             | le            | EQI             | J =                                                | A6<br>A7<br>A8<br>A9<br>!E                                                                  | a<br>&<br>&<br>&<br>&<br>&<br>XP                                     | 183<br>186<br>187<br>188<br>189<br># | π<br>#<br>#<br>#                                                     | ! A6<br>! A7<br>! A8<br>! A9                                                                | 8<br>&<br>&<br>&                                   | B6<br>B7<br>B8<br>B9)      | +<br>+<br>+          | "I                       | f El             | P=۱                  | ) en                      | abl         | e E             | QU,              | if               | =1 1             | chen              |
|------------------|---------------|-----------------|----------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------|----------------------|--------------------------|------------------|----------------------|---------------------------|-------------|-----------------|------------------|------------------|------------------|-------------------|
|                  |               |                 | A0<br>A1<br>A3<br>A4<br>A5<br>A6<br>A7<br>A8<br>A9 | &<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>& | ! B0<br>! B1<br>! B3<br>! B4<br>! B5<br>! B6<br>! B7<br>! B8<br>! B9 | # # # # # # #                        | ! A0<br>! A1<br>! A3<br>! A4<br>! A5<br>! A6<br>! A7<br>! A8<br>! A9 | &<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>&<br>& | B0<br>B1<br>B3<br>B4<br>B5<br>B6<br>B7<br>B8<br>B9 | #<br>#<br>#<br>#<br>#<br># | "c<br>"I<br>"I<br>"t | omp<br>f A<br>f A<br>hat | are<br>/=<br>EQU | A<br>B,<br>B,<br>J=1 | to B<br>EQU<br>EQU<br>via | is<br>pu    | en<br>di<br>ll- | abl<br>sab<br>up | ed<br>led<br>res | and<br>so<br>ist | = 0.              |
| TESI<br>(A9<br>0 | VI<br>A8<br>0 | ECTO<br>A7<br>0 | DRS<br>A6<br>0                                     | A5<br>0                                                                                     | A4<br>0                                                              | A3<br>0                              | A2<br>0                                                              | A1<br>0                                                                                     | A0<br>0                                            | B9<br>(                    | B8<br>) 0            | В7<br>0                  | B6 1<br>0        | 35 1<br>0            | 34 В<br>0                 | зв:<br>0    | 2 B<br>0        | 1 B<br>0         | 0 E              | EXP<br>0         | ->EQU<br>->H      |
| 0<br>1<br>1      | 0<br>0<br>0   | 0<br>1<br>1     | 0<br>0<br>0                                        | 0<br>1<br>1                                                                                 | 0<br>0<br>0                                                          | 0<br>1<br>1                          | 0<br>0<br>0                                                          | 0<br>1<br>1                                                                                 | 1<br>0<br>0                                        | (<br>]<br>(<br>1           | ) 0<br>L 0<br>) 1    | 0<br>1<br>0<br>1         | 0<br>0<br>1      | 0<br>1<br>0          | 0<br>0<br>1               | 0<br>1<br>0 | 0<br>0<br>1     | 0<br>1<br>0<br>1 | 0<br>0<br>1      | 0<br>0<br>0      | ->L<br>->H<br>->L |
| 1<br>0<br>0      | 1<br>0<br>0   | 1<br>0<br>0     | 1<br>0<br>0                                        | 1<br>0<br>0                                                                                 | 1<br>0<br>0                                                          | 1<br>0<br>0                          | 1<br>0<br>0                                                          | 1<br>0<br>0                                                                                 | 1<br>0<br>1                                        | 1<br>(<br>(                | 1<br>1<br>0 0<br>0 0 | 1<br>0<br>0              | 1<br>0<br>0      | 1<br>0<br>0          | 1<br>0<br>0               | 1<br>0<br>0 | 1<br>0<br>0     | 1<br>0<br>0      | 0<br>0<br>0      | 0<br>1<br>1      | ->L<br>->Z<br>->L |
| 1<br>1<br>1      | 0<br>0<br>1   | 1<br>1<br>1     | 0<br>0<br>1                                        | 1<br>1<br>1                                                                                 | 0<br>0<br>1                                                          | 1<br>1<br>1                          | 0<br>0<br>1                                                          | 1<br>1<br>1                                                                                 | 0<br>0<br>1                                        | 1<br>(<br>]                | 0<br>1               | 1<br>0<br>1              | 0<br>1<br>1      | 1<br>0<br>1          | 0<br>1<br>1               | 1<br>0<br>1 | 0<br>1<br>1     | 1<br>0<br>1      | 0<br>1<br>1      | 1<br>1<br>1      | ->Z<br>->L<br>->Z |
| T                | 1             | 1               | T                                                  | T                                                                                           | 1                                                                    | Ţ                                    | 1                                                                    | 1                                                                                           | 1                                                  |                            | . 1                  | T                        | 1                | T                    | 1                         | T           | 1               | T                | U                | 1                | ->Г               |
|                  |               |                 |                                                    |                                                                                             |                                                                      |                                      |                                                                      |                                                                                             |                                                    |                            |                      |                          |                  |                      |                           |             |                 |                  |                  |                  |                   |
|                  |               |                 |                                                    |                                                                                             |                                                                      |                                      |                                                                      |                                                                                             |                                                    |                            |                      |                          |                  |                      |                           |             |                 |                  |                  |                  |                   |
|                  |               |                 |                                                    |                                                                                             |                                                                      |                                      |                                                                      |                                                                                             |                                                    |                            |                      |                          |                  |                      |                           |             |                 |                  |                  |                  |                   |
|                  |               |                 |                                                    |                                                                                             |                                                                      |                                      |                                                                      |                                                                                             |                                                    |                            |                      |                          |                  |                      |                           |             |                 |                  |                  |                  |                   |



# **Appendix A: Editor Commands**

The PDK-1 provides two methods for controlling the editor: Keyboard commands, or pull-down menus. These commands are summarized in the sections that follow. For a step-by-step guide to using the editor, please refer to section 4.

## **Keyboard Commands**

The editor can be driven with commands issued from the keyboard. The commands are given by striking certain characters on the keyboard while holding down the Control key. In the sequences shown below, the "^" character represents the [Ctrl] key. For example, to execute the command ^K^B, hold down the [Ctrl] key while striking K, then B.

The keyboard commands of the PEEL editor are like those used by WordStar. For example, the "E D X S Diamond" (see figure A-1) can be used like the numeric key pad to move the cursor around the screen while the Control key is held down. Similarly, the letters adjacent to this diamond allow you to move the cursor from word to word, to scroll up and down through your file, etc



Figure A-1. "E D X S Diamond"

| Control | Key Pad      | Description             |
|---------|--------------|-------------------------|
| Command | Command      |                         |
|         |              |                         |
| ^A      |              | Left word               |
| ^S      | .left arrow  | Left character          |
| ^D      | .right arrow | Right character         |
| ^F      |              | Right word              |
| ^E      | .up arrow    | Up line                 |
| ^X      | .down arrow  | Down line               |
| ^R      | .[PgUp]      | Up page                 |
| ^C      | .[PgDn]      | Down page               |
| ^W      |              | Scroll up               |
| ^Z      |              | Scroll down             |
| [Enter] |              | New line                |
| ^N      |              | Insert line             |
| ^G      | .[Del]       | Delete character        |
| ^I      |              | Tab                     |
| ^T      |              | Delete word             |
| ^Y      |              | Delete line             |
| ^B      |              | Reformat paragraph      |
| ^U      |              | Abort current command   |
| ^J      |              | Home or Beg/end of line |

To enter a character using its ASCII number, hold the [ALT] key down while typing in the ASCII number on the key-pad.

Note that the keyboard command sequences do not work while in the pulldown menu mode

#### Enter/Exit pull-Down Menu Mode

The PDK also provides a convenient system of pull-down menus to drive the editor.

| General<br>Command | Pulldown<br>Command | Description |
|--------------------|---------------------|-------------|
|                    |                     |             |

[F10] .....Enter pulldown window mode [Esc] twice ......Exit from pulldow window mode to edit mode

# **Block Functions**

| Control<br>Commano | Pulldown<br>I Command | Description  |  |
|--------------------|-----------------------|--------------|--|
| ^K^B               | Begin                 | Begin block  |  |
| ^K^K               | End                   | End block    |  |
| ^K^C               | Copy                  | Copy block   |  |
| ^K^V               | Move                  | Move block   |  |
| ^K^R               | Read                  | Read block   |  |
| ^K^W               | Write                 | Write block  |  |
| ^K^Y               | Delete                | Delete block |  |
| ^K^H               | Hide/show             | Hide/display |  |
|                    | Spell/check           | Spell check  |  |

# **Search Functions**

| Control | Pulldown | Description |
|---------|----------|-------------|
| Command | Command  |             |

| ^Q^F | Find        | Find                      |
|------|-------------|---------------------------|
| ^Q^A | Find/Replac | eFind and replace         |
| ^L   | Next        | Next Find or Find/Replace |

# Go to Functions

| Control | Pulldown<br>Command | Description            |  |
|---------|---------------------|------------------------|--|
| Command | Commanu             |                        |  |
| ^Q^R    | Top of file         | Cursor to top of file  |  |
| ^Q^C    | End of file         | Cursor to end of file  |  |
| ^Q^B    | Begin block         | Cursor to top of block |  |
| ^Q^K    | End block           | Cursor to end of block |  |
| ^O^N    | Line                | Go to line number      |  |
| ^O^I    | Column              | Go to column number    |  |
| ^Q^J    | Go marker           | Go to marker number    |  |
| ^K^M    | Set marker          | Set marker number      |  |

# **Text format Functions**

| Control         | Pulldown      | Description               |
|-----------------|---------------|---------------------------|
| Command Command |               |                           |
| ^V              | Insert        | Toggle insert mode        |
| ^O^W            | Word wrap     | Toggle word wrap          |
| ^Q^I            | Auto indent   | Toggle auto indent        |
| ^O^L            | Left margin   | Set left margin           |
| ^O^R            | Right margin  | Set right margin          |
| ^K^T            | Tab size      | Set tab spacing           |
| ^O^S            | Undo limit    | Set undo limit            |
|                 | Save settings | Save text format settings |

# **Window Functions**

| Control<br>Command | Pulldown<br>Command | Description          |  |
|--------------------|---------------------|----------------------|--|
| ^O^G               | Select              | Select second window |  |
| ^0^0               | Open                | Open second window   |  |

^O^Y......Close second window

# **File Functions**

| Control<br>Command | Pulldown<br>Command | Description                  |  |
|--------------------|---------------------|------------------------------|--|
| ٨Κ٨Ŋ               | Open                | Close current and Open file  |  |
| ^K^O               | Close               | Close file                   |  |
| ^K^S               | . Save              | Save file                    |  |
|                    | .save As            | Save file under another name |  |
|                    | Directory           | List directory               |  |
|                    | .Logged dir         | Log directory of disk        |  |
|                    | .Print              | Print file                   |  |
|                    | .copY               | Copy file                    |  |
|                    | .Rename             | Rename file                  |  |
|                    | .Erase              | Erase file                   |  |
| ^K^X               |                     |                              |  |
| ^K^Q               | .Quit               | Abandon file                 |  |

# **Appendix B: Programming Support**

Support as of Q2 1989. For additional information contact ICT or specific PLD programmer manufacturer.

## International CMOS Technology (408) 434-0678

|                 | PDS-1 PEEL™ Development System ♦        |                           |
|-----------------|-----------------------------------------|---------------------------|
| ICT Part Number | Software                                | Adapter                   |
| PEEL18CV8       | PDS-1 Software Version V1.20 or greater | Call ICT for PLCC Adapter |
| PEEL20CG10      | PDS-1 Software Version V3.20 or greater |                           |
| PEEL22CV10      |                                         |                           |
| PEEL22CV10Z     |                                         |                           |
| PEEL153         | PDS-1 Software Version V2.20 or greater |                           |
| PEEL253         |                                         |                           |
| PEEL173         | PDS-1 Software Version V2.00 or greater |                           |
| PEEL273         |                                         |                           |

#### Adams-MacDonald (408) 373-3607

|                 | Sprint Plus 🗇 |  |
|-----------------|---------------|--|
| ICT Part Number | Software      |  |
| PEEL18CV8       | Version V3.10 |  |
| PEEL153         | Version V3.20 |  |
| PEEL253         |               |  |

## Advin Systems (408) 984-8600

|                 | Sailor-PAL 🔹 |
|-----------------|--------------|
| ICT Part Number | Software     |
| PEEL18CV8       | Version 8.0  |
| PEEL22CV10      | Version 9.4  |

## BP Microsystems (800) 225-2102

|                 | Record of the second se |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | PLD 1100 \$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ICT Part Number | Software                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PEEL18CV8       | Version 1.07 or greater                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PEEL153         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PEEL253         | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PEEL173         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PEEL273         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PEEL22CV10      | Please call BP Microsys                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Systems and updates identifed by this symbol have been qualified by ICT for their ability to program the devices listed. Contact ICT for information on systems not listed in this table.

7

#### Digelec (800) 367-8750, in California call (818) 887-3755

|                 | Model 860 Programmer       |  |
|-----------------|----------------------------|--|
| ICT Part Number | Software                   |  |
| PEEL18CV8       | Version A-1.3 or greater 🔹 |  |
| PEEL153         | Version A-1.4 or greater   |  |
| PEEL173         | Version A-1.4 or greater   |  |
| PEEL253         | Version A-1.4 or greater   |  |
| PEEL273         | Version A-1.4 or greater   |  |
| PEEL22CV10      | Please call Digelec        |  |

|                 | Unisite 40      |        |        |
|-----------------|-----------------|--------|--------|
| ICT Part Number | Software        | Family | Pinout |
| PEEL18CV8       | V1.4 or greater | 8D     | ЗA     |
| PEEL20CG10      | V2.3 or greater |        | 56     |
| PEEL22CV10      |                 |        | 28     |
| PEEL22CV10Z     | V2.2 or greater | 7      | A3     |
| PEEL153         |                 |        | 65     |
| PEEL253         |                 |        | 85     |
| PEEL173         |                 |        | 76     |
| PEEL273         |                 |        | 86     |

|                 | Model 29B Programmer 🗇 |                           |        |        |  |
|-----------------|------------------------|---------------------------|--------|--------|--|
| ICT Part Number | Module                 | Adapter/ Firmware         | Family | Pinout |  |
| PEEL18CV8       | LogicPak™ V04          | 303A-011A /V02 or greater | 8D     | ЗA     |  |
| PEEL20CG10      | ]                      | 303A-011A /V09 or greater |        | 56     |  |
| PEEL22CV10      |                        | 303A-011A/ V06 or greater |        | 28     |  |
| PEEL22CV10Z     |                        |                           |        | A3     |  |
| PEEL153         |                        | 303A-011A/ V06 or greater |        | 65     |  |
| PEEL253         |                        |                           |        | 85     |  |
| PEEL173         | ]                      | 303A-011A/ V04 or greater |        | 76     |  |
| PEEL273         | ]                      |                           |        | 86     |  |

|                 | Model 60A | *           | Model 60H 🔹          |        |        |
|-----------------|-----------|-------------|----------------------|--------|--------|
| ICT Part Number | Adapter   | Firmware    | Firmware             | Family | Pinout |
| PEEL18CV8       | 360A-001  | Version V11 | Version V12          | 8D     | ЗA     |
| PEEL20CG10      |           | Version V14 | Version V14          |        | 56     |
| PEEL22CV10      |           | (Summer     | (Summer 1989)        |        | 28     |
| PEEL22CV10      |           | 1989)       |                      |        | A3     |
| PEEL153         |           | Please call | Please call Data I/O |        | 65     |
| PEEL253         |           | Data I/O    |                      |        | 85     |
| PEEL173         | ]         |             |                      |        | 76     |
| PEEL273         |           |             |                      |        | 86     |

# INLAB (303) 460-0103

|                 | Model 28U 🔹              |
|-----------------|--------------------------|
| ICT Part Number | Firmware                 |
| PEEL18CV8       | Version 11.02 or greater |
| PEEL22CV10      |                          |
| PEEL153         | 7                        |
| PEEL253         | _                        |
| PEEL173         | -                        |
| PEEL273         | 7                        |

# Kontron Electronics (800) 227-8834

|                 | MPP-80S Portable Programmer<br>with Universal Module UPM/B | EPP-80 Base Programmer<br>with Universal Module UPM/B |
|-----------------|------------------------------------------------------------|-------------------------------------------------------|
| ICT Part Number | Firmware                                                   | Firmware                                              |
| PEEL18CV8       | Version 2.1 or greater                                     | Version 2.1 or greater                                |
| PEEL153         | Please call Kontron                                        | Please call Kontron                                   |
| PEEL253         |                                                            |                                                       |
| PEEL173         | Version 2.2 or greater                                     | Version 2.2 or greater                                |
| PEEL273         | 1                                                          |                                                       |

# Logical Devices (305) 974-0975

|                 | ALLPRO Programmer *         |
|-----------------|-----------------------------|
| ICT Part Number | Software                    |
| PEEL18CV8       | Version 1.44 or greater 🔹   |
| PEEL20CG10      | Please call Logical Devices |
| PEEL22CV10      | Version 1.47c or greater    |
| PEEL22CV10Z     | Please call Logical Devices |
| PEEL153         | Version 1.47c or greater    |
| PEEL253         | Please call Logical Devices |
| PEEL173         | Version 1.45 or greater 🔹   |
| PEEL273         |                             |

# Stag Microsystems (408) 988-1118

|                 | PPZ Programmer |                  | ZL-30A Programmer |                  |
|-----------------|----------------|------------------|-------------------|------------------|
| ICT Part Number | Module         | Firmware         | Module            | Firmware         |
| PEEL18CV8       | ZM2200         | Version 34       | 30A800            | Version 30A26    |
| PEEL153         |                | Version 37       |                   | Version 30A32    |
| PEEL253         |                |                  |                   |                  |
| PEEL173         |                |                  |                   |                  |
| PEEL273         |                |                  |                   |                  |
| PEEL22CV10      |                | Please call Stag |                   | Please call Stag |

# System General (Taiwan) 886-2-7212613

|                 | SGUP-85 *              |  |
|-----------------|------------------------|--|
| ICT Part Number | Firmware               |  |
| PEEL18CV8       | Version 3.0 or greater |  |
| PEEL22CV10      |                        |  |
| PEEL22CV10Z     | Version 3.1 or greater |  |
| PEEL153         | -                      |  |
| PEEL253         |                        |  |
| PEEL173         | 7                      |  |
| PEEL273         |                        |  |



PEEL (Programmable Electrically Erasable Logic) devices. The PDS-1 is a personal PLD work-station providing everything needed to implement your logic designs from concept to silicon. Several options for desiging with PEEL devices are available with the PDS-1. For example, an existing PLD design (i.e., PAL, GAL or EPLD JEDEC file) can be automatically translated and programmed into a PEEL device. Additionally, the translation capability allows you to use your present PLD logic assembler or compiler to design with PEEL devices.

#### Io fully support the advanced features of PEEL devices, the PDS-1 also provides the tools needed to design from start to finish, including a built-in word processor for design entry and editing, the APEEL™ boolean-logic assembler, a complete PEEL-device programmer and enhanced logic tester. The capabilities of the software-controlled programmer will be expanded as new devices are released by ICT. Registered owners are enrolled in the ICT software update service and receive programmer/development-software updates.



PDS-1, PEEL Development System



#### PEEL18CV8 Logic Array Diagram

D-1

7



### PEEL20CG10 Logic Array Diagram



PEEL22CV10 / PEEL22CV10Z Logic Array Diagram


# PEEL153 Logic Array Diagram



INPUT/OUTPUT PIN LABELS

PEEL253 Logic Array Diagram



PEEL173 Logic Array Diagram



PEEL273 Logic Array Diagram

# ICT North American Sales

# Headquarters

2125 Lundy Avenue San Jose, CA 95131 TEL......(408) 434-0678 FAX ......(408) 434-0688 TWX .......(910) 997-1531

# Western Area Sales

2125 Lundy Avenue San Jose, CA 95131 Tel:......(408) 434-0678 Fax:......(408) 434-0688

# **Central Area Sales**

# Eastern Area Sales

# **Sales Representatives**

#### Alabama

#### Arizona

Oasis Sales, Inc. . (602) 277-2714

#### California

Epsilon Marketing Northern Calif. ..... (408) 241-8111

DynaRep, Inc. Los Angeles ....... (805) 527-0072 Orange County:.... (714) 545-3255

Littlefield & Smith San Diego ...... (619) 455-0055

#### Colorado

Electrodyne ...... (303) 695-8903

#### Connecticut

Datatrack Engineering, Inc. ......(203) 271-1311

# Florida

Technology Marketing Associates Orlando......(407) 857-3760 Deerfield Beach....(305) 427-1090 Largo ......(813) 541-1591

#### Georgia

Technology Marketing Associates .....(404) 446-3565

#### Indiana

Electronic Sales & Engineering ......(317) 849-4260

#### Illinois

Martan, Inc. ..... (312) 303-5660

#### lowa

Contact ICT ..... (312) 490-5389

Kansas Contact ICT ......... (312) 490-5389

Maryland

Conroy Sales Inc. (301) 296-2444

#### Massachusetts

### Michigan

R.C. Nordstrom & Company .....(313) 559-7373

#### Minnesota

George Russell & Associates ......(612) 854-1166

#### Missouri

Contact ICT ...... (312) 490-5389

#### New Hampshire

#### New Jersey

Nexus Technology Sales, Inc. North New Jersey. (201) 947-0151

Tritek Sales South New Jersey (609) 429-1551

#### New Mexico

Oasis Sales, Inc. .. (602) 277-2714

#### New York

Pi'Tronics NY State ...... (315) 455-7346

#### North Carolina

Quantum Marketing ......(919) 846-5728

#### Ohio

#### Oregon

Contact ICT ...... (408) 434-0678

#### Pennsylvania

Tritek Sales ...... (609) 429-1551

#### South Carolina

Quantum Marketing ......(704) 523-8822

#### Tennessee

Technology Marketing Associates .....(205) 883-7893

#### Texas

T.L. Marketing Dallas.....(214) 484-6800 Austin.....(512) 453-4586 Houston .....(713) 589-2763

#### Utah

Utah Component Sales, Inc. ......(801) 268-8440

#### Vermont

#### Washington

Contact ICT ...... (408) 434-0678

#### Wisconsin

Martan, Inc. ..... (414) 241-4955

#### Canada

Bytewide Marketing Montreal.....(514) 636-4121 Ottawa ......(613) 728-0031 Toronto ......(416) 675-1868

# ICT North American Distributor Network

#### Alabama

Marshall Industries Huntsville ......(205) 881-9235

#### Arizona

Marshall Industries Phoenix......(602) 496-0290

#### California

Marshall Industries El Monte......(818) 459-5500 Chatsworth.......(818) 407-4100 Irvine ......(714) 458-5301 San Diego .......(619) 578-9600 Rancho Cordova ...(916) 635-9700 Milpitas ......(408) 942-4600

#### Western Microtechnology

#### Colorado

Marshall Industries Thornton.....(303) 451-8383

#### Connecticut

Marshall Industries Wallingford.....(203) 265-3822

#### Florida

Marshall Industries Altamonte Springs (407) 767-8585 Ft. Lauderdale......(305) 977-4880 St. Petersburg......(813) 573-1399

#### Georgia

Marshall Industries Norcross......(404) 923-5750

#### Illinois

Marshall Industries Schaumburg.......(312) 490-0155

# Indiana

Marshall Industries Indianapolis ........ (317) 297-0483

## Kansas

#### Maryland

Marshall Industries Silver Springs ...... (301) 622-1118

# Massachusetts

Marshall Industries Wilmington...... (508) 658-0810

Western Microtechnology Burlington ...... (617) 273-2800

# Michigan

Marshall Industries Livonia ...... (313) 525-5850

# Minnesota

Marshall Industries Minneapolis ........ (612) 559-2211

#### Missouri

Marshall Industries Bridgeton ...... (314) 291-4650

# New Jersey

#### **New York**

#### North Carolina

Marshall Industries Raleigh ...... (919) 878-9882

## Ohio

Marshall Industries Dayton.....(513) 898-4480 Westerville.....(614) 891-7580 Solon.....(216) 248-1788

#### Oregon

Marshall Industries Beaverton.....(503) 644-5050

Western Microtechnology Beaverton......(503) 629-2082

#### Pennsivania

Marshall Industries Pittsburgh.....(412) 963-0441

#### Texas

Marshall Industries El Paso......(915) 593-0706 Carrollton.....(214) 233-5200 Houston.....(713) 895-9200 Austin......(512) 837-1991 Brownsville.......(512) 542-4589

#### Insight Electronics

Austin ......(512) 467-0800 Ft. Worth ......(817) 338-0800 Houston ......(713) 448-0800 Richardson ......(214) 783-0800

### Utah

Marshall Industries Salt Lake City......(801) 485-1551

#### Washington

Marshall Industries Bothell .....(206) 486-5747

Western Microtechnology Redmond......(206) 881-6737

#### Wisconson

Marshall Industries Waukesha ......(414) 797-8400

### Canada

Marshall Industries Ontario ......(416) 674-2161 Montreal .....(514) 848-9112 Ottawa.....(613) 564-0166

# ICT International Sales Representatives

# **ICT European Sales**

# West Germany

United Semiconductor Engineering .....(49) 89 339292

#### Alfred Neye Enatechnik

.....(49) 4106 6120

# France

| ASAP (33) 16 1 30 43 823 |
|--------------------------|
|--------------------------|

MISIL..... (33) 1 45 60 00 21

# United Kingdom

Sequoia Technololgy Limited .....(44) 0734 311822

#### The Netherlands

Acal Auriema ......(31) 40 816565

#### Denmark

PRC Components (45) 6 62 37 99

| Norway                                       |
|----------------------------------------------|
| Abemi A/S472 807200                          |
| Finland                                      |
| Abemi Oy Ab3580 755 6722                     |
| <u>Italy</u><br>MicroELit S.P.A (39) 4817900 |
| Belgium                                      |
| Acal Auriema (32) 2523 6295                  |
| Spain<br>Anatronic, S.A242 44 55             |
| Switzerland                                  |
| Inteltro AG 01 741 41 21                     |
| Sweden                                       |
| Titan08 754 9175                             |
| Israel                                       |
| SegTec 972-3-556-7548                        |

# **ICT Far East Sales**

# Hong Kong, Korea, Singapore,

Excel Associates...... 03 7210900

### Tiawan

Jatron Electronics, Inc. .....02-307-0152

Sertek International Inc. .....02-501-0055

# Australia

Reptechnic ...... 621-436-3422

## Japan

Motono International Co., Ltd. .....03-404-5750

Tokyo Denshi Hanbai Co., Ltd. .....03-348-3401

Paltek Corporation .... 03-707-5455

Shin-Nichi Electronics Co., Ltd. .....03-833-2431

PEEL<sup>™</sup> and APEEL<sup>™</sup> are trademarks of International CMOS Technology, Inc.

 $\mathsf{PAL} \ensuremath{\mathbb{R}}$  is a registered trademark of Advanced Micro Devices, Inc.

ABEL<sup>™</sup> is a trademark of DATA I/O Corporation

CUPL<sup>™</sup> is a trademark of Logical Devices





2125 Lundy Avenue San Jose, CA 95131 (408) 434-0678

