# TECHNICAL MANUAL F口R 

## AM-1 00

2-BDARD 16-BIT CPப



Manufactured By
ALPHA MICROSYSTEMS
17881 SKY PARK NDRTH
IRVINE, CALIFORNIA 92714

## 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.
"AMOS," "Alpha BASIC," and "AM-100" are trademarks of products and software of ALPHA MICROSYSTEMS, Irvine, California-92714 © 1978, 1979, ALPHA MICROSYSTEMS.


DOCUMENT: TITLE/NUMBER/REVISION

COMMENTS:

ATTN: EDUCATIONAL SERVICES DIVISION

FOLD

TABLE OF CONTENTS
Paragraph Page
SECTION 1 GENERAL DESCRIPTION
1.0 Introduction ..... 1-1
1.1 Circuit Board Description ..... 1-1
1.2 App1ication ..... 1-2
SECTION 2 OPERATING DATA
2.0 Introduction ..... 2-1
2.1 Capabilities and Specifications ..... 2-1
2.2 Interface Description and Wiring ..... 2-2
2.3 User Options ..... 2-6
2.4 Interrupt and DMA Options ..... 2-8
2.5 System Connections ..... 2-8
SECTION 3 PROGRAMMING
3.0 Introduction ..... 3-1
3.1 System Configuration ..... 3-1
3.2 Software Overview ..... 3-5
3.2 .1 Operating System ..... 3-5
3.2 .2 Assembly Language Program ..... 3-5
3.2 .3 Text Editor ..... 3-6
3.2 .4 Utility and Sort Programs ..... 3-6
3.2 .5 Alphabasic Program ..... 3-6
3.2 .6 Accounting Package ..... 3-7
3.2 .7 AlphaLisp ..... 3-7
3.2 .8 AlphaPascal ..... 3-7

SECTION 4 FUNCTIONAL THEORY OF OPERATION

4.1.3.3 Microm Chips ..... 4-18
4.1.3.4 Microinstruction Bus ..... 4-18
4.2 CPU Operations ..... 4-21
4.2 .1 Clock Generator ..... 4-34
4.2.2 State Code Decoder Logic ..... 4-35
4.2.3 Sequencer Operation ..... 4-35
4.2.4 Initialization and Status ..... 4-47
4.2.5 Data Access ..... 4-48
4.2.5.1 Addressing Operations ..... 4-50
4.2.5.2 Write Operations ..... 4-50
4.2.5.3 Read Operations ..... 4-51
4.2.6 DMA and Interrupt Operations ..... 4-51
4.2.6.1 CPU Chip Set Interrupts ..... 4-52
4.2.6.2 Vectored Interrupts ..... 4-53
4.2.6.3 DMA Operations ..... 4-53
4.3 CPU Microprocessor Chip Set Description ..... 4-54
4.3.1 System Components ..... 4-58
4.3.1.1 Registers ..... 4-59
4.3.1.2 Instruction Address Generation ..... 4-64
4.3.1.3 Microinstruction Bus ..... 4-65
4.3.1.4 Data Access Bus ..... 4-66
4.3.1.5 Microinstruction Storage ..... 4-66
4.3.2 CPU Operations ..... 4-66
4.3.2.1 CPU Sequencing ..... 4-67
4.3.2.2 Contro1 Lines ..... 4-75
Paragraph Page
4.3.3 Programmable Translation Array (PTA) ..... 4-78
4.3.3.1 Programmable Translation Array Conponents ..... 4-79
4.3.3.2 Programmable Translation Array Operations ..... 4-90
4.3.4 Microinstructions ..... 4-96
4.3.5 Microinstruction Bus Operation ..... 4-108
4.3.5.1 Bus Operation ..... 4-109
4.3.5.2 Microinstruction Bus Element Description ..... 4-109
4.3.5.3 Data Chip ..... 4-114
4.3.5.4 Control Chip ..... 4-114
4.3.5.5 Microinstruction ROM ..... 4-116
4.3.6 Data Access ..... 4-117
4.3.6.1 Input/Output Instructions ..... 4-118
4.3.6.2 Data/Address Lines ..... 4-134
4.3.6.3 Control Lines ..... 4-134
4.3.6.4 Interrupt, Reset, and Compute ..... 4-136
4.3.6.5 Input/Output Operations ..... 4-137
4.4 Circuit Module Description ..... 4-142
4.4.1 Four-Phase Clock Generator (Board 2, U12). ..... 4-143
4.4.2 Tri-State 4-Bit D Type Register (Board 1, U1, U9, U10) ..... 4-145
4.4.3 High-Speed Hex Inverter (Board 1, U7) ..... 4-146
4.4.4 Tri-State Buffers (Board 1, U5, U8, U22, U24, U26; Board 2, U45, U46, U48) ..... 4-147
4.4.5 Hex Tri-State Buffers (Board 2, U11, U47). ..... 4-148
4.4.6 Eight-Line to Three-Line Encoder (Board 2, U29, U30). ..... 4-149
4.4.7 Data Selector/Mu1tiplexer (Board 1, U16, U17, U18, U21) ..... 4-150
4.4 .8 NAND TTL-to-MOS Driver Board (Board 1, U2; U3) . ..... 4-151
4.4.9 D Positive-Edge-Triggered Flip-Flops with Preset and Clear (Board 2, U6, U18, U19, U23, U31, U32, U34, U36) ..... 4-152
4.4.10 Dual J-K Negative-Edge-Triggered F1ip-F1ops With Preset (Board 2, U10, U28, U40, U50, U51) ..... 4-153
4.4.11 Dual Retriggerable One-Shots With C1ear (Board 2, U22) ..... 4-154
4.4.12 Dual Voltage Controlled Oscillators (Board 2, U5) ..... 4-155
4.4.13 Decoder (Board 2, U7, U8, U42) ..... 4-156
4.4.14 D F1ip-F1ops With C1ear (Board 1, U13, U14, U25; Board 2, U10) ..... 4-157
4.4.15 Tri-State Octal Buffers (Board 1, J6, U11, U19, U27) ..... 4-158
SECTION 5 MAINTENANCE AND TROUBLESHOOTING
5.0 Introduction ..... 5-1
5.1 Circuit Board Checkout ..... 5-1
5.2 Warranty Procedures ..... 5-2
SECTION 6 SCHEMATIC AND PARTS LIST
Schematic and Parts List ..... 6-1

## LIST OF ILLUSTRATIONS

## Figure

Page
1-1 AM-100 Circuit Board Set Simplified Block Diagram ..... 1-3
1-2 AM-100 System Block Diagram ..... 1-5
2-1 Header Jumper Wiring ..... 2-7
2-2 Real Time Clock Connection ..... 2-10
4-1 S-100 Bus Read Timing ..... 4-5
4-2 S-100 Bus Write Timing ..... 4-6
4-3 S-100 Bus Read-Modify-Write Timing ..... 4-7
4-4 S-100 Bus DMA Timing ..... 4-8
4-5 CPU Chip Set ..... 4-17
4-6 Microinstruction Bus Timing ..... 4-20
4-7 AM-100 Functional Block Diagram ..... 4-23
4-8 AM-100 System C1ocks ..... 4-34
4-9 Sequencer F1ow Diagram ..... 4-39
4-10 Sequencer Logic Equations ..... 4-40
4-11 CPU Read Byte Timing ..... 4-41
4-12 CPU Read Word Timing ..... 4-42
4-13 CPU Write Byte Timing ..... 4-43
4-14 CPU Write Word Timing ..... 4-44
4-15 CPU Read-Modify-Write Byte Timing ..... 4-45
4-16 CPU Read-Modify-Write Word Timing ..... 4-46
4-17 AM-100 Power-Up Sequence ..... 4-49
4-18 MCP 1600 Microprocessor Block Diagram ..... 4-55
4-19 Register File ..... 4-61
4-20 Ø1 Data Paths ..... 4-70
4-21 Ø2 Data Paths ..... 4-71
4-22 Ø3 Data Paths ..... 4-72
4-23 Ø4 Data Paths ..... 4-73
4-24 ø4 Data Paths Second Cyc1e ..... 4-74
4-25 Major Control Lines ..... 4-76
4-26 PTA Component Interconnections ..... 4-80
4-27 Array No. 1 Organization ..... 4-81
4-28 Typical Gate - Array No. 1 ..... 4-81
4-29 Array No. 2 Data Specification ..... 4-82
4-30 Array No. 2 Organization ..... 4-83
4-31 Array No. 2 Gate and Interconnect Structure ..... 4-83
4-32 Data Specification ..... 4-85
4-33 Array No. 3 Interrupt Organization ..... 4-86
4-34 Array No. 3 Translation Register Organization. ..... 4-86
4-35 Typical Gate of Array No. 3 ..... 4-87
4-36 Array No. 4 Organization ..... 4-89
4-37 ø1 Data F1ow ..... 4-92
4-38 ø2 Data F1ow ..... 4-93
4-39 ø3 Data F1ow ..... 4-94
4-40 ø4 Data F1ow ..... 4-95
4-41 System Interconnections Microprocessor Set ..... 4-108
4-42 TTL Output Timing CP1631B ..... 4-113
4-43 Microinstruction Bus Interface Timing ..... 4-115
4-44 Control Chip Microinstruction Bus Timing ..... 4-116
4-45 Microinstruction Bus Timing CP1631B ..... 4-117
4-46 I/0 Instruction Condition Testing ..... 4-120
4-47 Execution of Read Instruction ..... 4-121
4-48 Execution of Write Instruction ..... 4-124
4-49 Execution of Input Instruction ..... 4-128
4-50 Execution of Output Instruction ..... 4-131
4-51 Write/Output Sequence ..... 4-139
4-52 Read/Input Sequence ..... 4-139
4-53 Read-Modify-Write Sequence ..... 4-140
4-54 Interrupt Acknowledge Sequence ..... 4-141FigurePage
4-55 Four Phase Clock Logic and Timing ..... 4-144
4-56 Tri-State 4-Bit D Type Register Connections. ..... 4-145
4-57 High Speed Hex Inverter Connections ..... 4-146
4-58 Tri-State Buffer Connections ..... 4-147
4-59 Hex Tri-State Buffer Connections ..... 4-148
4-60 Eight-Line to Three-Line Encoder Connections ..... 4-149
4-61 Data Selector/Multiplexer Connections ..... 4-150
4-62 NAND TTL-To-MOS Driver Connections ..... 4-151
4-63 D F1ip-F1op Connections ..... 4-152
4-64 J-K Flip-Flop Connections ..... 4-153
4-65 One-Shot Connections ..... 4-154
4-66 Dual Voltage Controlled Oscillator Connections ..... 4-155
4-67 Decoder Connections ..... 4-156
4-68 D F1ip-F1op Connections ..... 4-157
4-69 Tri-State Octal Buffer Connections ..... 4-158
Table Page
2-1 AM-100 Specifications ..... 2-1
2-2 AM-100 Interface Signals ..... 2-3
3-1 A1pha Micro I/O Addresses ..... 3-2
3-2 Boot Addresses ..... 3-3
3-3 DMA Leve1s ..... 3-4
3-4 Interrupt Leve1s ..... 3-4
4-1 S-100 Bus Command/Control Lines ..... 4-3
4-2 S-100 Bus Status Lines ..... 4-3
4-3 S-100 Bus Utility Lines ..... 4-3
4-4 S-100 Bus Interface Signals List ..... 4-10
4-5 AM-100 Signals List ..... 4-27
4-6 Microm State Code Functions ..... 4-36
4-7 Status Byte Buffer Bits ..... 4-47
4-8 CPU Chip Set Interrupts ..... 4-52
4-9 Data Chip (CP1611B) Pin Assignments ..... 4-56
4-10 Control Chip (CP1621B) Pin Assignments ..... 4-57
4-11 Microm Chip (CP1631B) Pin Assignments ..... 4-57
4-12 Translation State Code Outputs -- 4 of ..... 4-84
4-13 Translation State Code Outputs -- 5 of 7 ..... 4-84
4-14 Microinstruction Set ..... 4-99
4-15 Microinstructions ..... 4-100
4-16 Summary of Microinstruction and Status F1ags ..... 4-105
4-17 Microbus Timing ..... 4-110

SECTION 1
GENERAL DESCRIPTION

### 1.0 INTRODUCTION.

This manual provides operating and maintenance instructions for the AM-100 Central Processor Unit (CPU) circuit board set manufactured by Alpha Microsystems 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-100 CPU circuit board set is a 16 -bit microprocessor board set that is compatible with the S-100 Bus structure. The AM-100 utilizes the Western Digital. WD16 chip set microprogrammed to enhance the software of the operating system. The microprocessor provides 16 -bit flexibility and speed with floating point arithmetic to provide large throughput. The two board AM-100 supports most of the standard S-100 Bus peripherals including static memory, I/O facilities and video.

A simplified block diagram of the AM-100 CPU board set is shown in Figure 1-1. For a complete detailed description of CPU operation, see Section 4 of this manual.

### 1.2 APPLICATION.

The AM-100 is a 16 -bit CPU that is fully compatible with a standard 8-bit $S-100$ bus system. It is fully compatible with many available peripherals from other manufacturers. A block diagram of the system capability is contained in Figure 1-2. This shows the basic S-100 Bus structure, the currently available Alpha Micro circuit cards, and the commercially available peripherals that can be used for a fully integrated system.


Figure 1-1. AM-100 Simplifier Block Diagram


## SECTION 2 <br> OPERATING DATA

### 2.0 INTRODUCTION.

This Section contains information on the use of the AM-100 CPU two board set. Capabilities, specifications, interface wiring and user option descriptions are provided for the successful integration of the board into the user's system.

### 2.1 CAPABILITIES AND SPECIFICATIONS.

This two board set operates from the standard S-100 Bus structure and can be integrated, into a complete system. Specifications for the AM-100 are contained in Table 2-1.

Table 2-1. AM-100 Specifications

| PARAMETER | SPECIFICATION |
| :---: | :--- |
| Interface type | Standard S-100 Bus, 16-Bit words, <br> byte multiplexed for compatibility <br> to 8-bit peripherals and memories. |
| Instruction Set | Over 150 standard instructions coded <br> in unique microcode executed on the <br> WD-16 CPU chip set. |
| Arithmetic | Hardware floating point arithmetic <br> to 11 significant digits. |
| CPU Architecture | Microprogrammed instruction set; <br> eight 16-bit general purpose regis- <br> ters; floating point hardware unit; <br> special high-speed byte multiplexing <br> logic. |

Table 2-1 (Cont.). AM-100 Specifications

| PARAMETER | SPECIFICATION |
| :---: | :--- |
| Interrupt Capability | Eight vectored and one non-vectored <br> interrupt lines. |
| DMA Capability | Seven DMA channels. (Included in vec- <br> tored interrupt line count.) |
| Real Time Clock | Standard Feature. <br> Circuit BoardsTwo board set - standard $5^{\prime \prime} \mathrm{x}$ xith $100-\mathrm{pin}$ connectors. |

### 2.2 INTERFACE DESCRIPTION AND WIRING.

The AM-100 CPU interfaces with the standard S-100 Bus structure. All data inputs, outputs, and control signals are transferred through these lines. The $S-100$ bus connections are made by the bottom edge connectors and are 1isted in Table 2-2.

Table 2-2. AM-100 Interface Signals

| SIGNAL | NAME | $\begin{aligned} & \text { J1 } \\ & \text { PIN NO. } \end{aligned}$ |
| :---: | :---: | :---: |
| A0 | Address 0 | 79 |
| A. 1 | Address 1 | 30 |
| A 2 | Address 2 | 81 |
| A3 | Address 3 | 31 |
| A4 | Address 4 | 30 |
| A5 | Address 5 | 29 |
| A6 | Address 6 | 82 |
| A 7 | Address 7 | 83 |
| A 8 | Address 8 | 84 |
| A9 | Address 9 | 34 |
| A10 | Address 10 | 37 |
| A11 | Address 11 | 87 |
| A12 | Address 12 | 33 |
| A13 | Address 13 | 85 |
| A14 | Address 14 | 86 |
| A15 | Address 15 | 32 |
| CLOC | 2 MHz Clock | 49 |
| DI 0 | Data Input Bus | 95 |
| DI 1 | Bits 0-7 | 94 |
| DI2 |  | 41 |
| DI 3 |  | 42 |
| DI4 |  | 91 |
| DI 5 |  | 92 |
| DI6 |  | 93 |
| DI 7 |  | 43 |

Tab1e 2-2 (Cont.). AM-100 Interface Signals

| SIGNAL | NAME | $\begin{aligned} & \text { J1 } \\ & \text { PIN NO. } \end{aligned}$ |
| :---: | :---: | :---: |
| $\overline{\text { DMAGR0 }}$ | DMA Grant | 63 |
| DMAGR1 |  | 62 |
| $\overline{\text { DMAGR2 }}$ |  | 61 |
| $\overline{\text { DMAGR3 }}$ |  | 60 |
| $\overline{\text { DMAGR4 }}$ |  | 59 |
| DMAGR5 |  | 58 |
| $\overline{\text { DMAGR6 }}$ |  | 57 |
| DMAGR7 |  | 56 |
| $\overline{\text { DMARCVD }}$ | DMA Received | 64 |
| D00 | Data Out Bus | 36 |
| D0 1 | Bits 0-7 | 35 |
| D0 2 |  | 88 |
| D03 |  | 89 |
| D04 |  | 38 |
| D0 5 |  | 39 |
| D06 |  | 40 |
| D0 7 |  | 90 |
| $\overline{\mathrm{C} / \mathrm{CDSB}}$ | Not Used | 18 |
| $\overline{\text { ADDDSB }}$ |  | 19 |
| $\overline{\text { DODSB }}$ |  | 22 |
| MWRITE | Memory Write | 68 |
| PDBIN | Data Bus In | 78 |
| PHLDA | P-Hold Acknowledge | 26 |

Table 2-2 (Cont.). AM-100 Interface Signals

| SIGNAL | NAME | J1 <br> PIN NO. |
| :---: | :---: | :---: |
| $\overline{\text { PHOLD }}$ | DMA Request Line | 74 |
| PINTE | CPU Interrupt Enable | 28 |
| $\overline{\mathrm{POC}}$ | Power On C1ear | 99 |
| PRDY | Processor Ready | 72 |
| $\overline{\text { PRESET }}$ | Preset | 75 |
| PSYNC | Processor Sync | 76 |
| PWAIT | CPU Wait | 27 |
| $\overline{\text { PWR }}$ | Write Strobe | 77 |
| SINP | I/O Input Cycle | 46 |
| SINTA | Interrupt Acknowledge | 96 |
| SMEMR | Memory Read Cycle | 47 |
| SM1 | Bus Master OP Code Fetch | 44 |
| SOUT | I/O Output Cycle | 45 |
| SW0 | Bus Master Output | 97 |

Table 2-2 (Cont.). AM-100 Interface Signa1s

| SIGNAL | NAME | $\begin{aligned} & \text { J1 } \\ & \text { PIN NO. } \end{aligned}$ |
| :---: | :---: | :---: |
| $\overline{\mathrm{VI0}}$ $\overline{\mathrm{VI} 1}$ $\overline{\mathrm{VI} 2}$ $\overline{\mathrm{VI} 3}$ $\overline{\mathrm{VI} 4}$ $\overline{\mathrm{VI} 5}$ $\overline{\mathrm{VI} 6}$ $\overline{\mathrm{VI} 7}$ | Vectored Interrupt 0 <br> Vectored Interrupt 1 <br> Vectored Interrupt 2 <br> Vectored Interrupt 3 <br> Vectored Interrupt 4 <br> Vectored Interrupt 5 <br> Vectored Interrupt 6 <br> Vectored Interrupt 7 | $\begin{array}{r} 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \end{array}$ |
| $\overline{\text { STVAL }}$ | Status and Address Valid | 25 |
| XRDY | External Ready | 3 |
| $\emptyset 2$ | Phase 2 Clock | 24 |

2.3 USER OPTIONS.

Most of the optional capabilities of the AM-100 CPU are exercised with software, and an overview of the available software capability is contained in Section 3. The hardware option that must be implemented is for the bootstrap Loader program and determines which peripheral the boot loader is accessed from.

The boot loader may be accessed from either the AM-200 circuit board (floppy disk controller), the AM-500 (hard disk controller) or the AM-400 (hard disk interface). Header U3 selects the base address for the boot program by the jumper wires as shown in Figure 2-1.

## CPU1 Header U3



Figure 2-1. Header Jumper Wiring

Header U3 on CPU1 can be jumpered for other non-standard jump addresses. The address lines that are jumper selectable are A8-A13 with A14 and A15 always high (1).

To select an address, pins $3,4,5,6,7$ and 8 can be jumpered to ground or left open to generate the desired code. An open (no jumper) selects a one for that address bit and a jumper to pin 14 selects a zero.

NOTE
Pins 9, $10,11,12,13$ and 14 on header U3 must always be connected together.

The pins on header that correspond to the various address bits are as follows:

| Address line | Pin on U3 |
| :---: | :---: |
| 8 | 5 |
| 9 | 4 |
| 10 | 7 |
| 11 | 3 |
| 12 | 8 |
| 13 | 6 |
| GND | 14 |

2.4 INTERRUPT AND DMA OPTIONS.

The AM-100 provides seven levels of DMA or eight levels of interrupt capability. The interrupt and DMA signal lines to the S-100 bus are user selected with jumper wires applied to the circuit board. These jumpers select the desired vectored interrupts or DMA grant signals.

### 2.5 SYSTEM CONNECTIONS.

The AM-100 board set plugs into two adjacent slots in a S-100 Bus chassis and are connected together by a 40 pin flat cable along the top of the circuit boards. An additional input must be connected to the real time clock of the CPU. This can be supplied from the 50 or 60 Hz power of the low voltage power supply in the $\mathrm{S}-100$ bus chassis. Connect this 50 or 60 Hz signal to CPU board 2 at header $U 3$ pin 12 according to the following procedure as shown in Figure 2-2. The AM-100 is then ready for use.

1. Make sure $A C$ power is off and chassis is unplugged.
2. Locate the secondary transformer tap supplying the +8 volt rectifier. The accompanying schematic illustrates this point for the TEI MCS-122 chassis.
3. Locate the $E-Z$ hook cable supplied with the AM-100 CPU board set.
4. Cut one end off the cable so that it is long enough to reach from the top of the AM-100 CPU set to the transformer tap connection located in Step 2. (Make sure that the cable is long enough to be conveniently routed.)
5. Solder the cut end of the cable to the transformer tap connection.
6. Before attaching the cable to the AM-100, perform the following steps:
a. Plug in the chassis and turn on $A C$ power.
b. Observe the waveform at the "E-Z" hook contact. It should appear as a $\pm 10$ volt signal at 60 or 50 Hz .
7. If the waveform at Step 6 b appears correct, turn off $A C$ power, attach the "E-Z" hook to CPU board \#2 at J3 pin 4. An extended resistor lead is provided for convenience in hook-up.


Figure 2-2. Real Time Clock Connection

### 3.0 INTRODUCTION.

This section provides information for programming the AM-100 CPU and integrating it into the user's system. The actual software itself is not contained in this manual. Only the requirements and descriptions of the available software programs and their capabilities are presented here.

### 3.1 SYSTEM CONFIGURATION.

A minimum system can consist of the AM-100 two board set, a minimum of 32 K bytes of memory on a $\mathrm{S}-100$ Bus memory board, a serial $I / O$ card such as the AM-300, a disk memory, and a terminal. A PROM is needed to bootstrap the system and this can be located on one of the peripheral interface boards. Other standard Alpha Micro devices include:

1. F1oppy disk subsystem (AM-200/AM-210).
2. Ten megabyte hard disk (AM-500).
3. Large storage capacity hard disk (AM-400/AM-410).
4. Tape storage subsystem (AM-600).

To utilize other devices in the system, it is necessary to write a driver program for the device and place the resulting module in a preassigned disk area. The bootstrap PROM can be located on either the floppy controller interface board (AM-200) or the hard disk controller interface board (AM-500 or AM-400). The starting address for the bootstrap program is jumper selectable on a platform header on CPU Board 1, U3.

The standard addresses used in Alpha Micro systems are listed in Table 3-1 and boot addresses are listed in Table 3-2. The standard DMA levels are listed in Table 3-4 and the standard interrupt levels are listed in Table 3-5. For further details on interfacing Alpha Micro circuit boards, consult the Technical manual for the individual board.

Table 3-1. Alpha Micro I/O Addresses

| Address (Hex) | Interface |
| :---: | :---: |
| 00-0F | Reserved |
| $10-3 \mathrm{~B}$ | Unassigned |
| 3C-3F | Reserved |
| $40-4 F$ | Memory Bank Switching (1 port/memory bd) |
| $50-6 F$ | Unassigned |
| 70-7F | Phone Link (DC Hayes bd) |
| 80-83 | Imsai PIO (paralle1 port, Data I/O control, etc.) |
| $84-9 F$ | Unassigned |
| A0 - A7 | AM-600 Mag Tape I/F |
| A 8 - AF | Unassigned |
| B0 - BF | AM-310 4 Port Communications Bd (4 ports required/bd) |
| C0 - C7 | ICOM F1oppy Controller or AM-500 Disk Controller (4 ports/bd) |
| C8 - CF | Unassigned |
| C2 | Unassigned |

Table 3-1 (Cont.). A1pha Micro I/O Addresses

| Address (Hex) | Interface |
| :---: | :---: |
| D0 - D3 | AM-410 Disk Controller |
| D4 - DF | Unassigned |
| E0 - E7 | AM-400 Trident Formatter I/F |
| E8 - EF | AM-300 Alternate (2nd board) |
| F0 - F7 | AM- 200 Floppy Controller or AM- 210 F1oppy <br> Contro11er |
| F8 - FF | AM-300 6 Port Serial I/0 Board |

Table 3-2. Boot Addresses

