# TECHNICAL MANUAL **AM-420** DISK DRIVE CONTROLLER CIRCUIT BOARD

DWM-00420-00 REV. A00



1. 30

## **FIRST EDITION**

OCTOBER, 1981

## **REVISIONS INCORPORATED:**

EDITION

0

DATE

#### **PROPRIETARY NOTICE**

This document and the information herein disclosed is the proprietary property of ALPHA MICRO, 17881 Sky Park North, Irvine, California 92714. Any person or entity to whom this document is furnished or having possession thereof, by acceptance, assumes custody thereof and agrees that the document is given in confidence and will not be copied or reproduced in whole or in part, nor used or revealed to any person in any manner except to meet the purposes for which it was delivered. Additional rights and obligations regarding this document and its contents may be defined by a separate written agreement with ALPHA MICROSYSTEMS, and if so, such separate written agreement shall be controlling.

## TABLE OF CONTENTS

## Paragraph

## Page

## SECTION I

## GENERAL DESCRIPTION

| 1.0 | Introduction              | 1-1 |
|-----|---------------------------|-----|
| 1.1 | Circuit Board Description | 1-1 |
| 1.2 | Application               | 1-1 |

## SECTION II

#### OPERATING DATA

| 2.0   | Introduction                    | 2–1  |
|-------|---------------------------------|------|
| 2.1   | Capabilities and Specifications | 2–1  |
| 2.2   | Installation And Start-Up       | 2-4  |
| 2.2.1 | Installation                    | 2-4  |
| 2.3   | Interface Description           | 2-12 |
| 2.3.1 | S-100 Bus Interface             | 2–12 |
| 2.3.2 | Disk Drive Interface            | 2-12 |
| 2.4   | User Options                    | 2-13 |
| 2.4.1 | Address Code                    | 2-13 |
| 2.4.2 | Interrupt Lines                 | 2-13 |
| 2.4.3 | Boot Option                     | 2-13 |
| 2.4.4 | AM-100 Preparation              | 2-13 |

i

## SECTION III PROGRAMMING

| 3.0      | Introduction                        | 3-1  |
|----------|-------------------------------------|------|
| 3.1      | Unique Software Considerations      | 3-1  |
| 3.2      | Addressing                          | 3-1  |
| 3.3      | Initialization                      | 3-2  |
| 3.4      | Command Register                    | 3-2  |
| 3.5      | Status Register                     | 3-4  |
| 3.6      | Interrupt Mode                      | 3-4  |
| 3.7      | Handshake Sequence                  | 3-4  |
| 3.8      | DMA Buffer                          | 3-7  |
| 3.8.1    | DMA Buffer Operation For Disk Write | 3-7  |
| 3.8.2    | DMA Buffer Operation For Disk Read  | 3-10 |
| 3.8.3    | Physical Address                    | 3-11 |
| 3.9      | Restore Command                     | 3-12 |
| 3.10     | Status Check                        | 3-12 |
| 3.11     | Special Commands                    | 3-13 |
| 3.11.1   | Type I Commands                     | 3-14 |
| 3.11.2   | Type II Commands                    | 3-14 |
| 3.11.2.1 | Read Revision Level (OF Hex)        | 3-14 |
| 3.11.2.2 | RAM Test (1F Hex)                   | 3-14 |
| 3.11.2.3 | Sequence Up Drive (2F Hex)          | 3-15 |
| 3.11.2.4 | Sequence Down Drive (3F Hex)        | 3-16 |
| 3.11.2.5 | Reset Drive (4F Hex)                | 3-16 |
| 3.11.2.6 | Read Drive ID (5F Hex)              | 3-16 |
| 3.11.2.7 | Read Drive Sector Size (6F Hex)     | 3-17 |
| 3.11.2.8 | Read Current Cylinder (7F Hex)      | 3-17 |
| 3.11.2.9 | Read Drive Status (8F Hex)          | 3-17 |

## SECTION IV

FUNCTIONAL THEORY OF OPERATION

| 4.0   | Introduction            | 4-1  |
|-------|-------------------------|------|
| 4.1   | Circuit Board Operation | 4-1  |
| 4.1.1 | Power-Up Reset          | 4-16 |

ii

## SECTION IV

## FUNCTIONAL THEORY OF OPERATION (Con't)

| 4.1.2    | Addressing                         | 4-16 |
|----------|------------------------------------|------|
| 4.1.3    | CPU Output                         | 4-16 |
| 4.1.3.1  | Command Data                       | 4-17 |
| 4.1.3.2  | Command Types                      | 4-17 |
| 4.1.3.3  | Output Data                        | 4-22 |
| 4.1.4    | CPU Input                          | 4-22 |
| 4.1.4.1  | Status Register                    | 4-22 |
| 4.1.4.2  | Status Word Formats                | 4-23 |
| 4.1.4.3  | Input Data Register                | 4-23 |
| 4.1.5    | Boot Load Procedure                | 4-23 |
| 4.1.6    | Interrupts                         | 4-25 |
| 4.1.7    | Byte Clock Counter                 | 4-25 |
| 4.1.8    | Disk Transfer Logic                | 4-26 |
| 4.1.9    | Sector Counter                     | 4-26 |
| 4.1.10   | Data Write Logic                   | 4-26 |
| 4.1.10.1 | Disk Drive Controls                | 4-27 |
| 4.1.11   | Input From Disk Drive              | 4–27 |
| 4.1.12   | AM-420 Board Operations and Timing | 4-27 |
| 4.1.12.1 | Data Transfer Operations           | 4-27 |
| 4.1.12.2 | Disk Transfer Operations           | 4-28 |
| 4.1.12.3 | Disk Read Clocks                   | 4-29 |
| 4.1.12.4 | Disk Write Clocks                  | 4-30 |
| 4.1.12.5 | Sector Beginning Format Operations | 4-30 |
| 4.1.12.6 | Sector End Format Operations       | 4-31 |
| 4.1.12.7 | DMA Transfer Operations            | 4-32 |
| 4.2      | Circuit Module Description         | 4-33 |
| 4.2.1    | CPU Microprocessor (U11)           | 4-33 |
| 4.2.1.1  | Instruction Op-Code Fetch          | 4-39 |
| 4.2.1.2  | Memory Read Or Write Cycles        | 4-40 |
| 4.2.1.3  | Input Or Output Cycles             | 4-41 |
| 4.2.1.4  | Interrupt Request/Acknowledge      | 4-41 |
| 4.2.1.5  | CPU Instruction Set                | 4-42 |

## SECTION IV