| Address (Hex) | Boot Location |
| :---: | :---: |
| F400 | AM-500 Boot Address <br> AM-410 Boot Address |
| FC00 | AM-200 Boot Address <br> AM-210 Boot Address <br> AM-400 Boot address |
| C000 | ICOM Floppy Boot Address |

TABLE 3-3. DMA Leve1s

| Leve1 | Device |
| :--- | :---: |
| 0 |  |
| 1 |  |
| 2 | AM-600 Mag Tape Contro11er |
| 3 | AM-200 F1oppy Contro11er |
| 4 |  |
| 7 |  |
| 7 |  |

Table 3-4. Interrupt Levels

| Leve1 | Device |
| :---: | :---: |
| 0 | AM- 310 4 Port Communications Board |
| 1 | AM-410 Disk Controller |
| 2 | AM- 300 6 Port Serial I/O |
| 3 | Not available on old systems |
| 4 |  |
| 5 |  |
| 7 |  |

### 3.2 SOFTWARE OVERVIEW.

A wide variety of software programs are available for use in the AM-100 system that have been operating in the commercial environment for many years. These programs have been written under copyright solely by Alpha Microsystems and are available in either floppy disk or hard disk form.

### 3.2.1 OPERATING SYSTEM.

The operating system is a commercial, full multi-tasking, timesharing system capable of supporting as many job partitions as memory capacity will allow. Each job may be controlled by its own terminal or several jobs may be controlled by the same user terminal under a unique software control system built into the monitor. One job may also control several terminals. The status of each job may be optionally displayed on a central video display interfaced through a controller.

The I/O structure is fully device independent and contained within the monitor. To incorporate a new device into the system, the user creates a software driver to interface to the device and includes it in the monitor.

The terminal service routines are also device independent and operate through terminal drivers. Each terminal driver contains a software translation routine to allow the use of special terminal functions such as cursor address and common I/O routines to all types of terminals, without being dependent on which brand of terminal is attached to the system.

### 3.2.2 ASSEMBLY LANGUAGE PROGRAM.

The assembly language program development system includes:

1. A multi-phase macro assembler.
2. A linking loader.
3. A symbolic debugger.
3.2.3 TEXT EDITORS.
Two text editor programs are included:
4. A character oriented editor.
5. A cursor-controlled screen editor.
3.2.4 UTILITY AND SUPPORT PROGRAMS.
Utility and support programs are available that include:
6. File maintenance programs.
7. Dump programs.
8. Memory test programs.
9. Device test programs.
10. Line printer spooler system.
11. Dynamic system status monitor programs.
12. A system generation procedure that allows customtailoring of the monitor to individual userrequirements.
13. Text formatting.
3.2.5 ALPHABASIC PROGRAM.
The AlphaBasic programming language processor is a full com-piler that is disk oriented and supports:
14. Strings.
15. Multi-dimensioned arrays.
16. Disk I/O file accessing.
17. A unique variable mapping system for file manipula-tion in applications programs and for assemblylanguage subroutine processing.
18. Assembly language subroutines.
19. Terminal independent cursor control.

The AM-100 utilizes floating point hardware so it typically runs several times faster than other Basic systems. It is precise to eleven decimal digits using a three-word binary floating-point format which is identical to that used by the WD16 instruction set.
3.2.6 ACCOUNTING PACKAGE.

An accounting package is available under special license that includes:

1. General ledger.
2. Accounts receivable.
3. Accounts payable.
4. Order entry-inventory control.
5. Payroll.

Each of these is a fully interactive, menu-driven, complete system by itself. However, interface is provided between all five modules to create a totally integrated accounting package.

### 3.2.7 ALPHALISP.

An Alpha Micro version of the programming language LISP is available. It is designed for users that require a language that is both a formal mathematical language and (with extensions) a convenient programming language.

### 3.2.8 ALPHAPASCAL.

ALPHAPASCAL is a systematic procedure-oriented, structured programming language that is available. Adapted from the UCSD/PASCAL system, ALPHAPASCAL utilizes a dynamic paging system that allows the system to run in a small amount of memory.

SECTION 4<br>FUNCTIONAL THEORY OF OPERATION

### 4.0 INTRODUCTION.

This section describes in detail the functional theory of operation of the AM-100 Central Processor Unit (CPU). The first part of this section provides a general description of the configuration of the CPU and its integration into an S-100 Bus system. The second part describes the details of CPU operation and how the CPU chip set operates with its associated logic elements. The third part provides a complete description of the CPU chip set and the fourth part describes the operation of the individual logic elements that support the CPU chip set.

### 4.1 CPU CONFIGRUATION.

The AM-100 circuit cards function as a 16 -bit CPU that plugs in to an S-100 Bus system. The data processing logic is contained on a two-board set that is fully integrated into an S-100 Bus system.
4.1.1 AM-100 TWO-BOARD SET.

The AM-100 CPU is packaged on two circuit boards connected together by a 40 -conductor flat ribbon cable. Both boards mate with the standard 100 pin connectors in the $\mathrm{S}-100$ Bus system.

One Circuit board, CPU No. 1, contains the CPU chip set that consists of five $40-\mathrm{pin}$ MOS/LSI chips. This chip set contains the necessary data processing capability for CPU operation. The second circuit board, CPU No. 2, contains the logic that interfaces the 16 -bit bus of the CPU to the 8 -bit $S-100$ bus plus the DMA and interrupt logic.

The CPU chip set contains six 16 -bit accumulators/index registers, a stack pointer and program counter, eight addressing modes, hardware SAVE and RESTORE, and hardware floating point arithmetic.

### 4.1.2 S-100 BUS OPERATION.

The $\mathrm{S}-100$ Bus system is the single bus computer architecture that supports the AM-100 CPU and its associated memory and peripherals. The I/O connectors are standard 100-pin type and each of the 100 lines are bussed together throughout the computer chassis.

The $\mathrm{S}-100$ bus is an eight-bit format with eight bits of tri-state data for CPU input, eight for CPU output, 16 bits for address, and various control, status, and utility lines. There are also eight lines for vectored interrupts/DMA requests and eight for DMA Grant lines. The various devices connected to the bus are referred to as bus master and bus slave depending on the operational configuration taking place. The CPU is not the only device that can control the bus. Any DMA device has the capability of controlling the bus as a bus master.

The command and control lines determine the timing of the bus and are listed in Table 4-1. The status lines are associated with the address lines and indicate what type of bus cycle is taking place. Any bus master must generate these signals or at least ensure that the unasserted level is maintained. The AM-100 status lines are listed in Table 4-2. The utility lines are clocks, power, and initialization and are listed in Table 4-3.

Table 4-1. S-100 Bus Command/Control Lines

| SIGNAL | NAME |
| :--- | :--- |
| PSYNC | Processor Sync |
| PDBIN | Data Bus In |
| $\overline{\text { PWR }}$ | Write Strobe |
| PHLDA | P-Hold Acknowledge |
| $\overline{\text { PHOLD }}$ | Processor Hold Request Line |

Table 4-2. S-100 Bus Status Lines

| SIGNAL | NAME |
| :--- | :--- |
| SM1 | Bus Master OP Code Fetch |
| SOUT | I/O Output Cycle |
| SINP | I/O Input Cycle |
| SMEMR | Memory Read Cycle |
| $\overline{\text { SWO }}$ | Bus Master Output |
| SINTA | Interrupt Acknowledge |

Table 4-3. S-100 Bus Utility Lines

| SIGNAL | NAME |
| :--- | :--- |
| Power | GND, +8VDC, +16VDC, -16VDC |
| $\emptyset 2$ | 2 MHz Phase 2 Clock |
| $\overline{\text { CLOC }}$ | 2 MHz Clock |
| MWRITE | Memory Write |
| $\overline{\text { PRESET }}$ | Preset |
| $\overline{\text { POC }}$ | Power-On Clear |

Read Timing. The timing of the signals involved with a READ BYTE sequence on the $\mathrm{S}-100$ bus is shown in Figure 4-1. When an $I / O$ operation takes place, PSYNC is generated as the first state of the bus cycle. Signal PDBIN is next to indicate that a read operation is taking place. Address lines are valid shortly after PSYNC and remain so until the next bus operation. The addressed memory or peripheral has 400 ns to place its data on the bus for the read cycle. Once the $C P U$ reads the data, PDBIN is lowered, ending the cycle. The READ WORD cycle is a similar sequence twice because two bytes are read. Timing for the READ WORD sequence is also shown in Figure 4-1.

Write Timing. The timing of the signals involved with a WRITE BYTE sequence on the $\mathrm{S}-100$ bus is shown in Figure 4-2. With this sequence, PSYNC starts the bus cycle like the read timing. Signal PWR occurs next to indicate that there is valid data on the bus that is to be written into the addressed location. Status and address data is placed on the bus $\leq 100 \mathrm{nsec}$ after PSYNC by the bus master. The WRITE WORD cycle is a similar sequence twice because two bytes are written as shown in Figure 4-2.

Read-Modify-Write Timing. The READ-MODIFY-WRITE cycle combines these operations into a single sequence as is shown in Figure 4-3.

DMA Timing. The timing and sequence for a DMA cycle is shown in Figure 4-4. The selected vector interrupt signal initiates this cycle and it is acknowledged by DMARCVD. The selected DMAGRANT signal indicates an active DMA cycle and the busses are active $\leq 50 \mathrm{~ns}$ later.


READ WORD TIMING


PDBIN MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN.

Figure 4-1. S-100 Bus Read Timing


Figure 4-2. S-100 Write Timing

i psync may be stretched one or more cycles due to dout delay caused by microcode.
PDBIN AND PWR MAY BE STRETCHED BY CONTROLLING PRDY.
PRDY is EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN OR PWR.
Figure 4-3. S-100 Bus Read-Modify-Write Timing


4 DMAGRANT MAY BE DELAYED IF A BUS CYCLE IS IN PROGRESS WHEN A DMA REQUEST IS GENERATED. IT WILL BE ISSUED IMMEDIATELY FOLLOWING THE COMPLETION OF SYNC.
2. $\overline{\text { PHOLD IS ALWAYS FORCED LOW. }}$
3. PHLDA IS ALWAYS HIGH.

Figure 4-4. S-100 Bus DMA Timing

For a complete description of the $\mathrm{S}-100$ bus signals in the AM-100 system, refer to Table 4-4. This table lists all signals in alphabetical order with AM-100 pin numbers and also the sheet number of the schematic where they interface with the AM-100 CPU. A complete description of each signal is also given.

Table 4-4. S-100 Bus Interface Signals List

| SI GNAL | NAME | $\begin{gathered} \mathrm{J} 1 \\ \text { PIN NO. } \end{gathered}$ | $\begin{aligned} & \text { SCHEM } \\ & \text { PAGE } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| A0 | Address 0 | 79 | CPU1-9 | 16 bits of tri-state addressing. |
| A1 | Address 1 | 80 | CPU1-9 |  |
| A2 | Address 2 | 81 | CPU1-9 |  |
| A3 | Address 3 | 31 | CPU1-9 |  |
| A4 | Address 4 | 30 | CPU1-9 |  |
| A5 | Address 5 | 29 | CPU1-9 |  |
| A6 | Address 6 | 82 | CPU1-9 |  |
| A7 | Address 7 | 83 | CPU1-9 |  |
| A 8 | Address 8 | 84 | CPU1-10 |  |
| A9 | Address 9 | 34 | CPU1-10 |  |
| A10 | Address 10 | 37 | CPU1-10 |  |
| A11 | Address 11 | 87 | CPU1-10 |  |
| A12 | Address 12 | 33 | CPU1-10 |  |
| A13 | Address 13 | 85 | CPU1-10 |  |
| A14 | Address 14 | 86 | CPU1-10 |  |
| A15 | Address 15 | 32 | CPU1-10 |  |
| $\overline{\text { CLOC }}$ | 2 MHz Clock | 49 | CPU2-3 | 2 MHz clock from same source as $\emptyset 2$. |

Table 4-4 (Cont.). S-100 Bus Interface Signals List


Table 4-4 (Cont.). S-100 Bus Interface Signals List

| SIGNAL | NAME | J1 <br> PIN NO. | $\begin{aligned} & \text { SCHEM } \\ & \text { PAGE } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { D00 } \\ & \text { D01 } \\ & \text { D02 } \\ & \text { D03 } \\ & \text { D04 } \\ & \text { D05 } \\ & \text { D06 } \\ & \text { D0 } \end{aligned}$ | Data Out Bus Bits 0-7 | 36 35 88 89 38 39 40 90 | $\begin{aligned} & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \\ & \text { CPU1-8 } \end{aligned}$ | Data output port. Eight bit tri-state data bus from bus master to bus slave. |
| ENDF |  | $\begin{aligned} & 18 \\ & 19 \\ & 22 \end{aligned}$ | CPU2-2 | Only used internal to the AM-100 |
| MWRITE | Memory Write | 68 | CPU2-2 | Gated combination of PWR and SOUT. |
| PDBIN | Data Bus In | 78 | CPU2-9 | Read Enable. Used by bus master to request address slave to place data on the data bus. |
| PHLDA | P-Hold | 26 | CPU2-3 | When asserted, indicates that the CPU is releasing control of the bus in response to a DMA request ( $\overline{\mathrm{PHOLD}}$ ). (This signal is forced high by the AM-100 and not used.) |

Table 4-4 (Cont.). S-100 Bus Interface Signa1s List

| SIGNAL | NAME | $\begin{aligned} & \text { J1 } \\ & \text { PIN NO. } \end{aligned}$ | $\begin{aligned} & \text { SCHEM } \\ & \text { PAGE } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PHOLD }}$ | DMA Request | 74 | CPU2-2 | Used by DMA controllers to request bus mastership. (This signal. is held low by the AM-100 and not used.) |
| PINTE | CPU Interrupt Enable | 28 | CPU2-7 | Output from CPU to enable slave interrupts (not used by Alpha Micro Systems). |
| $\overline{\text { POC }}$ | Power On Clear | 99 | CPU2-3 | Clear signal generated by the CPU on initial turn on. |
| PRDY | Processor Ready | 72 | CPU2-8 | When low, increases the duration of PDBIN or $\overline{\text { PWR }}$. |
| $\overline{\text { PRESET }}$ | Preset | 75 | CPU2-2 | Reset signal normally originating from front panel reset pushbutton. |
| PSYNC | Processor Sync | 76 | CPU2-7 | When asserted, indicates the start of a bus cycle. |
| PWAIT | CPU Wait | 27 | CPU2-7 | When asserted, indicates that the CPU is in a wait period. |

Table 4-4 (Cont.). S-100 Bus Interface Signals List

| SIGNAL | NAME | $\begin{aligned} & \text { J1 } \\ & \text { PIN NO. } \end{aligned}$ | $\begin{aligned} & \text { SCHEM } \\ & \text { PAGE } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PWR }}$ | Write Strobe | 77 | CPU2-7 | When asserted, is a command from the bus master for the addressed slave to accept the data on the data bus. |
| SINP | I/O Input Cycle | 46 | CPU2-7 | When asserted, indicates that the current bus cycle is a bus master input from an I/O address. |
| SINTA | Interrupt <br> Acknowledge | 96 | CPU2-7 | When asserted, indicates acceptance by bus master of an interrupt request. |
| SMEMR | Memory Read Cycle | 47 | CPU2-7 | When asserted, indicates that the current bus cycle is a bus master input from a memory address. |
| SM1 | Bus Master <br> OP Code Fetch | 44 | CPU2-7 | When asserted, indicates that the current bus cycle is a bus master OP code fetch. |
| SOUT | I/O Output Cycle | 45 | CPU2-7 | When asserted, indicates that the current bus cycle is a bus master output to an $1 / 0$ address. |
| SWO | Bus Master Output | 97 | CPU2-7 | When asserted, indicates that the current bus cycle is a bus master output. |

Table 4-4 (Cont.). S-100 Bus Interface Signals List

| SIGNAL | NAME | J1 <br> PIN NO. | $\begin{aligned} & \text { SCHEM } \\ & \text { PAGE } \end{aligned}$ | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\mathrm{VI} 0} \\ & \overline{\mathrm{VI} 1} \\ & \overline{\mathrm{VI} 2} \\ & \overline{\mathrm{VI} 3} \\ & \overline{\mathrm{VI} 4} \\ & \overline{\mathrm{VI} 5} \\ & \overline{\mathrm{VI} 6} \\ & \overline{\mathrm{VI} 7} \end{aligned}$ | Vectored Interrupt 0 <br> Vectored Interrupt 1 <br> Vectored Interrupt 2 <br> Vectored Interrupt 3 <br> Vectored Interrupt 4 <br> Vectored Interrupt 5 <br> Vectored Interrupt 6 <br> Vectored Interrupt 7 | $\begin{array}{r} 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \end{array}$ | $\begin{aligned} & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Vectored interrupt lines used for both interrupt requests and DMA requests. |
| $\overline{\text { STVAL }}$ | Status Valid | 25 | CPU2-3 | Indicates Status \& Address lines valid during PSYNC. |
| XRDY | External Ready | 3 | CPU2-8 | When low, increases the duration of PDBIN or $\overline{\text { PWR }}$. |
| $\emptyset 2$ | Phase 2 Clock | 24 | CPU2-3 | 2 MHz clock Phase 2. Master Timing signal for the bus. |
| $\begin{aligned} & +8 \mathrm{~V} \\ & +16 \mathrm{~V} \\ & -16 \mathrm{~V} \\ & \text { GND } \end{aligned}$ | +8 vdc power <br> +16 vdc power <br> - 16 vdc power <br> Gnd | $\begin{array}{ll} 1, & 51 \\ 1, & 51 \\ 2 & \\ 52 & \\ 50, & \\ 100 & \end{array}$ | $\begin{aligned} & \text { CPU1-1 } \\ & \text { CPU2-1 } \\ & \text { CPU1-1 } \\ & \text { CPU1-1 } \\ & \text { CPU1-1 } \\ & \text { CPU2-1 } \end{aligned}$ | System power and ground. |

### 4.1.3 CPU CHIP SET.

The CPU chip set consists of five $40-\mathrm{pin}$ MOS/LSI chips that include a data chip, a control chip, and three microms. A detailed description of the operation of the individual chips is contained in paragraph 4.3. The chip set utilizes 16-bit architecture with both word and byte operation. Since the S-100 Bus is an eight-bit system, further data processing is required for compatibility and this is described in paragraph 4.2. The primary features of the chip are as follows:
a. 16-bit architecture with both word and byte operation.
b. 16-bit data access port to memory and I/O.
c. Eight 16-bit registers.
d. Four external interrupts.
e. Three internal interrupts.
f. Eight addressing modes.

The chip set is microprogrammable by the coded data within the microms. Figure 4-5 contains a block diagram of the five chips in the CPU chip set.
4.1.3.1 DATA CHIP.

The data chip provides the interfacing capability for data and addressing. A 16 -bit Data and Address bus (DAL) interfaces the CPU to external logic. It also contains eight 16-bit registers, the Arithmetic Logic Unit (ALU), microinstruction bus lines, and some microinstruction decoding logic.


Figure 4-5. CPU Chip Set

### 4.1.3.2 CONTROL CHIP.

The control chip contains the microinstruction address register which controls accessing of the microinstructions. It also contains translation array logic and the interrupt logic. The master timing control is directed by the control chip which indicates when an address is valid on the DAL lines and indicates a read or write operation and a byte or word operation.

### 4.1.3.3 MICROM CHIPS.

The microm chips are 512 word by 22 bit ROMs which are programmed to Alpha Micro specifications. These 22-bit outputs comprise the microinstruction bus (MIB) that allows the chips in the CPU to communicate with each other (MIBOO-MIB21). Each ROM location contains a 16-bit microinstruction, two control bits, and four auxiliary bits. The 16 -bit microinstructions and the two control bits form a high impedance tri-state bus. Bits MIB18-MIB21 are the auxiliary bits and are the state codes that direct external logic to perform special functions.
4.1.3.4 MICROINSTRUCTION BUS.

The Microinstruction Bus (MIB) is a high impedance MOS bus for data transmission between the chips in the CPU and is very sensitive to external monitoring even with oscilloscope probes. The capacitors located on CPU 1 suppress noise and optimize data transmission on the bus.

Bits MIB00-MIB10 serve a dual purpose. During the portion of the cycle that addresses the microinstruction from the microm, these bits contain the 11-bit address. During another part of the cycle, they are used to transmit the microinstruction to the other chips. Bits MIB11-MIB17 just transfer part of the microinstruction. Therefore, during the address phase, MIB00MIB10 address the microinstruction and during another phase MIB00-MIB17 transfer the microinstruction.

Timing of the microinstruction bus is shown in Figure 4-6. The four phases are running continuously, and phase two places the address of the next required microinstruction on the MIB in bits $0-10$. This address data comes from the control chip. Phase three decodes the microinstruction. Phase four provides the precharge necessary for the nodes since this is a MOS bus. At phase 1, the microinstruction is placed on the bus and the process repeats.

The function of the state codes and operation of the CPU with its associated external logic is described in paragraph 4.2.

*Except for MIB15 which is precharged at $\emptyset 3$. It is used to transfer conditional jump results back to the control chip during $\emptyset 4$.

MIB16 is precharged during $\emptyset 2$ and $\emptyset 4$. It is conditionally discharged during $\emptyset 1$ to control RR register, and conditionally discharged during $\emptyset 3$ to disable microm output buffers.

Figure 4-6. Microinstruction Bus Timing

### 4.2 CPU OPERATIONS.

The AM-100 CPU board set consists of the CPU chip set and associated logic elements that provide data processing capability for the S-100 bus system. This Section describes operation of the CPU in the system and operation of the CPU chip set with its associated logic elements.

An overall block diagram of the CPU board set is shown in Figure 4-7. Sheet 1 contains all the logic on CPU board 1 , and sheet 2 contains all the logic on board 2. Table 4-5 contains a complete list of the signals in the AM-100 CPU. The list is alphabetical by signal mnemonic, and a description is given for the function of each signal and the location where it can be found on the schematic diagram.



Table 4-5. AM-100 Signals List

| SI GNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE <br> OF SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| BDAL00- <br> BDAL15 | Buffered Data and Address Lines | 1 | - | CPU1-8 | Internal tri-state bus for Data and Address Lines. |
| BUSY | Busy | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 14 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-5 } \end{aligned}$ | Asserted when any of the seven vectored interrupts (VIO-VI6, PHOLD) are received. Indicates that a DMA exchange is in process. |
| $\overline{\text { CLOC }}$ | 2 MHz Clock | 2 | - | CPU2-3 | Output of 2 MHz clock. |
| DALOODAL15 | Data and Address Lines | 1 | - | $\begin{gathered} \text { CPU1-4 } \\ 6,7 \end{gathered}$ | Tri-state bus for Data and Address Lines. |
| $\frac{\text { DBIN }}{\overline{\text { DBIN }}}$ | Data Bus In | 2 | - | CPU2-8 | Read Enable equivalent to PDBIN on S-100 Bus. Enables CPU to read data from the Data In Bus. |
| $\frac{\mathrm{DIN}}{\overline{\mathrm{DIN}}}$ | Data In | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 5 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Control signal from the processor to cause the address unit to gate its read data on the data lines. |
| DOUT | Data Out | 2 | 9 | CPU1-5 <br> CPU2-3 | Control signal from the processor which is made high at the same time that the write data is placed on the DAL bus by the processor. |
| $\overline{\text { EARS }}$ | External Address Register Select | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 29 | $\begin{aligned} & \text { CPU1-7 } \\ & \text { CPU2-4 } \end{aligned}$ | Output of the state code decoder that reads the starting address of the bootstrap PROM. |

Table 4-5 (Cont.). AM-100 Signa1s List

| SI GNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE OF SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ENDF |  | 2 | - | CPU2-5 | Not used. |
| ENDR |  | 2 | - | CPU2-5 | Not used. |
| $\overline{\text { FIVE }}$ | Sequencer Count Five | 2 | - | CPU2-9 | Sequencer output for count five. |
| $\frac{\text { FOUR }}{\overline{\text { FOUR }}}$ | Sequencer Count Four | 2 | - | CPU2-9 | Sequencer output for count four. |
| HALT | Halt | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 10 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Used for CPU interrupt I3. |
| HALTA | Halt-A | 2 | - | CPU2-2 | Output of real time clock header used to generate HALT for CPU interrupt I3. |
| $\frac{\text { HIBYTE }}{\overline{\text { HIBYTE }}}$ | High Byte | 2 | 3 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-8 } \end{aligned}$ | When asserted, switches the upper byte (bits 8-15) to the output port from the WD16. When it is low, the lower byte (bits 0-7) is selected. |
| $\begin{gathered} \text { IACK } \\ \overline{\text { IACK }} \end{gathered}$ | Interrupt Acknowledge | 2 | 7 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-7 } \end{aligned}$ | Control signal output from the CPU to indicate that the processor is responding to an interrupt. |
| IAO | Initiate Address AO | 1 | 26 | $\begin{aligned} & \text { CPU1-10 } \\ & \text { CPU2-3 } \end{aligned}$ | Sequencer output to generate LSB of address byte in either bit A0 or A8. |
| IDIN | Interrupt Data In | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 30 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-6 } \end{aligned}$ | Enable signal to apply stored vectored interrupts VINTR1-VINTR3 to Data and Access Lines DAL1-DAL3. |
| INTFF | Vectored Interrupt Input | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 13 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | CPU vectored interrupt IO. Asserted with any of the vectored interrupts. |

Table 4-5 (Cont.). AM-100 Signa1s List

| SI GNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE of SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { IOSEL }}$ | I/O Selected | 1,2 | 24 | $\begin{aligned} & \text { CPU1-9 } \\ & \text { CPU2-7 } \end{aligned}$ | Asserted for an $I / O$ data transfer. False for a memory transfer. |
| $\overline{\overline{I S R}}$ | Input Status Register | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 28 | $\begin{aligned} & \text { CPU1-7 } \\ & \text { CPU2-4 } \end{aligned}$ | Generated by State Code 6 ( $\overline{\text { SC6 }}$ ) to apply the status data to the DAL bus bits DALO-DAL7. |
| I2 | Interrupt 2 | 2 | - | CPU2-6 | Interrupt signal set by State Code 4 ( $\overline{\mathrm{SC} 4}$ ) and cleared by State Code 5 ( $\overline{\mathrm{SC} 5}$ ). Serves as an Interrupt enable for vectored interrupts. |
| I2 FF | CPU Interrupt 12 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 11 | $\begin{aligned} & \text { CPU1-7 } \\ & \text { CPU2-6 } \end{aligned}$ | CPU vectored interrupt 12 generated by any vectored interrupt. |
| JFIVE | Set Sequence 5 | 2 | - | CPU2-9 | $J$ input to sequencer f1ip-f1op 5. |
| $\frac{\text { JFOUR }}{\overline{\text { JFOUR }}}$ | Set Sequence 4 | 2 | - | CPU2-9 | $J$ input to sequencer flip-flop 4. |
| $\overline{\overline{J R E S T}}$ | Set Sequence Rest | 2 | - | CPU2-8 | $J$ input to sequencer flip-flop zero (REST). |
| $\overline{\text { JSEVEN }}$ | Set Sequence 7 | 2 | - | CPU2-9 | $J$ input to sequencer flip-flop 7. |
| JTHREE | Set Sequence 3 | 2 | - | CPU2-9 | $J$ input to sequencer flip-flop 3. |
| MIB00- <br> MIB21 | Microinstruction <br> Bus Bits 0-21 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{array}{ll} 21, & 22, \\ 23, & 25 \end{array}$ | $\begin{aligned} & \text { CPU1-2, 3,4,5 } \\ & \text { CPU2-4 } \end{aligned}$ | Data bus to transmit data between the five chips at the CPU chip set. |
| $\frac{\text { MSYNC1 }}{\frac{\text { MSYNC1 }}{}}$ | M Sync One | 2 | - | CPU2-8 | State one of the sequencer. |
| PHLDA | P-Hold Acknowledge | 2 | - | CPU2-3 | When asserted, indicates that present bus master is releasing control of the bus in response to a DMA request (PHOLD) (forced high and not used). |

Tab1e 4-5 (Cont.). AM-100 Signa1s List

| S I GNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE of SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PHOLD | DMA Request Line | 2 | - | CPU2-2 | Used by DMA controllers to request bus mastership (forced low and not used). |
| $\overline{\text { POC }}$ | Power On Clear | 2 | - | CPU2-3 | Pulse signal asserted on initial power-up and by PRESETB signa1. |
| $\overline{\text { POS }}$ | Power On Set | 2 | - | CPU2-3 | Inverse of Power On Clear. |
| $\overline{\text { PR ESETB }}$ | Preset | 2 | - | CPU2-2 | Buffered preset signal from S-100 Bus. |
| PSYNCI | Processor Sync Internal | 2 | - | CPU2-7 | Indicates the start of a bus cycle, used to generate PSYNC on S-100 BUS. |
| RAO | Stored Address Zero | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 27 | $\begin{aligned} & \text { CPU1-9 } \\ & \text { CPU2-3 } \end{aligned}$ | Address data bit zero stored from the DAL bus clocked into the register by SYNC. |
| RA01RA15 | Stored Address | 1 | - | CPU1-9 | Address Data stored from the DAL bus clocked into the register by SYNC. |
| $\frac{\mathrm{RB}}{\overline{\mathrm{RB}}}$ | Read Byte | 2 | - | CPU2-4 | State Code decoder signal for Read Byte operation. |
| READWORD | Read Word | 2 | - | CPU2-4 | State code decoder signal for Read Word operation. |
| $\frac{\text { READY }}{\text { READY }}$ | Ready | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 4 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-8 } \end{aligned}$ | Sequencer output indicating that the CPU chip set is ready to accept data. |
| REST | Rest | 2 | - | CPU2-8 | The state of the sequencer when no instruction or bus operations are taking place (state 0 of the sequencer). |
| RMW | Read-Modify-Write | 2 | - | CPU2-4 | State code decoder signal for Read-Modify-Write either word or byte. |

Table 4-5 (Cont.). AM-100 Signals List

| SIGNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE OF SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { RMWB }}{\frac{\text { RMWB }}{}}$ | Read-Modify-Write-Byte | 2 | - | CPU2-4 | Generated during an INPUT BYTE micro op code with RMW active to indicate a Read-Modify-Write byte sequence (1010 Microcode). |
| $\frac{\text { RMWW }}{\overline{\text { RMWW }}}$ | Read-Modify-Write-Word | 2 | - | CPU2-4 | Generated during an INPUT WORD micro op code with RMW active to indicate a Read-Modify-Write word sequence (1001 Microcode). |
| RPLY | Reply | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 16 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Control signal used by the addressed unit to respond to the processors data access signals. |
| $\overline{\text { RST }}$ | CPU Reset | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 15 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Resets CPU chip set on initial power-up. |
| RTC | Real Time Clock | 2 | - | CPU2-2 |  |
| RTCFF | CPU Real Time Clock | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 12 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-6 } \end{aligned}$ | Real time clock input to CPU. |
| SC1-SCF | State Codes 1-F (Hex) | 2 | - | CPU2-4 | Outputs of state code decoder. |
| $\overline{\text { SEVEN }}$ | Sequencer Count Seven | 2 | - | CPU2-9 | Sequencer output for count seven. |
| SIX | Sequencer Count Six | 2 | - | CPU2-9 | Sequencer output for count six. |
| $\frac{\text { SOUT }}{\frac{\text { SOUT }}{}}$ | I/O Output Cycle | 2 | - | CPU2-7 | When asserted indicates that the current bus cycle is a bus master output to an $I / O$ address. |
| $\frac{\text { SYNC }}{\frac{\text { SYNC }}{}}$ | Sync | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 6 | $\begin{aligned} & \text { CPU1-5 } \\ & \text { CPU2-4 } \end{aligned}$ | Output of the CPU chip set indicating the start of an $I / O$ operation. |

Table 4-5 (Cont.). AM-100 Signals List

| SIGNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | $\begin{gathered} \text { J2 } \\ \text { PIN NO. } \end{gathered}$ | SCHEM PAGE of SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\frac{\text { THREE }}{\text { THREE }}$ | Sequencer Count Three | 2 | - | CPU2-9 | Sequencer output for count three. |
| VINTR 1 | Vectored Interrupt 1 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 31 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-6 } \end{aligned}$ | Vectored interrupt level one signal for the DAL bus. |
| VINTR 2 | Vectored Interrupt 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 32 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-6 } \end{aligned}$ | Vectored interrupt level two signal for the DAL bus. |
| VINTR 3 | Vectored Interrupt 3 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 33 | $\begin{aligned} & \text { CPU1-6 } \\ & \text { CPU2-6 } \end{aligned}$ | Vectored interrupt level three signal for the DAL bus. |
| $\frac{\text { WO }}{\overline{\text { WO }}}$ | Write Operation | 2 | - | CPU2-7 | Indicates that the current process is a write operation. |
| WAIT | Wait | 1 | - | CPU1-4 | Signal from CPU data chip to control chip to establish whether the data chip is in the Run or Wait mode. Low $=$ Run, and the microinstruction is loaded and executed. |
| WB | Write Byte | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 8 |  | Control signal from the processor which is high when the address is on the bus to signify a WRITE rather than a READ and high during Data Out to signify BYTE rather than WORD. |
| $\frac{\text { WBFF }}{\overline{\text { WBFF }}}$ | Write Byte Output | 2 |  | CPU2-3 | Write Byte signal clocked by DOUT. |
| XDMAG | XDMA Grant | - | 2 | $\begin{aligned} & \text { CPU1-8 } \\ & \text { CPU2-5 } \end{aligned}$ | Controls the buffers that interface the CPU control signals with the $\mathrm{S}-100$ bus to allow them to be removed when another master is controlling the bus. |

Table 4-5 (Cont.). AM-100 Signals List

| SI GNAL | NAME | $\begin{gathered} \text { BOARD } \\ \text { NO. } \end{gathered}$ | J2 <br> PIN NO. | SCHEM PAGE OF SOURCE | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| XDMAGRANT | XDMA Grant | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 1 | $\begin{aligned} & \text { CPU1-10 } \\ & \text { CPU2-5 } \end{aligned}$ | Same as XDMAG. |
| $\overline{\emptyset 1}$ | Phase 1 Clock | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 18 | $\begin{aligned} & \text { CPU1-1 } \\ & \text { CPU2-2 } \end{aligned}$ | Phase 1 of 2 MHz 4 -phase clock see Figure 4-8. |
| $\emptyset 1 \mathrm{M}$ | Phase 1 Clock, MOS Levels | 1 | - | CPU1-1 | Phase 1 of 2 MHz 4 -phase clock buffered for 10.5 volt operation of CPU chip set. |
| $\bar{\emptyset} 2$ | Phase 2 Clock | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 17 | $\begin{aligned} & \text { CPU1-1 } \\ & \text { CPU2-2 } \end{aligned}$ | Phase 2 of 2 MHz 4 -phase clock see Figure 4-8. |
| $\emptyset 2 \mathrm{~B}$ | Phase 2 Clock | 2 | - | CPU2-8 | Phase 2 of 2 MHz 4 -phase clock buffered for operation sequencer flip-flops. |
| $\emptyset 2 \mathrm{M}$ | Phase 2 Clock, MOS Levels | 1 | - | CPU1-1 | Phase 2 of 2 MHz 4 -phase clock buffered for 10.5 volt operation of CPU chip set. |
| $\bar{\square} \overline{3}$ | Phase 3 Clock | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 20 | $\begin{aligned} & \text { CPU1-1 } \\ & \text { CPU2-2 } \end{aligned}$ | Phase 3 of 2 MHz 4 -phase clock see Figure 4-8. |
| $\emptyset 3 \mathrm{M}$ | Phase 3 Clock, MOS Leve1s | 1 | - | CPU1-1 | Phase 3 of 2 MHz 4 -phase clock buffered for operation of CPU chip set. |
| $\bar{\emptyset} 4$ | Phase 4 Clock | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | 19 | $\begin{aligned} & \text { CPU1-1 } \\ & \text { CPU2-2 } \end{aligned}$ | Phase 4 of 2 MHz 4 -phase clock see Figure 4-8. |
| $\emptyset 4 \mathrm{M}$ | Phase 4 Clock, MOS Levels | 1 | - | CPU1-1 | Phase 4 of 2 MHz 4 -phase clock buffered for operation of CPU chip set. |

### 4.2.1 CLOCK GENERATOR.

The basic clock signals originate at the 4 MHz crystal oscillator U5. Its output is divided-by-two by the J-k f1ipflop U23, gated and buffered to generate clock signa1s $\emptyset 1, \emptyset 2$ and $\overline{\text { CLOC. Clock }} \emptyset 2$ provides the $\mathrm{S}-100$ Bus clock and $\overline{\mathrm{CLOC}}$ drives the four-phase clock generator U12. The four phase clock generator provides the internal clock signals to drive the CPU chip set and to synchronize its associated logic. Operation of $U 12$ is described in paragraph 4.4.1. The timing relationship of the $S-100$ bus clocks and the four-phase clocks is described in Figure 4-8.

The TTL level clocks from CPU 2 are sent to CPU 1 where they are buffered through $U 2$ and $U 3$ to a leve1 of at least 10.5 volts to drive the CPU chip set.


Figure 4-8. AM-100 System C1ocks
4.2.2 STATE CODE DECODER LOGIC.

The microinstruction state codes are contained in microinstruction bits MIB18-MIB21 from the microinstruction bus in the CPU chip set located on CPU 1. These bits are buffered on CPU 1 and then sent to decoders U 7 and U3 on CPU 2. The information contained in these bits controls the type of processing to be performed. The decoder logic generates signals to control the input of the status register and control the sequencer to perform the required processing operations (write, read, read/ modify/write). The state codes and their functions are listed in Table 4-6.

### 4.2.3 SEQUENCER OPERATION.

The sequencer on the AM-100 CPU provides the timing and synchronizing required to interface the 16 bit CPU chip set to the 8 -bit $\mathrm{S}-100$ Bus. There are ten states in this sequencer that provide the various operations required for CPU data processing.

| State | Function |
| :---: | :---: |
| 0 | Rest |
| 1 | MSYNC1 - The sync signal for memory or I/O. |
| 2, 3 | DBIN - Input functions. Once around for byte, twice for word. |
| 4 | Read-Modify-Write chain. |
| 5, 7 | Output functions. Once around for byte, twice for word. |
| HIBYTE | LSB Address Control. |
| READY | Replies to the CPU and latches the upper byte of the DAL to the lower byte of the DAL during READ WORD operations. |

Table 4-6. Microm State Code Functions

| CODE | MNEMONIC | NAME | FUNCTION |
| :---: | :---: | :---: | :---: |
| 0001 | PMSK | Priority Mask Out. | The state code is generated on an OUTPUT WORD instruction when a new mask is written into location 2 E . It signals the $\mathrm{I} / \mathrm{O}$ devices that a new interrupt mask is on the DAL. (Not used on AM-100.) |
| 0010 | RUN | Macro Instruction Fetch | Generated during macro instruction fetch from memory for a run 1ight. |
| 0011 | IORST | I/O Reset | Not Used. |
| 0100 | INTEN | I2 Set | Enables, the interrupt enable line I2. Sets $12 \mathrm{flip-f1op}$. |
| 0101 | INTDS | 12 Reset | Disables the interrupt enable line I2. Resets I2 flip-flop. |
| 0110 | ESRR | External Status Register Request | Generated during an INPUT STATUS BYTE micro op code to indicate that the external status register is being requested. |
| 0111 | SRS | System Reset | Not used. |
| 1000 | BYTE | Read Byte Operation | Generated during an INPUT BYTE micro op code to indicate a read byte operation without a read/modify/write. (Not used on AM-100.) |
| 1001 | RMWW | Read/Modify/Write Word | Generated during an INPUT WORD micro op code with RMW active to indicate a read/modify/write word sequence. (Not used on AM-100.) |
| 1010 | RMWB | Read/Modify/Write Byte | Generated during an INPUT BYTE micro op code with RMW active to indicate a read/modify/write byte sequence. (Not used on AM-100.) |

Table 4-6. Microm State Code Functions

| CODE | MNEMONIC | NAME |  |
| :--- | :--- | :--- | :--- |
| 1011 | RLCI | Reset Line Clock <br> Interrupt |  |
| 1100 | EARR | External Address <br> Register Request | Controls where the CPU looks for the bootstrap PROM upon power up. |
| 1101 | - | Duplicate of BYTE | Same as BYTE except one bit sooner. |
| 1110 | - | Duplicate of RMWW | Same as RMWW except one bit sooner. |
| 1111 | - | Duplicate of RMWB | Same as RMWB except one bit sooner. |

The flow diagram for sequencer operations is shown in Figure 4-9 and the associated logic equations are shown in Figure 4-10. Each block on the flow diagram represents a f1ip-f1op (CPU2 schematic sheets 8 and 9). The J equations set the f1ip-flop on the next clock, and the $K$ equations reset the flip-f1op on the next clock.

$$
\begin{aligned}
& \text { The sequencer clock is } \frac{\text { Note }}{\emptyset 2} \text { from the four-phase } \\
& \text { clock generator. }
\end{aligned}
$$

Timing diagrams for sequencer operations are contained in Figure 4-11 through 4-16. The timing relationships given show the $\mathrm{S}-100$ Bus timing on the top part of the diagram with the processor signals necessary to produce the bus signals drawn underneath. On1y one state of the sequencer is active at a time.

On initial power up, the reset line (PRESETB) is forced 1ow initializing the sequencer to the rest or zero state. The sequencer is in this state until a bus operation is required.

When the CPU chip set is ready for an I/O operation, SYNC is asserted to generate MSYNC1 which is state one of the sequencer. When the Interrupt Acknowledge (IACK) line is true, the processor is not allowed to perform a bus operation. Input signals to the sequencer from the state code decoder and CPU then determine what type of sequence is required. Eight different sequences are possible as shown on Figure 4-9. The sequencer then proceeds through the required combinations of states as shown on the flow diagram.


| MODE | STATES | REPLY LOBIC* |
| :---: | :---: | :---: |
| 1. READY BYTE (MEM OR I/O) | 0-1-2-0 | READY - RB - DIN |
| 2. READY WORD (MEM OR I/O) | 0-1-2-3-2-0 | READY - RW - HYBITE - DIN |
| 3. WRITE BYTE (MEM OR I O) | 0-1-5-6-0 | READY - WB - 5 |
| 4. WRITE WORD (MEM OR I O) | 0-1-5-6-7-6-6-0 | READY - WB - 5 - HIBYTE |
| 5. RMW BYTE (MEM) | 0-1-2-4-5-6-0 | 1+3 ABOVE |
| 6. RWM WORD (MEM) | 0-1-2-3-2-4-5-6-7-5-6-0 | 2+4 ABOVE |
| 7. RMW BYTE (I/O) | 0-1-6-6-0 | DIN+3 ABOVE |
| 8. RMW WORD (1/O) | 0-1-5-6-7-6-6-0 | DIN+4 ABOVE |

-STROBED AT $\phi 1$ TRAILING EDGE AND GATED WITH SYNC. REPLY LOGIC GENERATES SIGNALS TO TERMINATE CPU CYCLE.

Figure 4-9. Sequencer Flow Diagram

```
REST
    JREST = DBIN }\cdot\overline{SYNC}\cdot\overline{DIN}+6\cdot\overline{SYNC
    KREST = JMSYNC 
MSYNC
    JMSYNC 
    KMSYNC1 = JDBIN + J5
DBIN
    DBIN = 3+MSYNC }
    KDBIN = JREST + J3 + J4
4
    J4 = DBIN · DIN }\cdot(\mathrm{ RMWB · READY + RHWW · READY · HIBYTE)
    K4 = 4 · DOUT
5
    J5 = MSYNC 
    K5 = J6
3
    J3 = READY . }\overline{\textrm{HIBYTE}}\cdot\textrm{DBIN}\cdot(\overline{\textrm{RB}+\mathrm{ RMWB}}
    K3=3
6
    J6 = 5 R READY
    K6 = JREST + J7
7
    J7=6
    K7 = 7
ADDRESS LSB LOGIC
    A
HIBYTE
BUS SIGNALS
    JHIBYTE - J3 + J7 PSYNC = MSYNC 
    KHIBYTE = J4
    PWR = 5
    DIR. RESET = REST
READY
    JREADY = PRDY · XRDY · (DBIN + 5)
    KREADY = PSYNC + }
    PDBIN = DBIN
    SMEMR = \overline{OWEL}\cdot\overline{SW}
    SINP = IOSEL }\cdot\overline{SW
    SOUT = IOSEL }\cdot\mathrm{ SW O
    MWRITE = PWR · SOUT
    DIR RESET = REST
```

Figure 4-10. Sequencer Logic Equations


PDBIN MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN.

Figure 4-11. CPU Read Byte Timing

© pobin mar be staetched by controlling prdy. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN.


SYNC ( $\mathbf{\phi}^{2}$ )


DIN ( $\boldsymbol{\phi}_{2}$ )


READY ( $\phi 1$ )


RPLY ( $\phi \mathbf{2}$ )


READY WORD (MEMORY)

1 PDBIN MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN.

Figure 4-12. CPU Read Word Timing


WRITE BYTE (MEMORY OR I/O)

PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY CAUSED BY MICROCODE.
PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PWR.

Figure 4-13. CPU Write Byte Timing


WRITE WORD (MEMORY)

1 pSync may be stretched one or more cycles due to dout delay CAUSED BY MICROCODE.
2. PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PWR.

Figure 4-14. CPU Write Word Timing


PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY CAUSED BY MICROCODE.
2. PDBIN AND PWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ (WD) LEADING EDGE TIME DURING PDBIN OR PWR.

Figure 4-15. CPU Read-Modify-Write Byte Timing


READ-MODIFY-WRITE WORD
1 PSYNC MAY BE STRETCHED ONE OR MORE CYCLES DUE TO DOUT DELAY CAUSED BY MICROCODE.

1. PDBIN AND FWR MAY BE STRETCHED BY CONTROLLING PRDY. PRDY IS EXAMINED AT $\phi 1$ WDDI LEADING EDGE TIME DURING PDBIN OR PWR.

Figure 4-16. CPU Read-Modify-Write Word Timing

### 4.2.4 INITIALIZATION AND STATUS.

Initialization of the $\mathrm{AM}-100$ occurs when the board set receives its initial power. Initial reset is accomplished by Power-On-Clear signal POC which goes low on initial power-up or for the PRESET signal that actuates the $\overline{\text { POC }}$ one-shot U22. Signal $\overline{\text { POC }}$ provides an output to the $\mathrm{S}-100$ Bus and also clears register $U 10$ in the reply logic.

The logic that controls initialization of the CPU chip set is located on CPU1 and consists of two buffers: the status Byte Register buffer and the External Address Register Select buffer.

The Status Byte buffer is used by the CPU chip set during power-up to determine the initialization sequence. There are eight bits in this register that function as defined in Table 4-7. The CPU chip set checks these bits as it proceeds through its initialization.

Table 4-7. Status Byte Buffer Bits

| BIT | NAME | FUNCTION |
| :---: | :---: | :---: |
| 0 1 | Power-Up <br> Option Jumpers | 00 Used for $\mathrm{AM}-100$ |
| 2 3 | Ha1t Option Jumpers | Not Used |
| 4 | Interrupt Enable | Vectored Interrupt Enable |
| 5 | Parity Error Status | Wired to ground |
| 6 | Bus Error Status | Wired to ground |
| 7 | Power Fail Status | Wired to ground |

The external address register is used by the CPU to determine the base address of the bootstrap ROM. The base address is six bits that are jumper selected by the header in U3. During the power-up sequence, these six bits are added to C000 to determine the bootstrap starting address.

Note
See Section 2 of this manual for header U3 wiring for the various peripherals used with the AM-100.

The initialization process for the AM-100 must proceed through the sequence described below so that the CPU can access the bootstrap load program and begin executing. When the RESET pushbutton is pressed, the CPU sends out an external request to read the Status Register. This signal is $\overline{I S R}$ that accesses the eight bits of data as defined in Table 4-7. The CPU then checks each bit as described in Figure 4-17. When the CPU has checked the eight bits of the Status Register, signal $\overline{\text { EARS }}$ is asserted from the state code decoder and reads the base address from header U3.

### 4.2.5 DATA ACCESS.

Data is processed from the eight-bit $S-100$ bus system to the 16 -bit CPU through the supporting logic on both CPU boards. The data bus is addressed and then the CPU performs either read or write operations. Read/Modify/Write is a combination of both in one sequence.


Figure 4-17. AM-100 Power Up Sequence

### 4.2.5.1 ADDRESSING OPERATIONS.

The CPU chip set utilizes a data bus that contains both the data and address multiplexed onto the same lines. When the CPU chip set has address data on the DAL, the SYNC signal goes true. This is applied to the clock input of the address latches U13, U14 and U25 to store the address data. Bits A1-A7 are app1ied directly to the S-100 bus through buffers, but the other bits require additional processing.

There are two basic bus operations where addressing is concerned: memory and $I / 0$. If we are performing memory read or write, then the lower byte contains A0-A7 and the upper byte contains A8-A15. When $I / O$ operations are taking place, the CPU sends out Hex address FFXX. This generates signal IOSEL from the gate on U15 to distinguish between I/O and memory operations. Signal IOSEL switches the Data Select MUX to place A0-A7 on both the upper and lower bytes of the address bus.

Address line AO is generated by the sequencer logic on CPU2 to provide for byte/word data operations. With word operations, two sequential addresses are fetched so A0 is sequenced first with 0 , then with 1 . With byte operations, address 1ine A0 is unaffected by the sequencer.

### 4.2.5.2 WRITE OPERATIONS.

The DAL bus that processed the address data also contains the data for write operations. The buffered data lines are applied to the data select MUX on U17 and U18. This selects the appropriate byte for $S-100$ bus transfer to the selected memory or $I / O$ controller. Signal HIBYTE selects either the upper byte or lower byte for transfer to the output bus of the S-100 Bus.

If a write byte operation is taking place, only eight bits of data are required. The address is first transmitted and then the lower byte of data is placed on both DALO-DAL7 and DAL8-DAL15. If a write word operation is taking place, a two-stage operation transmits the lower byte first to the eight S-100 lines and then switches to the upper byte. Signal HIBYTE makes this selection.

### 4.2.5.3 READ OPERATIONS.

The data input lines are buffered and are applied to the internal DAL bus on DAL8-DAL15. This input data is then stored in the Low Byte Input Storage register on $U 9$ and U10. For the read byte sequence, the $\mathrm{S}-100$ bus signals request that the addressed memory or $I / O$ port place its data on $\mathrm{S}-100$ bus 1ines DIO-DI7; signal $\overline{\mathrm{DIN}}$ gates it on to the internal data bus to the lower byte storage. Signal READY from the sequencer indicates that the CPU chip set is ready to accept the data so it is clocked into the Low Byte Input Storage register. The lower byte of data is on both DALO-DAL7 and DAL8-DAL15, and the CPU can read from either one.

For the read word sequence, the lower byte is transmitted exactly like the read byte sequence. The sequencer then starts another cycle and increments the LSB of the address to fetch the data from an odd address in memory. The data is applied to the input port as before and is gated to DAL8DAL15. The Low Byte Input Storage register is not clocked this time so it still contains the low byte and the high byte is on DAL8-DAL15. The operation is terminated and the CPU chip set reads a 16-bit word from DAL0-DAL15.