FUNCTIONAL THEORY OF OPERATION (Con't)

| 4.2.2   | DMA Address Generator (U10, U21)                    | 4-47          |
|---------|-----------------------------------------------------|---------------|
| 4.2.2.1 | Architecture                                        | 4-48          |
| 4.2.2.2 | Control Modes                                       | 4-51          |
| 4.2.2.3 | Instructions                                        | 4-52          |
| 4.2.3   | Cyclic Redundancy (CRC) Generator/Checker (U15)     | 4-53          |
| 4.2.4   | Positive-Edge-Triggered Flip-Flops with Preset      |               |
|         | and Clear (U5, U14, U53, U55, U62)                  | 4-57          |
| 4.2.5   | Dual J-K Negative-Edge Triggered Flip-Flops with    |               |
|         | Preset and Clear (U17)                              | 4-57          |
| 4.2.6   | Decoder (U25, U26, U71)                             | 4-58          |
| 4.2.7   | Decoder/Demultiplexer (U30)                         | 4 <b>-</b> 59 |
| 4.2.8   | Data Selector/Multiplexer (U13)                     | 4-60          |
| 4.2.9   | Quad Two-Line to One-Line Data Selector/            |               |
|         | Multiplexer (U61)                                   | 4-60          |
| 4.2.10  | Quad Inverting Two-Line to One-Line Data Selector/  |               |
|         | Multiplexer (U18, U19)                              | 4-62          |
| 4.2.11  | Four-Bit Binary Counter With Asynchronous Clear     |               |
|         | (U75)                                               | 4-63          |
| 4.2.12  | Four-Bit Binary Counter With Synchronous Clear      |               |
|         | (U23, U24, U74)                                     | 4-66          |
| 4.2.13  | Eight-Bit Serial In/Parallel Out Shift Register     |               |
|         | (U66)                                               | 4-69          |
| 4.2.14  | Eight Bit Parallel In/Serial Out Shift Register     |               |
|         | (U67)                                               |               |
| 4.2.15  | Quad D Flip-Flops With Clear (U63)                  | 4-72          |
| 4.2.16  | Inverting Tri-State Buffer (U34, U65, U72)          |               |
| 4.2.17  | Octal D-Type Flip-Flop With Clear (U35, U79)        | 4-74          |
| 4.2.18  | Octal D-Type Transparent Latch (U39)                | 4-75          |
| 4.2.19  | Tri-State D Flip-Flops (U37, U48, U40, U76, U77,    |               |
|         | U80)                                                | 4-76          |
| 4.2.20  | 1024 X 4-Bit Static Random Access Memory (U41, U42) |               |
| 4.2.21  | Bus Comparator (U27, U68)                           |               |
| 4.2.22  | Tri-State Octal Buffers (U36)                       | 4-79          |
| 4.2.23  | Bidirectional Transceiver (U43, U64)                | 4-80          |

#### SECTION V

## MAINTENANCE AND TROUBLESHOOTING

| 5.0 | Introduction           | 5-1 |
|-----|------------------------|-----|
| 5.1 | Circuit Board Checkout | 5-1 |
| 5.2 | Warranty Procedures    | 5-2 |

## SECTION VI

PARTS LIST AND SCHEMATIC

## LIST OF ILLUSTRATIONS

Figure

| 1 – 1 | AM-420 Simplified Block Diagram                       | 1-2  |
|-------|-------------------------------------------------------|------|
| 2–1   | Disk Drive Interface Cabling                          | 2-5  |
| 2-2   | Jumper Options                                        | 2-14 |
| 3–1   | System Commands                                       | 3-3  |
| 3-2   | AM-420 Status Words                                   | 3-5  |
| 3-3   | DMA Buffer Operation                                  | 3-6  |
| 3-4   | Handshake Sequence                                    | 3-8  |
| 3-5   | DMA Transfer Sequence                                 | 3-9  |
| 4-1   | AM-420 Functional Block Diagram                       | 4-2  |
| 4-2   | AM-420 Functional Block Diagram                       | 4-3  |
| 4-3   | Status Word Formats                                   | 4-24 |
| 4-4   | Data Transfer Timing                                  | 4-28 |
| 4-5   | Disk Transfer Timing                                  | 4-29 |
| 4-6   | BYTCLK-BYTENB Timing                                  | 4-29 |
| 4-7   | Disk Write Timing                                     | 4-30 |
| 4-8   | Sector Beginning Timing                               | 4-31 |
| 4-9   | Sector End Format Timing                              | 4-32 |
| 4–10  | DMA Transfer Timing                                   | 4-33 |
| 4-11  | CPU Block Diagram                                     | 4-34 |
| 4-12  | CPU Registers                                         | 4-34 |
| 4-13  | CPU Pin Configuration                                 | 4-34 |
| 4-14  | DMA Address Generator Connections                     | 4-47 |
| 4–15  | DMA Address Generator Block Diagram                   | 4-48 |
| 4–16  | Control Register Format Definition                    | 4-49 |
| 4-17  | CRC Checker Connections                               | 4-55 |
| 4-18  | CRC Equivalent Ciruit For $X^{16} + X^{17} + X^2 + 1$ | 4-56 |
| 4-19  | CRC Check Word Generation                             | 4-56 |
| 4–20  | Dual D Flip-Flop Connections                          | 4-57 |
| 4-21  | Dual J-K Flip-Flop Connections                        | 4-57 |
| 4-22  | Decoder Connections                                   | 4-58 |
| 4-23  | Decoder/Demultiplexer Connections                     | 4-59 |
| 4-24  | Data Selector/Multiplexer, Logic and Connections      | 4-60 |

## LIST OF ILLUSTRATIONS (Con't)

| 4–25 | Quad Two-Line to One-Line Data Selector/Multiplexer |      |
|------|-----------------------------------------------------|------|
|      | Connections                                         | 4-61 |
| 4-26 | Quad Inverting Two-Line to One-Line Data Selector/  |      |
|      | Multiplexer Connections                             | 4-62 |
| 4–27 | Binary Counter With Asynchronous Clear, Logic and   |      |
|      | Connections (Sh 1 of 2)                             | 4-64 |
| 4-27 | Binary Counter with Asynchronous Clear, Logic and   |      |
|      | Connections (Sh 2 of 2)                             | 4-65 |
| 4–28 | Binary Counter With Synchronous Clear, Logic and    |      |
|      | Connections (Sh 1 of 2)                             | 4-67 |
| 4–28 | Binary Counter With Synchronous Clear, Logic and    |      |
|      | Connections (Sh 2 of 2)                             | 4-68 |
|      |                                                     |      |
| 4-29 | Eight-Bit Shift Register, Logic and Connections     | 4-69 |
| 4-30 | Eight Bit Parallel In/Serial Out Shift Register,    |      |
|      | Logic and Connections (Sh 1 of 2)                   | 4-70 |
| 4-30 | Eight Bit Parallel In/Serial Out Shift Register,    |      |
|      | Logic and Connections (Sh 2 of 2)                   | 4-71 |
| 4-31 | Quad D Flip-Flops With Clear, Logic and Connections | 4-72 |
| 4-32 | Inverting Tri-State Buffer, Logic and Connections   | 4-73 |
| 4-33 | Octal D-Type Flip-Flop With Clear, Logic and        |      |
|      | Connections                                         | 4-74 |
| 4-34 | Transparent Latch, Logic and Connections            | 4-75 |
| 4-35 | Tri-State D Flip-Flop Connections                   | 4-76 |
| 4-36 | RAM Connections                                     | 4-77 |
| 4-37 | Bus Comparator Connections                          | 4-78 |
| 4-38 | Tri-State Octal Buffers, Logic and Connections      | 4-79 |
| 4-39 | Bidirectional Transceiver, Logic and Connections    | 4-80 |

.

## LIST OF TABLES

Table

## Page

1

| 2-1 | AM-420 Specifications 2             | 2-2          |
|-----|-------------------------------------|--------------|
| 2-2 | Alpha Micro Bus Interface Signals 2 | 2-6          |
| 4-1 | AM-420 Signals List 4               | 1-4          |
| 4-2 | Non-Disk Command Bits 4             | <b>1–</b> 18 |
| 4-3 | Non-Disk Command Formats 4          | <b>1–</b> 19 |
| 4-4 | Disk Command Bits 4                 | 1-20         |
| 4-5 | Disk Command Codes 4                | 1-21         |
| 4–6 | CPU Signal List 4                   | 1-35         |
| 4-7 | CPU Instruction Set 4               | 1-43         |
| 4-8 | DMA Register Instructions 4         | 1-52         |
| 4-9 | CRC Polynomial Select Codes 4       | 1-56         |

#### 1.0 INTRODUCTION

This manual provides operating and maintenance instructions for the AM-420 Winchester Disk Drive Controller circuit board manufactured by Alpha Microsystems Inc., located in Irvine, California. Circuit board description, operating and usage instructions, programming, theory of operation, and maintenance instructions are included to provide the user with the information necessary to utilize this circuit board to its full capability.

#### 1.1 CIRCUIT BOARD DESCRIPTION

The AM-420 Wincheter Disk Drive Controller circuit board provides data processing, control and interface capability between a standard S-100 Bus system and one to four PRIAM Winchester hard disk drives. A CPU microprocessor, a DMA address generator, a Random Access Memory (RAM) with associated control logic provide the sophisticated data processing necessary for control of up to four PRIAM Winchester disk drives. A 2K Read Only Memory (ROM) is contained on the board to provide a bootstrap load program and also to contain the microcode necessary for the CPU module operation.

A simplified block diagram of the circuit board is shown in Figure 1-1. For a complete detailed description of circuit board operation, see Section IV of this manual. For programming requirements, see Section III of this manual.

#### 1.2 APPLICATION

This circuit board provides the data processing and interface capability necessary for operation of up to four PRIAM Winchester hard Data is transferred at an average rate of 8 MHz between disk drives. the controller and drives. See Section II of this manual for wiring For complete instructions and system interface information. information on the disk drive, see the appropriate PRIAM Hardware Maintenance Manual.



Figure 1-1. AM-420 Simplified Block Diagram

#### 2.0 INTRODUCTION

This section contains information on the use of the AM-420 Disk Controller circuit board. Capabilities, specifications, interface wiring, and user option descriptions are provided for the successful integration of the AM-420 into the user's system.

#### 2.1 CAPABILITIES AND SPECIFICATIONS

This circuit board operates from the standard S-100 Bus structure to interface with the PRIAM Winchester hard disk drive. The board can interface with up to four disk drives. Detailed specifications are contained in Table 2-1.

## Table 2-1. AM-420 Specifications

| PARAMETER                                 | SPECIFICATIONS                                                                                                                               |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| CPU Interface                             | Standard S-100 Bus                                                                                                                           |
| Drives per Controller                     | 1-4                                                                                                                                          |
| Printed Circuit Boards                    | 1                                                                                                                                            |
| Data Transfer Modes                       | Programmed Multi-Level<br>Interrupts, Full Sector<br>Block Transfers.                                                                        |
| Data Transfer - Controller<br>to Disk     | Serial                                                                                                                                       |
| Data Transfer - Controller<br>to Computer | 8-bit bytes Parallel                                                                                                                         |
| Data Transfer Format                      | 512 bytes per sector, plus<br>CRC and sentinel check bytes.                                                                                  |
| On-Board Buffer                           | 1024 bytes                                                                                                                                   |
| Error Checking                            | CRC Error Code                                                                                                                               |
| Input Power                               | +8 volts DC @2.0 amps                                                                                                                        |
| Interconnections                          | One mounting slot of an S-100<br>Bus chassis. One 50-pin cable<br>to first drive (25 feet max-<br>imum cumulative length on four<br>drives). |
| Dimensions                                | 9" x 10"                                                                                                                                     |

| PARAMETER                                          | SPECIFICATIONS                                             |
|----------------------------------------------------|------------------------------------------------------------|
| Environment (operating)<br>Temperature<br>Humidity | 60° to 104° F (15° to 40°C)<br>10% to 80% (non-condensing) |

Table 2-1 (Con't). AM-420 Specifications

#### 2.2 INSTALLATION AND START-UP

When the AM-420 circuit board is received, it is ready for use. No adjustment or calibration is required for operation. The hardware requirements for installation and use are described in this section and the software requirements are described in Section III.

#### 2.2.1 Installation

First ensure that the proper power wiring is available and that the correct voltages are connected to the disk drive and to the various pins of the circuit board as shown in Table 2-2. Connect the cables to the disk drives as shown in Figure 2-1.



Figure 2-1. Disk Drive Interface Cabling

| MNEMONIC | NAME                          | PIN NO. |
|----------|-------------------------------|---------|
| +7.5₹    | + 7.5vdc Power                | 1       |
| +16⊽     | + 16vdc Power                 | 2       |
| VI8      | Vectored Interrupt 8          | 3       |
| VIO      | Vectored Interrupt O          | 4       |
| VI1      | Vectored Interrupt 1          | 5       |
| VI2      | Vectored Interrupt 2          | 6       |
| VI3      | Vectored Interrupt 3          | 7       |
| VI4      | Vectored Interrupt 4          | 8       |
| VI5      | Vectored Interrupt 5          | 9       |
| VIG      | Vectored Interrupt 6          | 10      |
| VI7      | Vectored Interrupt 7          | 11      |
| RTC      | Real Time Clock, 50Hz or 60Hz | 12      |
| POWFAIL  | AC Power Failure Status       | 13      |
| VI9      | Vectored Interrupt 9          | 14      |
| A18      | Address 18                    | 15      |
| A16      | Address 16                    | 16      |
| A17      | Address 17                    | 17      |
| STATDSB  | Status Disable                | 18      |
| C/CDSB   | Command/Control Disable       | 19      |
| GND      | Ground                        | 20      |

Table 2-2. Alpha Micro Bus Interface Signals List

DWM-00420-00 REV. A00

ĺ

| MNEMONIC                           | NAME                                                                         | PIN NO.                          |
|------------------------------------|------------------------------------------------------------------------------|----------------------------------|
| IODIS                              | I/O Disable                                                                  | 21                               |
| ADDDSB                             | Address Disable                                                              | 22                               |
| DODSB                              | Data Bus Disable                                                             | 23                               |
| <b>ø</b> 2                         | Phase 2 Clock                                                                | 24                               |
| STVAL                              | Status and Address Valid                                                     | 25                               |
| PHLDA                              | DMA Request Acknowledge                                                      | 26                               |
| PWAIT                              | Processor Wait                                                               | 27                               |
| N/U                                | Not Used                                                                     | 28                               |
| A5<br>A4<br>A3<br>A15<br>A12<br>A9 | Address 5<br>Address 4<br>Address 3<br>Address 15<br>Address 12<br>Address 9 | 29<br>30<br>31<br>32<br>33<br>34 |
| DOUT 1/D1<br>DOUT 0/DO             | Data Bus Bit 1<br>Data Bus Bit O                                             | 35<br>36                         |
| A10                                | Address 10                                                                   | 37                               |

Table 2-2.(con't) Alpha Micro Bus Interface Signals List

| Table 2-2. | (con't) | Alpha | Micro | Bus | Interface | Signals | List |
|------------|---------|-------|-------|-----|-----------|---------|------|
|------------|---------|-------|-------|-----|-----------|---------|------|

| MNEMONIC                                                                   | NAME                                                                                                        | PIN NO.                          |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------|
| DOUT 4/D4<br>DOUT 5/D5<br>DOUT 6/D6<br>DIN 2/D10<br>DIN 3/D11<br>DIN 7/D15 | Data Bus Bit 4<br>Data Bus Bit 5<br>Data Bus Bit 6<br>Data Bus Bit 10<br>Data Bus Bit 11<br>Data Bus Bit 15 | 38<br>39<br>40<br>41<br>42<br>43 |
| SMI                                                                        | Bus Master OP Code Fetch                                                                                    | 44                               |
| SOUT                                                                       | I/O Output Cycle                                                                                            | 45                               |
| SINP                                                                       | I/O Input Cycle                                                                                             | 46                               |
| SMEMR                                                                      | Memory Read Cycle                                                                                           | 47                               |
| SHLTA                                                                      | HLT Acknowledge                                                                                             | 48                               |
| PERR                                                                       | Parity Error Pulse                                                                                          | 49                               |
| GND                                                                        | Ground                                                                                                      | 50                               |
| +7.5₹                                                                      | +7.5vdc Power                                                                                               | 51                               |
| -16V                                                                       | -16vdc Power                                                                                                | 52                               |
| GND                                                                        | Ground                                                                                                      | 53                               |
| SLAVECLR                                                                   | Reset Signal To All I/O Devices                                                                             | 54                               |

| MNEMONIC                 | NAME                                                 | PIN NO.              |  |  |
|--------------------------|------------------------------------------------------|----------------------|--|--|
| DMAO                     | DMA Controller Arbitration                           | 55                   |  |  |
| DMA 1                    | Lines For Use With Standard                          | 56                   |  |  |
| DMA2                     | S-100 Bus DMA System                                 | 57                   |  |  |
| SXTRQ                    | 16 Bit Cycle                                         | 58                   |  |  |
| A19                      | Address 19                                           | 59                   |  |  |
| N/U                      | Not Used                                             | 60                   |  |  |
| A20<br>A21<br>A22<br>A23 | Address 20<br>Address 21<br>Address 22<br>Address 23 | 61<br>62<br>63<br>64 |  |  |
| ADVAL                    | Address Valid On Data Bus                            | 65                   |  |  |
| WRDIS                    | Write Disable                                        | 66                   |  |  |
| PHANTOM                  | PHANTOM ROM Memory Enable                            |                      |  |  |
| N/U<br>N/U               | Not Used<br>Not Used                                 | 68<br>69             |  |  |
| Gnd                      | Ground                                               | 70                   |  |  |
| N/U                      | Not Used                                             | 71                   |  |  |
| PRDY                     | Processor Ready                                      | 72                   |  |  |

Table 2-2.(con't) Alpha Micro Bus Interface Signals List

| MNEMONIC  | NAME                               |    |  |  |  |  |  |
|-----------|------------------------------------|----|--|--|--|--|--|
| N/U       | Not Used                           | 73 |  |  |  |  |  |
| PHOLD     | DMA Request                        | 74 |  |  |  |  |  |
| PRESET    | Preset                             | 75 |  |  |  |  |  |
| PSYNC     | Processor Sync, Start of Bus Cycle | 76 |  |  |  |  |  |
| PWR       | Write Strobe                       | 77 |  |  |  |  |  |
| PDBIN     | Data Bus Input Command             | 78 |  |  |  |  |  |
| AO        | Address O                          | 79 |  |  |  |  |  |
| A1        | Address 1                          | 80 |  |  |  |  |  |
| A2        | Address 2                          | 81 |  |  |  |  |  |
| A6        | Address 6                          | 82 |  |  |  |  |  |
| Α7        | Address 7                          | 83 |  |  |  |  |  |
| 88        | Address 8                          | 84 |  |  |  |  |  |
| A13       | Address 13                         | 85 |  |  |  |  |  |
| A14       | Address 14                         | 86 |  |  |  |  |  |
| A11       | Address 11                         | 87 |  |  |  |  |  |
| DOUT 2/D2 | Data Bus Bit 2                     | 88 |  |  |  |  |  |
| DOUT 3/D3 | Data Bus Bit 3                     | 89 |  |  |  |  |  |
| DOUT 7/D7 | Data Bus Bit 7                     | 90 |  |  |  |  |  |
| DIN 4/D12 | Data Bus Bit 7                     | 91 |  |  |  |  |  |
| DIN 5/D13 | Data Bus Bit 13                    | 92 |  |  |  |  |  |
| DIN 6/D14 | Data Bus Bit 14                    | 93 |  |  |  |  |  |
| DIN 1/D9  | Data Bus Bit 9                     | 94 |  |  |  |  |  |
| DIN O/D8  | Data Bus Bit 8                     | 95 |  |  |  |  |  |

Table 2-2.(con't) Alpha Micro Bus Interface Signals List

| MNEMONIC | NAME                   | PIN NO. |
|----------|------------------------|---------|
| SINTA    | Interrupt Acknowledge  | 96      |
| SWO      | Bus Master Output      | 97      |
| ERROR    | Memory Error Interrupt | 98      |
| BERR     | Bus Error              | 99      |
| GND      | Ground                 | 100     |

Table 2-2.(con't) Alpha Micro Bus Interface Signals List

#### 2.3 INTERFACE DESCRIPTION

The AM-420 Disk Controller Circuit board provides interface capability between the standard S-100 Bus and the PRIAM Winchester disk drives.

#### 2.3.1 S-100 Bus Interface

The AM-420 circuit board is fully S-100 Bus compatible. The board and its associated disk drives are addressed through the address lines and data is transferred through the standard data-in and data-out ports. The S-100 bus connections are made via the bottom edge connector and are listed in Table 2-2. For a complete description of these signals and their operation in the AM-420, see Section IV of this manual.

#### 2.3.2 Disk Drive Interface

One AM-420 Circuit Board accommodates a maximum of four PRIAM disk drives. Interface connections are made through one cable connecting to all four drives in a daisy-chain (50 pin ribbon cable). Pin 1 on the daisy chain cable is identified by a stripe wire along one edge. Connect pin 1 of the cable to pin 1 of the connector on both the drive and the AM-420. Terminate only the last drive in sequence on the daisy-chain cable using the terminator card provided with the drive.

Interface cabling is shown in Figure 2-1. For further information on operation of the AM-420 interface, see Section IV of this manual.

#### 2.4 USER OPTIONS

Some features of the AM-420 can be changed by selection of jumpers at the user's option. Location of the jumper pads is shown in Figure 2-2.

#### 2.4.1 Address Code

Circuit board addressing can be selected at the user's option for any address block (in increments of four) on the address lines AD2-AD7. The standard address (C4 Hex) is contained in etch when the circuit board is manufactured. To change the address, cut the desired etch and leave open for pull up, jumper or ground to generate the desired board address.

#### 2.4.2 Interrupt Lines

Interrupt compatibility for any S-100 bus system is provided with jumpers to any of the vectored interrupt lines VIO-VI7. Attach the jumper wire from the pad located as shown in Figure 2-2 to the desired interrupt line. The standard interrupt line is VI5 which is contained in etch. Cut this jumper to change the interrupt.

#### 2.4.3 Boot Option

The AM-420 contains a bootstrap loader program contained in an internal PROM that the user may utilize. If the user decides to boot from another source, the boot feature must be disabled with a jumper block as shown in Figure 2-2. When using the AM-420 with the AM-100/T CPU, always disable the boot feature. Various boot PROM's exist to allow booting from various backup devices. Consult the Alpha Micro International Support/Services Group for additional details.

#### 2.4.4 AM-100 Preparation

If the Alpha Micro AM-100 CPU is used in the system, the interrupt jumper must be added on the CPU board at VI5 for compatibility with the AM-420.





#### 3.0 INTRODUCTION

This section describes the programming requirements for the AM-420 circuit board. Circuit board addressing, bootstrap loader, and AM-420 internal programming are described for complete system compatibility.

When the AM-420 circuit board is received, it is ready for use with the PRIAM disk drive as described in Section II of this manual. The bootstrap loader and the microcode contained in internal firmware is designed only for these disk drives.

#### 3.1 UNIQUE SOFTWARE CONSIDERATIONS

One of the most important differences between the Winchester drives and lower capacity conventional drives is that the software must accept media flaws. The track and bit densities are so great with these high capacity memory disks that it is impossible to manufacture platters with no media flaws. Therefore, software consideration is made for these faulty blocks.

The technique used to detect and flag these tracks writes to and reads from every track and flags any tracks that are faulty. To accommodate this technique, a new program called "CRT420" is included. New versions of old programs have also been included.

#### 3.2 ADDRESSING

The AM-420 and associated disk drives are addressed through the S-100 bus address lines. The circuit board address is jumper selectable by the jumpers connected to U27. Pull-ups to either +5V or ground jumpers select the board address on S-100 bus address lines AD2-AD7. Address C4 (Hex) is etched in the board to occupy I/O ports C4 and C5 (Hex).

#### 3.3 INITIALIZATION

On initial power-up or reset, the AM-420 goes into a dormant state waiting for initialization. With the boot option enabled, the phantom signal is activated, disabling any phantom controlled memory. The S-100 bus is enabled to access the bootstrap loader contained in the AM-420 PROM.

The 2K x 8 EPROM (U31) contains both the bootstrap routine and the controller microcode. The microcode resides in the first 1K bytes, and the bootstrap routine resides in the second 1K bytes of this PROM. The current bootstrap routine is written in AM-100 code. However, other user codes may be used.

NOTE: If the user code contained in the AM-420 EPROM is changed from the current boot routine, the microcode in the first 1K of memory must be duplicated exactly.

Initialization of the AM-420 is accomplished by writing a zero byte into the AM-420 command register during system initialization. The on-board CPU finishes initialization of the disk controller and releases the Phantom signal.

#### 3.4 COMMAND REGISTER

The command register receives AM-420 commands from the S-100 bus. It is accessed by writing to the selected address. The base addresses are in multiples of four from the first address FFOO (Hex) to FFFC (Hex) in increments of four. A software handshake sequence must be used for the command transfer (see paragraph 3.7). FFC4 (Hex) is the base address when it is shipped from the factory.

There are three basic types of commands used for operation of the AM-420 system; non-disk commands, disk commands and special commands. All three types are described in Figure 3-1.

NON-DISK COMMANDS:



DISK COMMANDS:



- 7. 6F HEX READ SECTOR SIZE
- 8. 7F HEX READ CURRENT CYLINDER 9. 8F HEX READ DRIVE STATUS

Figure 3-1. System Commands

#### 3.5 STATUS REGISTER

The status register is used to determine the current status of the AM-420 controller. It is accessed from the S-100 bus by reading from the user selected base address of the circuit board FFC4 (Hex). The format of the status register is described in Figure 3-2.

#### 3.6 INTERRUPT MODE

The interrupt mode in the AM-420 can be selected by both disk and non-disk commands. If the interrupt mode is selected, the interrupt occurs at the completion of the current AM-420 command. The interrupt must be cleared by the user by setting bit 6=1 of any non-disk command.

#### 3.7 HANDSHAKE SEQUENCE

A handshaking type interaction is required between the AM-420 circuit board and the CPU any time a command is sent to the AM-420. This handshaking is a software operation that uses bit 7 of the Status Register. Handshake operations proceed in the following sequence:

- 1. A command is sent from the S-100 bus to the Command Register.
- 2. The system software waits for bit 7 of the Status Register to become a 1 to guarantee that the AM-420 has received the command.
- 3. The system software writes a zero into the Command Register to clear the previous command.
- 4. The system software waits until bit 7 of the Status Register becomes a O indicating that the Command Register has been cleared and the command has been executed.

This completes the handshake operation and the program continues.

#### STATUS REGISTER BITS (PORT)

| D7               | D6 | D5 | D4 | D3 | D <b>2</b> | D1 | D0 |  |
|------------------|----|----|----|----|------------|----|----|--|
| CR               |    |    |    |    |            |    |    |  |
| DISK ERROR CODES |    |    |    |    |            |    |    |  |

| 02 | (HEX) | = | DRIVE SEQUENCING UP                |
|----|-------|---|------------------------------------|
| 03 | (HEX) | = | SPECIAL COMMAND ERROR              |
|    |       |   | (UNKNOWN SPECIAL COMMAND RECEIVED) |
| 04 | (HEX) | = | RAM SELF TEST ERROR                |
| 05 | (HEX) | = | DISK NOT READY                     |
| 0B | (HEX) | = | DISK WRITE PROTECTED               |
| 0F | (HEX) | = | DISK FAULT (THE CODE FOR THE FAULT |
|    |       |   | IS LOCATED IN THE DATA REGISTER    |
|    |       |   | (BASE ADDRESS +1)                  |
| 40 | (HEX) | = | READ CRC ERROR                     |
|    |       |   |                                    |

#### DATA REGISTER BITS FOR DISK FAULTS ONLY (PORT + 1)

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| CRJ | WPR | FLT | BSY | UNK | SKF | UNK | RDY |

| CRJ | - | COMMAND REJECT  | - | A COMMAND WAS SENT TO THE DRIVE WHILE<br>IT WAS ALREADY PROCESSING ONE |
|-----|---|-----------------|---|------------------------------------------------------------------------|
| WPR | _ | WRITE PROTECT   |   | DRIVE IS WRITE PROTECTED                                               |
| FLT | _ | DRIVE FAULT     | - | DRIVE FAULT                                                            |
| BSY | - | DRIVE BUSY      | - | DRIVE IS BUSY PROCESSING COMMAND                                       |
| SKF | - | SEEK FAULT      | _ | A DRIVE SEEK COMMAND CAUSED AN ERROR                                   |
| RDY |   | 3-5 DRIVE READY | _ | DRIVE IS READY                                                         |
| UNK | _ | UNKNOWN         | _ | BITS MAY BE IN ANY STATE                                               |

Figure 3-2. AM-420 Status Words



Figure 3-3. DMA Buffer Operation

#### 3.8 DMA BUFFER

The DMA buffer is the 1K RAM in the AM-420. All data transfers to or from the disk must pass through this buffer and are handled by the DMA logic.

The DMA buffer is accessed by addressing the AM-420 base address plus one and all data between the AM-420 and the S-100 bus must pass through this single port. No DMA type operations occur between the AM-420 and system memory because they are handled on a programmed basis only. The microcode initializes the buffer and sets the DMA channels for proper operation as shown in Figure 3-3. The Handshake sequence is shown in Figure 3-4, and the data transfer sequence is shown in Figure 3-5.

The starting location within the buffer is determined by bits 4 and 5 of non-disk commands. The RAM base address (D5=0, D4=0) points to the first location in the DMA buffer. The first eight locations of this buffer are used to store information regarding retry count, drive select, and cyclinder/sector/head select.

The data buffer address (D5=0, D4=1) points to the start of 512 data bytes within the buffer and begins at the ninth byte. The user pointer address (D5=1, D4=0) points to a location within the DMA buffer which may be loaded by the user to point to other buffer memory locations for data transfer or the start of user defined microcode. The actual location is the last two bytes of the 1K RAM used for the DMA buffer. The user pointer (D5=1, D4=1) is used to make indirect data transfers or jumps to microcode using the user pointer.

3.8.1 DMA Buffer Operation For Disk Write Transferring data to the DMA buffer and then performing disk write operations takes place as follows:

1. Send DMA write command O6 (Hex) to the AM-420 command register and perform a handshake.



Figure 3-4. Handshake Sequence

6



Figure 3-5. DMA Transfer Sequence

- 2. Send retry count to AM-420 DMA buffer (normally 8).
- 3. Send disk unit number (0-3) to DMA buffer (see note).
- 4. Write physical address plus two bytes of zeros (6 bytes total), sector, head, cylinder (2 bytes).
- 5. Send data (0-512 bytes) to DMA buffer.
- 6. Send disk write command 19 (Hex), or 99 (Hex) for interrupt, to AM-420 command register and perform a handshake.
- 7. Read AM-420 status register and check for zero condition indicating no error.
- 8. Continue with next command if no errors are detected.

NOTE: Disk unit number is sent as a radial select. i.e. Unit 0=0001 binary Unit 1=0010 binary Unit 2=0100 binary Unit 3=1000 binary

3.8.2 DMA Buffer Operation For Disk Read Transferring data from the disk into the DMA buffer and then reading the DMA buffer is performed as follows:

- 1. Send a DMA write command O6 (Hex) to the AM-420 command register and perform a handshake.
- 2. Write retry count into the DMA buffer.

- 3. Write disk unit number (0-3) into the DMA buffer.
- 4. Write physical address plus two bytes of zeros (six bytes total), sector, head, cylinder (2 bytes).
- 5. Write disk read command 15 (Hex), or 95 (Hex) for interrupt, to the AM-420 command register and perform a handshake.
- 6. Read AM-420 status register and check for zero condition indicating that no errors have occurred.
- 7. Assuming that no errors occurred during the disk read, send the DMA read command 12 (Hex), or 92 (Hex) for interrupts to the AM-420 command register and perform the normal handshake.
- 8. Read one byte of data from the DMA buffer and discard it (the first byte is always invalid data).
- 9. Read the valid data (1 to 512 bytes) from the DMA buffer.

#### 3.8.3 Physical Address

The term physical address refers to a four byte block pointing to the cylinder/sector/head within the drive. The user enters these four bytes in the following order:

- 1. Sector (1 byte)
- 2. Head (1 byte)
- 3. Cylinder (2 bytes)

A valid sector number is between zero and the maximum number of sectors around a disk track. A valid head number is between zero and the maximum number of heads in the drive. A valid cylinder number is a two byte number between zero and the maximum number of cylinders within a drive.

## 3.9 RESTORE COMMAND

The restore command is used to reset the disk logic and force the disk head to return to track zero. The user may force a restore command with a disk command 3 (Hex), or the microcode will exercise the restore command on its own following certain errors.

If a disk fault occurs, the microcode attempts one restore and then checks the fault status again. If the fault still exists, the microcode aborts the command operation and reports an error to the CPU.

#### 3.10 STATUS CHECK

The Read and Write Status check commands are used to access specific status information from the disk drive.

The Write Status check command is used to determine if the currently addressed disk is write protected. It does not attempt to actually write any data. If the addressed disk is write protected, error code ØB (Hex) is placed in the status register.

The Read Status check command (if SEEK bit 4 is on) seeks for the currently addressed track and then returns. Data is not read from the disk. If an error occurred, an error code is placed in the status register.

# 3.11 SPECIAL COMMANDS

The third class of commands are special feature commands. There are two types of these commands which will be discussed in paragraphs 3.11.1 and 3.11.2.

- 1. Read Microcode Revision Level This command will return the revision level of the microcode. This is a Type II Command.
- 2. Execute Internal RAM Test This command will execute an internal RAM Test. It takes about 5 seconds to run. This test is run at power up, but not at reset automatically. This is a Type II Command.
- 3. Sequence Up Drive Will sequence up the selected drive (Type I Command).
- 4. Sequence Down Drive Will sequence down the addressed drive (Type I Command).
- 5. Reset Drive Will reset fault on selected drive.
- 6. Read Drive Type Command Will return type of drive currently selected (Type II Command).
- 7. Read Drive Sector Size Will return number of bytes per sector on selected drive (Type II Command)
- 8. Read Current Cylinder Will return position of head on selected drive (Type II Command).
- 9. Read Drive Status Returns drive status on selected drive (Type II).

DWM-00420-00 REV. A00

3.11.1 Type I Commands Type I commands return no information.

3.11.2 Type II Commands Type II commands return information through both the Status Register and the on-board RAM Buffer.

A detailed listing of commands, their usage and how they return data is described in the following paragraphs.

3.11.2.1 Read Revision Level (OF hex)

- 1. Write a OF hex to command port.
- 2. Perform handshake sequence.
- 3. Write a 12 hex to command port.
- 4. Perform handshake.
- 5. Read one byte from the DMA buffer and discard (first byte is invalid data).
- 6. Read three ASCII characters from the DMA buffer. These will be the revision level of the Prom.

3.11.2.2 RAM Test (1F hex)

- Write command and perform handshake. It will take approximately 5-6 seconds for the RAM test and the completion of the handshake. If the test failed, a 4 hex will be returned in the status register at the end of the handshake. If no error, terminate.
- 2. If test fails write 12 hex to command port.

- 3. Perform handshake.
- 4. Read one byte from data port and discard.
- 5. The next four bytes contain:
  - a. Error address Lo.
  - b. Error address Hi.
  - c. Byte Written.
  - d. Byte read.
- 3.11.2.3 Sequence Up Drive (2F hex)
  - 1. Write a 6 hex to command port.
  - 2. Perform handshake.
  - 3. Write a zero to data port.
  - Write unit number to data port in a radial select fashion, i.e. Unit 0=01
  - 5. Write a 2F hex to command port.
  - 6. It is recommended that the drive status command be used to wait for the drive to become ready (see paragraph 3.1.2.9).

DWM-00420-00 REV. A00

3.11.2.4 Sequence Down Drive (3F hex)

1. Perform steps 1-4 as in Sequence Up Drive command.

2. Write a 3F hex to command port.

3. Perform handshake.

3.11.2.5 Reset Drive (4F hex)

1. Perform steps 1-4 as in Sequence Up Drive command.

2. Write a 4F hex to command port.

3. Perform handshake.

3.11.2.6 Read Drive ID (5F hex)

1. Perform steps 1-4 as in Sequence Up Drive command.

2. Write a 5F hex to command port.

3. Perform handshake.

4. Write a 12 hex to command port.

5. Perform handshake.

6. Read one byte from data port and discard.

7. Read byte from data port, this byte is the drive ID. Refer to the manual on the particular drive to determine the drive ID.

3.11.2.7 Read Drive Sector Size (6F hex)

- 1. Perform steps 1-4 as in Sequence Up Drive command.
- 2. Write a 6F hex to command port.
- 3. Perform steps 3-6 of Read Drive ID. command.
- 4. The next two bytes read from the data port are the number of bytes per sector stored at Low byte and High byte.

3.11.2.8 Read Current Cylinder (7F hex)

- 1. Perform steps 1-4 as in Sequence Up Drive command.
- 2. Write a 7F hex to command port.
- 3. Perform steps 3-6 as in Read Drive ID. command.
- 4. The next two bytes read from the data port are the current cylinder stored Low byte, High byte.

3.11.2.9 Read Drive Status (8F hex)

- 1. Perform steps 1-4 as in Sequence Up Drive command.
- 2. Write an 8F hex to command port.
- 3. Perform steps 3-6 as in Read Drive ID. command.

DWM-00420-00 REV. A00 3-17

4. Read drive status byte. Bits are as follows:

Bit O = Drive up to speed and ready

Bit 1 = Seek completed

Bit 2 = Seek fault

Bit 3 = Head on cylinder zero

Bit 4 = Drive processing command

Bit 5 = Drive unsafe condition

Bit 6 = Drive write protected

Bit 7 = Command received while busy

## SECTION IV

#### FUNCTIONAL THEORY OF OPERATION

# 4.0 INTRODUCTION

The AM-420 Disk Controller circuit board contains integrated circuit elements for the data processing necessary for the performance of the functions described in Sections I,II and III of this manual. This section describes the functional theory of operation of the circuit board and also provides information for each of the integrated circuit elements.

#### 4.1 CIRCUIT BOARD OPERATION

This circuit board provides control and interface capability between the S-100 bus and the PRIAM Winchester hard disk drive. The functional block diagrams of the circuit board are shown in Figures 4-1 and 4-2. The circuit board schematics, parts lists, and component cross reference lists are contained in Section VI of this manual. Table 4-1 contains a list of the signals used in these circuit boards with descriptions of their functions.





Figure 4-2. AM-420 Functional Block Diagram

Table 4-1. AM-420 Signals List

| SIGNAL           | NAME                 | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                                                                |
|------------------|----------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ABO-AB15         | Address Bus          |                         | 16 Bit Tri-state address bus. Provides<br>addressing for memory, data exchanges<br>and I/O device exchanges.                                                                               |
| BACK             | Bus Acknow-<br>ledge | SH1                     | CPU module output indicating that the<br>CPU module address bus, data bus, and<br>tri-state control bus signals have been<br>set to their high impedance state.                            |
| BOOT             | Bootstrap<br>Load    | SH1                     | Generated when the bootstrap program has<br>been selected. Enables the ROM, Address<br>Buffer and Input Data Register.                                                                     |
| BREQ             | Bus Request          | SH1                     | CPU module input requesting that the CPU<br>module set its address bus, data bus,<br>and tri-state control bus to the high<br>impedance state.                                             |
| BYTCLK<br>BYTCLK | Byte Clock           | SH3                     | Generated by the Byte Clock Counter at<br>the end of each byte of data written or<br>read. Used to control the Shift/ Load<br>of the write data shift register and<br>disk transfer logic. |

DWM-00420-00 REV. A00

4-4

~ ~

| Table 4-1 (Con't). | AM-420 Signals List |
|--------------------|---------------------|
|--------------------|---------------------|

| SIGNAL     | NAME          | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                             |
|------------|---------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <br>BYTENB | Byte Enable   | SH3                     | Byte clock counter output at the same<br>frequency as BYTCLK but twice the<br>duration. Used by the disk transfer<br>logic and disk data control logic. |
| CMDWRT     | Command Write | SH1                     | Output of the Command Decoder to clock<br>command data into the Write Command<br>Register and set up the initiate logic.                                |
| CRCERR     | CRC Error     | SH2                     | Output of the CRC checking module indicating an error in the data.                                                                                      |
| CRCLR      | CRC Clear     | SH2                     | Master reset input to the CRC checking module.                                                                                                          |

Table 4-1 (Con't). AM-420 Signals List

| SIGNAL | NAME                 | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                             |
|--------|----------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------|
| CSO    | Chip Select          | SH1                     | Output of the process select decoder and<br>is one of the signals that enables the<br>RAM.                              |
| CWEN   | Check Word<br>Enable | SH2                     | Generates the enable signal to the CRC<br>checker allowing the check word to be<br>generated and written onto the disk. |
| DATRD  | Data Read            | SH1                     | Command Decoder output to enable the<br>Input Data Register and to generate<br>S-100 transfer signals.                  |
| DATWRT | Data Write           | SH1                     | Command Decoder output to enable the<br>Output Data Register and to generate<br>S-100 transfer signals.                 |
| DENB   | DMA Enable           | SH2                     | Provides clock input to the DMA Address<br>Generator modules. DMA enable begins<br>each cycle of the DMA.               |

|           | , ,      |        |         |                 |
|-----------|----------|--------|---------|-----------------|
| Table 4-1 | (Con't). | AM-420 | Signals | $\mathtt{List}$ |

| SIGNAL            | NAME                 | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                                         |
|-------------------|----------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMASEL DMA Select |                      | SH1                     | Output of the process select decoder to<br>enable the selected DMA address<br>generator. Used to write data into or<br>read data from the DMA address<br>generator. |
| DMAX<br>DMAX      | DMA Access<br>Grant  | · SH2                   | Indicates that the on-board CPU is off<br>the busses and that control of those<br>busses may now pass to the DMA logic.                                             |
| DISK              | Disk Command         |                         | Output of the Command Register to set up<br>a disk operation with DMA Access Grant<br>signal.                                                                       |
| DONE              | Process<br>Command   | SH2                     | Output of the DMA Address Generator<br>indicating completion of the current<br>operation.                                                                           |
| DO-D7             | Data Bus<br>Bits 0-7 | SH1                     | Internal eight-bit tri-state data bus.                                                                                                                              |

•

| SIGNAL           | NAME         | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                                |
|------------------|--------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GO<br>           | Go           | SH2                     | Start command output from Command<br>Register. Initiates the transfer of bus<br>control from the on-board CPU to the DMA<br>logic.                         |
| GODSK            | Go Disk      | SH2                     | Initiates disk operations under DMA<br>logic control.                                                                                                      |
| IDXSEC<br>IDXSEC | Sector Reset | SH3                     | Reset command to byte clock counter to reset count to beginning of each sector.                                                                            |
| INDEX            | Disk Index   | SH3                     | Index pulse from disk drive. Occurs<br>once per revolution of the disk to<br>define the beginning of sector zero.                                          |
| INIT<br>INIT     | Initialize   | SH1                     | Internal reset signal generated from S-100 bus PRESET signal.                                                                                              |
| IOSEL            | I/O Select   | SH1                     | Generated from either Read or Write<br>output from the CPU microprocessor when<br>address lines A14 and A15 from the<br>internal address bus are both one. |

# Table 4-1 (Con't). AM-420 Signals List

Table 4-1 (Con't). AM-420 Signals List

| SIGNAL        | NAME                 | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                          |
|---------------|----------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| IO, I1        | Instruction<br>Codes | SH2                     | Instruction code inputs to the DMA<br>Address Generator from the Command<br>Register.                                                |
| I2LO,<br>I2HI | Instruction<br>Codes | SH2                     | Instruction code to either the upper<br>eight bits or lower eight bits of the<br>DMA Address generator from the command<br>register. |
| JAMG          | Preset Six           | SH3                     | Presets byte clock counter to a count of six to synchronize the read timing.                                                         |
| KILL          | Terminate            | SH2                     | Terminates the operation in process.                                                                                                 |
| MEMEN         | Memory Enable        | SH2                     | Enables the RAM for read or write operations.                                                                                        |
| MEMWR         | Memory Write         | SH2                     | Controls read or write operations of the RAM. Low = write, High = read.                                                              |
| OG            | Output Gate          | SH2                     | Allows transfer of data into or out of<br>the disk drive.                                                                            |

| Table | 4- | 1 (( | Con' | t). | AM-420 | Signals | List |
|-------|----|------|------|-----|--------|---------|------|
|       |    |      |      |     |        |         |      |
|       |    |      |      |     |        |         |      |

| SIGNAL     | NAME                  | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                        |
|------------|-----------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| RDATA      | Read Data             | SH3                     | The data recovered from the disk in NRZ form.                                                                                      |
| RDDATA STB | Read Data<br>Strobe   | SH2                     | Generated by the Disk Data Control logic<br>to transfer a byte of read data from the<br>buffer register to the data bus DBO-DB7.   |
| RDGATE     | Read Transfer<br>Gate | SH3                     | Instructs the disk drive to gate the<br>read data onto the interface. It occurs<br>for any disk transfer cycle (read or<br>write). |
| RDGT       | Read Gate             | SH2                     | Same as RDGATE but only during a read disk transfer (gated by $\overline{RD}/WR$ ).                                                |
| RD/WR      | Read/Write            | SH4                     | Generated from bit 4 of command word to<br>set either disk Read or Write<br>processing.                                            |
| RDO-RD3    | Read O -<br>Read 3    | SH1                     | Read select outputs from the Read/Write<br>decoder to enable read operations.                                                      |

Table 4-1 (Con't). AM-420 Signals List

| SIGNAL         | NAME                    | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                                                                      |
|----------------|-------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ROMSEL         | ROM Select              | SH1                     | Generates the output enable of the ROM.                                                                                                                                                          |
| RX1            | Output Data<br>Transfer | SH2                     | Output from the S-100 bus Transfer logic<br>to transfer data from the Output Data<br>Register to the Internal data bus DBO-<br>DB7 (logical OR of RD1 and the read<br>pulse from the DMA logic). |
| SA11           | S-100 Address<br>Bit 11 | SH1                     | Buffered S-100 address bit 11.                                                                                                                                                                   |
| SDREQ<br>SDREQ | S-100 Data<br>Request   | SH2                     | Generated from DATWRT or DATRD for S-100<br>bus data transfers.                                                                                                                                  |
| SECEQU         | Sector Equal            | SH3                     | Pulse output of the Sector Counter and<br>Control logic when the sector counter is<br>equal to the sector latch indicating<br>that the requested sector is under the<br>read/write head.         |

| SIGNAL | NAME              | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                   |
|--------|-------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| SECTOR | Sector Pulse      | SH3                     | Sector pulse that occurs at the<br>beginning of each disk sector except<br>sector zero which is marked by the INDEX<br>pulse. |
| SELCLK | Selected<br>Clock | SH3                     | Data Clock                                                                                                                    |
| SELDAT | Selected          | SH3                     | Either read data or write data depending on state of read/write command.                                                      |
| STATIN | Status In         | SH1                     | Output of the command decoder to enable<br>the Status Register.                                                               |
| S100   | S-100 Select      | SH2                     | Command Register output to enable an<br>S-100 bus data transfer.                                                              |
| WR     | Write             | SH1                     | Generated from on-board CPU Write (ZWR)<br>signal.                                                                            |
| WRDATA | Write Data        | SH3                     | Serial write data from the shift register into the CRC generator.                                                             |

DWM-00420-00 REV. A00

| SIGNAL     | NAME                     | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                         |
|------------|--------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| WRDATA STB | Write Data<br>Strobe     | SH2                     | Generated by the Disk Data Control logic<br>to clock the write data from the data<br>bus DBO-DB7 into the write buffer<br>register. |
| WRGT       | Write Trans-<br>fer Gate | SH2                     | Instructs the drive to write data onto<br>the selected surface. It occurs for<br>both read and write disk transfer<br>cycles.       |
| WRITE GATE | Write Gate               | SH3                     | Same as WRGATE but only during a write disk transfer (gated by $\overline{\text{RD}}/\text{WR}$ ).                                  |
| WRITE DATA | Disk Write<br>Data       | SH3                     | Disk write data from the CRC checker<br>logic applied to the write data drivers.                                                    |
| WRRD       | Write-Read               | SH1                     | Read pulse or write pulse from the on-board CPU.                                                                                    |

# Table 4-1 (Con't). AM-420 Signals List

| SIGNAL             | NAME                           | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                                                                                                                                   |
|--------------------|--------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WRO-WR3<br>WRD-WRF | WriteO-Write3<br>WriteD-WriteF | SH1                     | Write select outputs from the Read/Write<br>decoder that enable write operations to<br>selected latches.                                                      |
| WX1                | Write 1                        | SH2                     | The logical OR of WR1 and the write pulse from the DMA logic.                                                                                                 |
| XFER               | Transfer                       | SH2                     | Generated from DMAX and S-100 to strobe<br>the S-100 Transfer Logic to transfer<br>data from the Input and Output Data<br>Registers to the internal data bus. |
| X512               | Times 512                      | SH1                     | Used by the DMA logic to indicate when<br>all data has been written or read and<br>that CRC data is next.                                                     |
| ZWR                | CPU Write                      | SH1                     | Indicates that the CPU Module holds<br>valid data to be stored in the addressed<br>memory.                                                                    |

DWM-00420-00 REV. A00

| Table 4- | 1 (Con't | ). AM-42 | 20 Signals | s List |
|----------|----------|----------|------------|--------|
|----------|----------|----------|------------|--------|

| SIGNAL | NAME                | SCHEM PAGE<br>OF SOURCE | DESCRIPTION                                              |
|--------|---------------------|-------------------------|----------------------------------------------------------|
| 4 MHZ  | 4 MHz Clock         | SH1                     | 4 MHz clock from oscillator U9.                          |
| 02ENB  | S-100 Trans-<br>fer | SH2                     | Clock signal for every cycle of the S-100 data transfer. |

The major processing components of this board are the CPU microprocessor (U11) and the DMA Address Generator (U10 and U21). The ROM (U31) contains the bootstrap load routine and also contains the microcode necessary for operation of the microprocessors.

#### 4.1.1 Power-Up Reset

On initial power-up, the circuit board is in a dormant state waiting for initialization. The PRESET signal from the S-100 bus sets the INIT flip-flop U14 to activate the PHANTOM signal to disable any main memory under phantom control and to enable the bootstrap gate. INIT generally resets logic on the circuit board to initial conditions.

#### 4.1.2 Addressing

Address data is received from the S-100 bus on address lines ADO-AD15. This address data is transferred to the internal address bus during boot loading for use by the controllers and memories within the circuit board and is also used for direct addressing of the circuit board. Buffers on U28 and U36 gate the addresses to the internal bus when enabled by bootstrap signal BOOT.

Address lines AD2-AD7 are wired directly to comparator U27 for circuit board addressing. The other inputs come from circuit board etch or jumper wires to either +5V pull-ups or ground to produce the desired address. The output of the comparator U27 is asserted when the data from the address lines compare with the address of the AM-420. This generates read and write signals from decoder U26. The address in etch is C4 (Hex) and other addresses can be selected as described in Section II.

## 4.1.3 CPU Output

CPU output data is transmitted to the AM-420 for circuit board control and data transfer by the S-100 bus data and control lines. Data is received by the AM-420, by the Output Data Register U37, and the Write Command Register U38. The Input to these data registers comes from the S-100 bus data lines D00-D07 and the output, when enabled, goes to internal data bus DB0-DB7.

# 4.1.3.1 Command Data

Data from the S-100 bus data lines is clocked into the Write Command Register by Command Write signal CMDWRT from the Command Decoder U26. This takes place when address lines ADO and AD1 are zero and I/Ooutput signal SOUT from the S-100 bus is asserted. Signal CMDWRT also resets the INIT flip-flop U14 and resets the initiate logic.

When the CPU microprocessor issues a write command (ZWR) and address lines AB14 and AB15 from the internal address bus are both one, IOSEL is asserted to enable the Read/Write decoder U25. Signal ZWR is also applied to buffer U28 to generate WR which is an input to the Read/Write decoder. When address bits ABO and AB1 from the internal bus are zero, the RDO output from the Read/Write decoder transfers the contents of the write command register to the internal data bus.

#### 4.1.3.2 Command Types

The non-disk commands issued to the AM-420 are used for control and operation of the logic internal to the circuit board. The bit functions are listed in Table 4-2 and the commands are listed in Table 4-3. Disk Commands are used to control the disk drive and access status information from the drive. Disk command bit functions are listed in Table 4-4, and disk command codes are listed in Table 4-5.

# Table 4-2. Non-Disk Command Bits

| ·      | * • •      |                                                                     |                  |                  |                                                                               |  |  |
|--------|------------|---------------------------------------------------------------------|------------------|------------------|-------------------------------------------------------------------------------|--|--|
| BIT    | NAME       |                                                                     |                  |                  | FUNCTION                                                                      |  |  |
| 0<br>1 | 0<br>1     |                                                                     |                  |                  | ates non-disk command<br>ity Bit.                                             |  |  |
| 2      | R/W        | Read/Write O=read (AM-420 to CPU),<br>1= write (CPU to AM-420).     |                  |                  |                                                                               |  |  |
| 3      | FN         | Command Function O=transfer 1=execute                               |                  |                  |                                                                               |  |  |
| 4<br>5 | BUF<br>DMA | Location in DMA buffer where data is to<br>be retrieved or stored.* |                  |                  |                                                                               |  |  |
| 6      | CLR        | Clear current interrupt O=nop 1=clear                               |                  |                  |                                                                               |  |  |
| 7      | IE         | Interrupt Enable O=disable 1=enable                                 |                  |                  |                                                                               |  |  |
|        |            | *                                                                   | В                | it               | Location                                                                      |  |  |
|        |            |                                                                     | 5                | 4                |                                                                               |  |  |
|        |            |                                                                     | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | RAM Base (Direct)<br>Data Buffer<br>User Pointer<br>@ User Pointer (Indirect) |  |  |
|        |            |                                                                     |                  |                  |                                                                               |  |  |

| BITS                                                    |                                                                                                         |
|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| 7 6 5 4 3 2 1 0                                         | FUNCTION                                                                                                |
| 0 0 0 0 0 0 0 0 0<br>X X 0 0 0 1 1 0<br>X X 0 1 0 1 1 0 | Initialization/Boot Load<br>Write data to DMA buffer (RAM Base)<br>Write data to DMA buffer (Data Base) |
| X X O O O O 1 O<br>X X O 1 O O 1 O                      | Read data from DMA buffer (RAM Base)<br>Read data from DMA buffer (Data Base)                           |
| 0 1 0 0 0 0 0 0<br>X 1 X X X X 1 0                      | Clear Interrupt (Clear Only)<br>Clear Interrupt (plus some other non-<br>disk command)                  |
| X X 1 0 0 1 1 0                                         | Write user microcode pointer                                                                            |
| X X 1 1 0 1 1 0                                         | Indirect load via user pointer                                                                          |
| X X 1 1 1 0 1 0                                         | Execute from users microcode pointer                                                                    |
| X X 1 1 0 0 1 0                                         | Indirect read via user pointer                                                                          |
| X X 1 0 0 0 1 0                                         | Read user microcode pointer                                                                             |

# Table 4-3. Non-Disk Command Formats

| BIT    | NAME | FUNCTION                                                           |
|--------|------|--------------------------------------------------------------------|
| 0      | DSK  | Always 1 for disk type commands.                                   |
| 1<br>2 |      | Command function comprised of bits 1, 2, and 3 taken as a whole. * |
| 3      | R/W* | O=read 1=write                                                     |
| 4      | SK   | Seek                                                               |
| 5      | -    | Not used                                                           |
| 6      | -    | Not used                                                           |
| 7      | IE   | Interrupt enable O=disable 1=enable                                |

\* See Table 4-5

DWM-00420-00 REV. A00

|     | BITS |   |                          |
|-----|------|---|--------------------------|
| 3   | 2    | 1 | FUNCTION                 |
| R/W |      |   |                          |
| 0   | 0    | 0 | Read Status Check        |
| 0   | 0    | 1 | Restore to Cylinder Zero |
| 0   | 1    | 0 | Read Record              |
| 0   | 1    | 1 | Read Record              |
| 1   | 0    | 0 | Write Record             |
| 1   | 0    | 1 | Write Status Check       |

#### 4.1.3.3 Output Data

The output data from the CPU to the AM-420 transfers from the S-100 bus data lines to the internal data bus through the Output Data Register U37. The input to the Output Data Register comes from the S-100 bus data lines DOO-DO7; and the output, when enabled, goes to the internal AM-420 data bus DBO-DB7.

Data from the S-100 bus data lines is clocked into the Output Data Register by data write signal DATWRT. This is generated by the Command Decoder when the board is addressed and address lines ADO=1 and AD1=0 and I/O output signals SOUT and PWR from the S-100 bus are asserted. Signal DATWRT also sets flip-flops in the S-100 transfer logic to generate  $\overline{\text{RX1}}$  to transfer the data from the Output Data Register to the internal bus during internal S-100 type DMA cycles.

#### 4.1.4 CPU Input

CPU input data is transmitted from the AM-420 by the S-100 bus data and control lines. It is transmitted from the AM-420 by the Status Register (U40) and the Input Data Register (U39).

# 4.1.4.1 Status Register

The Status Register is used to determine the current status of AM-420 board operations and to indicate disk drive faults. The input to the Status Register comes from the internal data bus DBO-DB7; and the output, when enabled, goes to the S-100 bus data lines DIO-DI7.

Data from the internal data bus is clocked into the Status Register by signal WRO from the Read/Write Decoder (U25). This occurs when the lines ADO, AD1, and WR are all low. The contents of the Status Register are transferred to the S-100 bus data lines by the STATIN signal from the Command Decoder. This signal is issued when ABO=0 AB1=0, PDBIN is true (high) and  $\overline{PWR}$  is false (high).

#### 4.1.4.2 Status Word Formats

Status words contain information regarding the operation of the AM-420 board and associated disk drives. Status word information and formats are contained in Figure 4-3. Bit 7 is the Command Received (CR) bit (1=Received, O=Cleared).

When the status word is received by the CPU, the data is checked for any of the four codes shown at the top of Figure 4-3. If the disk error code is found, the disk error status is accessed from the data register. Bit definitions for disk faults are shown in Figure 4-3.

## 4.1.4.3 Input Data Register

The Input Data Register (U39) controls the transfer of data from the internal data bus to the S-100 bus data lines. The inputs to this register come from internal data bus DBO-DB7 and the output, when enabled, goes to the S-100 bus data lines DIO-DI7.

Data from the internal bus is clocked into the register when either INIT or WX1 are True. Signal INIT controls the register during a boot data transfer and Write Transfer 1 ( $\overline{WX1}$ ) signal comes from the S-100 Signal WX1 is generated in the same way as RX1 transfer logic. bus described in paragraph 4.1.3.3 except RD/WR input to the S-100 bus transfer is in the Write state. Data is placed on the S-100 bus data lines when in the bootstrap mode by BOOT or by the DATRD output of the Command decoder. Signal DATRD is issued when the board is addressed ADO=1, AD1=0, Read Enable PDBIN is true (high) and Write Strobe and PWR is false (high).

# 4.1.5 Boot Load Procedure

The AM-420 contains a bootstrap load routine stored in the ROM on U31. The microcode for internal AM-420 microprocessor operation is also contained in the first 1K of ROM memory. The bootstrap program is contained in the second 1K of ROM memory.

NOTE: If the user code is changed from the current boot routine, the microcode in the first 1K of memory must be duplicated exactly.

| BIT |   |   |   |   |   |   |   | FUNCTION                                     |
|-----|---|---|---|---|---|---|---|----------------------------------------------|
| 7*  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                              |
| CR  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Status OK - Function Complete                |
| CR  | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Drive Sequencing Up - Power Up Only          |
| CR  | 0 | 0 | 0 | 0 | 0 | 1 | 1 | Special Command Error - Illegal Spec Command |
| CR  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | RAM Test Error                               |
| CR  | 0 | 0 | 0 | 0 | 1 | 0 | 1 | Disk Not Ready                               |
| CR  | 0 | 0 | 0 | 1 | 0 | 1 | 1 | Write Protected                              |
| CR  | 0 | 0 | 0 | 1 | 1 | 1 | 1 | Disk Error - See Below                       |
| CR  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | CRC Error                                    |

\* CR = Command Received, O = Cleared, 1 = Received

DATA REGISTER BITS FOR DISK FAULTS

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| CRJ | WPR | FLT | BSY | UNK | SKF | UNK | RDY |

| CRJ – COMMAND REJECT  | <ul> <li>A COMMAND WAS SENT TO THE DRIVE WHILE<br/>IT WAS ALREADY PROCESSING ONE</li> </ul> |
|-----------------------|---------------------------------------------------------------------------------------------|
| WPR - WRITE PROTECT   | - DRIVE IS WRITE PROTECTED                                                                  |
| FLT – DRIVE FAULT     | – DRIVE FAULT                                                                               |
| BSY - DRIVE BUSY      | - DRIVE IS BUSY PROCESSING COMMAND                                                          |
| SKF – SEEK FAULT      | - A DRIVE SEEK COMMAND CAUSED AN ERROR                                                      |
| RDY – 3-5 DRIVE READY | - DRIVE IS READY                                                                            |
| UNK – UNKNOWN         | BITS MAY BE IN ANY STATE                                                                    |
|                       |                                                                                             |

100

Figure 4-3. Status Word Formats

DWM-00420-00 REV. A00

The CPU reads the bootstrap load program by addressing the AM-420 board and reading from F400 (Hex) up. This address, combined with SMEMR from the S-100 bus and a high INIT signal which takes place on initial start-up, generates the BOOT signal. If the optional jumper is in the NO BOOT position, one input to the BOOT AND gate is connected to ground, disabling the bootstrap feature.

The BOOT signal enables the ROM (U31), the Address Buffer (U28 and U36), and the Input Data Register (U39). The INIT signal enables the clock input to the Input Data Register and since it is a transparent latch type register, the bootstrap program transfers from the ROM to the system.

# 4.1.6 Interrupts

The interrupt mode can be selected for AM-420 board operation when the software program sets bit 7 in either disk or non-disk commands. When the interrupt mode is selected, the interrupt occurs at the completion of the current AM-420 command. This is taken from the internal data bus by the command register (U35) and connected to the S-100 bus vectored interrupt lines. Any one of the seven interrupt lines  $(\overline{\text{VIO}-\text{VI7}})$  may be selected by a jumper as shown in Section II.

The interrupt mode may be cleared by the software program so that the interrupts do not occur. The program clears the interrupt mode by setting bit 6 in any non-disk command to a one (see Table 4-2).

## 4.1.7 Byte Clock Counter

The byte clock counter controls the shift registers for serial-to-parallel and parallel-to-serial conversion of read and write operations respectively. It consists of a counter on U74 with associated select and gating logic.

Signal RD/WR selects the necessary clocks and data for either read or write disk operations. During read operations, flip-flops on U62 detect the first bit (sentinel) and presets the byte counter (U74) to a count of 6 ( $\overline{JAM6}$ ). This counter then counts the selected clock pulses until a full byte is loaded into shift register U66. The counter output is gated (count 7) to generate the clock to load the shift register data into buffer register U78 for transfer through the internal data bus to the RAM. Write operations are similar except the counter output  $\overrightarrow{\text{BYTCLK}}$  controls the shift/load control to write shift register U67.

#### 4.1.8 Disk Transfer Logic

The disk transfer logic consists of a ROM (U33), a counter to sequence the ROM (U23 and U24), an input MUX (U13) and a D flip-flop register to buffer the ROM output (U32). This logic is common to both disk read and disk write, DMA transfer operations.

Signal BYTENB, that occurs once for each byte of data transferred, provides the clock input to the ROM sequence counter. Sequencing the ROM through its program controls the transfer of data from the disk to RAM and RAM to disk.

# 4.1.9 Sector Counter

The sector counter logic enables the controller to read or write data in a specific sector on the selected disk. Signal WRE clocks the data from the data bus DBO-DE7 into register U80. At the disk index, signal INDEX resets counter U56,U57 to FF and it then counts disk sector pulses (SECTOR) and provides its counter output to comparator U68. The other input to the comparator is the selected sector number stored in register U80. When the sector count equals the selected count, the compare output of the comparator generates sector equal signal (SECEQU) to the disk transfer logic.

# 4.1.10 Data Write Logic

The data write logic provides the clock and data outputs necessary for the disk drive write circuitry. Serial write data (WRDAT), from the write shift register U67 is sent to the CRC logic (U15) for error checking. For a description of the operation of the CRC module, see paragraph 4.2.3.

The selected clock and selected data (SELCLK) and SELDAT) provide the data and clock inputs to the CRC module. The output of the CRC logic is WRITE DATA that is applied to driver U49 to operate the selected write head. The SELCLK is applied to a delay to compensate for the propagation delays inherent in the write data path. The clock is then applied to driver U49 in the same manner as the write data for operation of the selected disk drive.

## 4.1.10.1 Disk Drive Controls

The CONTROL/STATUS informations are bidirectional through the data bus DBO-DB7 via U64. The direction of the data flow is controlled by the control decoder from address bits ABO-AB3 and IOSEL. The unit and head select data are also taken from the data bus and stored in the buffer U76 and U77.

# 4.1.11 Input From Disk Drive

Read data and clocks are received from the selected drive through line receiver U50. Serial READ DATA and READ CLK are applied to shift register for serial-to-parallel conversion. The data is then clocked into the register (U78) at the end of each 8-bit byte by BYTCLK. The read data strobe RDATASTB transfers that byte of data to the data bus DBO-DB7 and into the RAM (U41 and U42).

# 4.1.12 AM-420 Board Operations and Timing

The following paragraphs describe the timing and sequence of operations of the AM-420 board. The numbers in parentheses refer to the numbers on the associated timing diagram.

# 4.1.12.1 Data Transfer Operations

The system CPU issues a command to the AM-420 to perform a data transfer type of operation (data to or from the disk, or data to or from the S-100 bus). The on-board CPU sets up the board for the kind of transfer requested (disk or S-100), sets the direction of transfer (read data into the board or write data out from the board) via the  $\overline{\text{RD}}/\text{WR}$  bit, and sets up the DMA chips with their required address and word counts. The CPU then issues a GO command as shown in Figure 4-4.



Figure 4-4. Data Transfer Timing

When the GO line goes high, it sets flip-flop U5, which causes  $\overline{\text{BREQ}}$  to be asserted (1). When  $\overline{\text{BREQ}}$  (Bus Request) is asserted, the on-board CPU will, at its earliest convenience, take itself off the data and address busses and issue a  $\overline{\text{BACK}}$  (Bus Acknowledge) signal (2). Since  $\overline{\text{BACK}}$  indicates that the on-board CPU is tri-stated, the DMA circuitry can now use the data and address busses. The DMA circuit then does its job of transferring the data. When the last byte of data is transferred, a DONE signal is issued by the DMA logic. The issuance of DONE causes  $\overline{\text{BREQ}}$  to drop (3), thereby allowing the on-board CPU to reactivate itself (4), which then shuts off the GO signal (5).

# 4.1.12.2 Disk Transfer Operations

When the AM-420 has been issued a disk transfer command (read or write a sector), the on-board CPU checks the disk drive for error conditions and, if possible, corrects the condition. If no error exists, or it is corrected, the on-board CPU issues a GODSK command, as shown in Figure 4-5. (GODSK is the logical AND of signals GO, DISK and the CPU being tri-state, DMAX). GODSK causes the micro-engine (U13, U23, U24, U32, U33) to start up. The micro-engine then waits for the SECEQU (Sector Equals Requested Count) pulse. At this point. themicro-engine begins its sector format function, which causes the timing signals RDGATE, WRGATE, OG, CRCLR, CWEN (Read Gate, Write Gate, Output Gate, CRC Clear, Check Word Enable) to be issued at the appropriate time. The micro-engine is sequenced by the BYTCLK/BYTENB (Byte Clock, Byte Enable) signals, which are derived from the drive clock.



Figure 4-5. Disk Transfer Timing

## 4.1.12.3 Disk Read Clocks

The BYTCLK, BYTENB timing, as shown in Figure 4-6, is based on the signal READ CLOCK, which is received from the drive. Both BYTCLK and BYTENB are derived from a counter U74. The counter counts at the rising edge of SELCLK. When this count equals 7, BYTCLK is issued; When equal to 2 and 3, BYTEN is issued. When the count equals 0 (the next state) BYTCLK is dropped; when equal to 4, BYTEN is dropped. BYTENB is twice as long as BYTCLK. BYTCLK indicates when the last bit of a byte has been read or written.





4.1.12.4 Disk Write Clocks

The SERVO CLOCK from the drive is delayed and then transmitted as the WRITE CLOCK to the drive. The delay is set to equal the propagation delay of the CRC circuit. The WRITE CLOCK signal and the WRITE DATA signal must have the relationship shown in Figure 4-7. The trailing edge of WRITE CLOCK must occur in the middle of the data cell of both the WRDATA and the CRC check word.



Figure 4-7. Disk Write Timing

4.1.12.5 Sector Beginning Format Operations

This timing shows in greater detail (see Figure 4-8) the relationship between the various sector format signals, as created by themicro-engine, at the beginning of the sector. Note that the micro-engine has no idea of the direction of transfer, and therefore issues timing signals for both the read and write transfers. When the sector counter equals the requested sector number, a SECEQU (Sector Equal) pulse is issued. At the next byte, the WRGATE (Write Gate) signal goes high and the CRCLR (CRC Clear) signal is dropped. One byte later the RDGATE (Read Gate) signal goes high. Twelve bytes after read gate, OG (Output Gate) is raised. This signal enables the transfer of data to/from the RAM. After OG is asserted, if it is a write operation, a "sentinel" bit is written; if it is a read, the BYTCLK is disabled until the sentinel bit is detected. The



Figure 4-8. Sector Beginning Timing

sentinel bit is the indicator of the physical beginning of the sector. It is written out on the twelfth byte so that during a read, when the absolute timing from the sector pulse to the first bit of data is not known, the data bit cells can be synchronized. This means that the sentinel bit is written so that during a read the byte is synchronized such that bit O is interpreted as bit O and not as any other bit.

#### 4.1.12.6 Sector End Format Operations

This timing shows (see Figure 4-9) in greater detail the relationship between the sector format signals at the end of a sector. After 512 bytes of data have been transferred into RAM (one per BYTCLK/BYTENB) (Check Word Enable) signal goes high causing the CRC the CWEN generator to output the current check word if a write is occurring. signal is ignored and the check word is During a read. the CWEN entered into the serial data stream to be checked by the CRC chip. At the end of this time the CRC generator will issue a CRCERR (CRC Error) signal if an error in receiving occurred. A tranmsit CRC is error impossible. OG (Output Gate) drops at the end of the CRC field, shutting off further data transfers to RAM. RDGATE (Read Gate) is dropped after OG to insure that no glitches enter into the serial data stream, and WRGATE (Write Gate) drops several bytes later to insure



Figure 4-9. Sector End Format Timing

to insure that the data stream after the CRC check word is zero. A short while later, the next sector pulse, defining the next sector occurs and SECEQU also drops. The DONE signal will have occurred coincident with the falling edge of OG causing the DMA cycle to end and return bus control back to the on-board CPU.

#### 4.1.12.7 DMA Transfer Operations

The whole process of transferring data to or from the RAM, to or from the board, is done as a DMA cycle. The CPU sets up the board for the sets the DMA address and word counts, sets the read/write transfer. bit for transfer into or out of the AM-420, and then sets the GO bit and either the DISK bit or the S-100 bit. These three bits, (DIS, S-100 and  $\overline{RD}/WR$ ) cause the DMA cycle to follow the correct path. The IC's U18 and U19 steer the DMA logic to provide the requested transfer. U18 is used for a disk type transfer, while U19 is used for the S-100 type transfer. For any of the four types of transfers, RAM to S-100, S-100 to RAM, RAM to disk, or disk to RAM, the process is to set the three bits in the registers  $(\overline{RD}/WR, DISK, or S-100)$  and issue a GO command. The DMA hardware takes care of the rest of the Each byte is transferred into or out of RAM via one of two process. signals: BYTENB or O2ENB (phase 2 Enable). BYTENB is used for a

disk type transfer, and O2ENB is used for the S-100 type transfers. Each signal was designed to be no less than 200ns, or the access time of the RAMs. To this end the signal O2ENB is one whole cycle of the 4MHz master clock. When the system CPU reads from or writes to the AM-420 data ports, a DATRD (Data Read) or DATWRT (Data Write) pulse occurs. These signals are OR'ed to cause a SDREQ (S-100 DMA Request) which forces JK flip-flop U17 to toggle, creating O2ENB.



Figure 4-10. DMA Transfer Timing

#### 4.2 CIRCUIT MODULE DESCRIPTION

This section describes the operation of the individual circuit packages (DIPS) contained on the AM-420 circuit board. Most of the processing is handled by the CPU and DMA address generator modules, so these are described in detail. The control logic and interface modules are also described with logic and connection diagrams for each one.

#### 4.2.1 CPU Microprocessor (U11).

The CPU microprocessor is a single DIP module that handles the data processing of the AM-420 circuit board.

Figure 4-11 is a block diagram of the CPU, and Figure 4-12 details the internal register configuration which contains 208 bits of Read/Write memory that are accessible to the programmer. The registers include two sets of six general purpose registers that may be used individually as 8-bit registers or as 16-bit register pairs.



Figure 4-11. CPU Block Diagram



Figure 4-12. CPU Registers

Figure 4-13 shows the CPU pin in figuration and Table 4-6 contains a list of the CPU signals.



Figure 4-13. CPU Pin Configuration

DWM-00420-00 REV. A00

| SIGNAL                       | PIN | FUNCTION                                                                                                                                                                                                                                                                                                                                |
|------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AO-15<br>ADDRESS BUS         |     | Tri-state output, active high.<br>AO-A15 constitute a 16-bit address<br>bus. The address bus provides th<br>address for memory (up to 64K<br>bytes) data exchanges and for I/0<br>device data exchanges.                                                                                                                                |
| DO-D7<br>DATA BUS            |     | Tri-state input/output, active<br>high. DO-D7 constitute an 8-bit<br>bidirectional data bus. The data<br>bus is used for data exchanges<br>with memory and I/O devices.                                                                                                                                                                 |
| M1<br>MACHINE CYCLE ONE      | 27  | Output, active low. M1 indicates<br>that the current machine cycle is<br>the OP code fetch cycle of an<br>instruction execution.                                                                                                                                                                                                        |
| MREQ<br>MEMORY REQUEST       | 19  | Tri-state output, active low. T<br>memory request signal indicates<br>that the address bus holds a val<br>address for a memory read or<br>memory write operation.                                                                                                                                                                       |
| IORQ<br>INPUT/OUTPUT REQUEST | 20  | Tri-state output, active low. T<br>$\overline{IORQ}$ signal indicates that the<br>lower half of the address bus ho<br>a valid I/O address for an I/O r<br>or write operation. An IORQ sig<br>is also generated when an interr<br>is being acknowledged to indicat<br>that an interrupt response vecto<br>can be placed on the data bus. |

## Table 4-6 (Con't). CPU Signal List

| SIGNAL             | PIN | FUNCTION                                                                                                                                                                                                                                                                                                        |
|--------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RD<br>MEMORY READ  | 21  | Tri-state output, active low. $\overline{\text{RD}}$<br>indicates that the CPU wants to<br>read data from memory or an I/O<br>device. The addressed I/O device<br>or memory should use this signal<br>to gate data onto the CPU data<br>bus.                                                                    |
| WR<br>MEMORY WRITE | 22  | Tri-state output, active low. WR indicates that the CPU data bus holds valid data to be stored in the addressed memory or $I/O$ device.                                                                                                                                                                         |
| RFSH<br>REFRESH    | 28  | Output, active low. RFSH<br>indicates that the lower 7 bits of<br>the address bus contain a refresh<br>address for dynamic memories and<br>the current MREQ signal should be<br>used to do a refresh read to all<br>dynamic memories.                                                                           |
| HALT<br>HALT STATE | 18  | Output, active low. HALT indi-<br>cates that the CPU has executed a<br>HALT software instruction and is<br>awaiting either a nonmaskable or<br>a maskable interrupt (with the<br>mask enabled) before operation can<br>resume. While halted, the CPU-<br>executes NOP's to maintain memory<br>refresh activity. |

Table 4-6 (Con't). CPU Signal List

| SIGNAL                           | PIN | FUNCTION                                                                                                                                                                                                                                                                                                               |
|----------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT<br>WAIT                     | 24  | Input, active low. WAIT indicates<br>to the CPU that the addressed me-<br>mory or I/O devices are not ready<br>for a data transfer. The CPU con-<br>tinues to enter wait states for<br>as long as this signal is active.                                                                                               |
| INT<br>INTERRUPT REQUEST         | 16  | Input, active low. The Interrupt<br>Request signal is generated by I/O<br>devices. A request will be<br>honored at the end of the current<br>instruction if the internal soft-<br>ware controlled interrupt enable<br>flip-flop (IFF) is enabled.                                                                      |
| NMI<br>NON MASKABLE<br>INTERRUPT | 17  | Input, active low. The non-mask-<br>able interrupt request line has a<br>higher priority than INT and is<br>always recognized at the end of<br>the status of the interrupt enable<br>flip-flop. NMI automatically<br>forces the CPU to restart to loca-<br>tion 0066H.                                                 |
| RESET                            | 26  | Input, active low. RESET initial-<br>izes the CPU as follows: reset<br>interrupt enable flip-flop, clear<br>PC and registers I and R and set<br>interrupt to 8080A mode. During<br>reset time, the address and data<br>bus go to a high impedance state<br>and all control output signals go<br>to the inactive state. |

# Table 4-6 (Con't). CPU Signal List

| SIGNAL                   | PIN | FUNCTION                                                                                                                                                                                                                                                                                                                                          |
|--------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSRQ<br>BUS REQUEST     | 25  | Input, active low. The bus re-<br>quest signal has a higher priority<br>than NMI and is always recognized<br>at the end of the current machine<br>cycle and is used to request the<br>CPU address bus, data bus and tri-<br>state output control signals to<br>go to a high impedance state so<br>that other devices can control<br>these busses. |
| BUSAK<br>BUS ACKNOWLEDGE | 23  | Output, active low. Bus acknow-<br>ledge is used to indicate to the<br>requesting device that the CPU<br>address bus, data bus and tri-<br>state control bus signals have<br>been set to their high impedance<br>state and the external device<br>can now control these signals.                                                                  |

There are also two sets of accumulator and flag registers. The programmer has access to either set of main or alternate registers through a group of exchange instructions. This alternate set allows foreground/background mode of operation or may be reserved for very fast interrupt response. Each CPU also contains a 16-bit stack pointer which permits simple implementation of multiple level interrupts, unlimited subroutine nesting and simplification of many types of data handling.

The two 16-bit index registers allow tabular data manipulation and easy implementation of relocatable code. The Refresh register provides for automatic, totally transparent refresh of external dynamic memories. The I register is used in a powerful interrupt response mode to form the upper 8 bits of a pointer to an interrupt service address table, while the interrupting device supplies the lower 8 bits of the pointer. An indirect call is then made to this service address.

#### 4.2.1.1 Instruction Op-Code Fetch

the address The program counter content (PC) is placed on bus immediately at the start of the cycle. One half clock time later MREQ goes active. The falling edge of MREQ can be used directly as a chip enable to dynamic memories.  $\overline{RD}$  when active indicates that thememory data should be enabled onto the CPU data bus. The CPU samples data with the rising edge of the clock state T3. Clock states T3 and Т4 of a fetch cycle are used to refresh dynamic memories while the internally decoding and executing the instruction. CPU is The refresh control signal  $\overline{\text{RFSH}}$  indicates that a refresh read of all dynamic memories should be accomplished.



### 4.2.1.2 Memory Read Or Write Cycles

Illustrated here is the timing of memory read or write cycles other than an OP code fetch (M1 cycle). The  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals are used exactly as in the fetch cycle. In the case of a memory write cycle, the MREQ also becomes active when the address bus is stable so that it can be used directly as a chip enable for dynamic memories. The WR line is active when data on the data bus is stable so that it can an R/W pulse to virtually any type be used directly as of semiconductor memory.



#### 4.2.1.3 Input Or Output Cycles

Illustrated here is the timing for an I/O read or I/O write operation. Notice that during I/O operations a single wait state is automatically inserted (Tw\*). The reason for this is that during I/Ooperations this extra state allows sufficient time for an I/O port to decode its address and activate the WAIT line if a wait is required.



4.2.1.4 Interrupt Request/Acknowledge Cycle

The interrupt signal is sampled by the CPU with the rising edge of the last clock at the end of any instruction. When an interrupt is accepted, a special M1 cycle is generated. During this M1 cycle, the  $\overline{\text{IORQ}}$  signal becomes active (instead of  $\overline{\text{MREQ}}$ ) to indicate that the interrupting device can place an 8-bit vector on the data bus. Two wait states (Tw\*) are automatically added to this cycle so that a ripple priority interrupt scheme, such as the one used in the peripheral controller, can be easily implemented.



DWM-00420-00 REV. A00

## 4.2.1.5 CPU Instruction Set

The following is a summary of the CPU instruction set showing the assembly language mnemonic and the symbolic operation performed by the instruction. The instructions are divided into the following categories:

| 8-bit loads                 | Miscellaneous Group     |
|-----------------------------|-------------------------|
| 16-bit loads                | Rotates and Shifts      |
| Exchanges                   | Bit Set, Reset and Test |
| Memory Block Moves          | Input and Output        |
| Memory Block Searche        | Jumps                   |
| 8-bit arithmetic andic      | Calls                   |
| 16-bit arithmetic           | Restarts                |
| General Purpose Accumulator | Returns                 |
| & Flag Operations           |                         |

In Table 4-7, the following terminology is used:

| b<br>cc | <ul> <li>a bit number in any 8-bit register or memory location</li> <li>flag condition code</li> <li>NZ = non zero</li> <li>Z = zero</li> <li>NC = non carry</li> <li>C = carry</li> <li>PO = Parity odd or no over flow</li> <li>PE = Parity even or over flow</li> <li>P = Positive</li> <li>M = Negative (minus)</li> </ul> | <ul> <li>d ≡ any 8-bit destination register or memory location</li> <li>dd ≡ any 16-bit destination register or memory location</li> <li>e ≡ 8-bit signed 2's complement displacement used in relative jumps and indexed addressing</li> <li>L ≡ 8 special call locations in page zero. In decimal notation these are 0, 8, 16, 24, 32, 40, 48 and 56</li> <li>n ≡ any 8-bit binary number</li> <li>nn ≡ any 16-bit binary number</li> <li>r ≡ any 8-bit general purpose register (A, B, C, D, E, H, or L)</li> <li>s ≡ any 8-bit source register or memory location</li> <li>sb ≡ a bit in a specific 8-bit register or memory location</li> <li>ss ≡ any 16-bit source register or memory location</li> <li>subscript "L" ≡ the low order 8 bits of a 16-bit register</li> </ul> |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                                                                                                                                                                                                                                                                                                                                | <ul> <li>() ≡ the contents within the () are to be used as a pointer to a memory location or I/O port number</li> <li>8-bit registers are A, B, C, D, E, H, L, I and R</li> <li>16-bit register pairs are AF, BC, DE and HL</li> <li>16-bit registers are SP, PC, IX and IY</li> <li>Addressing Modes implemented include combinations of the following: Immediate Indexed Immediate extended Register</li> <li>Modified Page Zero Implied</li> </ul>                                                                                                                                                                                                                                                                                                                              |

| DWM-00420-00 F | REV | 00A |
|----------------|-----|-----|
|----------------|-----|-----|

Relative

Extended

**Register Indirect** 

Bit

Table 4-7. CPU Instruction Set

|                    | Mnemonic    | Symbolic Operation                                                                                                | Comments                                               |
|--------------------|-------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
|                    | LD r. s     | r ← s                                                                                                             | $s \equiv r, n, (HL),$                                 |
|                    | LD d. r     | d ← r                                                                                                             | (IX+e), (IY+e)<br>$d \equiv (HL), r$<br>(IX+e), (IY+e) |
| 8-BIT LOADS        | LD d. n     | d ← n                                                                                                             | $d \equiv (HL),$<br>(IX+e), (IY+e)                     |
|                    | LD A, s     | A ← s                                                                                                             | $s \equiv (BC), (DE),$<br>(nn), I, R                   |
|                    | LD d, A     | d ← A                                                                                                             | $d \equiv (BC), (DE),$<br>(nn), I, R                   |
|                    | LD dd, nn   | dd ← nn                                                                                                           | $dd \equiv BC, DE, HL, SP, IX, IY$                     |
|                    | LD dd, (nn) | dd ← (nn)                                                                                                         | $dd \equiv BC, DE,$<br>HL, SP, IX, IY                  |
| 16-BIT LOADS       | LD (nn), ss | (nn) ← ss                                                                                                         | $ss \equiv BC, DE,$<br>HL, SP, 1X, IY                  |
|                    | LD SP, ss   | SP ← ss                                                                                                           | ss = HL, IX, IY                                        |
|                    | PUSH ss     | $(SP-1) \leftarrow ss_H; (SP-2) \leftarrow ss_L$                                                                  | ss = BC, DE,                                           |
|                    | POP dd      | $dd_L \leftarrow (SP); dd_H \leftarrow (SP+1)$                                                                    | HL, AF, IX, IY $dd = BC, DE,$                          |
|                    |             |                                                                                                                   | HL, AF, IX, IY                                         |
|                    | EX DE, HL   | DE ↔ HL                                                                                                           |                                                        |
| EXCULANCES         | EX AF, AF'  | AF ↔ AF'                                                                                                          |                                                        |
| EXCHANGES          | EXX         | $ \begin{pmatrix} BC \\ DE \\ HL \end{pmatrix} \leftrightarrow \begin{pmatrix} BC' \\ DE' \\ HL' \end{pmatrix} $  | ų.                                                     |
|                    | EX (SP), ss | $(SP) \leftrightarrow ss_L, (SP+1) \leftrightarrow ss_H$                                                          | ss≡HL, IX, IY                                          |
|                    | LDI         | $(DE) \leftarrow (HL)$ . $DE \leftarrow DE+1$                                                                     |                                                        |
| MEMORY BLOCK MOVES | LDIR        | HL ← HL+1, BC ← BC-1<br>(DE) ← (HL), DE ← DE+1<br>HL ← HL+1, BC ← BC-1                                            |                                                        |
|                    | LDD         | Repeat until BC = 0<br>(DE) $\leftarrow$ (HL), DE $\leftarrow$ DE-1<br>HL $\leftarrow$ HL-1, BC $\leftarrow$ BC-1 |                                                        |
|                    | LDDR        | (DE) ← (HL), DE ← DE-1<br>HL ← HL-1, BC ← BC-1                                                                    |                                                        |
|                    |             | Repeat until $BC = 0$                                                                                             |                                                        |

Table 4-7. (Cont.). CPU Instruction Set

|                          | Mnemonic   | Symbolic Operation                                                                       | Comments                                            |
|--------------------------|------------|------------------------------------------------------------------------------------------|-----------------------------------------------------|
|                          | СРІ        | A-(HL), HL ← HL+1<br>BC ← BC-1                                                           |                                                     |
| Y BLOCK SEARCHES         | CPIR       | A-(HL), HL $\leftarrow$ HL+1<br>BC $\leftarrow$ BC-1, Repeat<br>until BC = 0 or A = (HL) | A-(HL) sets<br>the flags only.<br>A is not affected |
|                          | CPD        | A-(HL), HL ← HL-1<br>BC ← BC-1                                                           |                                                     |
|                          | CPDR       | A-(HL), HL ← HL-1<br>BC ← BC-1, Repeat<br>until BC= 0 or A = (HL)                        |                                                     |
|                          | ADD s      | $A \leftarrow A + s$                                                                     |                                                     |
|                          | ADC s      | $A \leftarrow A + s + CY$                                                                | CY is the                                           |
|                          | SUB s      | A ← A - s                                                                                | carry flag                                          |
|                          | SBC s      | A ← A - s - CY                                                                           | s≡ r, n, (HL)                                       |
|                          | AND s      | $\mathbf{A} \leftarrow \mathbf{A} \wedge \mathbf{s}$                                     | (IX+e), (IY+e)                                      |
| 8-BIT ALU                | OR s       | $\mathbf{A} \leftarrow \mathbf{A} \lor \mathbf{s}$                                       |                                                     |
|                          | XOR s      | <b>A</b> ← <b>A</b> ⊕ s                                                                  |                                                     |
|                          | CP s       | A - s                                                                                    | s = r, n (HL)                                       |
|                          | INC d      | d ← d + 1                                                                                | (IX+e), (IY+e)                                      |
|                          |            |                                                                                          | d = r, (HL)                                         |
|                          | DEC d      | d ← d – 1                                                                                | (IX+e), (IY+e)                                      |
|                          |            |                                                                                          |                                                     |
|                          | ADD HL, ss | HL ← HL + ss                                                                             | $ss \equiv BC, DE$                                  |
|                          | ADC HL, ss | HL ← HL + ss + CY                                                                        | HL, SP                                              |
|                          | SBC HL, ss | HL ← HL - ss - CY                                                                        | P = PC DE                                           |
|                          | ADD IX, ss | $IX \leftarrow IX + ss$                                                                  | $ss \equiv BC, DE, IX, SP$                          |
| <b>16-BIT ARITHMETIC</b> | ADD IY, ss | $IY \leftarrow IY + ss$                                                                  | $ss \equiv BC, DE,$<br>IY, SP                       |
|                          | INC dd     | dd ← dd + 1                                                                              | $dd \equiv BC, DE, HL, SP, IX, IY$                  |
|                          | DEC dd     | dd ← dd – 1                                                                              | $dd \equiv BC, DE$ ,                                |
|                          |            |                                                                                          | HL, SP, IX, IY                                      |
|                          | DAA        | Converts A contents into                                                                 | Operands must                                       |
|                          |            | packed BCD following add                                                                 | be in packed                                        |
|                          |            | or subtract.                                                                             | BCD format                                          |
| GP ACC. AND FLAG         | CDI        | . —                                                                                      |                                                     |
|                          | CPL        | $A \leftarrow \overline{A}$                                                              |                                                     |
|                          | NEG<br>CCF | $A \leftarrow 00 - A$ $CY \leftarrow \overline{CY}$                                      |                                                     |
|                          |            | $1 + Y \leftarrow 1 + Y$                                                                 | 1 1                                                 |
|                          | SCF        | $CY \leftarrow 1$                                                                        |                                                     |

MEMORY

DWM-00420-00 REV. A00

|                    | Mnemonic  | Symbolic Operation                                                          | Comments                             |
|--------------------|-----------|-----------------------------------------------------------------------------|--------------------------------------|
|                    | NOP       | No operation                                                                |                                      |
|                    | HALT      | Halt CPU                                                                    |                                      |
| MISCELLANEOUS      | DI        | Disable Interrupts                                                          |                                      |
| MIDCLEDINCLOOD     | EI        | Enable Interrupts                                                           |                                      |
|                    | IM O      | Set interrupt mode 0                                                        | 8080A mode                           |
|                    | IM 1      | Set interrupt mode 1                                                        | Call to 0038 <sub>H</sub>            |
|                    | IM 2      | Set interrupt mode 2                                                        | Indirect Call                        |
|                    | RLC s     |                                                                             |                                      |
|                    | RL s      |                                                                             |                                      |
|                    | RRC s     |                                                                             |                                      |
|                    | RR s      |                                                                             |                                      |
| ROTATES AND SHIFTS | SLA s     | (Y) 7 - 0<br>S                                                              | $s \equiv r, (HL)$<br>(IX+e), (IY+e) |
|                    | SRA s     |                                                                             |                                      |
|                    | SRL s     | $0 \longrightarrow \boxed{7 \longrightarrow 0} \longrightarrow \boxed{(Y)}$ |                                      |
|                    | RLD       | 7 4 3 0 7 4 3 7 (HL)<br>A                                                   |                                      |
|                    | RRD       | 7 4 3 0 7 4 3 0 (HL)<br>A                                                   |                                      |
|                    | BIT b.s   | $Z \leftarrow \overline{s_{h}}$                                             | Z is zero flag                       |
| BITS S, R, AND T   | SET b.s   | s <sub>h</sub> ← 1                                                          | s ≡ r, (HL)                          |
|                    | RES b, s  | $s_b \leftarrow 0$                                                          | (IX+e), (IY+e)                       |
|                    | IN A, (n) | A ← (n)                                                                     |                                      |
|                    | IN r, (C) | $r \leftarrow (C)$                                                          | Set flags                            |
|                    | INI       | $(HL) \leftarrow (C), HL \leftarrow HL + 1$                                 | C C                                  |
|                    |           | <b>B</b> ← <b>B</b> - 1                                                     |                                      |
|                    | INIR      | $(HL) \leftarrow (C), HL \leftarrow HL + 1$                                 |                                      |
| INPUT AND OUTPUT   |           | $\mathbf{B} \leftarrow \mathbf{B} - 1$                                      |                                      |
|                    |           | Repeat until $\mathbf{B} = 0$                                               |                                      |
|                    | IND       | $(HL) \leftarrow (C), HL \leftarrow HL - 1$ $B \leftarrow B - 1$            |                                      |
|                    |           |                                                                             |                                      |
|                    |           |                                                                             |                                      |
|                    | INDR      | $(HL) \leftarrow (C), HL \leftarrow HL - 1$<br>B \le B - 1                  |                                      |

Table 4-7. (Cont.). CPU Instruction Set

Table 4-7. (Cont.). CPU Instruction Set

|                  | Mnemonic                       | Symbolic Operation                                                                                                                      | Comments                                                                    |
|------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|                  | OUT(n), A<br>OUT(C), r<br>OUTI | $(n) \leftarrow A$ $(C) \leftarrow r$ $(C) \leftarrow (HL), HL \leftarrow HL + 1$                                                       |                                                                             |
| INPUT AND OUTPUT | OTIR                           | B ← B - 1<br>(C) ← (HL), HL ← HL + 1<br>B ← B - 1<br>Parast instit B = 0                                                                |                                                                             |
|                  | OUTD                           | Repeat until B = 0<br>(C)← (HL), HL ← HL - 1<br>B ← B - 1                                                                               |                                                                             |
|                  | OTDR                           | $(C) \leftarrow (HL), HL \leftarrow HL - 1$<br>$B \leftarrow B - 1$<br>Repeat until $B = 0$                                             |                                                                             |
|                  | JP nn<br>JP ee, nn             | PC ← nn<br>If condition cc is true<br>PC ← nn, else continue                                                                            | cc<br>NZ PO<br>Z PE<br>NC P                                                 |
| JUMPS            | JR e<br>JR kk.e                | PC ← PC + e<br>If condition kk is true<br>PC ← PC + e, else continue                                                                    | $ \begin{cases} C & M \\ kk \\ \begin{cases} NZ & NC \\ Z & C \end{cases} $ |
|                  | JP (ss)<br>DJNZ e              | PC ← ss<br>B ← B - 1, if B = 0<br>continue, else PC ← PC + e                                                                            | ss = HL, IX, IY                                                             |
| CALLS            | CALL nn<br>CALL ee, nn         | $(SP-1) \leftarrow PC_H$<br>$(SP-2) \leftarrow PC_L, PC \leftarrow nn$<br>If condition cc is false<br>continue, else same as<br>CALL nn | cc $\begin{cases} NZ & PO \\ Z & PE \\ NC & P \\ C & M \end{cases}$         |
| RESTARTS         | RST L                          | $(SP-1) \leftarrow PC_{H}$<br>$(SP-2) \leftarrow PC_{L}, PC_{H} \leftarrow 0$<br>$PC_{L} \leftarrow L$                                  |                                                                             |
|                  | RET                            | PC <sub>L</sub> ← (SP),<br>PC <sub>H</sub> ← (SP+1)<br>If condition cc is false                                                         | N7 10                                                                       |
| RETURNS          | RET ee<br>RETI                 | Return from interrupt,<br>same as RET                                                                                                   | $\begin{array}{c} c \\ c$           |
|                  | RETN                           | Return from non-<br>maskable interrupt                                                                                                  |                                                                             |

DWM-00420-00 REV. A00

4.2.2 DMA Address Generator (U10, U21).

This device is a high-speed, 8-bit wide direct memory access address generator slice that can be cascaded to form larger addresses. Device connections are shown in Figure 4-14.

The primary function of the device is to generate sequential memory addresses for use in the sequential transfer of data to or from a memory. It also maintains a data word count and generates a DONE signal when a programmable terminal count has been reached. The device is designed for use in peripheral controllers with DMA capability or in any other system which transfers data to or from sequential locations of a memory.

The device can be programmed to increment or decrement the memory address in any of four control modes and executes eight different instructions. The initial address and word count are saved internally so that they can be restored later in order to repeat the data transfer operation.

Logic Symbol

Connection Diagram Top View





DWM-00420-00 REV. A00

### 4.2.2.1 Architecture

As shown in Figure 4-15, the device consists of the following:

- A three-bit Control Register.
- An eight-bit Address Counter with input multiplexer.
- An eight-bit Address Register.
- An eight-bit Word Counter with input multiplexer.
- An eight-bit Word Count Register.
- Transfer complete circuitry.
- An eight-bit wide data multiplexer with three-state output buffers.
- Three-state address output buffers with external output enable control.
- An instruction decoder.



Figure 4-15. DMA Address Generator Block Diagram

<u>Control Register</u>. Under instruction control, the Control Register can be loaded or read from the bidirectional DATA lines DO-D7. Control Register bits O and 1 determine the Control Mode, and bit 2 determines whether the Address Counter increments or decrements. Figure 4-16 defines the Control Register format.

| CR1 | CR0 | Control Mode<br>Number | Control<br>Mode Type   | Word<br>Counter | Done<br>Output Signal                                |
|-----|-----|------------------------|------------------------|-----------------|------------------------------------------------------|
| L   | L   | 0                      | Word Count Equals One  | Decrement       | HIGH when Word Counter = 1                           |
| L   | н   | 1                      | Word Count Compare     | Increment       | HIGH when Word Counter +1 equals Word Count Register |
| н   | L   | 2                      | Address Compare        | Hold            | HIGH when Word Counter - Address Counter             |
| н   | н   | 3                      | Word Counter Carry out | Increment       | Always LOW.                                          |

Address Counter

Increment

Decrement

| Con             | trol Reg | ister           |
|-----------------|----------|-----------------|
| CR <sub>2</sub> | CR1      | CR <sub>0</sub> |

| 1 |  |  |  |
|---|--|--|--|
|   |  |  |  |

H = HIGH

L = LOW

### Figure 4-16. Control Register Format Definition

CRa

L

н

Address Counter. The Address Counter, which provides the current memory address, is an eight-bit, binary, up/down counter with full look-ahead carry generation. The Address Carry Input (ACI) and Address Carry Output (ACO) allow cascading to accommodate larger instruction control, the Address Counter can be addresses. Under enabled, disabled, and loaded from the DATA inputs, DO-D7, or the Address Register. When enabled and the ACI input is LOW, the Address increments/decrements on the LOW to HIGH transition of the Counter CLOCK input, CP. The Address Counter output can be enabled onto thethree-state ADDRESS outputs AO-A7 under control of the Output Enable input, OEA.

<u>Address Register</u>. The eight-bit Address Register saves the initial address so that it can be restored later in order to repeat a transfer operation. When the LOAD ADDRESS instruction is executed, the Address Register and Address Counter are simultaneously loaded from the DATA inputs, DO-D7. <u>Word Counter and Word Count Register</u>. The Word Counter and Word Count Register, which maintain and save a word count, are similar in structure and operation to the Address Counter and Address Register, with the exception that the Word Counter increments in Control Modes 1 and 3, decrements in Control Mode O, and is disabled in Control Mode 2. The LOAD WORD COUNT instruction simultaneously loads the Word Counter and Word Count Register.

<u>Transfer Complete Circuitry</u>. The Transfer Complete Circuitry is a combinational logic network which detects the completion of the data transfer operation in three control Modes and generates the DONE output signal. The DONE signal is an open-collector output, which can be dot-anded between chips.

Data Multiplexer. The Data Multiplexer is an eight-bit wide, 3-input multiplexer which allows the Address Counter, Word Counter, and Control Register to be read at the DATA lines, DO-D7. The Data Multiplexer and three-state Data output buffers are instruction controlled.

Address Output Buffers. The three-state Address Output Buffers allow the Address Counter output to be enabled onto the ADDRESS lines, AO-A7, under external control. When the Output Enable input, OEA, is LOW, the Address output buffers are enabled; when OEA is HIGH, the ADDRESS lines are in the high-impedance state. The address and Data Output Buffers can sink 24mA output current over the commercial operating range.

<u>Instruction Decoder</u>. The Instruction Decoder generates required internal control signals as a function of the INSTRUCTION inputs, IO-I2 and Control Register bits O and 1.

<u>Clock</u>. The CLOCK input, CP is used to clock the Address Register, Address Counter, Word Count Register, Word Counter, and Control Register, all on the LOW to HIGH transition of the CP signal.

#### 4.2.2.2 Control Modes

<u>Control Mode O - Word Count Equals One Mode</u>. In this mode, the number of data words to be transferred is initially loaded into the Word Counter and Word Count Register. When the Word Counter is enabled and the Word Counter Carry-In, WCI, is LOW, the Word Counter decrements on the LOW to HIGH transition of the CLOCK input, CP. The DONE signal is generated during the last word transfer, i.e., when the Word Counter equals one.

Control Mode 1 - Word Count Compare Mode. Initially, the number of data words to be transferred is loaded into the Word Count Register and the Word Counter is cleared. When the Word Counter is enabled the WCI input is LOW, the Word Counter increments on the LOW to and HIGH transition of the CLOCK input, CP. In this mode. the Word always indicates the number of data words that have been Counter transferred. The Transfer Complete Circuitry compares the Word Counter with the Word Count Register and generates the DONE signal during the last word transfer; i.e., when the Word Counter plus one equals the Word Count Register.

Control Mode 2 - Address Compare Mode. In this mode, only an initial final memory address need be specified. The initial Memory and Address is loaded into the Address Register and Address Counter and final memory address is loaded into the Word Count Register and theWord Counter. The Word Counter is always disabled in this mode and as a holding register for the final memory address. When the serves Address Counter is enabled and the ACI input is LOW, the Address increments or decrements (depending on Control Register bit Counter 2) on the LOW to HIGH transition of the CLOCK input, CP. The Complete Circuitry compares the Address Counter with the Transfer Word Counter and generates the DONE signal during the last word transfer; i.e., when the Address Counter equals the Word Counter.

<u>Control Mode 3 - Word Counter Carry Out Mode.</u> For this mode of operation, the user can load the Word Count Register and Word Counter with the two's complement of the number of data words to be transferred. When the Word Counter is enabled and the WCI input is LOW, the Word Counter increments on the LOW to HIGH transition of the CLOCK input, CP. A Word Counter Carry Out signal, WCO, indicates the last data word is being transferred. The DONE signal is not required in this mode and, therefore, is always LOW.

#### 4.2.2.3 Instructions

The instruction set consists of eight instructions. Six instructions load and read the Address Counter, Word Counter and Control Register; one instruction enables the Address and Word counters. and one instruction reinitializes the Address and Word counters. The function of the REINITIALIZE COUNTERS, LOAD WORD COUNT, and ENABLE COUNTERS instructions varies with the Control Mode being utilized. Table 4-8 defines the instructions as a function of instruction inputs IO-I2 and the four Control Modes.

| 5  | ч | 1 <sub>0</sub> | Octal<br>Code | Function                     | Mnemonic | Control<br>Mode | Word<br>Reg. | Word<br>Counter | Address<br>Reg. | Address<br>Counter | Control<br>Register                | Data<br>D <sub>0</sub> -D <sub>7</sub>         |
|----|---|----------------|---------------|------------------------------|----------|-----------------|--------------|-----------------|-----------------|--------------------|------------------------------------|------------------------------------------------|
| L  | L | L              | 0             | WRITE<br>CONTROL<br>REGISTER | WRCR     | 0, 1, 2, 3      | HOLD         | HOLD            | HOLD            | HOLD               | D <sub>0</sub> -D <sub>2</sub> →CR | INPUT                                          |
| L  | L | н              | 1             | READ<br>CONTROL<br>REGISTER  | RDCR     | 0, 1, 2, 3      | HOLD         | HOLD            | HOLD            | HOLD               | HOLD                               | CR →D <sub>0</sub> -D <sub>2</sub><br>(Note 1) |
| L  | н | L              | 2             | READ<br>WORD<br>COUNTER      | RDWC     | 0, 1, 2, 3      | HOLD         | HOLD            | HOLD            | HOLD               | HOLD                               | WC→D                                           |
| L  | н | н              | 3             | READ<br>ADDRESS<br>COUNTER   | RDAC     | 0, 1, 2, 3      | HOLD         | HOLD            | HOLD            | HOLD               | HOLD                               | AC→D                                           |
|    | L | L              | 4             | REINITIALIZE                 | REIN     | 0, 2, 3         | HOLD         | WCR→WC          | HOLD            | AR→AC              | HOLD                               | Z                                              |
| 1" | L | ۲.             | -             | COUNTERS                     | nein     | 1               | HOLD         | ZERO→WC         | HOLD            | AR→AC              | HOLD                               | Z                                              |
| н  | L | н              | 5             | LOAD<br>ADDRESS              | LDAD     | 0, 1, 2, 3      | HOLD         | HOLD            | D→AR            | D→AC               | HOLD                               | INPUT                                          |
|    | н |                | 6             | LOAD<br>WORD                 | LDWC     | 0, 2, 3         | D→WR         | D→WC            | HOLD            | HOLD               | HOLD                               | INPUT                                          |
| "  | п | L              | 0             | COUNT                        | LDWC     | 1               | D→WR         | ZERO→WC         | HOLD            | HOLD               | HOLD                               | INPUT                                          |
| н  | н | н              | 7             | ENABLE                       | ENCT     | 0, 1, 3         | HOLD         | ENABLE<br>COUNT | HOLD            | ENABLE<br>COUNT    | HOLD                               | z                                              |
| Ľ  |   |                |               | COUNTERS                     |          | 2               | HOLD         | HOLD            | HOLD            | ENABLE<br>COUNT    | HOLD                               | z                                              |

| Table 4-8. | DMA | Register | Instructions |
|------------|-----|----------|--------------|
|------------|-----|----------|--------------|

CR = Control Reg.

WC = Word CounterD = Data

WCR = Word Count Reg.

L = LOW H = HIGH

Z = High Impedance

AR = Address Reg.AC = Address Counter

Note 1: Data Bits  $D_3$ - $D_7$  are high during this instruction.

The WRITE CONTROL REGISTER instruction writes DATA input DO-D2 into the Control Register; DATA inputs D3-D7 are "don't care" inputs for this instruction. The READ CONTROL REGISTER instruction gates the Control Register outputs to DATA lines, DO-D2. DATA lines D3-D7 are in the HIGH state during this instruction.

The Word Counter can be read using the READ WORD COUNTER instruction, which gates the Word Counter outputs to DATA lines DO-D7. The LOAD WORD COUNT instruction is Control Mode dependent. In Control Modes O, 2, and 3, DATA inputs DO-D7 are written into both the Word Count Register and Word Counter. In Control Mode 1, DATA inputs DO-D7 are written into the Word Count Register and the Word Counter is cleared.

The READ ADDRESS COUNTER instruction gates the Address Counter outputs to DATA lines DO-D7, and the LOAD ADDRESS instruction writes DATA inputs DO-D7 into both the Address Register and Address Counter.

In Control Modes O, 1, and 3, the ENABLE COUNTERS instruction enables both the Address and Word Counters; in Control Mode 2, the Address Counter is enabled and the Word Counter holds its contents. When enabled and the carry input is active, the counter increment on the LOW to HIGH transition of the CLOCK input, CP. Thus, with this instruction applied, counting can be controlled by the carry inputs.

The REINITIALIZE COUNTERS instruction also is Control Mode dependent. In Control Modes O, 1, and 3, the contents of the Address Register and Word Count Register are transferred to the respective Address Counter and Word Counter; in Control Mode 1, the content of the Address Register is transferred to the Address Counter and the Word Counter is cleared. The REINITIALIZE COUNTERS instruction allows a data transfer operation to be repeated without reloading the address and word count from the DATA lines.

4.2.3 Cyclic Redundancy Check (CRC) Generator/Checker (U15). Cyclic Redundancy Check (CRC) Generator/Checker is a 16-bit programmable device which operates on serial data streams and provides a means of detecting transmission errors. Cyclic encoding

and decoding schemes for error detection are based on polynomial manipulation in modulo arithmetic. For encoding, the data stream (message polynomial) is divided by a selected polynomial. This division results in a remainder which is appended to the message as check bits. For error checking, the bit stream containing both data and check bits is divided by the same selected polynomial. If there are no detectable errors, this division results in a zero remainder. Although it is possible to choose many generating polynomials of a given degree, standards exist that specify a small number of useful polynomials. This device implements the polynomials listed in Table 4-10 by applying the appropriate logic levels to the select pin SO, S1 and S2. The CRC connections are shown in Figure 4-17.

The device consists of a 16-bit register, a Read Only Memory (ROM) and associated control circuitry as shown in the Block Diagram. The polynomial control mode presented at inputs SO, S1 and S2 is decoded by the ROM, selecting the desired polynomial by establishing shift mode operation on the register with Exclusive OR gates at appropriate To generate the check bits, the data stream is entered via inputs. (D), using the HIGH to LOW transition of the Clock Inputs theData This data is gated with the most significant Output Input (CP). (0) of the register, and controls the Exclusive OR gates (Figure 4-18). The Check Word Enable (CWE) must be held HIGH while the data is being entered. After the last bit is entered, the CWE is brought LOW and the check bits are shifted out of the register and appended to the data bits using external gating (Figure 4-19).

To check an incoming message for errors, both the data and check bits are entered through the D Input with the CWE Input held high. The device is not in the data path, but only monitors the message. The Error Output becomes valid after the last check bit has been entered into the device by a HIGH to LOW transition of CP. If no detectable errors have occurred during the data transmission, the resultant internal register bits are all LOW and the Error Output (ER) is LOW. If a detectable error has occurred, ER is HIGH; ER remains valid until the next HIGH to LOW transition of CP or until the device has been preset or reset.

A HIGH on the Master Reset Input (MR) asynchronously clears the register. A LOW on the Preset Input (P) asynchronously sets the entire register if the control code inputs specify a 16-bit polynomial; in the case of 12 or 8-bit check polynomials, only the most significant 12 or 8 register bits are set, and the remaining bits are cleared.

#### LOGIC SYMBOL



 $V_{CC} = Pin 14$ GND = Pin 7

#### CONNECTION DIAGRAM DIP (TOP VIEW)



Pins 6 and 9 not connected.

NOTE:

The Flatpak version has the same pinouts (Connection Diagram) as the Dual In-line Package.

## Figure 4-17. CRC Checker Connections

### PIN NAMES

| \$ <sub>0</sub> - \$ <sub>2</sub> | Polynomial Select Inputs         |
|-----------------------------------|----------------------------------|
| D                                 | Data Input                       |
| CP                                | Clock (Operates on HIGH-to-      |
|                                   | LOW Transition) Input            |
| CWE                               | Check Word Enable Input          |
| P                                 | Preset (Active LOW) Input        |
| MR                                | Master Reset (Active HIGH) Input |
| ٥                                 | Data Output (Note b)             |
| ER                                | Error Output (Note b)            |

#### **BLOCK DIAGRAM**



V<sub>CC</sub> = Pin 14 GND = Pin 7

DWM-00420-00 REV. A00

| S              | ELECT COL      | DE .           | POLYNOMIAL                                                            | REMARKS           |
|----------------|----------------|----------------|-----------------------------------------------------------------------|-------------------|
| S <sub>2</sub> | s <sub>1</sub> | s <sub>o</sub> | FOLTNOMIAL                                                            | nemanka           |
| L              | L              | L              | x16+x15+x2+1                                                          | CRC-16            |
| L              | L              | н              | x16+x14+x+1                                                           | CRC-16 REVERSE    |
| L              | н              | L              | x16+x15+x13+x7+x4+x2+x1+1                                             |                   |
| L              | н              | н              | x <sup>12</sup> +x <sup>11</sup> +x <sup>3</sup> +x <sup>2</sup> +x+1 | CRC-12            |
| н              | L              | L              | x8+x7+x5+x4+x+1                                                       |                   |
| н              | L              | н              | x <sup>8</sup> +1                                                     | LRC-8             |
| н              | н              | L              | x <sup>16</sup> +x <sup>12</sup> +x <sup>5</sup> +1                   | CRC/CCITT         |
| н              | н              | н              | x16+x11+x4+1                                                          | CRC-CCITT REVERSE |









#### NOTES

Check word Enable is HIGH while data is being clocked, LOW during transmission of check bits.
 9401 must be reset or preset before each computation.
 CRC check bits are generated and appended to data bits.

Figure 4-19.

CRC Check Word Generation

4.2.4 Positive-Edge-Triggered Flip-Flops with Preset and Clear (U5, U14, U53, U55, U62).

For logic and connections, see Figure 4-20.



Truth Table

|    | INPL | лтs |   | OUTP | UTS |
|----|------|-----|---|------|-----|
| PR | CLR  | CLK | D | ٩    | ā   |
| L  | н    | x   | x | н    | L   |
| н  | L    | x   | х | L    | н   |
| L  | L    | x   | х | н•   | н•  |
| н  | н    | t   | н | н    | L   |
| н  | н    | t   | L | L    | н   |
| н  | н    | L   | x | 00   | Ō0  |

Notes. \_\_\_ = high-level pulse; data inputs should be held constant while clock is high; data is transferred to output on the falling edge of the pulse.

Q0 = the level of Q before the indicated input conditions were established.

TOGGLE. Each output changes to the complement of its previous level on each active transition (pulse) of the clock. \*This configuration is nonstable, that is, it will not persist when preset and clear inputs return to their inactive (high) level

Figure 4-20. Dual D Flip-Flop Connections

4.2.5 Dual J-K Negative-Edge-Triggered Flip-Flops with Preset and Clear (U17).

For device logic and connections, see Figure 4-21.

Connection Diagram



#### Truth Table

|    | H   | NPUTS |   |   | OUT | PUTS |
|----|-----|-------|---|---|-----|------|
| PR | CLR | CLK   | J | к | ٩   | ā    |
| L  | н   | x     | × | X | н   | L    |
| н  | L   | x     | x | x | L   | н    |
| L  | L   | x     | x | x | н.  | н•   |
| н  | н   | 1     | L | L | 00  | Õ0   |
| н  | н   | ŧ     | н | L | н   | L    |
| н  | н   | 4     | L | н | L   | н    |
| н  | н   | ŧ     | н | н | TOG | GLE  |
| н  | н   | н     | x | х | 00  | ÕΟ   |

Notes. Q0 = the level of Q before the indicated input conditions were established.

TOGGLE: Each output changes to the complement of its previous level on each active transition of the clock. \*This configuration is nonstable; that is, it will not persist when preset and clear inputs return to their inective (high) level.

Figure 4-21. J-K Flip-Flop Connections

4.2.6 Decoder (U25, U26, U71).

These are Schottky-clamped circuits designed for memory-decoding or data-routing applications requiring very short propagation delay This DIP decodes one of eight lines based on the conditions times. at the three binary select inputs and the three enable inputs. For logic and connections, see Figure 4-22.

#### Connection and Logic Diagram





Truth Table

|               | 11  | VPUT | \$ | 1       |    |    |    | OUT | DITE |    |    |    |
|---------------|-----|------|----|---------|----|----|----|-----|------|----|----|----|
| ENABLE SELECT |     |      |    | OUTPUTS |    |    |    |     |      |    |    |    |
| G1            | 62. | C    | B  |         | YO | ¥1 | Y2 | ¥3  | ¥4   | Y5 | ¥6 | ¥7 |
| x             | н   | x    | x  | x       | н  | н  | н  | н   | н    | н  | н  | н  |
| L             | x   | x    | x  | x       | н  | н  | н  | н   | н    | н  | н  | н  |
| н             | L   | L    | L  | L       | L  | н  | н  | н   | н    | н  | н  | н  |
| н             | L   | L    | L  | н       | н  | L  | н  | н   | н    | н  | н  | н  |
| н             | L   | L    | н  | L       | н  | н  | L  | н   | н    | н  | н  | н  |
| н             | L   | ι    | н  | н       | н  | н  | н  | L   | н    | н  | н  | н  |
| н             | L   | н    | L  | L       | н  | н  | н  | н   | L    | н  | н  | н  |
| н             | L   | н    | L  | н       | н  | н  | н  | н   | н    | L  | н  | н  |
| н             | L   | н    | н  | L       | н  | н  | ·н | н   | н    | н  | L  | н  |
| н             | L   | н    | н  | н       | н  | н  | н  | н   | н    | н  | н  | L  |

G2 = G2A + G2B High level, L = low level, X = don't care

Figure 4-22.

Decoder Connections

## 4.2.7 Decoder/Demultiplexer (U30).

These Schottky-clamped circuits are designed to be used in high performance memory decoding or data routing applications requiring very short propagation delay times. This device contains two separate two-line to four-line decoders in one package. The active-low enable input can be used as a data line in demultiplexing The device features fully buffered inputs, presenting applications. only one normalized load to its driving circuit. All inputs are clamped with high performance Schottky diodes tosuppress line-ringing. For logic and connections, see Figure 4-23.



Logic Diagram



H = high level, L = low level, X = don't care

Figure 4-23. Decoder/Demultiplexer Connections

## 4.2.8 Data Selector/Multiplexer (U13).

This data selector/multiplexer contains full on-chip decoding to select one of eight data sources. A strobe input must be at a low logic level to enable the device. A high level at the strobe forces the W output high and the Y output low. See Figure 4-24 for logic and connections.

### Connection Diagram



#### Truth Table

|    | 1    | NPUT       | 8      | OUT | PUTS |
|----|------|------------|--------|-----|------|
| \$ | ELEC | т          | STROBE |     |      |
| c  | B    | •          | S .    | Ŧ   | W    |
| X  | х    | <b>X</b> , | н      | L   | н    |
| L  | L    | L          | L      | DO  | 00   |
| L  | ι    | н          | L      | D1  | DI   |
| L  | н    | L          | ι.     | D2  | D2   |
| L  | н    | н          | ι ι    | D3  | D3   |
| н  | ι    | L          | L      | D4  | D4   |
| н  | L    | н          | ι      | D5  | D5   |
| н  | н    | ι          | L      | D6  | D6   |
| н  | н    | н          | ι I    | 07  | 07   |

H = High Level, L = Low Level, X = Don't Care E0, E1 . . . E15 = the complement of the level of the ective E input

D0, D1 . . . D7 = the level of the respective D input

# Figure 4-24. Data Selector/Multiplexer Logic and Connections

# DWM-00420-00 REV. A00

Logic Diagram





4.2.9 Quad Two-Line to One-Line Data Selector/Multiplexer (U61). This data selector/multiplexer contains drivers to supply full on-chip data selection to the four output gates. A separate strobe input is provided. A four-bit word is selected from one of two sources and is routed to the four inputs. For logic and connections see Figure 4-25.



Logic Diagram





Truth Table

|        | INPUTS |   |   | OUTPUT Y |
|--------|--------|---|---|----------|
| STROBE | SELECT |   | 8 | i<br>1   |
| н      | x      | × | x | L        |
| L      | L      | L | x | L        |
| L      | L      | н | x | н        |
| L      | н      | х | L | . L      |
| L      | н      | x | н | н        |

H = High Level, L = Low Level, X = Don't Care

Figure 4-25. Quad 2-Line to 1-line Data Selector/Multiplexer Connections 4.2.10 Quad Inverting Two-Line to One-Line Data Selector/Multiplexer (U18, U19).

This data selector/multiplexer contains inverters and drivers to supply full on-chip data selection to the four output gates. A separate strobe input is provided. A four-bit word is selected from one of two sources and is routed to the four inputs. For logic and connections see Figure 4-26.



Logic Diagram





Truth Table

| OUTPUT Y |    |            | INPUTS |        |
|----------|----|------------|--------|--------|
| · ·      | 8  | <b>A</b> , | SELECT | STROBE |
| н        | x  | x          | ×      | н      |
| . н      | Χ. | L          | L      | L      |
| . L      | x  | н          | - L    | L      |
| H        | L  | x          | н      | ι      |
| L        | н  | x          | н      | L      |

Figure 4-26. Quad Inverting 2-Line to 1-Line Data Selector/Multiplexer Connections

4.2.11 Four-Bit Binary Counter With Asynchronous Clear (U75). This device is a synchronous, presettable, 4-bit binary counter featuring an internal carry look-ahead for applications in high-speed counting designs. Synchronous operation is provided by having all flip-flops clocked simultaneously so that the outputs change coincident with each other when so instructed by the count-enable internal gating. This mode of operation eliminates the inputs and counting spikes which normally output are associated with asynchronous (ripple clock) counters. A buffered clock input triggers the four flip-flops on the positive-going edge of the clock.

The counter is fully programmable; that is, the outputs may be preset to either level. Presetting is synchronous with the clock, and takes place regardless of the levels of the count enable inputs. A LOW level on the Parallel Enable ( $\overline{PE}$ ) input disables the counter and causes the data at the D inputs to be loaded into the counter on the next LOW-to-HIGH transition of the clock. The reset (clear) function is asynchronous. A LOW level on the Master Reset ( $\overline{MR}$ ) input sets all four of the flip-flop outputs LOW, regardless of the levels of the CP,  $\overline{PE}$ , CET, and CEP inputs.

carry look-ahead circuitry provides for cascading counters for The n-bit synchronous applications without additional gating. Instrumental in accomplishing this function are two Count Enable inputs (CET \* CEP) and a Terminal Count (TC) output. Both count enable inputs must be HIGH to count. The CET input is fed forward to enable the ΤC output. The TC output thus enabled, will produce a HIGH level portion of the Q output. This HIGH level TC pulse is used to enable successive cascading stages. For logic, connections, and timing, see Figure 4-27.

DWM-00420-00 REV. A00



Logic Symbol



Logic Diagram





## **MODE SELECT - FUNCTION TABLE**

| OPERATING         |    | INPUTS |      |      |      |    |       | OUTPUTS |  |
|-------------------|----|--------|------|------|------|----|-------|---------|--|
| MODE              | MR | СР     | CEP  | CET  | PE   | Dn | Qn    | тс      |  |
| Reset (Clear)     | L  | x      | ×    | ×    | x    | х  | L     | L       |  |
| Parallel Load     | н  | +      | X    | Х    | I    | I  | L     | L       |  |
|                   | н  | , t    | x    | x    | 1    | h  | н     | (b)     |  |
| Count             | н  | •      | h    | h    | h(d) | X  | count | (b)     |  |
| Hold (do nothing) | н  | X      | I(c) | X    | h(d) | X  | 9n    | (b)     |  |
|                   | н  | х      | x    | l(c) | h(d) | x  | 9n    | L       |  |

H = HIGH voltage level steady state

L = LOW voltage level steady state.

h = HIGH voltage level one setup time prior to the LOW-to-HIGH clock transition.

I = LOW voltage level one setup time prior to the LOW-to-HIGH clock transition

X = Don't care

g = Lower case letters indicate the state of the referenced output prior to the LOW-to-HIGH clock transition

= LOW-to-HIGH clock transition

#### NOTES

(b) The TC output is HIGH when CET is HIGH and the counter is at Terminal Count (HHHH for "161")

(c) The HIGH to LOW transition of CEP or CET on the 54/74161 should only occur while CP is HIGH for conventional operation

(d) The LOW to HIGH transition of PE on the 54 /74181 should only occur while CP is HIGH for conventional operation



#### TYPICAL CLEAR, PRESET, COUNT AND INHIBIT SEQUENCES

Figure 4-27 (SH2 of 2). Binary Counter with Asynchronous Clear Logic and Connections

4.2.12 Four-Bit Binary Counter With Synchronous Clear (U23, U24, U74).

This device is a synchronous presettable 4-bit binary counter featuring an internal carry look-ahead for applications in high-speed counting designs. Synchronous operation is provided by having all clocked simultaneously so that the outputs change flip-flops coincident with each other when so instructed by the count-enable inputs and internal gating. This mode of operation eliminates the output counting spikes which are normally associated with asynchronous (ripple clock) counters. A buffered clock input triggers the four flip-flops on the positive-going edge of the clock.

The counter is fully programmable; that is, the outputs may be preset to either level. Presetting is synchronous with the clock, and takes place regardless of the levels of the count enable inputs. A LOW level on the Parallel Enable ( $\overline{PE}$ ) input disables the counter and causes the data at the D inputs to be loaded into the counter on the next LOW-to-HIGH transition of the clock. The reset (clear) function is synchronous with the clock. The Synchronous Reset ( $\overline{SR}$ ), when LOW one setup time before the LOW-to-HIGH transition of the clock, overrides the CEP, CET, and  $\overline{PE}$  inputs, and causes the outputs to go LOW coincident with the positive clock transition.

The carry look-ahead circuitry provides for cascading counters for n-bit synchronous applications without additional gating. Instrumental in accomplishing this function are two Count Enable inputs (CET - CEP) and a Terminal Count (TC) output. Both count enable inputs must be HIGH to count. The CET input is fed forward to enable the TC output. The TC output thus enabled will produce a HIGH output pulse with a duration approximately equal to the HIGH level portion of the Q output. This HIGH level TC pulse is used to enable successive cascaded stages. For logic, connections and timing, see Figure 4-28.

4-66



Pin Configuration



Logic Diagram



Figure 4-28 (SH1 of 2). Binary Counter with Synchronous Clear Logic and Connections

DWM-00420-00 REV. A00

#### **MODE SELECT - FUNCTION TABLE**

| OPERATING         |      |    | INP  | UTS  |      |    | OUTPUTS        |     |  |  |
|-------------------|------|----|------|------|------|----|----------------|-----|--|--|
| MODE              | SR   | СР | CEP  | CET  | PE   | Dn | Qn             | TC  |  |  |
| Reset (Clear)     | Ι    | t  | x    | X    | X    | x  | L              | L   |  |  |
| Parallel Load     | h(d) | +  | X    | X    | 1    | 1  | L              | L   |  |  |
|                   | h(d) | ł  | X    | X    | 1    | h  | н              | (b) |  |  |
| Count             | h(d) | 1  | h    | h    | h(d) | X  | count          | (b) |  |  |
| Hold (do nothing) | h(d) | Х  | l(c) | X    | h(d) | X  | q <sub>n</sub> | (b) |  |  |
|                   | h(d) | Х  | X    | l(c) | h(d) | ×  | q <sub>n</sub> | L   |  |  |

H = HIGH voltage level steady state.

L = LOW voltage level steady state.

h = HIGH voltage level one setup time prior to the LOW-to-HIGH clock transition

I = LOW voltage level one setup time prior to the LOW-to-HIGH clock transition

X = Don't care.

q = Lower case letters indicate the state of the referenced output prior to the LOW-to-HIGH clock transition.

= LOW-to-HIGH clock transition

NOTES

(b) The TC output is HIGH when CET is HIGH and the counter is at Terminal Count (HHHH for "163").

(c) The HIGH-to-LOW transition of CEP or CET on the 54774183 should only occur while CP is HIGH for conventional operation

(d) The LOW to HIGH transition of PE or SR on the 54, 74 t63 should only occur while CP is HIGH for conventional operation

#### TYPICAL CLEAR, PRESET, COUNT AND INHIBIT SEQUENCES



Sequence:

(1) Clear outputs to zero

(2) Preset to binary twelve

(3) Count to thirteen, fourteen, fifteen, zero, one, and two

(4) Inhibit

Figure 4-28 (SH2 of 2). Binary Counter with Synchronous Clear Logic and Connections

4.2.13 Eight-Bit Serial In/Parallel Out Shift Register (U66). This 8-bit shift register features gated serial inputs and an asynchronous clear. A low logic level at either input inhibits entry of the new data, and resets the first flip-flop to the low level at the next clock pulse, thus providing complete control over incoming A high logic level on either input enables the other data. input. which then determines the state of the first flip-flop. Data at the serial inputs may be changed while the clock is high or low, but only information meeting the setup requirements will be entered. Clocking occurs on the low-to-high level transition of the clock input. All inputs are diode-clamped to minimize transmission-line effects. For logic and connections see Figure 4-29.



Connection Diagram

Timing Diagram

Figure 4-29. Eight-Bit Shift Register Logic and Connections

DWM-00420-00 REV. A00

4-69

4.2.14 Eight Bit Parallel In/Serial Out Shift Register (U67). This parallel-in or serial-in, serial-out shift register features gated clock inputs and an overriding clear input. The load mode is established by the shift/load input. When high, this input enables the serial data input and couples the eight flip-flops for serial shifting with each clock pulse. When low, the parallel (broadside) data inputs are enabled and synchronous loading occurs on the next clock pulse. During parallel loading, serial data flow is inhibited. Clocking is accomplished on the low-to-high level edge of the clock pulse through a two-input NOR gate, permitting one input to be used as a clock-enable or clock-inhibit function. Holding either of the clock inputs high inhibits clocking; holding either low enables the other clock input. This allows the system clock to be free-running, and the register can be stopped on command with the other clock input. The clock-inhibit input should be changed to the high level only while the clock input is high. A buffered, direct clear input overrides all other inputs, including the clock, and sets all flip-flops to zero. For logic and connections see Figure 4-30.

### Connection Diagram



Truth Table

|                  | INAL            | INTER           | INPUTS   |   |   |            |      |          |  |  |
|------------------|-----------------|-----------------|----------|---|---|------------|------|----------|--|--|
| OUTPUT           | UTS             | OUTP            | PARALLEL |   |   | CLOCK PARA |      | SHIFT/ C |  |  |
| QH               | QB              | QA              | ΑΗ       |   |   | INHIBIT    | LOAD | CLEAR    |  |  |
| L                | L               | L               | x        | x | X | ×          | x    | L        |  |  |
| 0,0              | Q <sub>BO</sub> | Q <sub>A0</sub> | ×        | х | L | L          | x    | н        |  |  |
| h                | ь               | а               | ah       | x | + | L          | L    | н        |  |  |
| Q <sub>G</sub> , | QAr             | н               | x        | н | 1 | L          | н    | н        |  |  |
| 0 <sub>G</sub> , | 0.4             | L.              | ×        | L | , | L          | н    | н        |  |  |
| 0,0              | Q <sub>BO</sub> | Q <sub>A0</sub> | ×        | x | ÷ | н          | x    | н        |  |  |

H = High Level (steady state), L = Low Level (steady state)

X = Don't Care (any input, including transitions)

t = Transition from low to high level

a . . . h = The level of steady-state input at inputs A through H, respectively.

 $\Omega_{A0},\,\Omega_{B0},\,\Omega_{H0}$  = The level of  $\Omega_A,\,\Omega_B$  or  $\Omega_H,\,\text{respectively},\,\text{before the indicated}$ 

steady-state input conditions were established.

 $\Omega_{An}, \Omega_{Gn}$  = The level of  $\Omega_A$  or  $\Omega_G$ , respectively, before the most recent  $\uparrow$  transition of the clock

Figure 4-30. Eight-Bit Parallel In/Serial Out Shift Register Logic and Connections (Sheet 1 of 2) Logic Diagram





Figure 4-30. Eight-Bit Parallel In/Serial Out Shift Register Logic and Connections (Sheet 2 of 2)

DWM-00420-00 REV. A00

## 4.2.15 Quad D Flip-Flops With Clear (U63)

These positive-edge-triggered flip-flops utilize TTL circuitry to implement D-type flip-flop logic. They feature a direct clear input and complementary outputs from each flip-flop. Information at the D inputs meeting the setup time requirements is transferred to the Q outputs on the positive-going edge of the clock pulse. Clock triggering occurs at a particular voltage level and is not directly related to the transition time of the positive-going pulse. When the clock input is at either the high or low level, the D input signal has no effect at the output. For logic and connections see Figure 4-31.

## Connection Diagram







state input

Truth Table

|       | INPUTS OUTPUTS |   |    | PUTS | H = High Level (steady state)                  |
|-------|----------------|---|----|------|------------------------------------------------|
| CLEAR | CLOCK          | D | ٥  | āt   | L = Low Level (steady state)<br>X = Don't Care |
| L     | x              | x | L  | н    | t = Transition from low to high level          |
| н     | t              | н | н  | L    | $Q_0$ = The level of Q before the indicate     |
| н     | t              | L | L  | H.   | conditions were established.                   |
| Н     | L              | x | 00 | Ō0   | t = 175, LS175, and S175 only                  |

Figure 4-31. Quad D Flip-Flops With Clear, Logic and Connections

4.2.16 Inverting Tri-State Buffer (U34, U65, U72). For logic and connections see Figure 4-32.



Connection Diagram

# Figure 4-32. Inverting Tri-State Buffer Logic and Connections

DWM-00420-00 REV. A00

4.2.17 Octal D-Type Flip-Flop With Clear (U35, U79). These monolithic, positive-edge-triggered flip-flops utilize TTL circuitry to implement D-type flip-flop logic with a direct clear input.

Information at the D inputs meeting the setup time requirements is transferred to the Q outputs on the positive-going edge of the clock pulse. Clock triggering occurs at a particular voltage level and is not directly related to the transition time of the positive-going pulse. When the clock input is at either the high or low level, the D input signal has no effect at the output. For logic and connections see Figure 4-33.



#### Truth Table

| (EACH FLIP-FLOP) |        |   |    |  |  |  |  |  |
|------------------|--------|---|----|--|--|--|--|--|
| IN               | OUTPUT |   |    |  |  |  |  |  |
| CLEAR            | CLOCK  | Q |    |  |  |  |  |  |
| L                | х      | х | L  |  |  |  |  |  |
| н                | t      | н | н  |  |  |  |  |  |
| н                | t      | L | L  |  |  |  |  |  |
| н                | L      | х | 00 |  |  |  |  |  |





Figure 4-33. Octal D-Type Flip-Flop With Clear, Logic And Connections

4.2.18 Octal D-Type Transparent Latch (U39).

This 8-bit register is a transparent D-type latch with three-state outputs. While the enable (G) is high, the Q outputs follow the data (D) inputs. When the enable is low, the output will be latched at the level of the data that was set up. For logic and connections see Figure 4-34.

## Connection Diagram

Logic Diagram





Truth Table

| OUTPUT  | ENABLE | D | OUTPUT |  |
|---------|--------|---|--------|--|
| CONTROL | G      | U | 001701 |  |
| L       | н      | н | н      |  |
| L.      | н      | L | L      |  |
| L       | 1 L    | x | 00     |  |
| н       | x      | x | z      |  |



4.2.19 Tri-State D Flip-Flops (U37, U38, U40, U76, U77, U80). These 3-bit registers contain D-type flip-flops with totem-pole tri-state outputs capable of driving highly capacitive or low impedance loads. When the output control is taken to a high logic level, the outputs go into the high impedance state. When a low logic level is applied to the output control, data at the D inputs are loaded into their respective flip-flops on the next positive-going transition of the clock. For logic and connections see Figure 4-35.









Truth Table

D

н

L

х

CLOCK

1

L

OUTPUT

н

L

00

OUTPUT

CONTROL

L

L

L

н

4-76

4.2.20 1024 X 4-Bit Static Random Access Memory (U41, U42). This device is a 4096-bit static Random Access Memory organized as 1024 words by 4 bits and requires no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided and a separate chip select (CS) lead allows easy selection of an individual package. For logic and connections, see Figure 4-36.



## WAVEFORMS



#### NOTES

3  $\overrightarrow{\mathsf{WE}}$  is high for a Read Cycle.

If the CS low transition occurs simultaneously with the WE low transition, the output buffers remain in a high impedance state.
 WE must be high during all address transitions.

WRITE CYCLE



4.2.21 Bus Comparator (U27, U68).

This device compares two binary words of two to six bits in length and indicates matching (bit-for-bit) of the two words. Inputs for one word are TTL inputs, whereas inputs of the second word are high impedance receivers driven by a terminated data bus. The output has a latch that is strobe controlled. The transfer of information to the output occurs when the STROBE input goes from a logical 1 to a logical 0 state. Inputs may be changed while the STROBE is at the logical 1 level, without affecting the state of the output. For logic and connections, see Figure 4-37.





Connection Diagram



## Truth Table

| CONDITION    | TROOPE | OUTPUT             |                    |  |  |
|--------------|--------|--------------------|--------------------|--|--|
| CONDITION    | SINUBE | DM71/8131          | DM71/8136          |  |  |
| T = B, T ≠ B | н      | Q <sub>N−1</sub> * | Q <sub>N-1</sub> * |  |  |
| T = B        | L      | L                  | н                  |  |  |
| T≠B          | L      | н                  | L                  |  |  |

\*Latched in previous state

Figure 4-37. Bus Comparator Connections

4.2.22 Tri-State Octal Buffers (U36).

This device provides eight, two-input buffers and employs Schottky TTL technology. One of the two inputs to each buffer is used as a control line to gate the output into the high impedance state, while the other input passes the data through the buffer with no inversion. Four buffers are enabled from one common line and the other four are enabled from another common line. The outputs are placed in the tri-state condition by applying a high logic level to the enable pins. For logic and connections, see Figure 4-38.





Truth Table

| INP | UTS | OUTPUT |
|-----|-----|--------|
| Ĝ   | A   | Y      |
| н   | x   | Z      |
| L   | н   | н      |
| L   | ι   | L      |

Figure 4-38. Tri-State Octal Buffer Logic and Connections

4.2.23 Bidirectional Transceiver (U43, U64).

This device is a Schottky device that provides bidirectional drive for bus oriented microprocessor systems. Transmit/Receive inputs determine the direction of logic signals through the device. The Chip Disable input disables both A and B ports by placing them in a tri-state condition. For logic and connections, see Figure 4-39.

## Connection and Logic Diagram



Logic Table

|                               | Inputs | <b>Resulting Conditions</b> |          |  |  |
|-------------------------------|--------|-----------------------------|----------|--|--|
| Chip Disable Transmit/Receive |        | A Port                      | B Port   |  |  |
| 0                             | 0      | OUT                         | 1N       |  |  |
| 0                             | 1      | IN                          | OUT      |  |  |
| 1                             | X      | TRI-STATE                   | TRISTATE |  |  |

X = Don't Care

# Figure 4-39. Bidirectional Transceiver Logic and Connections

## SECTION V

## MAINTENANCE AND TROUBLESHOOTING

## 5.0 INTRODUCTION

The AM-420 circuit board performs to full capacity with a minimum of maintenance. This section describes maintenance and troubleshooting procedures and procedures for handling warranty returns.

## 5.1 CIRCUIT BOARD CHECKOUT/TROUBLESHOOTING PROCEDURES

The AM-420 circuit board was fully tested before it left Alpha Microsystems and will operate satisfactorily in the system if the hardware and software requirements of Sections Two and Three of this manual are met. Should a problem arise, use the following procedures to identify and locate the fault.

- 1. Check the circuit boards for proper seating in the slot.
- 2. Check the hash totals on the latest operating system.
- 3. Check all power connections for correct voltages.
- Check jumper options to ensure correctness of application. These include boot jumper and interrupt jumper on AM-100/T, or AM-100.
- 5. Verify that the fault is in the AM-420 and not either in the system or in the peripherals. This can best be accomplished with substitution of a known good circuit board.
- 6. Check the error LED's on the AM-420. They are read with the right most being the LSB.

The errors are as follows:

a. Read data error

DWM-00420-00 REV. A00

5-1

b. Memory test error

c. Read CRC error

d. Drive not ready error

e. Drive Fault error

f. Restore error

g. Seeks error

7. Perform the diagnostic tests.

5.2 WARRANTY PROCEDURES

This circuit board is covered by warranty issued by Alpha Microsystems, Irvine, California. Complete details of the warranty are included with the circuit board. Should a problem arise with this circuit board, call your dealer or the Alpha Micro International Support/Services Group for information.

## SECTION VI

SCHEMATIC AND PARTS LIST

| REF<br>DESIG | MFG<br>TYPE NO. | PAR.<br>NO. | REF<br>DESIG | MFG<br>TYPE NO. | PAR<br>NO. |
|--------------|-----------------|-------------|--------------|-----------------|------------|
| Ū1           | 74LS04          | _           | U24          | 74LS163         | 4.2.12     |
| U2           | 74LS02          | _           | U25          | 74LS138         | 4.2.6      |
| U3           | 74800           | -           | U26          | 74LS138         | 4.2.6      |
| U4           | 74LS08          | -           | U27          | 8131            | 4.2.21     |
| U5           | 74LS74          | 4.2.4       | U28          | 74LS367         | 4.2.18     |
| U6           | 74LS08          | -           | U29          | 74LS30          | -          |
| <b>U7</b>    | 74LS11          | -           | U30          | 74LS139         | 4.2.7      |
| U8           | 74LS00          | -           | U31          | DWB-00422-00    | _          |
| U9           | 4MHz Osc.       | -           | U32          | 748374          | 4.2.20     |
| <b>ت</b> 10  | 2940            | 4.2.2       | U33          | DWB-00423-00    | -          |
| U11          | Z80             | 4.2.1       | U34          | 74LS240         | 4.2.16     |
| U12          | 74LS08          | -           | U35          | 74LS273         | 4.2.17     |
| U13          | 74LS151         | 4.2.8       | U36          | 81LS97          | 4.2.22     |
| U14          | 74LS74          | 4.2.4       | U37          | 74LS374         | 4.2.19     |
| U15          | 9401            | 4.2.3       | U38          | 74LS374         | 4.2.19     |
| U16          | 74LS32          | -           | U39          | 74LS373         | 4.2.18     |
| U17          | 74LS112         | 4.2.5       | U40          | 74LS374         | 4.2.19     |
| U18          | 74LS158         | 4.2.10      | U41          | 2114            | 4.2.20     |
| U19          | 74LS158         | 4.2.10      | U42          | 2114            | 4.2.20     |
| U20          | 74LS08          | -           | U43          | 8304            | 4.2.23     |
| U21          | 2940            | 4.2.2       | U44          | 7805            | _          |
| U22          | 75452           | -           | U45          | 7805            | _          |
| U23          | 74LS163         | 4.2.12      | U46          | 7805            | -          |

Table 6-1. AM-420 Component Cross-Reference List

6-1

| REF                                                                                                                                                                         | MFG                                                                                                                                                                                                    | PAR.                                                                                                                                                         | REF                                                                | MFG                                                                                            | PAR                                                                                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| DESIG.                                                                                                                                                                      | TYPE NO.                                                                                                                                                                                               | NO.                                                                                                                                                          | DESIG                                                              | TYPE NO.                                                                                       | NO.                                                                                    |
| U47<br>U49<br>U50<br>U51<br>U52<br>U53<br>U55<br>U56<br>U57<br>U58<br>U59<br>U60<br>U61<br>U62<br>U63<br>U64<br>U63<br>U64<br>U65<br>U64<br>U65<br>U66<br>U67<br>U68<br>U71 | 7805<br>75113<br>75115<br>74LS08<br>74LS00<br>74LS74<br>74LS74<br>74LS193<br>74LS193<br>74LS244<br>74LS32<br>74LS14<br>74LS74<br>74LS74<br>74LS175<br>8304<br>74LS240<br>74LS240<br>74LS164<br>74LS138 | -<br>-<br>-<br>4.2.4<br>4.2.4<br>-<br>-<br>-<br>-<br>4.2.9<br>4.2.4<br>4.2.15<br>4.2.23<br>4.2.15<br>4.2.15<br>4.2.13<br>4.2.14<br>4.2.11<br>4.2.21<br>4.2.6 | U72<br>U73<br>U74<br>U75<br>U76<br>U77<br>U78<br>U79<br>U80<br>U81 | 74LS240<br>74LS10<br>74LS163<br>74LS374<br>74LS374<br>74LS273<br>74LS273<br>74LS374<br>74LS244 | 4.2.16<br>4.2.14<br>4.2.12<br>4.2.11<br>4.2.19<br>4.2.13<br>4.2.17<br>4.2.19<br>4.2.11 |

Table 6-1 (Con't). AM-420 Component Cross-Reference List

6-2

FBILL # DWB-00420-00

REV.BO1

21 SEP,1981

DESCRIPTION 8" WINCHESTER CONTROLLER 8MB

PART NUMBER DESCRIPTION

| 1  | DWF-00420-00                   | P.C.B. DETAIL DWG, AM-420                                                                                                        | 1      |  |  |  |  |
|----|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|
| 2  | CNA-00006-00                   | P.C.B. DETAIL DWG, AM-420<br>CONN RECEPTACLE SHORTING 2CONT BLK<br>HEADER 50 PIN W/O EJC RT ANGLE<br>HEADER STRIP LINE PLUG MALE | 1      |  |  |  |  |
| 3  | CNF-00002-11                   | HEADER 50 PIN W/O EJC RT ANGLE                                                                                                   | 1      |  |  |  |  |
| 4  | CNF0003302                     | HEADER STRIP LINE PLUG MALE                                                                                                      | 2      |  |  |  |  |
| 5  | CNS-00020-00                   | SOCKET 20 PIN DIP                                                                                                                | 1      |  |  |  |  |
| 6  | CNS-00024-00                   | SOCKET 24 PIN DIP                                                                                                                | 1      |  |  |  |  |
| 7  | CNS-00028-00                   | SOCKET 28 PIN DIP                                                                                                                | 2      |  |  |  |  |
| 8  | CNS-00040-00                   | SOCKET 40 PIN DIP                                                                                                                | 1      |  |  |  |  |
| 9  | CPN-00474-01                   | SOCKET 20 PIN DIP<br>SOCKET 24 PIN DIP<br>SOCKET 28 PIN DIP<br>SOCKET 40 PIN DIP<br>CAPACITOR .47 UF<br>CAPACITOR .15 UF 20V     | 33     |  |  |  |  |
| 10 | CPP-00156-01                   | CAPACITOR 15 UF 20V                                                                                                              | 8      |  |  |  |  |
| 11 | DI0-00001-00                   | LED                                                                                                                              |        |  |  |  |  |
| 12 | DWB-00422-00                   | ASSY PROM PRILOD                                                                                                                 | 1      |  |  |  |  |
| 13 | DWB-00423-00                   | ASSY PROM ROM420<br>BUS BAR PC MOUNT 9 POSITION<br>BUS BAR PC MOUNT 11 POSITION<br>HEAT SINK .750WI .375HT .750LG                | j.     |  |  |  |  |
| 14 | HDM0000309                     | BUS BAR PC MOUNT 9 POSITION                                                                                                      | 2      |  |  |  |  |
| 15 | HDM-00003-11                   | BUS BAR PC MOUNT 11 POSITION                                                                                                     | 1      |  |  |  |  |
| 16 | HDM-00007-00                   | HEAT SINK .750WI .375HT .750LG                                                                                                   | 4      |  |  |  |  |
| 17 | HDN-10000-06                   | NUT HEX 6-32 KEP INT/EXT CAD STU                                                                                                 | 4      |  |  |  |  |
| 18 | HDS-10506-06                   | SCREW, PHMS, SS, PH RECESS, 6-32 X 3/8<br>IC DHAD 2 INPUT NAND GATE                                                              | 4      |  |  |  |  |
| 19 | 11. W. M. W. M. M. M. M. M. M. |                                                                                                                                  | ••••   |  |  |  |  |
| 20 |                                | IC QUAD 2 INPUT NAND GATE                                                                                                        | 1      |  |  |  |  |
| 21 | IC1-07402-01                   |                                                                                                                                  | 1.     |  |  |  |  |
| 22 | IC1-07404-01                   | IC HEX INVERTER                                                                                                                  | 1.     |  |  |  |  |
| 23 | IC1-07408-01                   | IC QUAD 2 INPUT AND GATE                                                                                                         | 3      |  |  |  |  |
| 24 | IC1-07408-02                   | IC QUAD 2 INPUT AND GATE                                                                                                         | 2      |  |  |  |  |
| 25 | IC1-07410-01                   | IC TRIPLE 3 INPUT NAND GATE                                                                                                      | 1      |  |  |  |  |
| 26 | IC1-07411-01                   | IC TRIPLE 3 INPUT AND GATE                                                                                                       | 1      |  |  |  |  |
| 27 | IC1-07414-01                   | IC HEX INVERTER W/HYSTERESIS                                                                                                     | 1      |  |  |  |  |
| 28 | IC1-07430-01                   | IC TRIPLE 3 INPUT AND GATE<br>IC HEX INVERTER W/HYSTERESIS<br>IC 8 INPUT NAND GATE<br>IC QUAD 2 INPUT OR GATE                    | 1      |  |  |  |  |
| 29 | IC1-07432-01                   | IC QUAD 2 INPUT OR GATE                                                                                                          | 2<br>5 |  |  |  |  |
| 30 | IC1-07474-01                   | IC DUAL D FLIPFLOP                                                                                                               | 5      |  |  |  |  |
| 31 | IC1-08131-00                   |                                                                                                                                  | 2      |  |  |  |  |
| 32 | IC1-08197-01                   |                                                                                                                                  | 1.     |  |  |  |  |
| 33 | IC1-08304-00                   |                                                                                                                                  | 2      |  |  |  |  |
| 34 | IC1-74112-01                   | IC DUAL J-K NEGATIVE FLIPFLOP                                                                                                    | Ĩ.     |  |  |  |  |
| 35 | 101-74138-01                   | IC DECODER 3 TO 8 LINE                                                                                                           | 3      |  |  |  |  |
| 36 | 101-74139-01                   | IC DECODER 2 TO 4 LINE DUAL<br>IC 8 INPUT MULTIPLEXER                                                                            | 1.     |  |  |  |  |
| 37 | 101-74151-01                   | IU 8 INFUT MULTIFLEXER                                                                                                           |        |  |  |  |  |

# PART NUMBER DESCRIPTION

QTY

| •••• •••• ••• |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | *** *** *** *** *** *** *** *** |
|---------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 38            | TC1-74157-02 | IC QUAD 2 TO 1 DATA SELECTOR<br>IC QUAD 2 TO 1 DATA SELECTOR<br>IC SYNCHRONOUS 4 BIT COUNTER<br>IC SYNCHRONOUS COUNTER<br>IC 8 BIT SER IN PAR OUT SR<br>IC 8 BIT PAR IN SER OUT SR<br>IC COUNTER 4 BIT BINARY<br>IC OCTAL BUS DRIVER INVERTING<br>IC OCTAL BUS DRIVER NONINVERT<br>IC OCTAL D REGISTER W/RESET<br>IC OCTAL D FLIPFLOP<br>IC OCTAL AND POWER DRIVER<br>IC REGULATOR + SV<br>RAM 1K X 4 BIT STATIC<br>IC OSCILLATOR 4MHZ<br>IC MICROPROCESSOR Z-80<br>IC DMA ADDRESS GENERATOR<br>IC GENERATOR CRC<br>RESISTOR 1 K 1/4W 5% CAR<br>RESISTOR 330 OHM 1/4W 5% CAR | 1                               |
| 39            | IC1-74158-01 | IC QUAD 2 TO 1 DATA SELECTOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2                               |
| 40            | IC1-74161-01 | IC SYNCHRONOUS 4 BIT COUNTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                               |
| 41            | IC1-74163-01 | IC SYNCHRONOUS COUNTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3                               |
| 42            | IC1-74164-01 | IC 8 BIT SER IN PAR OUT SR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1                               |
| 43            | IC1-74166-00 | IC 8 BIT PAR IN SER OUT SR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | İ.                              |
| 44            | IC1-74193-01 | IC COUNTER 4 BIT BINARY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2                               |
| 45            | IC1-74240-01 | IC OCTAL BUS DRIVER INVERTING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3                               |
| 46            | IC1-74244-01 | IC OCTAL BUS DRIVER NONINVERT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2                               |
| 47            | IC1-74273-01 | IC OCTAL D REGISTER W/RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2                               |
| 48            | IC1-74367-00 | IC HEX BUFFER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.                              |
| 49            | IC1-74373-01 | IC OCTAL D FLIPFLOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                               |
| 50            | IC1-74374-01 | IC OCTAL D FLIPFLOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 6                               |
| 51            | IC1-74374-02 | IC OCTAL D FLIPFLOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2                               |
| 52            | ICI-75115-00 | DUAL DIFFERENTIAL RECEIVER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1.                              |
| 53            | ICI-75452-00 | IC DUAL NAND POWER DRIVER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1.                              |
| 54            | ICL-07805-00 | IC REGULATOR + 5V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4                               |
| 55            | ICM-02114-04 | RAM 1K X 4 PIT STATIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2                               |
| 56            | ICS-00003-00 | IC OSCILLATOR 4MHZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                               |
| 57            | ICS-00080-00 | IC MICROPROCESSOR Z-80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3.                              |
| 58            | ICS-02940-00 | IC DMA ADDRESS GENERATOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2                               |
| 59            | ICS-09401-00 | IC GENERATOR CRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                               |
| 60            | RS2-00102-00 | RESISTOR 1 K 1/4W 5% CAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 8                               |
| 61            | RS2-00331-00 | RESISTOR 330 DHM 1/4W 5% CAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | śţ                              |
| 62            | RS2-00471-00 | RESISTOR 470 OHM 1/4W 5% CAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.                              |
| 63            | RSN-00008-00 | RES PACK 8 PIN SIP 1 K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1.                              |
| 64            | ICI-75113-00 | DUAL DIFFERENTIAL DRIVER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | j                               |
| 65            | IC1-74175-01 | IC QUAD D FLIPFLOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1.                              |
| 66            | RS2-00221-00 | RESISTOR 220 OHM 1/4W 5% CAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 6                               |
| 67            | DWL-00420-00 | * * * * RECORD NOT FOUND * * * *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                               |
| 68            | CBW-00026-20 | WIRE 26AWG BUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                               |
| 69            | HDM-00012-00 | THERMAL GREASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0<br>N                          |
| 70            | DWS-30000-04 | SPEC REGULATOR MTG ASSY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                               |
| 71            | LBL-00018-19 | RESISTOR 330 OHM 174W 5% CAR<br>RESISTOR 470 OHM 174W 5% CAR<br>RES PACK 8 PIN SIP 1 K<br>DUAL DIFFERENTIAL DRIVER<br>IC QUAD D FLIPFLOP<br>RESISTOR 220 OHM 174W 5% CAR<br>* * * * RECORD NOT FOUND * * * *<br>WIRE 26AWG BUS<br>THERMAL GREASE<br>SPEC REGULATOR MTG ASSY<br>LABEL PCB SERIAL I.D. AM 420                                                                                                                                                                                                                                                                                                                                                                                                            | 1                               |

2/2



DWM-00420-00 REV. AOO

1/4





DWM-00420-00 REV. A00



|        |        | ٧      | OLTAGE       | AND GROUN | ND CHART                                    |
|--------|--------|--------|--------------|-----------|---------------------------------------------|
| +511   | +5V2   | +5Y3   | +5VA         | GND       | IC REFERENCE DESIGNATIONS                   |
| PIN 18 |        |        |              | PIN 9     | U42, U43                                    |
| PIN 20 |        |        |              | PIN 10    | 032, 35, 34, 35, 36, 37, 38, 39, 40, 41     |
| PIN 24 |        |        |              | PIN 12    | U3I                                         |
|        | PIN 16 |        |              | PIN 8     | 123, 24, 26, 27, 28, 19, 30, 25, 13, 17, 18 |
|        | PIN 14 |        |              | PIN 7     | U12,14,15,16,20,29                          |
|        | PIN 8  |        |              | PIN 22    | U21                                         |
|        | PIN 8  |        |              | PIN 4     | V22                                         |
|        |        | PIN 8  |              | PIN 22    | UID                                         |
|        |        | PIN II |              | PIN 29    | ឋា                                          |
|        |        | PIN 14 |              | PIN 7     | U1,2,3,4,5,6,7,8,9                          |
|        |        | PIN 20 | A LOS TRUCKS | PIN 10    | 10,00,17,78,19,60,61                        |
|        |        |        | PIN 14       | PIN 7     | 150,51,52,53,54,55,59,60,62,66,73           |
|        |        |        | PIN 16       | PIN 8     | V48,49,56,57,61,63,67,68,69,76,71,74,75     |
|        |        |        | PIN 20       | PIN 10    | 158, 64,65,72                               |

DWM-00420-00 REV. A00

4/4

|       | USER COMMENTS | TECHNICAL PUBLICATIONS FILE REFERENCE                                                                            |
|-------|---------------|------------------------------------------------------------------------------------------------------------------|
| FROM: | NAME          |                                                                                                                  |
|       | ADDRESS       | NOTE: Use this form to communicate any errors,<br>suggested changes, or general comments<br>about this document. |
|       | CITY          | lf necessary, call us at:<br>(714) 957-6076                                                                      |
|       | STATE ZIP     |                                                                                                                  |

DOCUMENT: TITLE/NUMBER/REVISION\_\_\_\_\_

COMMENTS:



FOLD