### 4.2.6 DMA AND INTERRUPT OPERATIONS.

The AM-100 provides seven levels of DMA and eight levels of interrupt capability. This data access processing is integrated with the interrupt operations of the CPU chip set.

### 4.2.6.1 CPU CHIP SET INTERRUPTS.

The CPU chip set provides capability for four interrupts as listed in Table 4-8. These interrupts are inputs to the control chip U28 on CPU1.

Table 4-8. CPU Chip Set Interrupts

| INTERRUPT | PIN | SIGNAL | FUNCTION |
| :--- | :---: | :--- | :--- |
| I0 | 6 | INTFF | Vectored interrupt |
| I1 | 5 | RTCFF | Non-vectored interrupt - rea1 <br> time clock. |
| I2 | 4 | I2FF | Enable for I0 and I1, con- <br> trolled by user state codes. |
| I3 | 3 | HALT | Halt switch (not used). |

Interrupt $I 0$ is the vectored interrupt and is the normal interrupt procedure. It is used by the peripheral controllers to signal the CPU when they have finished a task. Signal INTFF provides the IO input from a signal generated on CPU2 when any of the eight vectored interrupts have been asserted. This signal is generated by decoder U29, inverted, and stored in a D flip-flop on U10. Interrupt $I 1$ is the non-vectored interrupt and the real time clock signal RTCFF supplies this input. Interrupt $I 2$ is an enable for $I 0$ and $I 1$ and is supplied by the user state codes. This is generated by f1ip-f1op U18 on CPU2 that is preset by $\overline{\mathrm{SC4}}$ and cleared by $\overline{\mathrm{SC5} 5}$. Interrupt I3 is a halt switch input that is not implemented on the AM-100.

When a non-vectored interrupt is received by the CPU chip set (real time clock), it checks the contents of the status register to examine bit 7. This is the power fail bit which is not implemented in the $\mathrm{S}-100$ bus structure so it is wired to ground. The CPU then determines that bit 7 is false and then fetches the program counter address from Location 2A.

### 4.2.6.2 VECTORED INTERRUPTS.

When a vectored interrupt is received by the CPU chip set (IO), the resulting process is similar to a read instruction. When Vectored Interrupt is asserted, jumper wires on CPU2 connect it to any of the eight pads VIO-VI7. This produces two outputs at the decoder: VINTR1-VINTR3 produce the interrupt code and the other output from pin 14 is asserted any time there is an input to the decoder. This produces INTFF which is applied to CPU interrupt IO. At the same time, VINTR1VINTR3 are sent to CPU1 to the interrupt storage register U1 where they are clocked in by IACK. When Data In (DIN) is received from the CPU, $\overline{I D I N}$ is asserted which applies VINTR1VINTR3 to the data bus DAL1-DAL3. The CPU then reads the interrupts from the bus.

### 4.2.6.3 DMA OPERATIONS.

The AM-100 provides seven levels of DMA capability. Levels VIO-VI6 are jumper selectable and level 7 is wired directly to PHOLD.

The other DMA inputs are jumper selectable and provide corresponding DMAGRANT ( $\overline{\text { DMAGRO-DMAGR6 }}$ ) outputs to the $\mathrm{S}-100$ Bus. A DMAG output ( $\overline{\text { DMARCVD }}$ ) is generated one clock cycle before the selected DMAGRANT to signal all the DMA boards that a new DMA grant is about to be issued. No DMA device should issue a DMA request during the time $\overline{\text { DMARCVD }}$ is asserted.

### 4.3 CPU MICROPROCESSOR CHIP SET DESCRIPTION.

The Western Digital MCP1600 microprocessor is an 8-bit microprogrammable computer implemented with 3 MOS/LSI chips using UDC's N-channel silicon gate process. The chip set consists of the CP1611B Data chip, the CP1621B Control Chip, and the CP1631B microinstruction ROM (MICROM) chip.

These chips are interconnected by the 22 bit Microinstruction Bus (MIB) which provides bi-directional communication between the chips for addresses and instructions. A Data Access Bus provides a 16 bit port for communicating with other system components such as memory and I/O.

The list below describes the pertinent aspects of the set:

- 8-bit Internal Organization
- 16-bit Data Access Port to Memory and I/O
- 26 Registers
- Extensive Microinstruction Set Including Decimal Operations
- Single and Double Byte Operations
- Micro and Macro Level Condition F1ags
- 512 Word x 22-bit Control ROM
- Control ROM Expandable to 2048 words
- Micro Level Subroutine Capability
- Programmable Translation Array for Macroinstruction Interpretation
- Four External Interrupts and Three Internal Interrupts
- External Instruction Set
- Power Supplies $+12 \mathrm{~V},+5 \mathrm{~V}$, and -5 V
- TTL Compatible 3 State Interface

Figure 4-18 describes the interconnection of the required components of the MCP 1600 microprocessor set. The DATA CHIP, (CP1611B) contains the arithmetic logic unit, the microinstruc-
tions decode and the register file. Additionally, it contains paths to control the operation of the processor.

The CONTROL CHIP (CP1621B) contains the program translation array, portions of the control circuitry to control operation of the processor set, the microinstruction counter and the I/O control system.

The MICROM CHIP (CP1631B) contains the microinstruction ROM. The MP1600 microprocessor set may be expanded up to four MICROMs giving the user a total of 2,04822 bit microinstructions. In addition to the three parts comprising the Microprocessor Set, twelve other available standard TTL parts are required. These parts serve to:

- Generate the clocks
- Latch and gate input signals
- Latch and gate output signals


Figure 4-18. MCP1600 Microprocessor Block Diagram

The three chips that make up the MP1600 microprocessor set are contained in standard $40-\mathrm{pin}$ DIPS with pin assignments as listed in Tables 4-9, 4-10, and 4-11.

Table 4-9. Data Chip (CP1611B) Pin Assignments

| $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SI GNAL | $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SI GNAL | PIN NO. | S I GNAL | PIN NO. | SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\emptyset 3$ | 11 | DALø 8 | 21 | $\emptyset 2$ | 31 | $\overline{\text { MIB }} \overline{7}$ |
| 2 | VBB | 12 | DALø9 | 22 | WAIT | 32 | $\overline{\text { MIBø }}$ |
| 3 | DALø $\emptyset$ | 13 | DAL1ø | 23 | $\overline{\text { MI B15 }}$ | 33 | $\overline{\text { MIB } \varnothing 5}$ |
| 4 | DALø1 | 14 | DAL 11 | 24 | $\overline{\text { MIB14 }}$ | 34 | $\overline{\text { MIB } \emptyset 4}$ |
| 5 | DALø 2 | 15 | DAL 12 | 25 | $\overline{\text { MIB13 }}$ | 35 | $\overline{\text { MIB } \emptyset 3}$ |
| 6 | DALø 3 | 16 | DAL 13 | 26 | $\overline{\text { MIB12 }}$ | 36 | $\overline{\text { MIBø } 2}$ |
| 7 | DALø 4 | 17 | DAL14 | 27 | $\overline{\text { MIB11 }}$ | 37 | $\overline{\text { MIB } \emptyset 1}$ |
| 8 | DALø 5 | 18 | DAL 15 | 28 | $\overline{\text { MIB1ø }}$ | 38 | $\overline{\text { MIB } \varnothing \varnothing}$ |
| 9 | DALø 6 | 19 | VSS | 29 | $\overline{\text { MIBø9 }}$ | 39 | VDD |
| 10 | DALø 7 | 20 | $\emptyset 4$ | 30 | $\overline{\text { MIBø8 }}$ | 40 | $\emptyset 1$ |

Table 4-10. Control Chip (CP1621B) Pin Assignments

| $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SIGNAL | $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | S I GNAL | $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SI GNAL | PIN NO. | SI GNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\emptyset 3$ | 11 | $\overline{\text { MIB16 }}$ | 21 | $\emptyset 2$ | 31 | $\overline{\text { MIB }} 7$ |
| 2 | VBB | 12 | REPLY | 22 | VCC | 32 | $\overline{\text { MI B66 }}$ |
| 3 | I3 | 13 | WAIT | 23 | MIB15 | 33 | $\overline{\text { MIB®5 }}$ |
| 4 | I2 | 14 | DOUT | 24 | $\overline{\text { MIB14 }}$ | 34 | MIBø4 |
| 5 | I1 | 15 | WB | 25 | $\overline{\text { MIB13 }}$ | 35 | $\overline{\text { MIB } \square^{3}}$ |
| 6 | I $\emptyset$ | 16 | IACK | 26 | $\overline{\text { MIB12 }}$ | 36 | $\overline{\text { MI B } \emptyset 2}$ |
| 7 | $\overline{\text { MIB17 }}$ | 17 | SYNC | 27 | $\overline{\text { MIB11 }}$ | 37 | $\overline{\text { MIB®1 }}$ |
| 8 | BUSY | 18 | DIN | 28 | $\overline{\text { MIB1 } \varnothing}$ | 38 | $\overline{\text { MI B } \emptyset \varnothing}$ |
| 9 | COMPUTE | 19 | VSS | 29 | $\overline{\text { MIB } \varnothing 9}$ | 39 | VDD |
| 10 | $\overline{\text { RESET }}$ | 20 | $\emptyset 4$ | 30 | $\overline{\text { MIB } \emptyset 8}$ | 40 | $\emptyset 1$ |

Table 4-11. Microm Chip (CP1631B) Pin Assignments

| $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SIGNAL | $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SIGNAL | PIN NO. | SI GNAL | $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | SI GNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\emptyset 3$ | 11 | $\overline{\text { MI B16 }}$ | 21 | $\emptyset 2$ | 31 | $\overline{\text { MIB } \emptyset 6}$ |
| 2 | VBB | 12 | $\overline{\text { MIB17 }}$ | 22 | VCC | 32 | $\overline{\text { MIBØ5 }}$ |
| 3 | NC | 13 | $\overline{\text { MIB18 }}$ | 23 | CHIP |  |  |
|  |  |  |  |  | SELECT | 33 | $\overline{\text { MIB } 0^{4}}$ |
| 4 | NC | 14 | $\overline{\text { MIB19 }}$ | 24 | NC | 34 | $\overline{\text { MIB }}$ ¢ 3 |
| 5 | NC | 15 | $\overline{\text { MIB2 } \varnothing}$ | 25 | NC | 35 | $\overline{\text { MIB } \emptyset 2}$ |
| 6 | NC | 16 | $\overline{\text { MIB21 }}$ | 26 | MIB11 | 36 | NC |
| 7 | $\overline{\text { MIB15 }}$ | 17 | NC | 27 | $\overline{\text { MIB1ø }}$ | 37 | $\overline{\text { MIBØ1 }}$ |
| 8 | $\overline{\text { MIB14 }}$ | 18 | NC | 28 | $\overline{\text { MI B69 }}$ | 38 | MIB $\bar{\square} \bar{\square}$ |
| 9 | $\overline{\text { MIB13 }}$ | 19 | VSS | 29 | $\overline{\text { MIB } \emptyset 8}$ | 39 | VDD |
| 10 | $\overline{\text { MIB12 }}$ | 20 | $\emptyset 4$ | 30 | $\overline{\text { MIB } \varnothing 7}$ | 40 | $\emptyset 1$ |

### 4.3.1 SYSTEM COMPONENTS.

The main functional components of the CPU microprocessor are physically partitioned into three kinds of devices. The logical partitioning of the system, however, encompasses five areas as follows:

1. Processing and Data Handling. This is generally handled on the CP1611B Data Chip.
2. Next Instruction Address Generation. This is generally handled on the CP1621B Control Chip.
3. Microinstruction Storage. These are contained on one or more CP1631B Microinstruction ROMs.
4. Microinstruction Bus. This bus connects the three types of devices together and provides a path for the microinstructions to flow from the microinstruction ROM to both the Control and the Data Chip.
5. Data Access Bus. This bus provides access from the MCP1600 microprocessor set to the outside world. Lines comprising this data access bus come from all three of the chip types. Lines containing the address and data come from the Data Chip, control lines defining the state of the data access come from the Control Chip and user programmable control lines come from the Microinstruction ROM.

The MCP 1600 operates on a four phase clock system. While there are some variations, the general use of each phase period is:

- D1 Instruction Access
- Ø2 Data Access
- Ø3 Execution
- Ø4 Data Update


### 4.3.1.1 REGISTERS.

The various registers in the CPU microprocessor are described in the following paragraphs.

Register File. The Register File consists of 26,8 bit registers which provide RAM data storage for the MCP1600 processor set. The register file has 2 output ports and 1 input port. Fourteen of the registers of the file can be directly addressed by the $A$ and/or $B$ register designators of a microinstruction. Additionally, the 16 top-most registers of the register file may be considered as register pairs and can be addressed by the $G$ register to permit operation on full words of data. The Register File is on the Data Chip.

The $A$ and the $B$ output ports of the register file feed into the ALU.

G Register. The G register is a pointer register on the Data Chip that describes the currently accessed linked consecutive pair of registers in the register file. Note that, when the G register is being used, access to the register file is from the top down. This is opposed to the access to the register file when only the A and B fields are being used as designators; in which case, it is from the bottom up. This register is loaded by IW and LGL instructions. "Input Word" instruction loads the G Register from the DAL bus as specified by the "b" field of the instruction. "Load G Low" instruction loads the G Register Ra.

The first (or lowest) 14 registers of the Register File are addressable only from the MIR register. The top 12 registers are addressable only from the $G$ Register. The middle 4 registers are addressable from either the $G$ or the MIR registers. Figure 4-19 describes the addressing conventions of this file. It is helpful to note that if the $a$ or $b$ fields of the MIR are 1 or 0 , then this enables $G$ Register addressing.

Assume $G=4, a=0, b=B$
Then one operand (A Port) will be from G'8' The other operand (B Port) will be from $R^{\prime} B^{\prime}$

Assume $G=0, a=7, b=1$
Then one operand (A Port) will be from R'7' The other operand (B Port) will be from G'1'

Assume $\mathrm{G}=\mathrm{b}, \mathrm{a}=1, \mathrm{~b}=0$
Then one operand (A Port) will be from G'D' The other operand (B Port) will be from $R^{\prime} D^{\prime}$

Assume $G=3, \mathrm{a}=6, \mathrm{~b}=\mathrm{A}$
Then one operand (A Port) will be from R'6' The other operand (B Port) will be from R'A'

Assume $G=5, a=0, b=1$
Then one operand (A Port) will be from G'5' The other operand (B Port) will be from G'6'


Figure 4-19. Register File

ALU Status Bits. The ALU provides 4 status bit outputs which reflect the result of each 8 bit output which in turn reflects the result of each 8 bit operation. The $Z B$ and $N B$ bits are updated after every ALU operation. $C 4$ and $C 8$ are updated only during Arithmetic or Shift operations. These bits may be tested by Jump, but their primary function is to pass result data from the first cycle of a word instruction to the second cycle. The available status bits are:

ZB: Set if the result of a Byte or Word operation is zero; cleared otherwise.

NB: Set if the high-order bit of a Byte or Word operation is a one; cleared otherwise (except for $\operatorname{SRW}$ and SRWC).

C4: Set if Carry Out of Position 3 is a one; cleared otherwise. Updated only on Arithmetic operations. This status bit is used mainly for decimal arithmetic corrections.

C8: Set if Carry Out of Position 7 is a one; cleared otherwise. (Note that this status bit is not set to borrow for subtract as is the case with the C Flag.) Also set if the shifted off bit of a Shift operation is a one; cleared otherwise.

Condition Flags. The Condition Flags consist of 4 latches which can reflect the status of the previous ALU results. The updating of these flags can be selectively enabled or disabled at the discretion of the microprogrammer. The condition flags are updated with odd-numbered instruction opcodes in the range of $8 \emptyset$-EF.
$Z$ Flag: Set if the result of a Byte or Word operation is zero, cleared otherwise.

N F1ag: Set if the high-order bit of the result of Byte or Word operation (except for SRW and SRWC)
is a one; cleared otherwise. (Note that this
is the complement of the sign of the result if overflow occurs.)

C Flag: Monitors the carry, borrow and shifted off bits as follows:

Add and Increment: Set if there is a carry from the most significant bit of the Byte or Word result; cleared otherwise.

Subtract and

## Decrement:


#### Abstract

Set if there is a borrow (complement of carry) from the most significant bit of the Byte or Word result; cleared otherwise.

Set if the bit shifted off in a left or right shift is a one; cleared otherwise.


Shift:

The C Flag is not affected for operations (other than those listed above) even if the other flags are updated.

V Flag: Set if there is an arithmetic overflow on Arithmetic operations, cleared if there is no overflow and on Non-arithmetic operations. On Add operations, overflow occurs when the sign of the two operands are the same and the sign of the result is different. On Subtract operations, overflow occurs when the signs of the two operands are different and the sign of the result is different from the operand in Ra ( $\mathrm{V}=\mathrm{C} 7 \otimes \mathrm{C} 8$ ).

The format of the ALU status and flag register word is shown below:

| NB | $Z B$ | $C 4$ | $C 8$ | $N$ | $Z$ | $V$ | $C$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

MIR Register. The 16 bit MIR register holds the least significant 16 bits of the 22 bit microinstruction currently being executed. The MIR register is loaded every $\emptyset 1$ unless the currently executing microinstruction is of the 2 cycle variety. In this case, the register is not clocked on the second occurrence of $\emptyset 1$.

### 4.3.1.2 INSTRUCTION ADDRESS GENERATION.

This paragraph describes the registers and arrays used in generating the next microinstruction address.

Location Counter Register. The Location Counter (LC) is an 11 bit register which holds the address of the next microinstruction to be accessed. Under normal conditions, the LC is incremented by one after each access of a microinstruction. The LC can be altered by other than one through execution of a Jump instruction or a Return from Sub-routine (RFS) instruction or by the invocation of a PTA translation.

Return Register. The Return Register (RR) holds an 11 bit address and permits a subroutine depth of one in the microprogram. When a subroutine jump is indicated (MIB $16=1$ ), the return register stores the incremented contents of the LC. Contents of the return register can be transferred to the LC under the control of a RFS - (Return From Subroutine).

Translation State Register. The Translation Register (TR) is a 16 bit register which holds the data presently being input to the PTA. Data on the Microinstruction Bus (MIB) is used to load the Translation Register. Note that only the upper or lower half of the Translation Register can be fed into Array 3 at one time.

Translation Arrays. There are four arrays on the control chip that control the generation of the next microinstruction address. They generate new inputs into the LC register, as a function of the LC register contents, the contents of the translation register, interrupts, and other miscellaneous inputs. The detailed operation of these arrays is discussed in Section 4.3.3, PROGRAMMABLE TRANSLATION ARRAY (PTA).
4.3.1.3 MICROINSTRUCTION BUS.

The Microinstruction Bus serves to interconnect the three required parts of the MCP1600 Microprocessor set. The bus is organized into 4 distinct sections.

MIB00 - MIB15 carry proper microinstruction data from the microinstruction ROM chip to both the control chip and the data chip. These lines may also carry data between the data chip and the control chip under certain conditions.

MIB 16 controls the subroutine jump operation. When MIB16 is set on a jump instruction, it causes the incremented contents of the LC register to be placed into the Return Register.

MIB17, if set, causes the PTA on the Control Chip to perform a Read Next Instruction translation.

MIB18 - MIB21 are TTL level outputs that can be programmed by the user as his needs dictate. They are not used by the MCP 1600 Microprocessor set to control its operations. They are provided for the convenience of the user in order that he may interface to the MIB bus or control devices directly from the microprogram leve1.
4.3.1.4 DATA ACCESS BUS.

The data access consists of three sections:

DAL00 - DAL15 carry address and data between the data chip and the outside world.

Outside Control Lines. There are five TTL level Outgoing Control Lines that inform the outside world of the present state of the MCP1600 set. These signals include Sync, Input Instruction, Output Instruction, Wait and Interrupt Acknow1edge.

Incoming Control Lines. There are 8 TTL level Incoming Control Lines. These incoming control 1ines inform the MCP1600 Microprocessor set of the state of affairs in the outside world. There are four interrupt lines, a Compute line, a Reset line, a Reply line and a Busy line.

With these lines, the MCP1600 can control a wide variety of peripheral devices.
4.3.1.5 MICROINSTRUCTION STORAGE.

The microinstruction ROM (MICROM) is a 512 x 22 -bit word, high speed ROM which stores the instructions of the microprogram. The transfer of addresses into the chip and the microinstruction out of the chip are performed over the MIB. Address is received from push-pull drivers in the Control Chip on $\emptyset 2$. The decoding takes place on $\emptyset 3$. On $\emptyset 4$ the selected microinstruction is internally accessed and the MIB is precharged. The accessed microinstruction is placed on MIB15MIB $\emptyset$ for transfer to the Data Chip and Control Chip during $\emptyset 1$.

### 4.3.2 CPU OPERATIONS.

This section describes the internal workings of the Data Chip, the CPU of the MCP1600 system. There are two important and distinct partitions to the processor. The first partition,
called the Data Chip, provides classical stored program processing. The Data Chip consists of:

- A register file
- An arithmetic logic unit (ALU)
- A Microinstruction register
- A register file address decoder
- A control signal generation function
-Condition flags
- Jump decoding
- Input/Output gating

The data chip is responsible for data manipulation as a result of instruction execution.

The second partition, the Control Chip, generates address data that directs the accessing of the next microinstruction to be executed. This address generation mechanism provides the MCP 1600 with its unique emulation capabilities. While the Data Chip is executing the presently fetched microinstruction, the Control Chip is performing a transformation upon the presently executing macroinstruction to determine the address from which to fetch the next microinstruction to be executed.

The description of the processor proceeds by first outlining the operation of the Data Chip (CPU) and then in the following section outlining the operation of the Control Chip. it is important to note that the two chips are not synchronized except by a common clock, and the fact that the contents of the MI register on the Control Chip and the contents of the MIR register on the Data Chip are the same. Very few control lines are passed between the Data Chip and the Control Chip.

### 4.3.2.1 CPU SEQUENCING.

First assume that the machine has been properly reset and has just entered the compute mode. The Control Chip causes a
microinstruction to be fetched from the MICROM to be placed on the MIB bus. (See Figure 4-20.) Assuming that the clock is now on the leading edge of $\emptyset 1$, the contents of the MIB bus are gated into the MIR register on the Data Chip and the MI register on the Control Chip.

At the end of $\emptyset 1$ (trailing edge of the clock), the contents of the MIR register have settled. The contents on the MIR register are held fixed until the next occurrence of $\emptyset 1$ (four phase times).

At the beginning of $\emptyset 2$, the contents of the MIR register are presented to the various different functions of the CPU. The A and $B$ fields are presented to the address decoder, as is the G register. The contents of the MIR register's C field and OP field are presented to the master control function of the Data Chip. During $\emptyset 2$ and $\emptyset 3$, the master control function decodes the $C$ field and generates signals which control the gating of data to the various functions of the Data Chip. In $\emptyset 2$, the address decoder is interpreting the contents of A field and the $B$ field and accessing the appropriate register in the register file. Also during $\emptyset 2$, the condition codes reflecting the result of the last ALU operation become valid. They are presented to the FLAGS register which retains them for examination on the next occurrence of $\emptyset 4$. Figure 4-21 illustrates $\emptyset 2$ data paths.

Phase 3 is the register access phase. During $\emptyset 3$, data is presented to the ALU by the $A$ and the $B$ output ports of the register file. Data may also be presented to the ALU B port by means of the literal path from the MIR register. Note the literal path (whose contents are the A and B field of the MIR) bypasses the address decoding logic and the register file. Also during $\emptyset 3$, the contents of the $A$ and $B$ register file output ports may be presented to the Data Access on 1ine DALOO
-DAL15. During this phase time, the contents of the register file A port may be presented to the flag register. Finally, during this phase time, the contents of the register files A and $B$ ports may be presented to the gating which controls access to the MIB bus. Figure 4-22 illustrates $\emptyset 3$ data paths.

During $\emptyset 4$, the output of the ALU becomes valid. Input to the ALU may occur from the data bus in $\emptyset 4$. That is, data presented on lines DALOO-DAL15 may be presented to the gating structure which controls the output of the ALU. Finally, during $\emptyset 4$, the data available from the Data Access may be presented to the gating structure that controls access to the MIB bus. Figure 4-23 illustrates the $\emptyset 4$ data paths. Note that, during $\emptyset 4$, the jump control takes place. If the jump decoder indicates that all the proper jump conditions are met and if JXX is asserted, then MIB15 will cause the Control Chip to effect a jump on the next clock cycle.

As the next $\emptyset 1$ clock occurs to start the next cycle of the instruction/execution, the data that was presented to the gating structure that controls access to the A input port of the register file is gated or not gated, depending upon a signal from the Master Control, into the register file. Figure 4-24 illustrates this path. If the instruction contained in the MIR register is one that requires only one clock cycle for execution, then a new instruction is fetched from the MICROM according to the address generated by the Control Chip and execution begins as in Figure 4-20.

If however, the instruction requires two cycles for execution, things proceed differently. At the beginning of $\emptyset 1$ of the second cycle, the contents of the MIR are preserved and no new data is gated in. The low order bits of both the 'A' and 'B' fields are complemented to access adjacent slots in the register


Figure 4-20. Ø1 Data Paths


Figure 4-21. Ø2 Data Paths


Figure 4-22. Ø3 Data Paths


Figure 4-23. $\varnothing 4$ Data Paths


Figure 4-24. Ø4 Data Paths Second Cycle
file to those previously addressed in the first cycle. Also during this phase, the CPU may output data to the MIB bus. Figure 4-24 illustrates this path.

Other than these exceptions, two cycle instructions proceed as do one cycle instructions.
4.3.2.2 CONTROL LINES.

During $\emptyset 2$ and $\emptyset 3$, the Master Control function is decoding the new contents of the MIR register in order to generate signals to control the data transfers described above. These control signals are generated on the basis of the contents of the $C$ and OP fields of the MIR register. All of the control lines generated by the Master Control function are not described here because some of them serve timing and sequencing functions that are not necessary to the understanding of the CPU operation and how it affects the Data Access and Microinstruction Bus. Several are described in detail in the following paragraphs and in Figure 4-25.

Register Load. This control line determines whether or not the output of the ALU will be gated back into the register file input port. It is invoked by register to register format instructions.

Load Flags. This line controls whether or not the output of the FLAGS register will be gated into the register file input port. It is generated by the Load Flags and Copy Flags instruction.

Load Hi Byte. This control line determines whether or not the contents of the DAL08-15 will be gated into the register file input port. This line is controlled primarily by the Input class of instructions.


Figure 4-25. Major Control Lines

Load Lo Byte. This control line determines whether the contents of DAL-07 will be gated into the register file input port. It is generated by input class instructions. Note that this signal and preceeding signal are generated by the specification in the $B$ field of the appropriate input instruction. Note also that one can input the low order byte, the hi order byte, or both bytes. This latter case is an input Word Instruction.

Modify Lo. This control line is invoked by the Modify instruction and causes the output of the A register file port to be gated on to the low order 7 bits of the microinstruction bus. This control line is also invoked by the Load Translation Register instruction.

Modify Hi. This control line is the high order analog of the previously described control line.

JXX. This control line is invoked by the jump instruction. It is made hi during the first phase four of the jump instruction, if the jump instructions have been met. It causes the contents of the MI register on the control chip to be placed into the LC register.

Load LIT. This instruction controls the multiplexer which selects the $B$ input to the ALU. The ALU B input port may be fed from either the literal field of the MIR register or the $B$ port output of the register file. This control signal is set by the literal class of instructions and causes the $B$ input to the ALU to be selected from the literal path.

Double/Single. This control line is generated by the Master Control for use by itself. It is invoked by instructions that require two cycles for execution. In the main, it controls
whether or not a new instruction is gated into the MIR register at the next occurrence of $\emptyset 1$.

Load TR. This control line is invoked by the Input Word instruction if either bits 4 or 5 of the $B$ field are set. These bits being set will cause the data on the Data Access to be placed into the translation register on the Control Chip. It is in this fashion that new macroinstructions are fetched from the user memory for decoding.
4.3.3 PROGRAMMABLE TRANSLATION ARRAY (PTA).

This section describes the operation of the MCP1600 Microprocessor set's most unique feature, the Programmable Translation Array. The Programmable Translation array serves to generate new microinstruction fetch addresses as a function of several parameters. These parameters are those which are normally considered during the decoding of a macroinstruction. While the Programmable Translation Array was designed specifically to eliminate most of the overhead of macroinstruction translation, it is useful for other purposes. For example, a data driven processor could determine the next operation to be performed on a data structure as a function of the present data and the present operation.

Briefly, the Programmable Translation Array consists of eight elements. They are:

- Location Counter
- Array 1
-Array 2
- Array 3
- Translation Register
- Array 4
- Translation State Register
- Return Register

These elements give the capability of calculating microinstruction addresses other than sequentially, or as specified by a jump instruction. Figure 4-26 depicts their interconnection. The mapping (or new Location Counter value) that the PTA generates, when invoked, is a function of the value of the Location Counter, the contents of the Translation Register, the interrupts, and the state of the RNI line.
4.3.3.1 PROGRAMMABLE TRANSLATION ARRAY COMPONENTS.

This Section describes the components of the Programmable Translation Array and their functions.

Location Counter. It is the function of the Location Counter to hold the address of the next microinstruction. The Location Counter is 11 bits wide and has outputs to MIB00-MIB10 and to Array No. 1. It has inputs from the Master Control function, Array No. 4 and the Return Register. There is also an input to the Location Counter from an incrementer.

Array No. 1. Array No. 1 is an 88 element array with 23 inputs. There are 11 true inputs and 11 complemented inputs from the Location Counter and the RNI bit (MIB17). Figure 4-27 illustrates the organization of Array No. 1. Figure 4-28 illustrates the concept, as opposed to implementation of a typical gate, one of 88 , that make up Array No. 1. The outputs of these gates make up the bulk of the inputs of Array No. 2.

The purpose of Array No. 1 is to perform a selection function. When the inputs to Array No. 1 match one (or more) of the word values (addresses), the output associated with that word is asserted. This array is programmed with 6 hexidecimal digits as shown in Figure 4-29. Transistors are placed in the array for 1 bits in the data specification. To program a group of addresses, the bits of the address to be left out are specified


Figure 4-26. PTA Component Interconnections


Figure 4-27. Array No. 1 Organization


Figure 4-28. Typical Gate - Array No. 1
as $\emptyset$ bits for the true and complement address inputs. This produces a 'DON'T CARE' effect for those bits and the result will always be a match. This lets the user match on modulo address.

The RNI serves to inhibit the output of Array No. 1. The reason for this is described later.

| 0 | LC ADDRESS | 0 | $\overline{\text { LC ADDRESS }}$ |
| :--- | :--- | :--- | :--- |
| 2322 |  | 121110 | 0 |

Example:
Address $=X^{\prime}$ 5F8 ${ }^{\prime}$
Array * 1 Data Word = X' 5F8A07'
Figure 4-29. Array No. 1 Data Specification

Array No. 2. Array No. 2 is an ORed array whose outputs are negated. The array has 89 inputs, 88 from Array No. 1 and one from MIB17, the RNI 1ine. The seven outputs from Array No. 2 represent a translation state code and become inputs into Array No. 3.

Figure 4-30 illustrates the organization of Array No. 2. Figure 4-31 illustrates in some detail, the conceptual structure of the gate and interconnect structure of Array No. 2. The small circles present where the lines would normally cross represent connections that can or cannot be made. It is via the making or not making of the connections with transistors that this array is programmed.


Figure 4-30. Array No. 2 Organization
ARRAY 1 OUTPUTS


Array \#2 is driven by the inputs from Array \#1. When one or more outputs of Array \#1 are asserted, Array 2 will make the corresponding word available as its outputs.

The purpose of Arrays \# 1 and \# 2 is to provide a mapping between the present value of the Location Counter and a preselected set of translation state codes.

Figure 4-31. Array No. 2 Gate and Interconnect Structure

Due to electrical considerations, there are restrictions placed on the configuration of Array No. 2. Normally this array is programmed in a 4 of 7 code ( 4 of 7 outputs may be selected to be high, the other 3 must be low), or more ideally, to reduce capacitive loading, a 5 of 7 code. The tables 4-12 and 4-13 describe the various state code outputs available in both the 4 of 7 and the 5 of 7 schemes.

Table 4-12. Translation
State Code Outputs--4 of 7

| 日F | $2 D$ | $3 C$ | 56 | 69 |
| :--- | :--- | :--- | :--- | :--- |
| 17 | $2 E$ | 47 | 59 | $6 A$ |
| $1 B$ | 33 | $4 B$ | $5 A$ | $6 C$ |
| $1 D$ | 35 | $4 D$ | $5 C$ | 71 |
| $1 E$ | 36 | $4 E$ | 63 | 72 |
| 27 | 39 | 53 | 65 | 74 |
| $2 B$ | $3 A$ | 55 | 66 | 78 |

Tab1e 4-13. Translation
State Code Outputs--5 of 7


The outputs of Array No. 2 represent some of the inputs to Array No. 3.

The RNI line (MIB17) deserves mention at this point. It is the purpose of the RNI line to force a particular user defined state code from the mapping represented by Arrays No. 1 and No. 2. This state code will be independent of the contents of the Location Counter.

Accordingly, RNI inhibits the outputs of Array No. 1 and invokes that state code selected by the user in Array No. 2 and makes it present at the output of Array No. 2.

The programming of Array No. 2 is illustrated in Figure 4-32. Transistors are put in the arrays for zero bits as per the data specifications.


Figure 4-32. Data Specification

Array No. 3. Array No. 3 is a NANDed array, and has 42 inputs. In contrast to Arrays No. 1 and No. 2, the inputs come from a variety of sources. The inputs to this array constitute a direct interface to the real world at the macromachine level, as one of the inputs is the translation register. The inputs to Array No. 3 are:

- Seven from Array No. 2. (Translation Code)
- Sixteen from the Translation register. Eight are true data and eight are complemented data.
- Fourteen inputs from the interrupt latches. Again, both true and complemented data are present.
- Two from the translation state register. Again, both true and complemented data are used.
- One input, called the $Q$ signal, not generally usable.

It is worth noting, that while there are 42 inputs in Array No. 3, they are not all present at the same time. The array is broken into two partitions. The first partition consists of words 0 through 15, and has as its inputs, the 14 bits from the interrupt latches. The second partition of the array, words 16 through 99 have in the same slots the 16 bits of inputs from the Translation Register.

The Figure 4-33 illustrates the structure of the first partition of the array. Figure 4-34 illustrates the second partition of the array. Figure 4-35 shows a conceptual picture of a typical gate in the array.


Figure 4-33. Array No. 3 Interrupt Organization

| Translation | Array 2 | Tramsation |
| :---: | :---: | :---: |
| State | Outputs | Register |
| Regrster |  |  |



Figure 4-34. Array No. 3 Translation Register Organization


Figure 4-35. Typical Gate of Array No. 3

Array No. 3, being an ANDed array, will try to match the configuration of its inputs against one of the words. that make up the array. If it finds a match, the output associated with that word will be asserted.

Array No. 3 is programmed with true data as eight hexadecimal digits. DON'T CAREs, which always result in matches, are created by placing both true and complemented bits to zero. Below is a data specification for the programming of Array No. 3.

## AND Gates

0. 15:


AND Gates 16.99:

| TSR | TSR | $\theta$ | $\theta$ | $\theta$ | 0 | $\theta$ | TRANSLATION <br> CODE | TRANSLATION <br> REGISTER |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $242322 \quad$- RANSLATION <br> REGISTER |  |  |  |  |  |  |  |  |

Array No. 4. Array No. 4 is a NORed array with 100 inputs which come from Array No. 3. The outputs generated by Array No. 4 include address data to be fed into the Location Counter, data to be fed into the Translation State Register, and three control lines. Two control lines determine whether the Location Counter will be loaded from the Return Register or the output of the translation array. The third control line determines whether or not the value presented to the Translation State Register will in fact be loaded into the Translation State Register. Figure 4-36 illustrates the organization of this array. Note that not all the outputs are complemented. The two control signa1s LRA and LTA are true data.

Array No. 4 will determine if any of its inputs are active. If they are, the word associated with the active input is placed on the output lines.

The array is programmed into terms of true data. Five hexadecimal digits are used to program each word. Transistors are placed in the array for 1 bits in the data specification. More than one active AND gate in Array 3 causes the outputs to OR.



Figure 4-36. Array No. 4 Organization

Translation State Register. The Translation State Register serves two functions. One is to determine whether the Hi or the Lo order byte of the Translation Register is to be selected for input to Array No. 3. The other is to provide a four state feedback as an input of Array No. 3. The loading of the Translation State Register is controlled by an output (LTSR) of Array No. 4.

Translation Register. The Translation Register holds the data presently serving as input to the Programmable Translation Array. It receives its inputs from the Microinstruction Bus (MIB00 MIB15) as a result of an LTR or IW instruction. Because of the fact that its output destination is 8 bits wide, only half of the Translation Register can be examined at any one time. The

Translation State Register controls which half of the Translation Register is gated into the input of Array No. 3, its destination. It serves as a feedback term of information to the second half of the word.

Bit 2 of the TSR controls the selection of translation input from the TR. When this bit is a zero, the upper byte of the TR is selected; when it is a one, the lower byte is selected. TSR2 does not serve as an input to Array No. 3.

### 4.3.3.2 PROGRAMMABLE TRANSLATION ARRAY OPERATIONS.

 This section describes the operation of the Programmable Translation Array. The Programmable Translation Array operates as a loop. The beginning and end points of the loop can be considered as the Location Counter.This loop is completed within one machine cycle and the main components are:

> The Location Counter
> Arrays No. 1 and No. 2, which taken together perform a mapping of the Location Counter to a translation code. The translation register, which holds the macroinstruction undergoing the translation process. Arrays No. 3 and No. 4 which take the translation code and the macroinstruction presently undergoing translation and map them into an address.

This newly generated address can then point to the beginning of a macroroutine to interpret the macroinstruction presently accessed.

The operation of the Programmable Translation Array is a function of phase time clocks and begins at $\emptyset 1$. During $\emptyset_{1}$, the location counter is loaded with its new value. The new value can come from any one of four sources as follows:

From Array No. 4 of the Programmable Translation Array
From the MI register
From the incrementer
From the Return Register

Figure 4-37 assumes, for the purposes of instruction, that the Location Counter is loaded from the incrementer. Concurrently, with the loading of the Location Counter at $\emptyset 1$, the Translation Register is also being loaded if either a LTR or an IW instruction was executed.

At the beginning of $\emptyset 2$, (see Figure 4-38) the contents of the Location Counter are clocked out to the MIB bus (MIBOO-10) and to Array No. 1. Both the true and complemented forms of the Location Counter are input to Array No. 1. A1so input is the RNI line. Array No. 1 takes the input data word and determines whether or not it has a match. If it has a match, then the appropriate output is set at the end of $\emptyset 2$. If there is no match, the translation proceeds no farther because no outputs are set.

At the beginning of $\emptyset 3$, (see Figure 4-39), Array No. 2 samples the outputs from Array No. 1 and determines whether any are active. If there is a match, then the translation code is generated and fed to Array No. 3, also during $\emptyset 3$.

During $\emptyset 3$, the contents of the selected byte of the Translation Register are fed to Array No. 3 along with the contents of the interrupt register, the Translation State Register, and the $Q$ bit. During the later portions of $\emptyset 3$, Array No. 3 determines if there is a match and, if a match is found, at the end of $\emptyset 3$ an output is generated.

This output is fed into Array No. 4 at the beginning of $\emptyset 4$. (See Figure 4-40.) During $\emptyset 4$, Array No. 4 determines whether there is an active input to it. If there is an active input,
the contents of the word associated with the input are sent out at the end of $\emptyset 4$. The Array No. 4 word may or may not cause the Translation State Register to be loaded, and may or may not cause the Location Counter to be loaded at the next occurrence of $\emptyset 1$.


Figure 4-37. Ø1 Data F1ow


Figure 4-38. Ø2 Data F1ow


Figure 4-39. Ø3 Data Flow


Figure 4-40. $\emptyset 4$ Data Flow

### 4.3.4 MICROINSTRUCTIONS.

This section contains descriptions of the microinstructions. With each description is a diagram showing the format of the instruction and its operation code given in hexadecimal. Above each diagram is the instruction mnemonic operation code, the argument needed by the assembler, the instruction, and the name of the instruction. Under each diagram is a description of the command and its timing in clock cycles.

While the formats presented here describe 16 bits of instruction word, be aware that the word is, in fact, 22 bits wide. The portion of the instruction described here controls the operation of the processor. The other 6 bits are:
-bits 16 and 17 are involved with control of the Location Counter. Bit 16 determines whether or not the contents of the Return Register will be loaded into the Location Counter. Bit 17 determines whether or not a Read Next Instruction translation will be invoked.

These two options are available on all instructions.
-bits 18 through 21 have nothing to do with control of the MCP1600 system. They are available for the user to program as TTL levels. These bits are available on all instructions.

Instruction Types. A11 of the MCP 1600 microinstructions are 22 bits long. Of the 22 bits, the 16 least significant effect the operation of the CPU. The purposes of the other 6 bits are covered in either the Programmed Translation Array description or the Micro Instruction Bus description.

The instructions for the MCP1600 are divided into four classes as follows:

| $O P$ | $R$ | Address |
| :--- | :--- | :--- |
| 15 | 121110 |  |

This format provides an 11-bit Control ROM address. It causes an unconditional jump to any location in the permissable MICROM address space by always asserting the jump control line (JXX on the Data Chip or MIB 15 on the Micro Instruction Bus). The unconditional jump instruction is the only one that utilizes this format.

Unconditional jump instructions always take two clock cycles; one to decode the instruction, the second to load the Location Counter on the Control Chip.

A special case of this format is the Return From Subroutine instruction, covered later.

CONDITIONAL JUMP FORMAT

| OP | $C$ | ADDRESS |
| :--- | :--- | :--- |
| 15 | 1211 | 87 |

This format provides a Jump address within a page. This instruction is substantially the same as the Unconditional Jump format with the exception of the reduced address space. It is also a two cycle instruction with the jump decision (based upon the contents of the $C$ Field) being made by the jump decode logic on the Data Chip during the first cycle. This decision is communicated to the Control Chip via MIB15 (JXX on the Data Chip). During the second cycle the jump is affected.

LITERAL FORMAT

| OP | Literal | $a$ |
| :--- | :--- | :--- |
| 15 | 1211 | 43 |

This format provides 8-bit literal data. The "a" field usually specifies a file register. These instructions invoke the "literal path" to fetch data around the register file for the " $b$ " input to the ALU. A11 of these instructions execute in one clock cycle.

REGISTER FORMAT

| $O P$ | $b$ | $a$ |
| :---: | :---: | :---: |
| 15 | 87 | 43 |

This format is by far the predominant one. In it, "b" and "a" are register file designators. Generally, depending upon the operation, there can be two meanings to the register designators:
"b" (operation) "a"
as, for instance, in a shift or move instruction "b" (operation)
"a" "a"
as, for instance, in an arithmetic instruction.
"b" and "a" can specify either a single byte data quantum or a word (double byte) data quantum. In this latter case, the designators usually point to the even addressed member of a register pair. While they may both point to an odd addressed pair, note carefully the instructions description for the effect.

If the designators apply to a word data quantum, the instruction takes two cycles to execute. The following sections describe MCP1600 instructions by classes of function. See Table 4-14 for the microinstruction set, Table 4-15 for a list of the microinstructions, and Table 4-16 for a summary of microinstruction and status flags.

Table 4-14. Microinstruction Set

| Symbols | Meaning |
| :---: | :---: |
| $\overrightarrow{1} 1$ <br> $\wedge$ <br> V <br> $\forall$ <br> Rx: Ry <br> Ra <br> Rb <br> Flag Setting <br> X <br> $\emptyset$ <br> 1 <br> - <br> $\bullet$ | is transferred to <br> contents of location or register <br> Logic Product (AND) <br> Inclusive "or" <br> Exclusive "or" <br> Forms extended register Ry $=\mathrm{LSB}, \mathrm{Rx}=\mathrm{MSB}$ <br> The register specified by the micro-instruction " $a$ " field <br> Designates no catagory <br> The register specified by the micro-instruction " $b$ " field <br> Don't care condition <br> Flag cleared (set to $\emptyset$ ) <br> Flag set <br> Flag not affected <br> Set according to function |

Table 4－15．Microinstructions

| Instruction | OP Code | Mnemonic | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Jump | $\theta(0)$ | JMP | 2 | （MIR11－00）－（LC）Jump unconditionally to microm location specified by MIR11－00 |
| Return from Subroutine | $0(1)$ | RFS | 2 | （RR）$)$（LC）Restore return address from subroutines |
| Jump if ZB False | 10 | JZBF | 2 | If $Z B=\emptyset$ ．（MIR 0700 ）$\cdot($ LC7．0）jump conditionally within microm page |
| Jump if ZB True | 11 | JZBT | 2 | If $Z B=1$ ，（MIR07－00）$+(L C 7-0)$ |
| Jump if C8 False | 12 | JC8F | 2 | If C8＝0，（MIRQ7－0日）－（LC7－0） |
| Jump if C8 True | 13 | JC8T | 2 | If C8＝1，（MIRロ7－90）－（LCC7－0） |
| Jump if ICS False | 14 | JIF | 2 | If ICS $=0$ ，（MIR6？－00）$+($ LC7－0） |
| Jump if ICS True | 15 | JIT | 2 | If ICS＝1，（MIRの7－00）－（LC7－0） |
| Jump if NB False | 16 | JNBF | 2 | If $\mathrm{NB}=0$ ，（MIRロ7－00）－（LC7－0） |
| Jump if NB True | 17 | JNBT | 2 | If NB－1，（MIR07－0日）－（LC7－0） |
| Jump if $Z$ False | 18 | JZF | 2 |  |
| Jump if $Z$ True | 19 | JZT | 2 | If $z=1$ ，（MIR07－00）（LCC7－0） |
| Jump if C False | 1A | JCF | 2 | If $\mathrm{C}=0$ ，（MIRD7－0日）－（LC7－0） |
| Jump if C True | 1B | JCT | 2 | If $\mathrm{C}=1$ ，（MIR07－00）－（LC7－0） |
| Jump if $V$ False | 1 C | JVF | 2 | If $V=0$ ，（MIR07－00）－（LC7－0） |
| Jump if $V$ True | 1D | JVT | 2 | If $\mathrm{V}=1$ ，（MIRQ7－0日）－$L$ LC7－0） |
| Jump if $N$ False | 1E | JNF | 2 | If $\mathrm{N}=0 .(\mathrm{MIR}$ O7－0日）－ $\mathrm{LC} 7-\emptyset$ ） |
| Jump if N True | 1F | JNT | 2 | If $\mathrm{N}=1$ ，（MIR＠7－0日）－ $\mathrm{LC} 7-0)$ |
| Add Literal | 2 | AL | 1 | （Ra）+ l．iteral－Ra the 8 bit constant is added to Ra |
| Compare Literal | 3 | CL | 1 | （Ra）－Literal．The 8 bit result of the literal is compared against $R a$ and the approprate flags set． |
| And Literal | 4 | NL | 1 | （Ra）$\wedge$ Literal－（Ra）The 8 bit result of a logical product of Ra and the literal are coded into Ra． |
| Test Literal | 5 | TL | 1 | （Ra）$\wedge$ Literal The 8 bit result of the logical product of Ra and the literal set condition Flags．The contents of Ra are unaffected． |
| Load Literal | 6 | LL | 1 | Literal•（Ra）．The 8 bit literal is loaded into Ra． |
| Reset Interrupts | 70 | RI | 1 | The three software interrupts 14，15，and 16 are reset as indicated in the instruction $b$ field． |
| Set Interrupts | 71 | SI | 1 | The three software interrupts 14．15，and are set as indicated in the instructions $b$ field． |
| Copy Condition Flags | 72 | CCF | 1 | Flags－（Ra）The four condition flags are four ALU status flags are loaded in Ra |
| Load Condition Flags | 73 | LCF | 1 | （Ra）－Flags．The contents of Ra are transferred to the ALU status flags unconditionally and to the condition flags under control of the $b$ field． |
| Reset TSR | 74 | RTSR | 1 | $0 \bullet$（TSR）．The three TSR bits in the control chip are reset |
| Load G Low <br> Conditionaily Increment Byte | 75 76 | $\begin{aligned} & \mathrm{LGL} \\ & \mathrm{CIB} \end{aligned}$ | 1 1 | （Ra） $2.0 \cdot(\mathrm{G})$ ．The three least significant bits of Ra are loaded into the $G$ register． If C8 is set，（Ra）$=1 \rightarrow\left(R_{a}\right)$ |
| Conditionally Decrement Byte | 77 | CDB | 1 | If C8 is set，（Ra） $1 \rightarrow(\mathrm{Ra})$ |

Table 4-15 (Cont.). Microinstructions

| Instruction | OP Code | Mnemonic | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Move Byte | 80/81 | MB | 1 | (Rb)-(Ra). The 8 bit contents of Rb are transferred to Ra. Rb is unaffected |
| Move Word | 82/83 | MW | 2 | $(\mathrm{Rb}) \cdot(\mathrm{Ra})$. The 16 bit contents of $\mathrm{Rb}+1 \mathrm{Rb}$ are transferred to $\mathrm{Ra}+1: \mathrm{Ra} . \mathrm{Rb}+\mathrm{I}$ and Rb are unaffected. |
| Conditionally Move Byte | 84/85 | CMB | 1 | ( Rb ) $\cdot(\mathrm{Ra})$, if $\mathrm{C}=1$. The 8 bit contents of Rb are transferred to Ra if the carry flags is set from a previous operation. |
| Conditionally Move Word | 86/87 | CMW | 2 | (Rb) $\cdot(\mathrm{Ra}$ ), if $\mathrm{C}=1$. The 16 bit contents of $R b=1: R b$ are transferred into Ra+1: Ra if the carry flag is set from a previous operation. |
| Shift Left Byte with Carry | 88/89 | SLBC | 1 | (Rbm)•(Ram+1), (carry) • (Rad). The 8 bit contents of Rb are shifted left one bit and loaded into Ra. The contents of the carry flag is inserted into the vacated low position of Ra. |
| Shift Left Word with Carry | 8A/8B | SLWC | 2 | (Rbm) + (Ram+1), (carry) $\cdot($ Raø). The 16 bit contents of $\mathrm{Rb}+\mathrm{I}: \mathrm{Rb}$ are shifted left one bit and loaded into Ra+l:Ra. The contents of the carry flag is inserted into the vacated low position of Ra. |
| Shift Left Byte | 8C/8D | SLB | 1 | (Rbm) $-($ Ram +1 ) The 8 bit contents of Rb are shifted left one bit and loaded into Ra. |
| Increment Byte by 1 | 9ø/91 | ICBI | 1 | ( Rb ) $+1 \cdot(\mathrm{Ra})$. The 8 bit contents of Rb are incremented by one and the result is transferred to Ra. |
| Increment Word by 1 | 92/93 | ICWI | 2 | ( Rb ) $+\mathrm{l} \cdot(\mathrm{Ra})$. The 16 bit contents of $\mathrm{Rb}+1: \mathrm{Rb}$ are incremented by one and the result transferred to Ra+1:Ra. |
| Increment Byte by 2 | 94/95 | ICB2 | 1 | $(\mathrm{Rb})+2 \cdot(\mathrm{Ra})$. The 8 bit contents of Rb are incremented by two and the result transferred to Ra. |
| Increment Word by 2 | 96/97 | ICW2 | 2 | (Rb) +2 (Ra). The 16 bit contents of $R b+1: R b$ are incremented by two and the result transferred to Ra+1: Ra. |
| Twos Complement Byte | 98/99 | TCB | 1 | $(\overline{\mathrm{Rb}})+1 \cdot R \mathrm{Ra}$. The 8 bit contents of Rb are two's complemented and transferred to Ra. |
| Twos Complement Word | 9A/9B | TCW | 2 | $(\overline{\mathrm{Rb}})+1 \cdot \mathrm{Ra}$. The 16 bit contents of Rb+1 Rb are two's complemented and transferred to Ra+1:Ra. |
| Ones Complement Byte | 9C/9D | OCB | 1 | $(\overline{\mathrm{Rb}}) \cdot \mathrm{Ra}$. The 8 bit contents of Rb are one's complemented and transferred to Ra. |
| One's Complement Word | 9E/9F | OCW | 2 | ( $\overline{\mathrm{Rb}}) \cdot \mathrm{Ra}$. The 16 bit contents of $\mathrm{Rb}+\mathrm{I}: \mathrm{Rb}$ are one's complemented and transferred to Ra+1:Ra. |
| Add Byte | Aø/Al | $A B$ | 1 | (Rb) $+(\mathrm{Ra}) \cdot(\mathrm{Ra})$. The 8 bit contents of Rb are added to Ra and loaded into Ra. |
| Add Word | A2/A3 | AW | 2 | $(\mathrm{Rb})+(\mathrm{Ra})+(\mathrm{Ra})$. The 16 bit contents of $R b+1: R b$ are added to Ra+1:Ra and loaded into Ra+1: Ra. |
| Conditionally Add Byte | A4/A5 | CAB | 1 | $(\mathrm{Rb})+(\mathrm{Ra}) \cdot(\mathrm{Ra})$, if $\mathrm{C}=1$. The 8 bit contents of Rb are added to Ra and the result is transferred to Ra if the carry flag is set from a previous operation. |
| Conditionally Add Word | A6/A7 | CAW | 2 | $(\mathrm{Rb})+(\mathrm{Ra}) \cdot(\mathrm{Ra})$, if $\mathrm{C}=1$. The 16 bit contents of $R b+1: R b$ are added to $R a+1: R a$ and the result is transferred to Ratl; Ra if the carry flag is set from a previous operation. |
| Add Byte with Carry | A8/A9 | ABC | 1 | $(R b)+(R a)+C \cdot(R a)$. The 8 bit sum of the contents of Rb plus the carry flag are added to Ra and the result is transferred to Ra. |

Tab1e 4-15 (Cont.). Microinstructions

| Instruction | OP Code | Mnemonic | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Add Word with Carry | AA/AB | AWC | 2 | (Rb) $+(R a)+C+(R a)$. The 16 bit sum of the contents of $\mathrm{Rb}+1: \mathrm{Rb}$ plus the carry flag are added to Ra+1: Ra and the result is transferrer to $R a+1$ : Ra. |
| Conditionally Add Digits | AC | CAD | 1 | The 4 least significant and/or 4 most significi. bits of Rb are added to their corresponding bits in Ra if C4 or C8 and reset respectively from a previous operation. This allows decimal arithmetic corrections. |
| Conditionally Add Word on Indirect Condition Status | AE/AF | CAWI | 2 | ( Rb$)+(\mathrm{Ra}) \cdot(\mathrm{Ra})$, if $\mathrm{ICS}=1$. The 16 bit contents of $\mathrm{Rb}+1 \mathrm{Rb}$ are added to $\mathrm{Ra}+1$ : Ra and the results transferred to Ra+1:Ra if the ICS code is set from a prior operation. This instruction allows address displacement addition on Branch conditions. |
| Subtract Byte | $B \emptyset / B 1$ | SB | 1 | (Ra).(Rb) $+(\mathrm{Ra}$ ). The 8 bit contents of Rb are subtracted from Ra and the result loaded into Ra. |
| Subtract Word | B2/B3 | SW | 2 | (Ra)-(Rb)-(Ra). The 16 bit contents of $R b+1: R b$ are subtracted from $R a+1: R a$ and the results loaded into Ra+1:Ra. |
| Compare Byte | B4/B5 | CB | 1 | (Ra)-(Rb). The 8 bit difference between the contents of Ra and Rb is used to set the status flags at all times and the condition flags if OP code B5 is selected Registers Ra and Rb are not changed. |
| Compare Word | B6/B7 | CW | 2 | (Ra)-(Rb). The 16 bit difference between the contents of $R a+1$ : Ra and $\mathrm{Rb}+1$ : Rb are used to set the status flags at all times and the condition flags if OP Code B7 is selected. Registers Ra+1:Ra and Rb+1:Rb are not changed. |
| Subtract Byte with Carry | B8/B9 | SBC | 1 | (Ra)-(Rb)-C•(Ra). The difference of the 8 bit contents of Rb subtracted from Ra minus the contents of $C$ flag is loaded into Ra . |
| Subtract Word with Carry | BA/BB | SWC | 2 | (Ra)-Rb)-C•(Ra). The difference of the 16 bit contents of $R b+1: R b$ subtracted from Ra+1: Ra minus the contents of the C flag is loaded into Ra+1: Ra. |
| Decrement Byte by 1 | BC/BD | DBI | 1 | (Rb)-1•Ra. The 8 bit contents of Rb minus one are loaded into Ra. |
| Decrement Word by 1 | BE/BF | DWI | 2 | ( Rb ) $1+\mathrm{Ra}$. The 16 bit contents of $\mathrm{Rb}+\mathrm{l}$ : Rb minus one are loaded into Ra+1:Ra. |
| And Byte | C®/CI | NB | 1 | $(R b) \wedge(R a)-(R a)$. The 8 bit logical product of Rb and Ra is loaded into Ra . |
| And Word | C2/C3 | NW | 2 | $(R b) \wedge(R a) \bullet(R a)$. The 16 bit logical product of $R b+1: R b$ and $R a+1: R a$ is loaded into $\mathrm{Ra}+\mathrm{I}: \mathrm{Ra}$. |
| Test Byte | C4/C5 | TB | 1 | $(R b) \wedge(R a)$. The 8 bit logical product of Rb and Ra sets the status flags at all times and the condition flags if OP code C 5 is selected. Ra and Rb are unchanged. |
| Test Word | C6/C7 | TW | 2 | $(R b) \wedge(R a)$. The 16 bit logical product of $R b+1: R b$ and Ra+1:Ra sets the status flags at all times and the condition flags if OP code C7 is selected. Ra and Rb are unchanged. |
| Or Byte | C8/C9 | OB | 1 | (Rb)V(Ra)-(Ra). The 8 bit logical OR operation is performed between the contents of Ra and Rb and the result are transferred to Ra. |

Table 4-15 (Cont.). Microinstructions

| Instruction | OP Code | Mnemonie | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Or Word | CA/CB | OW | 2 | (Rb)V(Ra)*(Ra). The 16 bit logical OR operation is performed between the contents of Ra+1:Ra and $\mathrm{Rb}+1: \mathrm{Rb}$ and the results are transferred to Ratl:Ra. |
| Exclusive-Or Byte | CC/CD | XB | 1 | (Rb) $\forall(R a) \cdot R a$. The 8 bit logical exclusive OR operation is performed between the contents of Rb and Ra and the result is transferred to Ra. |
| Exclusive-Or Word | CE/CF | XW | 2 | (Rb) $\forall(R a) \cdot R a$. The 16 bit logical exclusive OR operation is performed between the contents of $\mathrm{Rb}+1: \mathrm{Rb}$ and $\mathrm{Ra}+1: \mathrm{Ra}$ and the result is transferred to $\mathrm{Ra}+1: \mathrm{Ra}$. |
| And Complement Byte | Dø/DI | NCB | 1 | $(\overline{\mathrm{Rb}}) \wedge(\mathrm{Ra})+(\mathrm{Ra})$. The 8 bit logical product of the inverse of Rb and the contents of Ra is loaded into Ra. |
| And Complement Word | D2/D3 | NCW | 2 | $(\overline{\mathrm{Rb}}) \wedge(\mathrm{Ra}) \cdot(\mathrm{Ra})$. The 16 bit logical product of the inverse of $R b+1: R b$ and the contents of Ra+1: Ra is loaded into Ra+1:Ra. |
| Shift Right Byte with Carry | D8/D9 | SRBC | 1 | (Rbm+1).(Ram), (carry) $\rightarrow$ (Ra7). The 8 bit contents of Rb are shifted right one bit and loaded into Ra. The carry flag is inserted into the high order position of Ra. |
| Shift Right Word with Carry | DA/DB | SRWC | 2 | (Rbm+1)•(Ram), (carry) $\rightarrow$ (Ra15). The 16 bit contents of $\mathrm{Rb}+1: \mathrm{Rb}$ are shifted right one bit and loaded into Ra+1:Ra. The carry flag is inserted into the high order position of Ra+1. |
| Shift Right Byte | DC/DD | SRB | 1 | (Rbm+1)•(Ram). The 8 bit contents of Rb are shifted right one bit and loaded into Ra. |
| Shift Right Word | DE/DF | SRW | 2 | (Rbm+1)•(Ram). The 16 bit contents of $R b+1: R b$ are shifted right one bit and loaded into $\mathrm{Ra+1}$ :Ra. |
| Input Byte | EQEI | IB | 1 (min) | (DAL) $+(\mathrm{Ra})$. An 8 bit byte on the DAL is loaded into the specified Ra. The b field in this instruction selects read or readmodify - Write operation and selects upper (Bit 15-8) or lower (Bits 7-0) as the byte to be input from the Dal lines. |
| Input Word | E2/E3 | IW | 2 (min) | (DAL)*(Ra). The 16 bit word contained on the DAL is loaded into Ra+1:Ra. The b field in this instruction selects read or read-modify-write operation, selectively updates the $G$ register, and selectively sets the ICS bit. |
| Input Status Byte | E4/E5 | ISB | 1 | (DAL)-(Ra). The 8 bit byte from the DAL. line, as specified by the $b$ fold is input to register Ra, regardless of the state of reply or busy signal. |
| Input Status Word | E6/E7 | ISW | 2 | (DAL)•(Ra). The 16 bit word from the DAL line is loaded into Ra+l: Ra regardless of the state of the Reply or Busy signal. |
| Modify Instruction | EC/ED | MI | 1 | (MIB)V(Rb:Ra). The 16 bit contents of registers $\mathrm{Rb}: \mathbf{R a}$ are ORed with the contents of next microm micro-instruction on the MIB lines to modify any or all of the next micro-instruction. This instruction can be used to make on-line changes to microprogram flow. |

Table 4-15 (Cont.). Microinstructions

| Instruction | OP Code | Mnemonic | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Load Translation Register | EE/EF | LTR | 2 | (Rb: Ra)-(TR). The 16 bit contents of registers $\mathrm{Rb}: R \mathrm{Ra}$ are transferred to the Translation Register on the chip. This allows a translation of resultant data into a micro-instruction. |
| Read and Increment Byte by 1 | F0 | RIBI | 1 | ( $\mathrm{Rb}: \mathbf{R a}$ ) $=$ DAL ( Ra ) $+1+(\mathrm{Ra})$. The 16 bit address located in $\mathbf{R b}: R a$ is transferred to the DAL lines and a DATA READ operation is initiated. The contents of Ra are incremented by one. Rb is unchanged. |
| Write and Increment Byte by 1 | FI | WIBI | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $+\mathrm{DAL},(\mathrm{Rb})+1 \circ(\mathrm{Ra})$. The 16 bit address located in Rb; Ra is transferred to the DAL lines and a DATA WRITE operation is initiated. The contents qf Ra are incremented by one. $\mathbf{R b}$ is unchanged. |
| Read and Increment Word by I | F2 | RIWI | 2 | (Rb: Ra) -DAL, (Ra+1: Ra) $+1 \cdot($ Ra+1: Ra). The 16 bit address located in Rb ; Ra is transferred to the DAL lines and a DATA READ operation is initiated. The contents of Ra+1: Ra are incremented by one. |
| Write and Increment Word by I | F3 | WIWI | 2 | (Rb:Ra)•DAL, (Ra+1:Ra)+1•(Ra+1:Ra). The 16 bit address located in $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the DAL lines and a DATA WRITE operation is initiated. The contents of Ra+1:Ra are incremented by one. |
| Read and Increment Byte by 2 | F4 | RIB2 | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $-\mathrm{DAL},(\mathrm{Ra})+2 \cdot(\mathrm{Ra})$. The 16 bit address located in $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the DAL lines and a DATA READ operation is initiated. The contents of Ra are incremented by 2. Rb remains unchanged. |
| Write and Increment Byte by 2 | F5 | WIB2 | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $+\mathrm{DAL},(\mathrm{Ra})+2 \cdot(\mathrm{Ra})$. The 16 bit address located in $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the DAL line and a DATA WRITE operation is initiated. The contents of Ra are incremented by 2. Rb is not changed. |
| Read and Increment Word by 2 | F6 | RIW2 | 2 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $\rightleftharpoons \mathrm{DAL},(\mathrm{Ra}+\mathrm{I}: \mathrm{Ra})+2 \oplus(\mathrm{Ra}+\mathrm{I}: \mathrm{Ra})$. The 16 bit address located in $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the DAL lines and a DATA READ operation is initiated. The content of Ra+1:Ra are incremented by 2 . |
| Write and Increment Word by 2 | F7 | WIW2 | 2 | (Rb:Ra) $-D A L,(R a+1: R a)+2+(R a+1: R a)$. The 16 bit address located in Rb: Ra is transferred to the DAL lines and a DATA WRITE operation is initiated. The contents of Rat1: Ra are incremented by 2. |
| Read | F8 | R | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $=\mathrm{DAL}$. The 16 bit address located in $\mathrm{Rb}: \mathbf{R a}$ is transferred to the DAL line and a DATA READ operation is initiated. |
| Write | F9 | W | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) +DAL . The 16 bit address located in $\mathbf{R b}: \mathbf{R a}$ is transferred to the DAL lines and a DATA WRITE operation is initiated. |
| Read Acknowledge | FA | RA | 1 | (Rb: Ra) + (DAL, I +1 ACK. The 16 bit address located in $\mathbf{R b}: \mathbf{R a}$ is transferred to the DAL lines and a DATA READ operation is initiated. The interrupt acknowledge line is set high. |
| Write Acknowledge | FB | WA | 1 | ( $\mathrm{Rb}: \mathrm{Ra}$ ) + DAL, $1+1 \mathrm{ACK}$. The 16 bit address located in Rb: Ra is transferred to the DAI lines and a DATA WRITE operation is initiated. The Interrupt Acknowledge line is set high. |

Table 4-15 (Cont.). Microinstructions

| Instruction | OP Code | Mnemonic | Microcycles | Description of Operation |
| :---: | :---: | :---: | :---: | :---: |
| Output Byte | FC | OB | 1 (min.) | (Rb Ra)-DAL, I-DOUT. The 16 bit data contents of Rb Ra are transferred to the DAL lines. Registers Ra and Rb are unchanged. The DATA OUT signal is activated. This instruction is completed when the REPLY signal is received from the addressed unit. For byte operations Rb must equal Ra so that the same byte is placed in both 8 bit positions on the DAL. |
| Output Word | FD | OW | 1 (min.) | ( $\mathrm{Rb}: \mathrm{Ra}$ ) $-\mathrm{DAL}, \mathrm{I} \cdot \mathrm{DOUT}$. The 16 bit data contents of Rb Ra are transferred to the DAL lines. The DATA OUT signal is activated. Registers Ra and Rb are unchanged. This instruction is complete when the REPLY signal is received from the addressed unit. |
| Output Status | FE | OS | 1 | $(\mathrm{Rb}: \mathrm{Ra}) \cdot \mathrm{DAL}$. The 16 bit contents of registers $\mathrm{Rb}: \mathbf{R a}$ is transferred to the DAL lines and takes place regardless of the state of the Reply or Busy signal. DOUT is not activated and Sync is not terminated. Registers Rb and Ra are unchanged. |
| No Operation | FF | NOP | 1 | This instruction causes no operation. |

Table 4-16. Summary of Microinstruction and Status Flags

| Mnemonic | OP Code |  |  | Microcycles | ALU Status Flags |  |  |  | Condition Flags |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | NB | ZB | C4 | C8 | N | $z$ | V | C |
| A. Jump Format JMP | $\begin{array}{\|c} \hline \text { Bit } 15-12 \\ \emptyset \end{array}$ | $\begin{array}{lll} \hline 11 & 18 \\ 0 & A l \end{array}$ | $10.0$ ADDR |  | 2 | - | - | - | - | - | - | - | - |
| RFS |  | 1 - | --...... | 2 | - | - | - | - | - | - | - | - |
| B. Conditional Jump Format |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Bit 15-12 | 11.8 | 7-0 |  |  |  |  |  |  |  |  |  |
| JZBF | 1 | 0 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JZBT | 1 | 1 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JC8F | 1 | 2 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JC8T | 1 | 3 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JIF | 1 | 4 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JIT | 1 | 5 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JNBF | 1 | 6 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JNBT | 1 |  | ADDR | 2 | - | - | - | - | - | - | - | - |
| JZF | 1 | 8 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JZT | 1 | 9 | ADDR | 2 | - | - | - | - | - | - | - | - |
| JCF | 1 | A | ADDR | 2 | - | - | - | - | - | - | - | - |
| JCT | 1 | B | ADDR | 2 | - | - | - | - | - | - | - | - |
| JVF | 1 | C | ADDR | 2 | - | - | - | - | - | - | - | - |
| JVT | 1 | D | ADDR | 2 | - | - | - | - | - | - | - | - |
| JNF | 1 | E | ADDR | 2 | - | - | - | - | - | - | - | - |
| JNT | 1 | F | ADDR | 2 | - | - | - | - | - | - | - | - |
| C. Literal Format |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Bit 15-12 | 11.4 | 3-0 |  |  |  |  |  |  |  |  |  |
| AL | 2 | Lit | a | 1 | * | * | * | - | - | - | - | - |
| CL | 3 | Lit | a | 1 | * | * | - | - | - | - | - | - |
| NL | 4 | Lit | a | , | * | * | - | - | - | - | - | - |
| TL | 5 | Lit | a | 1 | * | * | - | - | - | - | - | - |
| LL | 6 | Lit | a | 1 | - | * | - | - | - | - | - | - |

Table 4-16. (Cont.). Summary of Microinstruction and Status Flags

| Mnemonic | OP Code |  |  | Microcycles | ALU Status Flags |  |  |  | Conditon Flags |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | NB | 2B | C4 | C8 | $N$ | Z | V | C |
| ). Register Format | Bit 15.8 |  | 3.0 |  |  |  |  |  |  |  |  |  |  |
| RI | 70 | b | x | 1 | - | - | - | - | - | - | . | . |
| SI | 71 | $b$ | x | 1 | - | - | - | - | - | - | - | - |
| CCF | 72 | x | a | 1 | - | - | - | - | - | - | - | - |
| LCF | 73 | b | a | 1 | - | - | - | - | - | - | - | - |
| RTSR | 74 | x | x | 1 | - | - | - | - | - | - | - | - |
| LGL | 75 | $x$ | a | 1 | - | - | - | - | - | - | - | . |
| CIB | 76 | $x$ | a | 1 | * | * | * | * | - | - | - | - |
| CDB | 77 | x | a | 1 | * | * | * | * | - | - | - |  |
| MB | 80/81 | b | a | 1 | * | * | - | - | * | * | 0 |  |
| MW | 82/83 | b | a | 2 | * | * | - | - | * | * | 0 | - |
| CMB | 84/85 | b | a | 1 | $1 *$ | * | - | - | * | * | 0 | -. C |
| CMW | 86/87 | b | a | 2 | $1 *$ | * | - | - | * | * | 0 | -).C |
| SLBC | 88/89 | b | a | 1 | * | * | * | * | * | * | * | * |
| SLWC | 8A/8B | b | a | 2 | * | * | * | * | * | * | * | * |
| SLB | 8C/8D | b | a | 1 | * | * | * | * | * | * | * | * |
| SLW | 8E/8F | b | a | 2 | * | * | * | * | * | * | * | * |
| ICB | 90/91 | b | a | 1 | * | * | * | * | * | * | * | * |
| ICWI | 92/93 | b | a | 2 | * | * | * | * | * | * | * | * |
| ICBZ | 94/95 | b | a | 1 | * | * | * | * | * | * | * | * |
| ICWZ | 96/97 | b | a | 2 | * | * | * | * | * | * | * | * |
| TCB | 98/99 | b | a | 1 | * | * | * | * | * | * | * | * |
| TCW | 9A/9B | b | a | 2 | * | * | * | * | * | * | * | * |
| OCB | 9C/9D | b | a | 1 | * | * | 0 | 0 | * | * | 0 | 1 |
| OCW | 9E/9F | b | a | 2 | * | * | 0 | 0 | * | * | 0 | 1 |
| $A B$ | Aめ/A1 | b | a | 1 | * | * | * | * | * | , | * | * |
| AW | A2/A3 | b | a | 2 | * | * | * | * | * | * | * | * |
| CAB | A4/A5 | b | a | 1 | (* | * | * | * | * | * | * | *).C |
| CAW | A6/A7 | b | a | 2 | (* | * | * | * | * | * | * | *. C |
| ABC | A8/A9 | b | a | 1 | * | * | * | * | * | * | * | . |
| AWC | AA/AB | b | a | 2 | * | * | * | * | * | * | * | * |
| CAD | AC | b | a | 1 | * | * | * | * | * | * | * | * |
| CAWI | AE/AF | b | a | 2 | $1 *$ | * | * | * | * | * | * | *. C |
| SB | B $\mid$ / 1 | b | a | 1 | * | * | * | * | * | * | * |  |
| SW | B2/B3 | $b$ | a | 2 | * | * | * | * | * | * | * | * |
| CB | B4/B5 | b | a | 1 | * | * | * | * | * | * | * | * |
| SW | B6/B7 | b | a | 2 | * | * | * | * | * | * | * | * |
| SBC | B8/B9 | b | a | 1 | * | * | * | * | * | * | * | * |
| SWC | BA/BB | b | a | 2 | * | * | * | * | * | * | * | * |
| DBI | BC/BD | b | a | 1 | * | * | * | * | * | * | * | * |
| DWI | BE/BF | b | a | 2 | * | * | * | * | * | * | * | * |
| NB | COCl | b | a | 1 | * | * | - | . | * | * | 0 | . |
| NW | C2/C3 | b | a | 2 | * | * | - | - | * | - | 0 | . |
| TB | C4/C5 | b | a | 1 | * | * | - | . | * | * | 0 | - |
| TW | C6/C7 | b | a | 2 | * | * | - | - | * | * | 0 | - |
| ORB | C8/C9 | b | a | 1 | * | * | - | . | * | * | 0 | . |
| ORW | CA/CB | $b$ | a | 2 | * | * | - | - | * | * | 0 | . |
| XB | CC/CD | $b$ | a | 1 | * | * | - | - | * | * | 0 | . |
| XW | CE/CF | b | a | 2 | * |  | - |  | * |  | 0 | - |

Table 4-16. (Cont.). Summary of Microinstruction and Status Flags

| Mnemonic | OP Code |  |  |  | ALU Status Flags |  |  |  | Condition Flags |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Microcycles | NB | ZB | C4 | C8 | N | $z$ | V | C |
| D. Register Format | Bit 15-8 | 7-4 | 3.0 |  |  |  |  |  |  |  |  |  |
| NCB | DWD1 | b | a | 1 | * | * | - | - | * | * | 0 | - |
| NCW | D2/D3 | $b$ | a | 2 | * | * | - | - | - | * | 0 | - |
| SRBC | D8/D9 | b | a | 1 | * | - | 0 | * | * | * | 0 | * |
| SRWC | DA/DB | $b$ | a | 2 | * | - | 0 | * | * | * | 0 | * |
| SRB | DC/DD | b | a | 1 | * | - | 0 | * | * | * | 0 | * |
| SRW | DE/DF | b | a | 2 | * | * | 0 | * | * | * | 0 | * |
| IB | EQE1 | $b$ | a | 1 | * | * | - | - | * | * | 0 | - |
| IW | E2/E3 | $b$ | a | 2 | * | * | - | - | * | * | 0 | - |
| ISB | E4/E5 | $b$ | a | 1 | * | * | - | - | * | * | 0 | - |
| ISW | E6/E7 | x | a | 2 | * | * | - | - | * | * | 0 | - |
| MI | EC/ED | $b$ | a | 1 | - | - | - | - | - | - | - | - |
| LTR | EE/EF | b | a | 2 | - | - | - | - | - | - | - | - |
| RIBI | $F \emptyset$ | b | a | 1 | * | * | * | * | - | - | - | - |
| WIBI | F1 | b | a | 1 | * | * | * | * | - | - | - | - |
| RIWI | F2 | b | a | 2 | * | * | * | * | - | - | - | - |
| WIWI | F3 | b | a | 2 | * | * | * | * | - | - | - | - |
| RIBZ | F4 | b | a | 1 | * | * | * | * | - | - | - | - |
| WIBZ | F5 | $b$ | a | 1 | * | * | * | * | - | - | - | - |
| RIWZ | F6 | b | a | 2 | * | - | * | * | - | - | - | - |
| WIWZ | F7 | b | aa | 2 | * | - | * | * | - | - | - | - |
| R | F8 | $b$ | a | 1 | - | - | - | - | - | - | - | - |
| W | F9 | $b$ | a | 1 | - | - | - | - | - | - | - | - |
| RA | FA | b | a | 1 | - | - | - | - | - | - | - | - |
| WA | FB | b | a | 1 | - | - | - | - | - | - | - | - |
| OB | FC | $b$ | a | 1 | - | - | - | - | - | - | - | - |
| OW | FD | b | a | 1 | - | - | - | - | - | - | - | - |
| OS | FE | b | a | 1 | - | - | - | - | - | - | - | - |
| NOP | FF | $\times$ | $\times$ | 1 | - | - | - | - | - | - | - | - |

4.3.5 MICROINSTRUCTION BUS OPERATION.

The Microinstruction Bus interconnects the three different circuits that make up a MCP 1600 Microprocessor system. Connected to the Microinstruction Bus can be one CP1611B Data Chip, one CP1621B Control Chip, and as many as four CP1631B Microinstruction ROM Chips. There may also be user supplied TTL logic connected to the Microinstruction Bus in a fashion to be defined below.

The discussion below describes the 22 different lines on the Microinstruction Bus from the standpoint of each of the various types of devices attached to it and from the standpoint of user attached devices. Figure 4-41 illustrates the system interconnections.


Figure 4-41. System Interconnections Microprocessor Set
4.3.5.1 BUS OPERATION.

The Microinstruction Bus consists of 22 lines. These lines are precharged by each of the microinstruction ROMs attached to the bus. Most generally, the lines are precharged high during $\emptyset 4$ but MIB15 is precharged high during $\emptyset 3$ and MIB16 is charged high during both $\emptyset 2$ and $\emptyset 4$. The microinstruction bus conveys its information by conditional discharge at the appropriate phase times. The microinstruction bus is a MOS compatible 4 phase bidirectional bus, and data on the bus is in logical complement form.

Table 4-17 defines the meaning of each of the lines on the bus at each phase time on the bus. Note that some lines have more than one meaning, depending upon the phase time.

### 4.3.5.2 MICROINSTRUCTION BUS ELEMENT DESCRIPTION.

The Microinstruction Bus is divided into seven partitions.
These partitions can carry data in both directions. They assume different meanings at different points in the clock cycle of the processor set. This section describes each element and its meaning as a function of the phase time in each clock cycle.

MIB00-MIB10. These lines serve to carry data bidirectionally between microinstruction ROMs and the Data and Control Chips. They are unconditionally precharged Hi at $\emptyset 4$ by the MICROMS attached to the bus. At the following $\emptyset 1$, they may have two different meanings depending upon whether the Microinstruction presently being executed is a one cycle or a two cycle instruction.

If the Microinstruction executes one cycle, then the next $\emptyset 1$ conveys the next microinstruction from the Microinstruction ROM to the Data Chip and Control Chip. If the Microinstruction takes two cycles, the second occurrence of $\emptyset 1$ may result in data being transferred from the Data Chip to the Control Chip.

Table 4-17. Microbus Timing

|  | 01 | 02 | 03 | 04 |
| :---: | :---: | :---: | :---: | :---: |
| MIB00-MIB10 | - Microinstruction from ROM to Data Chip and Control <br> - Second Cycle of 2-Cycle Instruction: Data from Data Chip to Control Chip. | - Address Data to MICROM | - Address must remain valid | - Precharge by MICROM |
| MIB11-MIB14 | - Microinstruction from ROM to Data Chip and Control Chip <br> - Second Cycle of 2-Cycle Instruction: Data from Data Chip to Control Chip. |  |  | - Precharge by MICROM |
| MIB15 | - Microinstruction from ROM to Data Chip and Control Chip. <br> - Second Cycle of 2-Cycle Instruction: Data from Data Chip to Control Chip. |  | - Precharge by MICROM | - Conditional Jump Results |
| M1B16 | - Load Return Register | - Precharge by MICROM | - Disable <br> MICROM outputs at next $\emptyset 1$ | - Precharge by MICROM |
| MIB17 | - RNI |  |  | - Precharge by MICROM |
| MIB 18-MIB21 | - TTL Outputs Valid |  |  | - Precharge by MICROM |

At $\emptyset 2$, address data is transferred from the Location Counter in the Control Chip to the MICROM. At $\emptyset 3$, the address data remains valid on the bus. The processor cycle is completed by an unconditional precharge of these lines by the MICROM at $\varnothing 4$.

MIB11-MIB14. These lines serve to convey Microinstruction data from the Microinstruction ROM to the Data and Control Chips in much the same fashion as the preceeding lines do. These lines are unconditionally precharged Hi by the MICROM at $\emptyset 4$. At $\emptyset 1$
of a single cycle, they are conditionally discharged to represent Microinstruction Data from the Microinstruction ROM to the Data Chip and the Control Chip.

If the preceeding Microinstruction was of the 2 -cycle variety, the second occurrence of $\emptyset 1$ on these lines can carry data from the Data Chip to the Control Chip. These lines have no other significance during $\emptyset 2$ and $\emptyset 3$.

MIB15. MIB 15 is used to carry Microinstruction data from the ROM to the Data Chip and Control Chip and also to transfer the results of conditional jump tests from the Data Chip to the Control Chip.

This line is precharged Hi unconditionally by the Microinstruction ROM at $\emptyset 3$. At $\emptyset 4$, it can be conditionally discharged by the results of a conditional jump test.

At $\emptyset 1$ this line conveys the microinstruction data from the ROM to the Data and Control Chip. In the case of a microinstruction whose execution takes two cycles, the second occurrence of $\emptyset 1$ may serve to convey data from the Data Chip to the Control Chip. The contents of MIB15 are not significant at $\emptyset 2$. The cycle is completed by an unconditional precharge of MIB15 at $\emptyset 3$.

MIB16. This control line conveys data from the ROM to the Control and Data Chips and from the Control Chip to the Microinstruction ROM. It is unconditionally precharged HI at both $\emptyset 2$ and $\emptyset 4$. At $\emptyset 1$ following $\emptyset 4$, it may conditionally discharge low by the MICROM; in which case, the signal is interpreted by the Control Chip as a command to load the subroutine Return Register with the incremented content of the Location Counter. On $\emptyset 2$, the lines are unconditionally precharged Hi. At $\emptyset 3$, the Control Chip may conditionally discharge these lines. If it does so, this is an instruction to the selected MICROM (Microinstruction ROM) to disable its outputs at the next $\emptyset 1$. In this fashion,

2 cycle instructions inhibit the transfer of new microinstructions from the MICROM to the Control Chip and the Data Chip.

MIB17. MIB17 has but one purpose. This is to convey the READ NEXT INSTRUCTION imperative from the MICROM to the Control Chip. This line is unconditionally precharged by the MICROMs attached to the Microinstruction Bus and conditionally discharged at $\emptyset 1$. A discharge indicates that the RNI imperative is required.

MIB18-MIB21. These lines are not part of the Microinstruction Bus in that they do not transfer data between the Microinstruction ROM and the Data Chip and the Control Chip. They are TTL level outputs capable of driving one TTL load per line. They represent four bits in the Microinstruction word and are made valid at the same time as the other outputs of the MICROM, Ø1. The lines are unconditionally precharged Hi by the MICROM at $\emptyset 4$ and conditionally discharged Low according to the contents of the word at $\emptyset 1$. The user may set these outputs in any fashion he chooses. They remain valid in the inclusive interval $\emptyset 1$ to $\emptyset 3$. Figure 4-42 illustrates their timing.

WAIT Line. The WAIT Line from the Control Chip to the Data Chip establishes whether or not the Data Chip is in the RUN or WAIT mode. Whenever the WAIT control line is in the Low state, the Data Chip is in the RUN mode and the Microinstruction will be loaded into the MIR register and executed. This line is normally Low and must be driven Hi during $\emptyset 4$ to cause the Data Chip to enter the WAIT state. It always returns to Low when the beginning edge of the $\emptyset 1$ clock appears.


NOTE TIL OUTPUTS (M̄IBTB. MIBT̄I) ARE UNCONDI IIONALIY DAIVEN HIGH AT GA AND UNTIL THE NEXT OQ

Figure 4-42. TTL Output Timing CP1631B
4.3.5.3 DATA CHIP.

The CP1611B Data Chip interacts with a subset of the Microinstruction Bus. Lines MIB00-MIB15 are present at the Data Chip. They convey Microinstructions from the Microinstruction ROM to the Data Chip, and they convey data from the Data Chip to the Control Chip. MIB15 also has a use as a control line conveying the results of conditional jump sets.

During the first $\emptyset 1$ of a two cycle instruction, data is transferred from the microinstruction ROM into the MIR register of the Data Chip. The microinstruction bus is not sampled during $\emptyset 2$ and $\emptyset 3$. At $\emptyset 4$, the Data Chip may conditionally discharge MIB15 to indicate the results of a conditional jump test. At the second occurrence of $\emptyset 1$ of a two cycle instruction, the Data Chip may or may not transfer data to the Control Chip. If the two cycle instruction was of the Jump class or word operation class, the Data Chip will not transfer data to the Control Chip. If the two cycle instruction was a LTR or IW instruction (with the appropriate bits in the control field properly set), then the Data Chip transfers 16 bits of data into the Control Chip. This data is gated into the Translation Register on the Control Chip.

During the execution of a one cycle microinstruction, data is only transferred from the microinstruction ROM to the Data Chip. This transfer occurs at $\not \boldsymbol{l}_{1}$. Figure 4-43 illustrates the timing of the Microinstruction bus interface as seen by the Data Chip.

### 4.3.5.4 CONTROL CHIP.

The CP1621B Control Chip interfaces with the MIB00-MIB17 as the Data bus. Data can come to the Control Chip from both the Data Chip and the Microinstruction ROM. From the Microinstruction ROM, the Control Chip can receive microinstructions into


Figure 4-43. Microinstruction Bus Interface Timing
the MI register. There these microinstructions are used to drive the Master Control function and are also present in the event that the Microinstruction is of the jump variety and a jump is required. Data from the microinstruction ROM also is presented on MIB16, which controls whether or not the Return Register will be loaded with the incremented contents of the Location Counter. MIB17 from the Microinstruction ROM, controls whether or not the RNI translation will be invoked. Data from the Data Chip to the Control Chip can be passed over MIB00-MIB15 as a result of an LTR instruction or an IW instruction. MIB15 is also used by the Data Chip to send the results to the Control Chip's Master Control function informing it of the results of a conditional jump test.

The Control Chip can generate a WAIT signal which goes to the Data Chip, and causes Data Chip operations to be suspended, pending the completion of an $I / O$ operation. The Control Chip also generates a signal placed on MIB16 which enables or disables the outputs of selected microinstruction ROM. This is used
during the second cycle of the execution of two cycle instructions to avoid conflicts on the microinstruction bus. The timing of the microinstruction bus as seen from the Control Chip is illustrated in Figure 4-44.


NOTES: 1. BUS PRECHARGING IS PERFORMED BY THE CP 16318. 2. ADDRESS OUTPUT SWITCHING TIME (TMOH AND TMOLI APPLIES TO MIBCA MTETT ONLV. 4. SWITCHING TIMES ARE MEASURED AT 10\% AND 90\% OF SPECIFIED LEVELS.

Figure 4-44. Control Chip Microinstruction Bus Timing

### 4.3.5.5 MICROINSTRUCTION ROM.

The Microinstruction ROM interfaces with all 22 lines of the Microinstruction bus. It receives Microinstruction addresses on MIB00-MIB10 from the Location Counter in the Control Chip. It also receives an ENABLE/DISABLE signal on MIB16. from the Contro1 Chip. It sends data on MIB00-MIB17 to the Control Chip and the Data Chip. MIB00-MIB15 are presented to both the Control Chip and the Data Chip. These 16 bits comprise microinstruction data for the Data Chip and the Control Chip to interpret. MIB16 is properly part of the microinstruction and controls whether or not the Return Register will be loaded with the incremented contents of the Location Counter. MIB17, also properly part of the microinstruction, controls whether or not the matrix represented by Arrays 1 and 2 will force a
user specified State code that will cause the "READ NEXT INSTRUCTIONS" translation to be performed. The interface of the microinstruction ROM to the microinstruction bus is illustrated in Figure 4-45.


NOTES: 1. MIB LINES EXCEPT MIB IE ARE PRECHARGED HIGH AT PHASE 4 MiBi is is Also PRECHARGED HIGH AT PHASE 2. MIB is IS DISCHARGED TO DISABLE THE MIBED WIB IS AND MIBIB MIE2I OUTPUTS AT O1 FROW DISCHARGING LOW.
AT O1 FROM DISCHARGING LOW. 5. SWITCHING TIMES ARE MEASURED AT IOX AND 9O\% OF SPECIFIED LEVELS.

Figure 4-45. Microinstruction Bus Timing CP1631B

### 4.3.6 DATA ACCESS.

Communications between the MCP1600 system and attached peripheral devices or memory is conducted via a path called the Data Access Bus. The Data Access Bus consists of 16 data lines (DALOO-DAL15), 7 control lines and 4 interrupt lines. The operation of these elements is controlled by the Input/Output class of instructions.

The Data Access provides a single 16 bit bidirectional path to and from the processor for transfer of data and addresses.

A number of different types of bus arrangements are possible with the data access, such as:
-Common data and address

- Separate data and address
-Separate input and output busses

The Data Access Bus provides for 16 bit address and either 8 or 16 bit data (addresses are conventionally deemed to be byte addresses) and provide a maximum addressing capability of 65 k bytes.

In accessing data, no distinction is made between memory and peripheral units or between instructions, data, control, or status. Each byte or word of information, regardless of function, is assigned an address and is referenced by means of this address.

In essence, then the Data Access Bus can be conceived to consist of the following elements:
-Data Lines (DAL00-DAL15)
-Control Lines (SYNC, REPLY, DATA-OUT or DOUT, DATA-IN or DIN, WRITE/BYTE, IACK, BUSY)
$\bullet$ Processor Control Lines (10, 11, 12, 13, COMPUTE, RESET)

The remainder of this section describes each of these elements of the data bus and their interactions and timings.
4.3.6.1 INPUT/OUTPUT INSTRUCTIONS.

This section breaks the I/O Instruction class into 5 classes. These classes are:

- Contro1 Instruction consisting of the READ and WRITE INSTRUCTIONS that serve mainly to operate the Control Lines on the Data Access and to provide addresses.
- Data Transfer Instruction, consisting of the INPUT and OUTPUT instructions which serve to pass data along the Data Access lines.
- ACKNOWLEDGE instructions which serve to respond to interrupts.

Figure 4-46 illustrates the condition testing performed prior to executing the Input/Output instructions. The execute function is described in the following sections.

READ Instructions. The READ instructions take a 16 bit address from a designated register pair and transfer it to the M register. When the address becomes valid on the bus, (during the following $\emptyset 1$ ) the SYNC line is made high. The variations on the READ instruction are primarily for address manipulation and easing the coding of $I / O$ routines. They cause the address source registers to be modified in some fashion. As far as the system designer is concerned, the pertinent operation of this instruction class is that it causes the selected address to be placed on the Data Access lines (DAL00-DAL15) and the SYNC line to be raised. The addressed device asserts the REPLY Line when ready for the data transfer. A flow diagram of the READ instruction operation is shown in Figure 4-47.

```
R b, a READ
```



The 16 -bit address in Registers $R b: R a$ is transferred to the $M$ Register and a DATA READ operation is initiated. Registers Rb and $R a$ are not changed.

Timing: 1 cycle


Figure 4-46. I/O Instruction Condition Testing


Figure 4-47. Execution of Read Instruction

RIB1 b. a READ AND INCREMENT BYTE BY 1

| FO | b | $a$ |
| :---: | :---: | :---: |
| 15 | 8 | 0 |

The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA READ operation is initiated. The contents of Register Ra are incremented by 1. Register Rb is not changed.

Timing: 1 cycle

RIB2 b, a READ AND INCREMENT BYTE BY 2

|  | F4 | $b$ | $a$ |
| :--- | :--- | :--- | :--- |

The 16 -bit address in Register $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA READ operation is initiated. The contents of Register Ra are incremented by 2. Register Rb is not changed.

Timing: 1 cycle

RIW1 b. a READ AND INCREMENT WORD BY 1

| F2 | b | $a$ |
| :--- | :--- | :--- |
| 15 | 8 | 0 |

The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA READ operation is initiated. The word in $\mathrm{Ra}+1: \mathrm{Ra}$ is incremented by 1 ,

Timing: 2 cycles


The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA READ operation is initiated. The word in $\mathrm{Ra}+1: \mathrm{Ra}$ is incremented by 2.

Timing: 2 cycles

Write Instructions. This class of instructions causes an address in a designated register pair to be placed on the Data Access 1ines DAL00-DAL15. The SYNC $1 i n e$ is raised as the address becomes valid at the next occurrence of $\emptyset 1$. A1so the WRITE-BYTE line is raised during the next occurrence of $\emptyset 1$. When the addressed device is ready to transfer data, it asserts the REPLY line.

The comments about address source register manipulation pertain to this class of instructions as they do to the READ class of instructions described above.

A DATA WRITE operation is distinguished from a DATA READ operation by the assertion of WRITE/BYTE at the same time the address becomes valid on the bus. Note carefully that this signal later is used to describe data length when the data becomes valid on the bus.

A flow diagram of the WRITE instruction operation is shown in Figure 4-48.


Figure 4-48. Execution Write Instruction


The 16-bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA WRITE operation is initiated. Registers Rb and Ra are not changed.

Timing: 1 cycle

WIB1 b, WRITE AND INCREMENT BYTE BY 1


The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA WRITE operation is initiated. The contents of Register Ra are incremented by 1. Register Rb is not changed.

Timing: 1 cycle

WIB2 b, a WRITE AND INCREMENT BYTE BY 2


The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA WRITE operation is initiated. The contents of Register Ra are incremented by 2. Register $R b$ is not changed.

Timing: 1 cycle
WIW1 b, a WRITE AND INCREMENT WORD BY 1

| F3 | $b$ | $a$ |  |
| :--- | :--- | :--- | :--- |
| 15 | 8 | 4 | 0 |

The 16-bit address in Registers Rb : Ra is transferred to the M Register and a DATA WRITE operation is initiated. The word in $\mathrm{Ra}+1: \mathrm{Ra}$ is incremented by a .

Timing: 2 cycles
WIW2 b, a WRITE AND INCREMENT WORD BY 2

| F7 | $b$ | $a$ |
| :--- | :--- | :--- |
| 15 | 8 | 0 |

The 16 -bit address in Registers $R b: R a$ is transferred to the $M$ Register and a DATA WRITE operation is initiated. The word in $\mathrm{Ra}+1: \mathrm{Ra}$ is incremented by 2 .

Timing: 2 cycles

INPUT Instructions. The INPUT Instructions control transfer of data from external devices on the Data Access to the processor. The data present on the data access is input by the instruction to the specified register or register pair. The INPUT class of instructions will not execute until a REPLY signal has been received from the device addressed by the previous READ instructions. Refer to a description of the REPLY signal below for the timing required. When this instruction is executed, it sets DATA-IN high to inform the addressed device that it should place its data on the bus. This instruction terminates by making SYNC and DATA-IN Low on the $\emptyset 2$ after completion.

Note that the instructions INPUT STATUS BYTE and INPUT STATUS WORD execute regardless of the state of the REPLY signal. Other
than this exception, these two instructions are identical to the rest of the INPUT class instructions.

Note also that there are no timing restrictions after the selection of a device. As long as the operations are executed in the proper sequence, no timeouts or arbitrary disciplines bother the system designer.

The flow diagram in Figure 4-49 illustrates the operation of the INPUT instruction.

IB b, a INPUT BYTE


The 8-byte from the Data Lines, as specified by b, is placed in Register Ra. Code E1 causes the condition flags, except $C$, to be updated. The Read Data Access operation is terminated unless Bit 6 is a one which allows a Read-Modify Write (RMW) requiring termination by an output instruction. The instruction will not execute until after a Reply signal has been received from the addressed unit. The optional inputs are listed below:
$\mathrm{b}=0 \quad$ Upper Byte (Bits 15-8)
$\mathrm{b}=1$ Lower Byte (Bits 7-0)
$b=2$ Upper Byte if $M(0)=1$; Lower Byte if $M(0)=0$
$b=3$ Lower Byte if $M(0)=1$; Upper Byte if $M(0)=0$
$\mathrm{b}=4$ Upper Byte (Bits 15-8) ; RMW
$\mathrm{b}=5$ Lower Byte (Bits 7-0) ; RMW
$b=6$ Upper Byte if $M(0)=1$; Lower Byte if $M(0)=0$; RMW
$b=7$ Lower Byte if $M(0)=1$; Upper Byte if $M(0)=0$; RMW
Timing: 1 cycle (minimum)


Figure 4-49. Execution of Input Instruction

## IW b. a INPUT WORD



The 16-bit word from the Data Lines is placed in Registers Ra+1: Ra. Code E 3 causes the condition flags, except $C$, to be updated. The Read Data Access operation is terminated unless Bit 6 is a one, which allows a Read-Modify-Write (RMW) operation requiring termination by an Output instruction. If Bit 4 or 5 is a one, the word on the Data Lines is loaded in the Translation Register; and at the same time, either Bits $6-4$ or Bits $8-6$ of the DAL are loaded into the $G$ Register. The instruction will not execute until after a Reply signal has been received from the addressed unit. The Lower Byte is loaded before the Upper Byte. The b options are listed below:


ISB b. a INPUT STATUS BYTE


The 8-bit byte from the Data Lines, as specified by b, is placed in Register Ra. Code E 5 causes the condition flags, except $C$, to be updated. The instruction will input regardless of the state of the Reply signal. These optional inputs are listed below:
$\mathrm{b}=0 \quad$ Upper Byte (Bits 15-8)
$b=1$ Lower Byte (Bits 7-0)
$b=2$ Upper Byte if $M(0)=1$; Lower Byte if $M(0)=0$
$b=3$ Lower Byte if $M(0)=1$; Upper Byte if $M(0)=0$
Timing: 1 cycle

ISW b, a INPUT STATUS WORD


The 16-bit word from the Data Lines is placed in Registers Ra+1: Ra. Code E7 causes the condition flags, except $C$, to be updated. This instruction inputs regardless of the state of the Reply signa1. The Lower Byte is loaded before the Upper Byte.

Timing: 2 cycles

OUTPUT Instructions. OUTPUT Instructions cause data to be transferred from the processor to the addressed peripheral devices. The OUTPUT instructions need the REPLY signal to be asserted before execution will proceed. DATA-OUT is set Hi by the processor during the first phase of the instruction to inform the peripheral device that data is presently available on the Data Access. Also during this time, the WRITE/BYTE signal may be set to indicate the length of data on the bus.

The OUTPUT STATUS command operates as the OUTPUT instructions except that it does not pay attention to the state of the REPLY 1ine.

After the execution of the OUTPUT instruction, data becomes valid on the bus. A1so, at this time, WRITE/BYTE is asserted if the data size is one byte. If the data size is a word, WRITE/BYTE becomes passive.

Refer to Figure 4-50 for the flow diagram of the OUTPUT instruction operation.


Figure 4-50. Execution of Output Instruction

## OB b, aUTPUT BYTE



The 16-bit contents of Registers $\mathrm{Rb}:$ Ra are transferred to the $M$ Register and the Data Lines. The Data Out signal is activated. Registers Rb and Ra are not changed. To provide proper operation with a 16 -bit Data Path, b must equal a so that the same byte is placed in both byte positions of the M Register. Output does not take place until Reply has been received from the addressed unit.

Timing: 1 cycle (minimum)

## OW b. a OUTPUT WORD



The 16-bit contents of Registers $\mathrm{Rb}:$ Ra are transferred to the M Register and the Data Lines. The Data Out signal is activated. Registers Rb and Ra are not changed. Output does not take place until Reply has been received from the addressed unit.

Timing: 1 cycle (minimum)

OS b. a OUTPUT STATUS


The 16 -bit contents of Registers $\mathrm{Rb}: \mathrm{Ra}$ are transferred to the $M$ Register and the Data Lines. Registers $R b$ and Ra are not changed. Output takes place regardless of the state of the Reply signal. This instruction is normally used without a Write instruction and cannot turn off Sync.

Timing: 1 cycle

Interrupt Acknowledge Instructions. These instructions perform in identical fashion to the READ/WRITE instructions. Additionally, they raise the Interrupt Acknowledge (IACK) 1ine. The Interrupt Acknowledge signal and a predetermined address placed on the Data Access bus by this instruction can be used as a signal to the I/O devices to inform the I/O set that the device requesting service should place its device number on the bus for transmission to the processor. Depending upon whether or not a READ acknowledge or a WRITE acknowledge was executed, the succeeding instruction may be an INPUT or OUTPUT Instruction respectively.

## RA b, a READ ACKNOWLEDGE

| FA | $b$ | $a$ |
| :--- | :--- | :--- |
| 15 | 8 | 4 |

The 16 -bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA READ operation is initiated with the Interrupt Acknowledge line high. Registers Rb and Ra are not changed. The Interrupt Acknowledge signal along with one or more address bits is used to form a signal which polls I/O units for the one interrupting the processor on the Interrupt line corresponding to the address. The processor inputs a byte or word containing the identification of the interrupting unit.

Timing: 1 cycle
WA b. a WRITE ACKNOWLEDGE


The 16-bit address in Registers $\mathrm{Rb}: \mathrm{Ra}$ is transferred to the M Register and a DATA WRITE operation is initiated with the Interrupt Acknowledge line high. Registers Rb and Ra are not
changed. The Interrupt Acknowledge signal along with one or more address bits is used to form a signal which polls I/O units for the one interrupting the processor on the Interrupt line corresponding to the address. This unit receives the next data output.

Timing: 1 cycle
4.3.6.2 DATA/ADDRESS LINES.

Sixteen Data/Address Lines, denoted DAL00-DAL15, are used to transfer addresses and data from the processor and to receive data into the processor. This bus is TTL compatible and signals on it are logical true data.

An address is output by the Data Chip as a result of executing a READ or a WRITE instruction. It appears on the bus at $\emptyset 1$ following the execution of the instruction. The address is valid on the bus during phases 2,3 and 4.

Data is output by the processor as a result of executing an OUTPUT instruction. It appears on the bus at the first $\emptyset 1$ after the microinstruction is executed and remains on the bus for a minimum of one cycle. Data is received from the Data Access into the processor by the INPUT instruction. It is clocked in at $\emptyset 4$ of the instruction cycle.

### 4.3.6.3 CONTROL LINES.

This section describes the Control lines generated by the CP1621 Control Chip as a result of $\mathrm{I} / \mathrm{O}$ instruction execution. It provides a functional description of the control lines. Their timing and interactions with the Data Access lines are further defined in Section 4.3.6.5.

Sync (TTL). The SYNC is a Control signal used to initiate and signify the length of a Data Access operation. SYNC is made high as soon as an address becomes valid. This occurs at $\varnothing 2$
following a READ or WRITE. It remains high until the termination of the operation.

Reply (TTL). The REPLY is a Control signal used by the addressed unit to respond to the Processor's Data Access signa1s.

The REPLY signal must be high during $\emptyset 3$ of the INPUT or OUTPUT microinstruction execution cycle in order to complete this operation. The REPLY signal is also interrogated by READ and WRITE microinstructions, and it must be low during $\varnothing 3$ for these operations to take place.

Data-In (TTL). The DATAIN (DIN) is a Control signal from the Processor that causes the address unit to gate its Read data on the Data lines. It is made high at the time the address is removed from the lines, or one cycle after the SYNC is made high (the second $\emptyset 2$ of the INPUT) and is a function of the READ instruction. The DATA-IN is made low at the end of the Input Byte or Input Word instruction or when SYNC is made low. This signal can be used to control the enabling of external TTL Tri-State Bus Driver/Receivers.

Data-Out (TTL). The DATA-OUT (DOUT) is a Control signal from the Processor which is made high at the same time as the Write data ( $\varnothing 1$ following the OUTPUT) is placed on the DAL bus by the Processor. It remains high for the duration of the OUTPUT instruction, dropping one phase before the data is taken off the DAL bus.

Write/Byte (TTL). The WRITE-BYTE (WB) is a Control signal from the Processor which is high during the time the address is on the bus to signify a WRITE rather than a READ operation; and is high during Data-Out to signify a Byte output rather than a Word output. To indicate an Output, it comes up at $\emptyset 1$ following a WRITE.

Interrupt Acknowledge (TTL). The IACK is a Control signal from the Processor which signifies that the Processor is responding to an Interrupt. This signal is made high at the same time the SYNC is made high as a result of either 'RA' or 'WA' instructions, and stays high as long as SYNC is high.

Busy (TTL). The BUSY is a Control signal from an external unit to the Processor requesting access to the bus. The signal can be used, for example, by a DMA unit to access the memory. The BUSY signal is interrogated at $\emptyset 3$ by the Processor every time READ or WRITE instructions are taking place. Whenever the BUSY signal is found to be one, the Processor enters a WAIT state inhibiting any access operation from taking place. The Processor will resume normal operation as soon as BUSY is turned off.
4.3.6.4 INTERRUPT, RESET, AND COMPUTE.

This section describes signals which would, in the normal scheme of things, be defined as processor control signals.

Reset. RESET is a TTL level line that may be controlled by an external device. Activation of the RESET line causes the Microprocessor to force 001 into the Location Counter. A NOP is also forced into the MIR and the MI registers. SYNC and DATA-IN are both reset. The RESET line can be wired to a POWER ON reset, or it may be used by the program for its own purposes.

Note that the activation of RESET is a hard action in that everything stops and the above mentioned conditions are forced.

Compute. COMPUTE is also a TTL level signal and it controls the processor's execution of microinstructions. The processor examines COMPUTE during every $\emptyset 1$ to determine whether or not it should execute the present microinstruction. In the case
of a two cycle instruction, COMPUTE need be high only during $\varnothing 1$ of the first cycle. Among other things, COMPUTE may be used to control single stepping of microinstructions. This line should not be confused with the WAIT signal on the MIB bus.

Interrupts. The external INTERRUPT lines of the MCP1600 system are IO-I3. These are microprogrammable. These lines provide inputs to Array 3 of the Programmable Translation Array and thus may be checked at certain user defined addresses in the Microprogram. As the examination of these lines is controlled by the contents of the Location Counter and the Macroinstruction being translated, it is easy for the microprogram to examine them for instance, before the FETCH cycle of every macroinstruction. There is no discipline associated with the use of these interrupt lines. Their state may be changed at any time. The system designer may implement his own interrupt control scheme by use of these lines and the ACKNOWLEDGE instructions.

### 4.3.6.5 INPUT/OUTPUT OPERATIONS.

The Data Access of the MCP1600, because of its flexibility, can be used to configure a variety of $I / O$ schemes. Several of the schemes that can be implemented were mentioned in the intro-. duction. This section will describe the interactions of the elements that comprise the Data Access and then define some canned operations that have been found useful. The combination of these canned operations and a discipline that structures interrupts and device addresses can result in a fast and powerful I/O structure.

Standard I/O Sequences. There are five standard I/O sequences that have been developed for the MCP1600 Processor System. These sequences provide for the orderly transfer of data to and from the processor. Two sequences provide for normal READs and WRITEs. One sequence provides a READ/MODIFY/WRITE capability which is useful for controlling random access memory devices. The last two sequences are READ/WRITE INTERRUPT ACKNOWLEDGE sequences.

Note that in the timing diagrams, the first clock cycle ( $\varnothing 1,---\emptyset 4$ ) is devoted to instruction interpretation. Bus operations do not begin to occur until the second clock cycle.

Write/Output Sequence. This sequence consists of two instructions:
WRITE Device Number
OUTPUT Data Source

The write operation transfers data from the processor to the addressed unit. The Write is initiated by a Write instruction which transfers a 16-bit address to the Data Access port. The address is present on the lines for one cycle. Data is transferred from the processor registers to the Data Access port by an Output Byte or Output Word instruction. The operation is terminated after the data has been on the lines for a minimum of one cycle. When outputting a byte with a 16-bit data path, the same byte must be placed in both the upper and the lower bytes of the port and the addressed unit takes care of storing the byte in the proper half of the word as selected by the low-order address bit.

The time period between selection of the device by the WRITE instruction and the transfer of the data is not critical if the device controller latches the selection. The sequence is graphically shown in Figure 4-51.

Read/Input Sequence. This sequence consists of two instructions which select the device, then transfer data.

READ Device Number
INPUT Data Destination

The Read operation transfers data from the addressed unit to the processor. The Read is initiated by a Read instruction which transfers a 16-bit address to the Data Access port. The address is present on the lines for one cycle and then the
processor signals the addressed unit to put its data on the lines. Data is input to the processor registers by an Input Byte or Input Word instruction. The Read operation is terminated by either Input or Output instructions. An Input Byte instruction allows for selection of the Upper Byte, Lower Byte or the Byte selected by the lower-order bit of the address.

The time period between execution of the READ and INPUT INSTRUCTIONS is not critical if selection latching is used in the device controller.

Figure 4-52 illustrates the READ/INPUT sequence.




SVIC IS MADE LOW ON O ODOUT IS MADE IOW ON OE ANO IDAL IS IAISIAIIDONOI
AEPIY CAN EE TUANED OF F AS SOOW AS SYMC IS MADE 1 llw
Figure 4-51. Write/Output Sequence


[^0]2 'REPLY' BEING LOW ON O3 CAUSES THE 'OUTPUT' INSTRUCTION TO BE EXECUTED REPEATEDLY
3 'DIN' IS MADE HIGH AS SOON AS THE ADDRESS IS TAKEN OFF THE BUS (02) AS FUNCTION OF READ MICROINSTRUCTION
4 'REPLY' AND 'DIN' MUST BE HIGH ON 03 IN ORDER FOR 'INPUT' INSTRUCTION TO TAKE PLACE 5 UPON TERMINATION OF ‘INPUT'INSTRUCTION, 'SYNC' AND ‘DIN' ARE MADE LOW ON 02

Figure 4-52. Read/Input Sequence

Read/Modify/Write Sequence (See Figure 4-53). The length of this sequence is variable. At least three instructions are required:

| READ | Device Number |
| :--- | :--- |
| INPUT | Destination Register |
|  | Microprogram can modify data |
| OUTPUT | Source Register |

A Read/Modify/Write operation is both a Read and Write in a single Data Access operation. This provides for inputting data from an addressed unit, modifying it, and outputting the changed data to the same addressed unit. The Read/Modify/Write is initiated by a Read instruction which transfers a 16-bit address to the Data Access port. The address is present on the lines for one cycle and then data is placed on the lines by the addressed unit. Data is input to the processor registers by an Input Byte or Input Word instruction. The Data Access operation is not terminated as in the case of a normal Read, but continues for a subsequent output as specified by the Input instruction. This suspended period can be used to modify the data, if desired. An example might be an Increment Memory instruction. After modification, data is transferred from the processor registers to the Data Access port by an output byte or Output Word instruction. The operation is terminated after the data has been on the line for a minimum of one cycle.


1 'INPUT \& MOD' WILL TURN 'DIN' OFF BUT WILL KEEP 'SYNC' ON
2 'FEPLY'CAN BE MADE LOW AS SOON AS 'SYNC' AND 'DIN' ARE OFF
Figure 4-53. Read/Modify/Write Sequence

Interrupt Acknowledge Sequences. These two sequences provide the system designer with the ability to structure his own interrupt system. In addition to the normal READ or WRITE sequences, the processor will raise IACK at the specified time.

The combination of IACK and a special reserved device number on DAL00-15 could, for example, order the device controller requesting attention to return its device number on the subsequent INPUT instruction.

Figure 4-54 illustrates the operation of both the READ and WRITE Interrupt Acknowledge.


Figure 4-54. Interrupt Acknowledge Sequence

### 4.4 CIRCUIT MODULE DESCRIPTION.

This Section describes the operation of the individual circuit packages (DIPS) contained on the AM-100 two-board set. The CPU processing is handled by the set of five DIPS as described in paragraph 4.3. The control and interface modules are also described in the following paragraphs with logic and connection diagrams for each one.
4.4.1 FOUR-PHASE CLOCK GENERATOR (Board 2.U12).

This device is a 4-phase clock generator using an external oscillator to initiate the phase-1 clock. By floating pins 9 and 15 , the chip also operates in a free-running mode where the phase-1 clock starts due to internal oscillation. Each of the other three clock phases follow in sequence provided the chip does not see another positive going edge from the oscillator. Once phase-4 has returned to $\emptyset$ volts, all four clock phases remain idle until the next positive going oscillator transition. If this transition occurs during one of the clock phases, the chip immediately tries to generate another phase-1. For stable operation, phase-4 should not overlap phase-1.

Each clock phase width is independently controlled by an externally applied capacitor to ground. A $1 \varnothing$ to $2 \emptyset \mathrm{pf}$ capacitor provides for an output clock phase width of $1 \emptyset \emptyset \mathrm{~ns}$. Logic and timing are shown in Figure $4=55$.

Pin Description

| Pin No. | Symbol | Function |
| :---: | :---: | :---: |
| 1 | VBB | -5 volts |
| 2 | NC | No connection |
| 3 | $\emptyset 4$ Out | Phase-4 Output |
| 4 | $\emptyset 3$ Out | Phase-3 Output |
| 5 | $\emptyset 2$ Out | Phase-2 Output |
| 6 | $\emptyset 1$ Out | Phase-1 Output |
| 7 | VSS | Ground |
| 8 | VCC | +5 to +15 volts |
| 9 | Osc Input | Oscillator Input |
| 10 | VDD | +12 volts |
| 11 | $\emptyset 1 \mathrm{Cap}$ | Phase-1 Capacitor |
| 12 | $\emptyset 2 \mathrm{Cap}$ | Phase-2 Capacitor |
| 13 | $\emptyset 3 \mathrm{Cap}$ | Phase-3 Capacitor |
| 14 | $\emptyset 4$ Cap | Phase-4 Capacitor |
| 15 | Gnd | Ground |
| 16 | NC | No Connection |



Figure 4-55. Four-phase Clock Logic and Timing
4.4.2 TRI-STATE 4-BIT D TYPE REGISTER (Board 1 U1, U9, U10). These four-bit registers contain D-type flip-flops with totem-pole TRI-STATE outputs, capable of driving high1y capacitive or low-impedance loads.

Gated enable inputs are provided for controlling the entry of data into the flip-flops. When both data-enable inputs are low, data at the $D$ inputs are loaded into their respective flip-flops on the next positive transition of the buffered clock input. Gate output control inputs are also provided. When both are low, the normal logic states of the four outputs are available for driving the loads or bus lines. The outputs are disabled independently from the level of the clock by a high logic level at either output-control input. The outputs then present a high impedance and neither load nor drive the bus 1ine. Detailed operation and logic is shown in Figure 4-56.


Truth Table

| imputs |  |  |  |  | $\begin{gathered} \text { OUtPut } \\ 0 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| clean | Clock | Data emable |  | $\begin{gathered} \text { Data } \\ \text { D } \\ \hline \end{gathered}$ |  |
|  |  | 01 | 02 |  |  |
| H | x | * | x | x | L |
| $\stackrel{1}{ }$ | L | x | $\times$ | x | $a_{0}$ |
| $t$ | 1 | H | x | x | $a_{0}$ |
| $t$ | , | x | H | $\times$ | $a_{0}$ |
| $t$ | , | $\downarrow$ | $t$ | 1 | 1 |
| $t$ | , | $\downarrow$ | 1 | H | H |
| When either $M$ or $N$ (or both) is (ere) himpt the output is dinebled to the high. impodences state: however, weciuentiol operstion of the flip-flops is not affected. |  |  |  |  |  |
| $\mathrm{H}=$ hiph level (strecotr state) |  |  |  |  |  |
| $L$ - low lovel (steody stoto) |  |  |  |  |  |
| - - low-to thigh level tronsition |  |  |  |  |  |
| $x$ - don't ceso (eny input including trencitions) |  |  |  |  |  |
| $\alpha_{0}$ - the level iot a before the indicated rteedy state ind |  |  |  |  |  |

## Logic Diagram



Figure 4-56. Tri-State 4-Bit D Type Register Connections
4.4.3 HIGH SPEED HEX INVERTER (Board 1, U7).

This device provides high speed low current interface logic. Logical inversion is provided with active pullups. See Figure 4-57 for logic and connections.


Figure 4-57. High Speed Hex Inverter Connections
4.4.4 TRI-STATE BUFFERS (Board 1, U5, U8, U22, U24, U26; Board 2, U45, U46, U48).
These devices provide six, two-input buffers in each package. One of the two inputs to each buffer is used as a control line to gate the output onto the high-impedance state, while the other input passes the data through the buffers. The outputs are placed in the tri-state condition by applying a high logic level to the control pins. See Figure 4-58 for logic diagram and truth table.

Logic and Connection Diagram


Truth Table

| INWUTS | OUTPUT |
| :---: | :---: |
| G | $A$ |
| $H$ | $X$ |
| $L$ | $H$ |
| $L$ | $H$ |

Figure 4-58. Tri-State Buffer Connections
4.4.5 HEX TRI-STATE BUFFERS (Board 2, U11, U47).

These devices provide six, two-input buffers in each package. One of the two inputs to each buffer is used as a control line to gate the output onto the high-impedance state, while the other input passes the data through the buffer. The outputs are placed in the tri-state condition by applying a high logic level to the control pins. See Figure 4-59 for logic diagram and truth table.

Logic and Connection Diagram
Truth Tab1e


| INPUTS |  | OUTPUT |
| :--- | :--- | :---: |
| $\bar{G}$ | $A$ | $Y$ |
| $H$ | $X$ | $H \cdot Z$ |
| $L$ | $H$ | $L$ |
| $L$ | $L$ | $H$ |

Figure 4-59. Hex Tri-State Buffer Connections
4.4.6 EIGHT-LINE TO THREE-LINE ENCODER (Board 2, U29, U30)._ This device encodes eight data lines to three line (4-2-1) binary (octal). Cascading circuitry (enable input E1 and output EO) are provided to allow octal expansion without the need for external circuitry. Data inputs and outputs are active at the low logic level. See Figure 4-60 for logic diagram and truth table.


Figure 4-60. Eight-Line to Three-Line Encoder Connections
4.4.7 DATA SELECTOR/MULTIPLEXER (Board 1, U16, U17, U18, U21). These Schottky clamped devices select a four-bit word from one of the two sources and route it to the four outputs as true data (no inversion). See Figure 4-61 for logic diagram and connections.


POSITIVE LOGIC.
Low logic level at $S$ selects $A$ inputs. High logic level at $S$ selects $B$ inputs.


Figure 4-61. Data Selector/Multiplexer Connections
4.4.8 NAND TTL-TO-MOS DRIVER (Board 1, U2, U3). This device is a monolithic, integrated, dual TTL-TO-MOS driver and interface circuit. It accepts standard TTL and DTL input signals and provides high-current and high voltage output levels suitable for driving MOS circuits. Specifically it can be used to drive address, control, and timing inputs for several types of MOS RAMS. See Figure 4-62 for logic and connections.

schematic (each driver)


Figure 4-62. NAND TTL-TO-MOS Driver Connections

```
4.4.9 D POSITIVE-EDGE-TRIGGERED FLIP-FLOPS WITH PRESET AND
CLEAR (Board 2, U6, U18, U19, U23, U31, U32, U34, U36).
See Figure 4-63 for logic diagram and truth table.
```

| INPUTS |  |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PR | CLR | CLK | D | 0 | $\overline{\mathbf{Q}}$ |
| L | H | $x$ | $x$ | H | $L$ |
| H | L | $x$ | $x$ | $L$ | H |
| L | L | $\times$ | $\times$ | $\mathrm{H}^{*}$ | $\mathrm{H}^{+}$ |
| H | H | $\dagger$ | H | H | $L$ |
| H | H | $\uparrow$ | L | L | H |
| H | H | $L$ | X | 00 | $\overline{0} 0$ |



Figure 4-63. D F1ip-F1op Connections
4.4.10 DUAL J-K NEGATIVE-EDGE TRIGGERED FLIP-FLOPS WITH PRESET (Board 2, U20, U28, U40, U50, U51). See Figure 4-69 for logic diagram and truth table.

Connection Diagram


Truth Table

| INPUTS |  |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PR | CLK | $J$ | K | 0 | $\overline{0}$ |
| L | $x$ | $\times$ | $\times$ | H | L |
| H | 1 | 1. | 1 | 00 | Oo |
| H | 1 | H | $L$ | H | 1 |
| H | - | L | H | L | H |
| H | 1 | H | H | TOG | Gle |
| H | H | X | X | 00 | Q̇o |

Figure 4-64. J-K F1ip-F1op Connections

### 4.4.11 DUAL RETRIGGERABLE ONE-SHOTS WITH CLEAR (Board 2, U22).

 See Figure 4-65 for logic diagram and truth table.
TMUTH TAELE

| INPUTS |  |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | CLR | O | O |  |
| H | X | H | L | H |  |
| X | L | H | L | H |  |
| L | H | H | $\Omega$ | U |  |
| L | H | H- | $\Omega$ | U |  |
| X | X | L | L | H |  |

Notes: $\Omega=$ one high-level pulse. $\tau$ = one low-level pulse.
To use the internal timing resistor of $54121 / 74121$, connect $\mathrm{A}_{\text {INT }}$ to $\mathrm{V}_{\mathrm{CC}}$.
An external timing capacitor may be connected between $\mathrm{C}_{\text {EXT }}$ and $\mathrm{R}_{\text {EXT }} / \mathrm{C}_{\text {EXT }}$ (positive).
For accurate repeatable pulse widths, connect an external resistor between $R_{E X T} / C_{E X T}$ and $V_{C C}$ with $R_{\text {INT }}$ openerircuited.
To ottain variatle pulse widths, connect external variable resistance between $R_{\text {INT }}$ or $R_{E X T} / C_{E X T}$ and $V_{C C}$.

Figure 4-65. One Shot Connections
4.4.12 DUAL VOLTAGE CONTROLLED OSCILLATORS (Board 2, U5). This device features two fully independent voltage-controlled oscillators (VCO's) in a single monolithic chip. The output frequency of each is established by a single external component, either a capacitor or a crystal, in combination with two voltagesensitive inputs, one for frequency range and one for frequency control. An enable input is provided that can be used to start or stop the output pulses when it is low or high, respectively. The internal oscillator runs continuously, even while the output is disabled. A pulse synchronizer ensures that the first output pulse is neither clipped nor extended. Duty cycle of the output pulses is fixed at approximately 50 percent. See Figure 4-66 for logic diagram and connections.

The highly stable oscillator can be set to operate at any frequency between 0.12 Hz and 50 MHz typically. The output frequency can be approximated as follows:

$$
f_{o}=\frac{500}{C_{e x t}}
$$

where: $\mathrm{F}_{\mathrm{o}}=$ output frequency in MHz

$$
\mathrm{C}_{\text {ext }}=\text { external capacitance in } \mathrm{pF}
$$



Figure 4-66. Dual Voltage Controlled Oscillator Connections
4.3.13 DECODER (Board 2, U7, U8, U42).

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

Connection and Logic Diagram


| INPUTS |  |  |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ENABLE |  | SELECT |  |  |  |  |  |  |  |  |  |  |
| G1 | 62* | c | B | A | Yo | Y1 | Y2 | Y3 | Y4 | Y5 | Y6 | Y7 |
| X | H | $x$ | $\dot{k}$ | $x$ | H | H | H | H | H | H | H | H |
| $L$ | $\times$ | $x$ | x | X | H | H | H | H | H | H | H | H |
| H | L | $L$ | $L$ | L | L | H | H | H | H | H | H | H |
| H | L | $L$ | 1 | H | H | L | H | H | H | H | H | H |
| H | 1 | L | H | L | H | H | L | H | H | H | H | H |
| H | $L$ | $L$ | H | H | H | H | H | L | H | H | H | H |
| H | $L$ | H | $L$ | L | H | H | H | H | L | H | H | H |
| H | $L$ | H | $L$ | H | H | H | H | H | H | L | H | H |
| H | $L$ | H | H | L | H | H | H | H | H | H | L | H |
| H | L | H | H | H | H | H | H | H | H | H | H | L |

- G2 $=\mathbf{G 2 A}+\mathbf{G 2 B}$
$H=$ High level, $L=$ low level, $X=$ don't care


Figure 4-67. Decoder Connections
4.4.14 D FLIP-FLOPS WITH CLEAR (Board 1, U13, U14, U25; Board 2, U10).
These positive-edge-triggered flip-flops utilize TTL circuitry to implement D-type flip-flop logic. 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 positivegoing pulse. When the clock input is at either the high or low leve1, the $D$ input signal has no effect at the output. See Figure 4-68 for logic diagram and truth table.

Logic Diagram


Connection Diagram


Truth Table

| INPUTS |  |  | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: |
| CLEAR | CLOCK | $D$ | Q | $\bar{Q}^{\dagger}$ |
| L | $X$ | $X$ | $L$ | $H$ |
| $H$ | $\uparrow$ | $H$ | $H$ | $L$ |
| $H$ | $\uparrow$ | $L$ | $L$ | $H$ |
| $H$ | $L$ | $X$ | $Q_{0}$ | $\bar{Q}_{0}$ |

$H=$ High Level (steedy state)
$L$ = Low Level (steedy stete)
$X=$ Don't Care
$t$ = Transition from low to high level
$\mathbf{O}_{\mathbf{0}}$ - The leval of $\mathbf{Q}$ before the indicated steedy-state input conditions were establisted.
$t=175$, LS175, and S175 only

Figure 4-68. D F1ip-F1op Connections
44.15 TRI-STATE OCTAL BUFFERS (Board 1, U6, U11, U19, U27). This device provides six, two-input buffers in each package. One of the two inputs is used as a control line to gate the output into a high impedance state, while the other passes the data through the buffer. The outputs are placed in the tri-state condition by applying a high logic level to the control pins. See Figure 4-69 for logic diagram and truth table.

Logic Diagram


Truth Tab1e


Figure 4-69. Tri-State Octal Buffer Connections

## SECTION 5 MAINTENANCE AND TROUBLESHOOTING

### 5.0 INTRODUCTION.

The AM-100 circuit board performs to full capability with a minimum of maintenance. This Section describes maintenance procedures and procedures for handiing warranty returns.

### 5.1 CIRCUIT BOARD CHECKOUT.

The AM-100 circuit board was fully tested before it left Alpha Microsystems and will operate satisfactorily in your system if the hardware and software requirements of Sections Two and Three of this manual are met. Should a problem arise after the circuit card has been in operation, perform the following preliminary checks to identify and locate the fault.

1. Check all cabling for proper seating of connectors.
2. Check the circuit board for proper seating in the slot.
3. Check all power connections for correct voltages.
4. Check all jumper options to ensure correctness for your application.
5. Verify that the fault is in the AM-100 and not either in the system or in the peripherals. This can best be accomplished with substitution of a known good circuit board if available.

### 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 Administrator for information.




















FBILL \# \#WB--00101-00
FEV. COO
18 Dec, 1979

FART NUMBER
MESCETFTION
w

2世： F 0HB $90.01 \cdots 00$  ..... AM－：
WET NUMRER Mッツ世ないTM ..... ？17
$\therefore \quad \|$ TW－063－$\because 91$  ..... 3
 ज口⿰亻二乚㇒夫见 ..... 1

REV.COO
18 MEC.1979
Mescriptron ASSY CPU $\# 2$
FAFT NUMEEF AM-100




[^0]:    1 'SYNC' IS MADE HIGH AS SOON AS A VALUD ADDRESS IS ON THE BUS (02)

