# GENERAL AUTOMATION # GA-16/110/220 maintenance manual ## NOTICE The information contained in this document is subject to change without notice. General Automation makes no warranty or representation with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. General Automation shall not be liable for errors contained herein. General Automation assumes no responsibility for the use or reliability of its software on equipment that is not furnished by General Automation. This document contains proprietary information which is protected by copyright. All rights are reserved. No part of this document may be photocopied, reproduced or translated to another program language without the prior written consent of General Automation. # GA-16/110/220 maintenance manual GENERAL AUTOMATION, INC. 1055 South East Street Anaheim, California 92803 (714) 778-4800 © 1979, General Automation, Inc. ## **RECORD OF REVISIONS** Title: GA-16/110/220 Maintenance Manual Document Number: 88AQQ5Q9A-A | DATE | ISSUE | |--------|-----------------------------------------------------------| | Apr 77 | Original Issue | | | Change Al - Pages affected: xi, xii Pages added: G-1, G-2 | | Mar 79 | Revision B | | | · | | · | | | | | | | | | | | | | | | | | | | | | | | | | | | · | | | | | ## FRONTISPIECE GA-16/110 In Compact Chassis GA-16/220 In Compact Chassis ## **FOREWORD** This GA-16/110/220 manual describes the configuration, functional operation, and interfaces of both the GA-16/110 and GA-16/220 computers. Both computers are similar in their basic design, configurations, and programming and are described in one manual. The purpose of this manual is to supplement the GA-16/110/220 System Reference Manual by supplying detailed information on the CPU hardware. This manual is intended to give a better understanding of the processor logic functions to those individuals with primary responsibility for maintaining the system hardware. The following documents are recommended for GA-16/110/220 hardware maintenance and supplemental systems information: | Document Number | <u>Title</u> | |-----------------|------------------------------------------| | 88A00525A | How to Use Your GA-16/220 | | 88A00508A | GA-16/110/220 System Reference Manual | | 94A01519A | T&V Reference Manual | | 94A01531A | Stand-Alone Utilities | | 90C02422A | Logic Diagram CPU 1 | | 31P02422A | Parts List CPU 1 | | 31D02422A | Assembly Drawing CPU 1 | | 90C02429A | Logic Diagram CPU 2 | | 31P02429A | Parts List CPU 2 | | 31D02429A | Assembly Drawing CPU 2 | | 90C02405A | Logic Diagram - Microconsole | | 31P02405A | Parts List - Microconsole | | 31D02405A | Assembly Drawing - Microconsole | | 90C02410A | Logic Diagram - 8K Memory | | 31P02410A | Parts List - 8K Memory | | 31D02410A | Assembly Drawing - 8K Memory | | 90C02301A | Logic Diagram - Memory Service Module | | 31D02301A | Assembly Drawing - Memory Service Module | | 31P02301A | Parts List - Memory Service Module | | 31D02277A | Assembly Drawing Piggy Back 2K RAM | | 90C02277A | Piggy Back 2K RAM | | 31D02371A | Assembly Drawing Memory Parity Protect | | Document Number | <u>Title</u> | |-----------------|---------------------------------------------| | 90C02371A | Memory Parity Protect | | 51D00073A | Jumbo Power Supply | | 90C02430A | Battery Back-up Reg. | | 90C02301A | Logic Diagram - Memory Service Module | | 31D02301A | Assembly Drawing - Memory Service<br>Module | | 31P02301A | Parts List - Memory Service Module | | 90A02469A | Logic Interconnect Diagram - Compact<br>MIB | | 31D02469A | Assembly Drawing - Compact MIB | | 31P02469A | Parts List - Compact MIB | | 90A02409A | Logic Interconnect Diagram - Jumbo<br>MIB | | 31P02409A | Parts List - Jumbo MIB | | 31D02409A | Assembly Drawing - Jumbo MIB | | 01D01386A | Assembly Drawing - AC Power Battery Back-up | The basic unit for both computers is the GA-16/110 CPU-1 module, which provides a microprogrammed CPU to carry out the GA-16/SPC-16 series instruction set. The GA-16/110 provides controls and indicators, memory bus, programmed I/O bus, vectored priority interrupts, cold start, real time clock interrupt, power fail/auto restart, and operations monitor alarm. An optional piggyback memory module plugs into the GA-16/110 module to provide 2K words of random access memory (RAM) (or combination RAM and programmable read-only-memory (EPROM)). An optional 64-word ROM may be installed on the piggyback memory to provide initial program load (IPL) capability from a peripheral device. A complete GA-16/110 computer (with memory) can, therefore, be provided on a single printed circuit module for insertion into a user's device, such as an "intelligent" terminal. A GA-16/220 computer consists of the GA-16/110 module plus a second module (CPU-2 module) which adds additional controls including data entry switches that may be sensed by a users program, and a vectored console interrupt button. The 220 module also provides a l millisecond real-time clock (RTC), memory mode change under program control, and control instructions for I/O reset and single-step execution. The 220 module enlarges the I/O capabilities to include a built-in serial I/O controller (with vectored interrupt) for TTY or CRT and a direct memory access (DMA) port. An optional system console interface module (SCI) may be plugged into the 220 module to provide an interactive operator program via TTY or CRT (console ROM). An optional IPL ROM may be installed on the SCI to provide program load capabilities from a variety of peripheral devices. Additional controls on the SCI select and adjust TTY baud rate, select the IPL device, and initiate IPL. Both the GA-16/110 and GA-16/220 computers may be installed in either a compact or jumbo enclosure which provides printed circuit card slots and connectors for the GA-16/110 CPU and the 220 module. In addition, it also provides slots and connectors for the installation of 4K or 8K dynamic RAM memory modules, a memory parity protect (MPP) module, a memory power supply with backup batteries, and a control module for the battery backup. I/O controller slots are also provided together with rear interface connectors for peripheral devices and provision for the connector of an I/O expansion chassis. The compact enclosure provides a compartment for a main power supply to run the CPU and I/O controllers, while the jumbo enclosure requires an external power supply unit. Specific differences between the two computers are defined in the text, and the term "GA-16/110/220" is generally used where characteristics are shared. ## CAUTION Several standard GA controllers have had to be updated for compatibility with both the SPC-16 and GA-16 series processors. The controllers affected are listed below: | CIT-16 Disk Controller MHSDC ABTU APU Asynchronous Communication Controller Asynchronous Communication Controller DMA Asynchronous Communication Controller DMA MUX SDLC Console Controller Paddle Board (Loop Back) | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Controllers constructed prior to May 1, 1976, may reflect the proper changes. Any of these controllers, not incorporating the necessary modifications, are not compatible with the GA-16/440, 16/330, 16/220, and 16/110 processors. Controllers constructed after May 1, 1976, are fully compatible with all GA-16 series and SPC-16 series processors. Consult your General Automation Field Representative for further details concerning these controllers. ## TABLE OF CONTENTS | SECTION | TITLE | PAGE | |---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 1 | INTRODUCTION. 1.1 COMPONENT IDENTIFICATION. 1.1.1 MEMORY MODULES. 1.1.2 GA-CPU-2 MODULE 1.1.3 GA-CPU-1 MODULE 1.1.4 CHASSIS ASSEMBLIES. | 1-6<br>1-6<br>1-6 | | 2 | GA-16/110/220 FUNCTIONAL DESCRIPTION. 2.1 GA-16/110 CPU (CPU-1 MODULE). 2.1.1 CONTROL READ-ONLY-MEMORY (CROM) 2.1.2 REGISTER ARITHMETIC AND LOGIC UNIT (RALU) 2.1.3 INITIAL PROGRAM DECODE BUS. 2.1.4 TIMING NETWORK 2.1.5 BUS CONTROL LATCH AND DECODE. 2.1.6 PIO CONTROL 2.1.7 THE ISE FILP-FLOP 2.1.8 TRI-STATE BUFFERED ADDRESS LATCH. 2.1.9 PIGGYBACK MEMORY AND IPL ROM. 2.1.10 TRI-STATE BI-DIRECTIONAL INTERFACE. 2.1.11 BUS NETWORKS. 2.1.12 INTERRUPT CONTROL 2.1.13 RESET DRIVER. 2.1.14 CONSOLE INTERFACE 2.1.15 TEST. 2.1.16 OPERATIONS MONITOR ALARM (OMA) 2.1.17 PHYSICAL CONFIGURATION. 2.2 GA-16/220 (CPU-2 MODULE). 2.2.1 REAL-TIME CLOCK 2.2.2 INTERRUPT CONTROL LOGIC 2.2.3 CONSOLE SWITCHES. 2.2.4 DMA TIMING AND CONTROL 2.2.5 SYSTEMS CONSOLE INTERFACE (SCI) 2.2.6 ADDRESS BUFFER AND MSIK DETECT 2.2.7 DMA ADDRESS LATCH 2.2.8 SERIAL I/O CONTROLLE. 2.2.9 I/O 3E/3F DECODE AND CONTROL 2.2.10 TIMING NETWORK. 2.2.11 PHYSICAL CONFIGURATION. 2.3 SYSTEM INTERFACE 2.4 POWER SUPPLIES. 2.4.1 COMPACT POWER SUPPLY. | 2-1<br>2-3<br>2-5<br>2-7<br>2-7<br>2-9<br>2-10<br>2-12<br>2-12<br>2-13<br>2-13<br>2-20<br>2-22<br>2-23<br>2-23<br>2-23<br>2-23<br>2-23<br>2-2 | | | 2.4.2 BACKUP POWER SUPPLY 2.4.2.1 Backup Power Supply Installation. 2.4.3 MEMORY SERVICE MODULE 2.4.4 EXTERNAL POWER SUPPLY | 2 <b>-</b> 36 | | SECTION | TITLE | PAGE | |---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------| | 3 | THEORY OF OPERATION | 3-1<br>3-2<br>3-3<br>3-5<br>3-5<br>3-6<br>3-7<br>3-8<br>3-10<br>3-12<br>3-13 | | | 3.1.5.8 LxW Operations | 3-13<br>3-14<br>3-18<br>3-24 | | • • | 3.2.4 MICROINSTRUCTION AT X'003' | 3-42<br>3-44<br>3-44<br>3-44<br>3-44 | | | 3.4 REAL-TIME CLOCK (RTCI) INTERRUPT. 3.5 POWER FAIL DETECT. 3.6 ERROR CORRECTION OPTION. 3.6.1 OPERATIONAL MODES. 3.6.2 INPUT STATUS MODE. 3.7 POWER UP/RESTART. 3.8 USER-DESIGNED CONSOLE INTERFACING. 3.9 SERIAL I/O CONTROLLER. 3.10 EPROM PROGRAMMER. | 3-48<br>3-50<br>3-50<br>3-51<br>3-52<br>3-55<br>3-56 | | NUMBER | LIST OF ILLUSTRATIONS . TITLE | PAGE | | 1-1<br>1-2<br>1-3<br>1-4<br>1-5 | 8K x 18 Memory Module | 1-7<br>1-8<br>1-9<br>1-10<br>1-11 | | NUMBER | TITLE | PAGE | |--------|--------------------------------------------------------------------|------| | 1-6 | GA-16/220 Jumbo Chassis | 1-12 | | 1-7 | CA-16/220 Compact Chassis | 1-13 | | 2-1 | GA-16/110 CPU Module Block Diagram | | | 2-2 | CROM Block Diagram | 2-4 | | 2-3 | RALU Block Diagram | 2-6 | | 2-4 | GA-16/110 System in Compact Chassis (No MPP) | | | 2-5 | GA-16/110 System in Jumbo Chassis (With MPP) | | | 2-6 | 220 (CPU-2) Module Block Diagram | | | 2-7 | GA-16/220 System in Compact Chassis (No MPP) | | | 2-8 | GA-16/220 System in Jumbo Chassis (With MPP) | | | 2-9 | GA-16/110/220 Interface | | | 3-1 | 34-Bit Microinstruction | | | 3-2 | CROM/RALU Interface CROM Address X'028' | | | 3-3 | B-CNTL Generation CROM Address X'028' | | | 3-4 | M-Bus to TA-Bus Gating | | | 3-5 | TA-Bus to Out-Bus Gating CROM Address X'028' | | | 3-6 | CLSFY Microcycle Timing CROM Address X'028' | | | 3-7 | No-Op Microcycles | | | 3-8 | In-Bus to TD-Bus, Typical Gating | | | 3-9 | CROM/RALU Interface, CROM Address X'10F' | | | 3-10 | B-CNTL Generation, CROM Address X'10F' | | | 3-11 | DTIR Microcycle Timing | | | 3-12 | MO through MF In-Bus Gating CROM Address X'10F' | 3-29 | | 3-13 | CROM/RALU Interface CROM Address X'003' | | | 3-14 | B-CNTL Generation, CROM Address X'003' | 3-32 | | 3-15 | Timing, INCP + 1 Microcycle | | | 3-16 | SYRT- Generation | | | 3-17 | P + Memory Address Gating (Partial Representation) | | | 3-18 | CROM/RALU Interface CROM Address X'021' | | | 3-19 | B-CNTL Generation, CROM Address X'021' | | | 3-20 | Timing, FTCH Microcycle | | | 3-21 | MREQ | | | 3-22 | TD to M-Bus Gating (Partial Representation) | | | 3-23 | Overall DTIR Microinstruction Sequence Timing | | | 3-24 | Read Cycle Timing | | | 3-25 | Write Cycle Timing | | | 3-26 | Read Modify Write Timing | | | 3-27 | | | | 3-28 | Refresh Timing | 3-49 | | 3-29 | Restart Vector Address Generation | 3-53 | | 3-30 | | 3-54 | | D-1 | Console ROM Address Logic | | | | | | | D-2 | GA-16/220 System in Compact Chassis (No MPP) | | | D-3 | GA-16/110 System in Jumbo Chassis (With MPP) | | | D-4 | GA-16/220 System in Jumbo Chassis (With MPP) | D-9 | | D-5 | Typical I/O System Interrupt Chain for Early Compact Jumbo Chassis | D-10 | | G-1 | Redesigned GA-16/110/220 Processor Boards | | | NUMBER | TITLE | PAGE | |------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | H-1<br>H-2<br>H-3<br>H-4<br>H-5<br>H-6 | Programming Discrete EPROMS | H-3<br>H-4<br>H-6<br>H-15 | | | LIST OF TABLES | | | NUMBER | TITLE | PAGE | | 1-1<br>2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-10<br>A-1<br>A-2<br>A-3 | GA-16/110/220 Computer Specifications. Connector Assignments for Compact Chassis GA-16/110. Connector Assignments for Jumbo Chassis GA-16/110. Connector Assignments for Compact Chassis GA-16/220. Connector Assignments for Jumbo Chassis GA-16/220. GA-16/110/220 Controls and Indicators. G-Field Decode Branch Codes Special Branch Logic Combinations. Bus Control. Function Field General Classification. Shift Group Operations Byte Oriented Operations Miscellaneous Group Operations SRL Group Operations Logical/Literal Group Operations General Instructions Summary of General Instructions Memory Reference Instructions EA Calculations. | 2-15<br>2-17<br>2-27<br>2-29<br>2-30<br>3-2<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-10<br>3-11<br>3-12<br>A-1 | | A-4 | Memory Reference with Indexing, EA Calculations, Ref. 2, 3, 4 in A-1 and A-2 | . A-10 | | A-5<br>D-1 | Standard I/O Data and Instructions | | | D-2 | Connector Assignments for Compact Chassis, GA-16/220 Computer System | | | D-3 | Connector Assignments for Jumbo Chassis, GA-16/110 Computer System | | | D-4 | Connector Assignments for Jumbo Chassis, GA-16/220 Computer System | | | H-1<br>H-2 | Programmer Address Boundaries For S2 Selections EPROM Addressing in IK Blocks | . н-7<br>. н-8 | | NUMBER | TITLE | PAGE | |--------|----------------------------------------------|------| | Α | GA-16/110/220 INSTRUCTION SUMMARY | A-1 | | В | GA-16/110/220 MICROCODE SUMMARY | B-1 | | С | GA-16/11-/220 MNEMONICS LIST | C-1 | | D | EARLY GA-16/110 AND GA-16/220 CONFIGURATIONS | D-1 | | Ε | GA-16/220 MICROCONSOLE SIGNAL INDEX | E-1 | | F | TEST AND VERIFY PROGRAMS | F-1 | | G | REDESIGNED GA-16/110/220 PROCESSOR BOARDS | G-1 | | Н | EPROM PROGRAMMER APPLICATION | H-1 | ## introduction The GA-16/110 CPU is a complete computer containing CPU, memory, and I/O on a single, 140-pin connector, printed circuit board measuring 7 3/4" x 11" (19.7 cm x 28.0 cm). The GA-16/110 is specifically designed as a "load-and-go" type of processor for dedicated systems, such as, remote controllers and concentrators in large networks. The I/O-Bus on the GA-16/110 is totally compatible with the SPC-16 and all other GA Series-16 computer systems. All GA-programmed I/O controllers (PIO) operate on the 16/110 systems, however, the 110 has no capability for direct memory access (DMA) controllers. If DMA access is required, the GA-16/110 must be upgraded to a GA-16/220. The GA-16/110 may be upgraded to a general-purpose GA-16/220 CPU by the addition of one 7 3/4" x 11" module, providing the capabilities of a GA-16/220 as identified in Table 1-1. Table 1-1. GA-16/110/220 Computer Specifications (Sheet 1 of 5) | Architecture | Microprogrammed 16-bit General-Purpose Comput Parallel Binary Two's Complem Single- and Double-Word Instru<br>Programmed and Direct Memory | ent Arithmetic<br>uctions | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--| | Technology | Processor -nMOS LSI and Tri-State (7400, 7400H and Schottky Logic) Circuitry and Unique Four-Layer Printer Circuit Board Packaging | | | | Memory | Semiconductor RAM, PROM, and EPROM | | | | Registers | Programmable Registers Accumulators Index/Accumulators Base Register Subroutine Linkage Shift Counter Register Program Counter Instruction Register | 16<br>6<br>6<br>2<br>2<br>1<br>1 | | Table 1-1. GA-16/110/220 Computer Specifications (Sheet 2 of 5) | Registers | Status Indicators 7 | | |----------------------|-----------------------------------------------------|--| | (Continued) | Zero | | | (Concinded) | Plus | | | | Link | | | | Overflow | | | | | | | | Foreground/Background | | | | 32K/64K Memory Mode | | | | Interrupt System Enable (ISE) Save | | | | Shift Count 1 | | | Standard Processor | Real-Time Clock (RTC) 1 ms | | | Scandard 11000001 | Operations Monitor Alarm (OMA) 150 ms - 300 ms | | | 1 | Power Fail/Auto Restart (PF/AR) | | | | Cold Start | | | | | | | | 64K Direct Addressing | | | | Memory Parity Protect (MPP) (Optional) | | | | Interrupt Program Timeout (Optional) | | | Arithmetic and Logic | Parallel Binary, Two's Complement, Fixed-Point, | | | | Bit, Byte, and Word | | | | ADD, SUB, COMP, INC, DEC, AND, OR, XOR, SET BIT, | | | | RESET BIT, TEST BIT | | | | Hardware Multiply and Divide (Unsigned) | | | | | | | | Signed Multiply/Divide (Optional) | | | Instructions | Memory Reference | | | (Fourteen Classes) | Memory Referenced Indexed | | | | Conditional Jump (Skip) on Eight (8) Conditions | | | | Register Operate and | | | | Register Operate and Compare | | | | Register Operate Literal and | | | | Register Operate Literal and Compare | | | | Subroutine Return Via Indirect Vector | | | | Register Change | | | | Shift Left | | | | | | | | Shift Right | | | | Control | | | | Input/Output (Addressing to 64 Device Select Codes) | | | | Read Console Switches (Additional Input/Output on | | | | GA-16/220) | | | | Multiply/Divide (Unsigned) | | | | Special (Enable Single Step Interrupt, I/O Reset) | | | | (Additional Input/Output on GA-16/220) | | | | | | | 1 | | | | | | | Table 1-1. GA-16/110/220 Computer Specifications (Sheet 3 of 5) | | offications (Sheet 5 of 5) | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Addressing<br>(Eleven Modes) | Direct Direct, Indexed Indirect Indirect, Indexed Program Relative Program Relative, Indirect Base Relative Base Relative, Indexed Base Relative, Indirect Base Relative, Indirect Literal | | Programmed I/O (PIO) | 16-Bit Parallel Transfers Vectored Priority Interrupts 120K Word Transfer Rate Data Transfer To/From Memory To/From Any One of the Sixteen (16) Programmable Registers | | Serial I/O<br>(GA-16/220) | Integral Universal Asynchronous Receiver Transmitter (UART) Serial I/O Controller for Console TTY or CRT Data Rates 110 or 9600 Baud (Early Model CPU2 boards) Sixteen Rates, 0 thru 9600 Baud (CPU2 31D02574A) | | Direct Memory Access<br>(DMA) I/O (GA-16/220) | 16-Bit Parallel Transfers Multi-Channel Operation with Vector Priority Sequencing 900K Word-Per-Second Transfer Rate Interleaved with CPU | | Interrupts | Non-Inhibitable (NI) Interrupts Power Fail Auto-Restart Memory Parity, Write Protect, and Program Timeout (Options) TRAP Instruction Single Step/Break (GA-16/220) | Table 1-1. GA-16/110/220 Computer Specifications (Sheet 4 of 5) | Interrupts<br>(Continued) | Internal Inhibitable (IN) Real-Time Clock Console TTY Console Interrupt External Inhibitable (IN) 64 Priority Interrupt Lev | Interrupts | | |--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--| | Dimensions | GA-16/110 CPU Module or Additional 220 Module | | | | | Height<br>Width<br>Width w/Piggyback RAM<br>(or SCI)<br>Depth | 7.250 in. (18.415 cm) 0.625 in. (1.588 cm) 1.063 in. (2.72 cm) 11.000 in. (27.940 cm) | | | - ' | Compact GA-16/110/220 System with Internal Power Supply or Jumbo GA-16/110/220 System (Requires Separate Power Supply) | | | | | Height Width Depth (w/o Cables) Depth (w/Cables) | 8.750 in. (18.415 cm)<br>19.000 in. (48.260 cm)<br>21.150 in. (53.721 cm)<br>22.250 in. (56.515 cm) | | | | Separate Power Supply for Jumbo GA-16/110/220 System | | | | | Height<br>Width<br>Depth (w/o Cables)<br>Depth (w/Cables) | 10.750 in. (27.305 cm)<br>19.000 in. (48.260 cm)<br>5.750 in. (14.605 cm)<br>7.750 in. (19.685 cm) | | | Temperature | Operable at 0°C to 50°C | | | | Humidity | Up to 90 Percent Relative (Non-condensing) | | | | Input/output<br>Interface<br>Signals | Low Level - 0.0 to 0.4 vol<br>High Level- 2.0 to 5.0 vol | ts | | | | I/O Drivers - 74365 Tri-State TTL Drivers Saturation voltage 0.4 volt Capable of sinking 40 ma to ground | | | | I/O Cable Termination | Twisted Pairlines - 100Ω c<br>Returns grounded at both | haracteristics impedance ends | | Table 1-1. GA-16/110/220 Computer Specifications (Sheet 5 of 5) | Power | GA-16/110 Module Only | |-------|-----------------------------------------------------------------------------------------| | | +5V@2.7A, +15V@0.092A, -15V@0.012A | | | Optional Piggyback RAM Memory for GA-16/110/220 | | | w/IPL +5V@1.620A, w/o IPL +5V@1.236A | | | GA-16/220 Module | | | +5V@2.58A, +15V@0.000A, -15V@0.012A | | | 8K by 16 Memory Module | | | +5V@1.5A, -5V@0.004A, +12V@0.400A | | | MPP | | | +5V@2.25A | | | Optional System Console Interface (SCI) | | | w/IPL +5V@1.2A w/o IPL +5V@0.64A | | | GA-16/110 or GA-16/220 Power Supplies for Compact and Jumbo MIB | | | 115 Volts AC, Single-Phase ±10 Percent, 47 to 63 Hz (Internal or External Power Supply) | | | 220 Volts AC, Single-Phase ±10 Percent, 47 to 63 Hz (External Power Supply Only) | | | 230 Watts Maximum (Compact) 500 Watts Maximum (Jumbo) | ## 1.1 COMPONENT IDENTIFICATION Figures l-1 through l-7 are supplied to aid in component module identification and installation. ## 1.1.1 MEMORY MODULES The Memory Modules (Figure 1-1) may be installed in J-9, J-10, J-11, and J-12 of the compact chassis (refer to Figures 2-2 and 2-5) and in J-11, J-12, J-13, J-14, J-15, J-16, and J-17 of the Jumbo Chassis (refer to Figures 2-3 and 2-6). The memory may contain one or more 4K, 8K, or 16K boards, or a 32K or 64K board. ## 1.1.2 GA-CPU-2 MODULE The CPU-2 (Figure 1-2) module upgrades the GA-16/110 to a GA-16/220. The CPU-2 module is placed in J-8 of the compact chassis (Figure 2-5) or in J-10 of the Jumbo Chassis (Figure 2-6). ## 1.1.3 GA-CPU-1 MODULE The CPU-1 Module (Figure 1-3) the nucleus of both the GA-16/110 and GA-16/220 has four possible locations: - 1. In the Compact Chassis GA-16/110, the CPU-1 Module is located in J-8 (Figure 2-2). - 2. In the Jumbo Chassis GA-16/110, the CPU-1 Module is located in J-10 (Figure 2-5). - 3. In the Compact Chassis GA-16/220, the CPU-1 Module is located in J-9 (Figure 2-5). - 4. In the Jumbo Chassis GA-16/220, the CPU-1 Module is located in J-11 (Figure 2-6). ## 1.1.4 CHASSIS ASSEMBLIES Figure 1-4, 1-5, 1-6 and 1-7 are provided to pictorially supplement Figure 2-3, 2-4, 2-5 and 2-6. These eight figures should answer any questions concerning actual card placement and chassis configuration. The following points should be noted: - All cards, when viewed from the front, MUST have the component side to the left. This means that the TTY/CRT Connector and the Memory Service Module (when installed) must have their components facing to the right when viewed from the back of the chassis. - The Memory Service Module will not be installed when a Back-up Power Supply is installed and must be installed when no Back-up Power Supply is in a system with plug-in dynamic RAM. It is not mandatory for the 2K piggyback static RAM. - When a Back-up Power Supply is installed there are two AC line cords to plug into the AC supply line; one cord from the Back-up Power Supply itself, the other from the main systems power supply (internal or external). Figure 1-2. GA-CPU-2 Module with SCI Figure 1-3. Figure 1-4. Jumbo Chassis (Rear View) Figure 1-5. Compact Chassis (Rear View) Figure 1-6. GA-16/220 Jumbo Chassis Figure 1-7. GA-16/220 Compact Chassis ## GA-16/110/220 2 functional description The purpose of this section is to present a basic functional and physical description of both the GA-16/110 and GA-16/220 computer systems. ## 2.1 GA-16/110 CPU (CPU-1 MODULE) The GA-16/110 processor (also the heart of the GA-16/220 system) is a high-speed, LSI microprocessor-controlled, CPU on a single board. The nucleus of the central processor is a micro-computer, consisting of two proprietary, N-channel, silicone gate, MOS chips; the Register Arithmetic and Logical Unit (RALU) and the Control Read-Only-Memory (CROM). The RALU, in effect, duplicates the internal organization of the SPC-16 and GA-Series 16 processors. The CROM contains the microcoded instructions and logic necessary to emulate an extended SPC-16 instruction set. The detailed block diagram of the GA-16/110 CPU module, Figure 2-1, includes key interface signals. The major blocks of the GA-16/110 (CPU-1) module are listed below. (For additional information, refer to the GA-16/110/220 Systems Reference Manual, Section 2.) - · Control Read Only Memory - · Register Arithmetic and Logical Unit - Initial Program Decode Bus - · Timing Network - · Bus Control Latch and Decode - Programmed Input/Output Control Network - · Interrupt System Enable Flip Flop - Tri-State Buffered Address Latch - · Piggyback Memory and IPL ROM - · Tri-State Bi-Directional Interface - · Tri-State Data Bus - · Tri-State Address Bus - Interrupt Control - · Reset Driver - · In-Bus - · Console Interface - Run, Test, SVI Figure 2-1. GA-16/110 CPU Module Block Diagram ## 2.1.1 CONTROL READ-ONLY-MEMORY (CROM) The CROM contains the microcode and logic necessary to emulate the expanded SPC-16 instruction set. The microinstructions utilized in the GA-16/110/220 are 34 bits in length and control all signal generation and data transfers within the system. The functional components of the CROM (reference Figure 2-2) are: - Program Instruction Register and Control. The "I" register contains the program (user) instruction now being executed. The I register is loaded, via the M-Bus, during instruction fetch (IFETCH) time. - Programmable Logic Array (PLA). The output of the I register (internal to the CROM) feeds the PLA and selects the correct address of the first instruction of the microprogram (within the CROM) to be executed for proper translation and operation of the current program instruction in I. - ROM Address Latch. This logic receives the output of the PLA and latches the address of the microinstruction in the CROM. - ROM. The actual microinstruction read-only-memory which contains all microinstruction sequences (320 words by 34 bits). - Tri-state drivers. The Schottky (tri-state) bus drivers output, at the proper time, the microinstruction, to the rest of the CPU logic. - IPDx Bus. The Initial Program Decode Bus is used to carry the output of the ROM (microinstruction) to the RALU and remainder of the system logic. 509-2-2 Figure 2-2. CROM Block Diagram ## 2.1.2 REGISTER ARITHMETIC AND LOGIC UNIT (RALU) The RALU (reference Figure 2-3) is the computational nucleus of the GA-16/110 and GA-16/220. The RALU performs all arithmetic and logical operations available to the system, as well as the majority of the general-purpose and working registers. The main functional components within the RALU are: - Microinstruction I-Latch. The register for the microinstruction currently being translated from the CROM. The microinstruction is gated, via the IPDx Bus, from the CROM. - Function Control Logic. This logic decodes the control functions of the microinstruction to select such things as, source register (RS), destination register (RD) adder inputs/outputs, etc. - · The general-purpose registers are P, W, S, and A through E. - · The Adder is the logic for computation of arithmetic and logical operations. - Adder gating. The E-Latch, D-Latch and Spread circuitry are used in controlling the selection and conditioning of data to be input to the adder circuitry. (The Spread circuitry is used for manipulation of the data from the W register during address calculations.) - The M-Bus is the bi-directional memory bus for transferring data between the CROM/RALU and the rest of the processor. Figure 2-3. RALU Block Diagram ## 2.1.3 INITIAL PROGRAM DECODE BUS The IPDX-Bus is the primary path for control information between the CROM and the RALU. This bus also serves as the path for transmitting control signals to other logic within the CPU. (These signals maintain control of the gating of data over the CPU bus network.) #### 2.1.4 TIMING NETWORK All processor timing is derived from a 20MHz crystal-controlled oscillator, the heart of the timing network. The timing network outputs the timing pulses CA+ (the processor 'A' clock) and CA- (the processor 'B' clock) to provide timing for the CROM and RALU chipset. The 20MHz+ timing signal is output, via Pl pin 69, to the CPU-2 module (when installed) for GA-16/220 internal timing. TACK+ is the buffered processor 'A' clock that is used in the microcycle timing. TACK+ has a frequency equal to one cycle per processor microcycle. POLL- and D3- are the I/O interface synchronization timing signals. ## 2.1.5 BUS CONTROL LATCH AND DECODE The BUS Control Latch and Decode circuitry provides the logic network for decoding the bus control (B-CNTL) field of the CROM microinstruction. The input/output signals are those signals as required for proper microcode operation and are listed below. - DMRQ1/DMRQ2 These signals are requests for memory access from DMA channels 1 and 2. - DMAK1/DMAK2 The DMAK signals are the CPU DMA acknowledge signals generated in response to DMRQ1 or DMRQ2. - CRRE The CROM/RALU Receive Enable signal. This signal is used to gate data into the CROM and RALU logic chips from sources external to the CROM/RALU chipset. - CRDE The CROM/RALU Drive Enable signal. This signal enables the output of the CROM or RALU to be gated to the logic outside of the CROM/RALU chipset. - INDAL Interrupt Data to RALU. The INDAL signal is generated by the microcode to gate interrupt data (interrupt vectors, etc.) into the RALU. - ADRL Address Load Enable. ADRL selects one of two data sources as the output to the TA-Bus (TAXX) lines. The data source may be either the TD lines or the CROM/RALU Data-Bus lines (MO through MF). - DMAK DMA Acknowledge. DMAK is a general acknowledge signal generated anytime the processor is acknowledging either a DMRQ1 or DMRQ2. - DIBE Data In-Bus Enable. When active, this control signal, gates the contents of the Tri-State Data-Bus (TDXX) to the CROM/RALU via the CROM/RALU Data Bus lines (MO through MF). - IOBSY I/O Busy. IOBSY indicates that the current microinstruction is performing an input/output operation. This signal enables the Tri-State Address Lines output (TAXX) to be gated to the Out-Bus lines to address the correct peripheral controller. - ALIOA RALU Output to I/O Address. Whenever an I/O operation is requested, ALIOA is generated by the microcode to produce IOBSY (see above). - ALIOD RALU to I/O Data. After the microcycle used to address a peripheral device (ALIOA), ALIOD is generated to gate the actual data from the processor to the designated peripheral controller. - IODAL I/O Data to RALU. This signal is generated during an I/O input microcycle to gate the data, from the I/O device, into the RALU registers. - ALSYN RALU to Sync. The sync output generates a timing strobe to allow synchronization of an oscilliscope with the CPU logic timing. - AIMD RALU Output to Memory Data. When the program requires the gating of the output of the RALU to memory, ALMD goes true to enable that output, on the chip data bus (M-Bus), to memory via the tri-state data bus (TD-Bus). - MDAL Memory Data to RALU. The microcode forces MDAL true to indicate a transfer of a memory word into the RALU. Memory data is transferred via the TD-Bus and M-Bus. - LSADD Load Starting Address. During start-up procedures, such as IPL, LSADD combines with the presence (or absence) of the IPL signal to select the proper starting ROM address for the IPL operation. - RMW Read/Modify/Write. RMW indicates that the data being read from memory is to be modified and re-written into the same memory location. ## 2.1.6 PIO CONTROL The Programmed input/output control network generates the signals necessary to govern operation of the I/O bus. It is the responsibility of this logic to maintain I/O timing compatability with General Automation peripheral controllers. The timing and gating pulses output from the PIO control network are as follows. - FAP Function and Address Pulse. FAP is utilized as an enable to select (address) a specific controller. FAP identifies the contents of the Out-Bus (bits $5 \rightarrow 0$ ) as the device select address. - DTP Data Transfer Pulse. DTP is used to synchronize the actual transfer of data between the CPU and peripheral. This signal indicates that either data input from a peripheral controller is available for the CPU on the In-Bus lines or data output to a peripheral controller is available on the Out-Bus lines. - WRIT The write signal is sent to the peripheral device to indicate that the current operation is a data output from the CPU. - READ The read signal is generated by the CPU, in response to a data input request, it indicates that a data input to the CPU operation is in progress. - CNTL Control indicates, to a peripheral controller, that bits 8, 9 and 10 of the Out-Bus contain a bit combination that is to be decoded as one of eight possible control commands. - SYNC The CPU Sync pulse is generated to allow an oscilliscope to be synchronized with the CPU timing cycles. This signal is available on Pl pin 42. ## 2.1.7 THE ISE FLIP-FLOP The Interrupt System Enable Flip-Flop allows a programmable enable/disable of all CPU inhibitable interrupts. The ISE has no effect on non-inhibitable interrupts, such as Power Fail Detect (PFD). #### 2.1.8 TRI-STATE BUFFERED ADDRESS LATCH The Tri-State Buffered Address Latch is comprised of a series of type 74173 (typical) logic gates and is mechanized to transfer the output of the CROM to the processor TAXX lines when addressing CPU memory. The address latch will also gate the CROM output onto Out-Bus, if IOBSY- is true, thereby indicating that an I/O operation is currently in progress. ## 2.1.9 PIGGYBACK MEMORY AND IPL ROM The Piggyback Memory may consist of either static RAM or EPROM combined with RAM. The static RAM piggyback contains 2K of RAM with an optional 64 word, single device, IPL ROM. The IPL may be either teletype (TTY) or high-speed paper tape reader (HSPTR). The alternate configuration for the piggyback memory is 3K of EPROM combined with 1K of RAM. In the 2K piggyback RAM, the IPL ROM is additional memory space and does not replace any of the 2K addresses in RAM. The signals utilized by the piggyback memory are: - MREQ Memory Request: The memory request signal notifies the memory that a memory cycle is pending. - STRD Stop Memory Read. This signal is used to end a memory read cycle. STRD partially enables the memory write operation when an RALU to memory microcycle (RALU → MD) is active. - MDRY Memory Data Ready. The MDRY signal is transmitted from the memory module to acknowledge a memory request (MREQ). The trailing edge indicates valid data on the memory output lines. - MWRE Memory Write Enable. At the end of a memory read cycle MWRE is generated to enable the gating of data to the addressed memory location. MWRE is generated only if an RALU → MD microcycle is active. #### 2.1.10 TRI-STATE BI-DIRECTIONAL INTERFACE Type N8T26B logic chips comprise the interface between the CROM/RALU chipset and the bi-directional Tri-State Data Bus (TD-Bus). Two signals control gating through this interface: CRDE+ and CRRE- (reference Section 2.1.5, Bus Control Latch and Decode). #### 2.1.11 BUS NETWORKS Four buses are used for communication between the CPU-1 module (16/110) and the other system modules: In-Bus, Out-Bus, TA-Bus and TD-Bus. - In-Bus In-Bus contains the 16 data lines for data input to the CPU-1 module from the CPU-2 module (16/220 configuration) and the peripheral controllers. The In-Bus lines are also used as the interrupt control access path. Data is enabled over these lines by the signal DIBE (Data In-Bus Enable). - Out-Bus The 16 Out-Bus lines are used as the data path for output from the CPU-1 module to the system I/O controllers. Out-Bus is also available to the CPU-2 module. Out-Bus Gating is enabled during I/O operations only (IOBSY-)true. - TD-Bus Tri-State Data Bus. The TD-Bus is the bi-directional communications lines for the transfer of data into and/or out of the CROM/RALU chipset and memory TD-Bus gating consists of tri-state Schottky logic chips. - TA-Bus-Tri-State Address Bus. The TA-Bus is the transfer path for memory addressing information from the CROM/RALU chipset. Like the TD-Bus, the TA-Bus gating consists of the tri-state Schottky logic chips. #### 2.1.12 INTERRUPT CONTROL The Interrupt Control network contains the logic for the recognition, programmable masking and generation of all interrupt signals available within the CPU-1 module and its'associated peripheral controllers. The interrupt signals received and generated by this logic are listed below. - ISE Interrupt Systems Enable. The output of the ISE flip-flop, when set, enables the recognition of the inhibitable interrupts. This setting of the ISE flip-flop is under program control. - POLL The POLL signal is a timing signal used for synchronization of I/O and interrupt signaling. - NIIR1 Non-Inhibitable Interrupt Number 1. NIIR1 goes true to indicate that a non-inhibitable interrupt is generated on MPP. - NIIR2 Non-Inhibitable Interrupt Number 2. NIIR2 is driven true when a non-inhibitable interrupt is generated on a GA-16/220 system, single step or break interrupt. - RTCKE Real-Time Clock Enable. The RTCKE line is the programmable enable input for the Real-Time Clock (RTC). - RTCKI Real-Time Clock (RTC). On the GA-16/110, this input is available for a user supplied interrupt clock pulse input. On the GA-16/220 the interrupt clock pulse is derived from the 20 MHz crystal oscillator. The GA-16/220 RTC interrupt pulse occurs each millisecond (lms). - IREQ Interrupt Request. Each peripheral device drives this input line active (low) when requesting interrupt access of the CPU. - CLDS Cold Start. System Startup and IPL procedures are dependant upon the condition (high or low) of this line. CLDS combines with other conditions to determine if start-up (or IPL) will be from ROM, RAM or manual intervention (refer to GA-16/110/220 Systems Reference Manual, Section 3.4.1.1, System Start-up). - PFD Power Fail Detect. The PFD circuit monitors the AC input line. If the AC input drops out of tolerance (below 105vac) the PFD circuit enables this line. - IPRS Interrupt Priority Return Status. A common signal, from the peripheral controllers, to indicate that interrupt priority has been established. (From the highest priority controller requesting an interrupt.) - NIIEC Non-Inhibitable Interrupt Mode Control. Any of the non-inhibitable interrupts going active forces NIIEC+ true (high). This forces the microcode to an interrupt microinstruction and disables any IPL or console ROM (16/220) operation. - INT Interrupt. The interrupt signal (INT) is generated, when an interrupt request is received by the CPU. INT is produced by a non-inhibitable interrupt or by an inhibitable interrupt with the interrupt system enabled (ISE+). - IHLD Interrupt Hold. Once an interrupt has been recognized and granted priority, by the CPU, IHLD is driven true (low) to disable any further interrupts. - IPSO Interrupt Priority Status Out. This is a serially transmitted priority signal propagated from each I/O controller to the next lowest priority controller. This signal is received via the Interrupt Priority Status In (IPSI) line. - INACK Interrupt Acknowledge. (Same as IACK.) The highest priority interrupting controller uses this timing signal to place its vector address on the In-Bus lines. - INDAL Interrupt Data To RALU. When the interrupt data is available to the chipset, INDAL is generated by the microcode to gate that data to the RALU. #### 2.1.13 RESET DRIVER The Reset Driver circuitry provides the logic to generate a processor reset (PRRT) to the CPU only (REST line) or a systems reset (SYRT) to the I/O controllers as well. The term RSET— is representative of a bi-directional line, activated via a console pushbutton, that causes a reset of the CPU only. ## 2.1.14 CONSOLE INTERFACE The Console Interface is a 16-pin DIP socket on the outward edge of the CPU-1 module. This connector is designed to allow the application of a user-designed console device to monitor and/or drive the following processor lines: - RUN The run line is a dual-purpose, bi-directional line. When tied (via P2 pin 6), to an indicator light network, RUN indicates the operational status of the CPU. The run line may also be connected to a console switch, thereby allowing a run command to be forced into the CROM/RALU chipset by driving RUN+true (high), and forcing step true. - SVI Save I. The Save I line, when placed into its' true state (low), forces the CROM to continually execute the instruction in the instruction (I) register. Any change to the I register is blocked. - STEP The step line allows for single instruction execution. With the processor in the idle mode (RUN) and this line true (high) one complete instruction execution cycle takes place, if RUN is forced true for one micro/cycle. If the system has been placed in the RUN mode (via P2 Pin 6) activating STEP initiates automatic program execution. - ENTER. Activation of the ENTER line gates the contents of user provided console switches (tied to the In-Bus lines O through 15) into the CROM/RALU chipset. - SWA, SWB, SWC, SWD The four "general-purpose register switches" are available to enable selection of one of eight general-purpose registers to receive the data set into the user-supplied data switches (gated in by ENTER). The processor must be in the idle condition. #### 2.1.15 TEST The TEST line returns the indication of the results of a Test instruction to the processor. In actuality, TEST may be active anytime an I/O operation is in progress. However, the processor only samples the TEST line when a TEST instruction is being executed. ## 2.1.16 OPERATIONS MONITOR ALARM (OMA) The OMA network provides for an automatic system shutdown if the users program fails to periodically execute a PMA instruction. Once armed (by a PMA instruction) the OMA timer allows 150 ms to 300 ms for the system program to issue another PMA instruction to re-arm the timer. If, within this time frame, the timer is not re-armed, the system switches from the RUN mode to the IDLE mode and forces the systems safe signal (SFEC) false (high). SFEC being high indicates that the system is in an "unsafe" condition. ## 2.1.17 PHYSICAL CONFIGURATION In order to aid in component placement, Figures 2-4 and 2-5 are supplied with corresponding Tables 2-1 and 2-2. If additional information is required concerning these items, refer to the GA-16/110/220 Systems Reference Manual, Section 3. Figure 2-4. GA-16/110 System in Compact Chassis (No MPP) Table 2-1. Connector Assignments for Compact Chassis GA-16/110 | | Front/Module (110) | | Rear/Interface (110) | |-------------------------|---------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------| | Jl | Main power supply | - | AC input connector and system grounding terminals on power | | J2 | Cable interface driver (CID) | | supply. | | J3<br>J4 | I/O controllers or shorting boards. | J13 | Connector for optional external power supply cable. | | J5<br>J6<br>J7 | Shorting boards are used in empty slots between con-trollers or CID to maintain | J14 | Cable to I/O expansion chassis (6-feet maximum). | | | priority chain continuity. | J15<br>·J16 | Paddleboards and cables interfacing controllers (in J3 | | 18 | CPU-1 module with optional piggyback memory and IPL ROM. | J17<br>J18<br>J19 | through J7) to peripheral devices. | | J9<br>J10<br>J11<br>J12 | Memory module or Memory Parity Protect module. J12 also used for battery | J20 | Access to cold-start (CLDS-) memory mode (64KM+) and remote control lines (IPLSW-, PFD-, RSET-, RUN-). | | - | Backup regulator board. Backup power supply and battery pack (use regulator board in J12). | J21<br>- | Memory Service Module if backup power is not used. AC cord for backup power supply. | | | | - | Terminals for external 12-volt battery on rear of battery pack. | 508-F-3 Figure 2-5. GA-16/110 System in Jumbo Chassis (With MPP) Table 2-2. Connector Assignments for Jumbo Chassis GA-16/110 | Front/Module (110) | Rear/Interface (110) | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J1 Cable interface driver (CID) J2 J3 J4 J5 Shorting boards are used in empty slots between controllers or CID to maintain interrupt chain continuity. CPU-1 module with optional piggyback memory and IPL ROM. J11 J12 J13 Memory modules or memory parity protect module. J17 also used for battery backup regulator board. | J18 Cable to I/O expansion chassis, (6-feet maximum). J19 J20 J21 J22 J23 J24 J25 J26 J27 Access to cold-start (CLDS-) memory mode (64KM+), and remote control lines (IPLSW-, PFD-, RSET-, RUN-). J28 Memory Service Module if backup power supply is not used. J30 Power cable from external power supply. | | - Backup power supply battery pack (use regulator board in J17). | J31 System grounding terminals. - AC cord for backup power supply. - Terminals for external 12-volt battery on rear of battery pack. | # 2.2 <u>GA-16/220 (CPU-2 MODULE)</u> The GA-16/220 processor is structured around the basic GA-16/110 (CPU-1 module) and one additional processor printed circuit board, the CPU-2 module. The CPU-2 module adds the DMA communications port, the Serial I/O controller (CRT/TTY interface), a one millisecond Real Time Clock (RTC) and additional controls and indicators. The detailed block diagram of the CPU-2 module (Figure 2-6) shows the features added to the GA-16/110 configuration by the addition of the CPU-2 module. The structure of the CPU-2 module is defined below. (For additional information, refer to the GA-16/110/220 Systems Reference Manual, Section 2.) - · lms Real-Time Clock - Interrupt Control Logic - · Console Switches - · DMA Timing and Control - Systems Console Interface - · Reset Driver - SCI Memory Control - · Address Buffer and MS1K Detect - · DMA Address Latch - Serial I/O Controller - I/O 3E/3F Decode and Control - · Timing Network Figure 2-6. 220 (CPU-2) Module Block Diagram #### 2.2.1 REAL-TIME CLOCK The one millisecond Real-Time Clock (RTC) pulse generates an interrupt (RTCKI+) each millisecond only when enabled by program command. If the RTC interrupt is disabled, the RTCKI+ signal is blocked from having any effect. The RTC derives its timing from the 20 MHz oscillator on the CPU-1 module. # 2.2.2 INTERRUPT CONTROL LOGIC The Interrupt Control Logic masks and monitors all interrupt generating conditions. If an interrupt occurs, and is programmatically enabled, the interrupt control logic allows generation of the interrupt via the I/O Bus. The signals POLL, IHLD, IACK, IPRS, IPSO, and IPSI are I/O network synchronizations and timing pulses and are described in Section 2.1.12, Interrupt Control (GA-16/110 Module description). The primary GA-16/220 interrupt signals are: - MSIK The Most Significant IK signal indicates that the current memory request is an address in the upper IK range and, therefore, is accessing the Systems Console Interface (SCI) ROM. - NIIR2 See Section 2.1.12. - CNSL INT The Console Interrupt-condition is produced by the manual depression of the Console Interrupt pushbutton on the CPU-2 module. - CIEN/TYIEN The Console Interrupt Enable (CIEN) and Teletype Interrupt Enable (TYIEN) lines signal the translation of the instructions that programmatically enable the interrupt network to detect and propagate the Console Interrupt and TTY Interrupt, respectively, to the CPU-1 module. #### 2.2.3 CONSOLE SWITCHES The Console Switches are the 16 miniature, rocker-type, switches mounted on the microconsole. These switches serve as a systems console for manual data input to the GA-16/220 system. Data, input via the console switches, are in binary format and are passed over the In-Bus lines. Only two signals are utilized by the Console Switch network; TACK+ and RCSW-. TACK+ is the buffered processor 'A' clock (CA+) and is used to mark the correct timing for input of the data contained in the switches. RCSW- is the strobe pulse to enable the gating of the data, from the switches, onto In-Bus. #### 2.2.4 DMA TIMING AND CONTROL The Direct Memory Access Timing and Control logic controls all data channel input/output (DCIO), from the Multiple High-Speed Data Channel Controller (MHSDC) over the I/O Bus. The DMA logic also oversees the direct DMA accesses from those controllers incorporating MHSDC-type logic and, therefore, not connected to an MHSDC module for memory access. All signals, except POLL and D3, being produced or used by the DMA Control are listed below. POLL and D3 are the standard I/O synchronization clock pulses. (Refer to GA-110/220 Systems Reference Manual, Table 6-19, I/O Bus Description). - DMRQ1 Direct Memory Request 1. DMRQ1 is forced true whenever a Direct Memory Access Request (DREQ) is received from the data channel. - DPSO Data Channel Priority Status Out. Just as the priority of the interrupting controllers is determined by IPSO/IPSI, so the priority of the data channel controllers is maintained by DPSO/DPSI. - DACK DMA Acknowledge. Upon recognition and acceptance of a DMA request from a peripheral (or the 220) the CPU-1 generates DACK to acknowledge that interrupt. - DDTP DMA Data Transfer Pulse. For standard PIO data outputs, the processor transmits DTP to signal valid data on Out-Bus and available to the controller. In DMA transfers, the same function is accomplished by DDTP. - DCHN-DMA Chain. The Data Channel Module (or similar logic on a non-MHSDC-DMA controller) produces the DCHN signal to indicate either a "chaining" mode or "initiate" mode in a data channel controller. - DMC Direct Memory Cycle. When a DMA request (DREQ) is received by the CPU-2, DMC is generated to indicate that a Direct Memory Cycle is active. - RQIN Request Input. RQIN indicates the direction of data flow in a DMA operation. RQIN being true indicates a data input (READ) operation. - DMAK1 DMA #1 Acknowledge. The CPU-1 generates DMAK1 to acknowledge a DMA request from the CPU-2 module. - DREQ -DMA Request. When a data channel controller requires service, DREQ is made low to signal the CPU-2 that a DMA device is seeking access to memory. - DMAER DMA Error. With the optional Memory Parity Protect (MPP) option installed, this line indicates a DMA access error (attempt to write into protected memory) by going true (low), or parity error has occurred. The signals MREQ, STRD, MWRE, and MDRY are memory control signals and are explained in Section 2.1.9. ## 2.2.5 SYSTEMS CONSOLE INTERFACE (SCI) The optional Systems Console Interface (SCI) contains a 256-word, random-access-memory (RAM), and a 512-word, read-only-memory (ROM), to provide an interactive TTY/CRT interface utility program. The SCI may also contain a 256-word IPL ROM. Several controls and indicators are also a part of the SCI and are described in the GA-16/110/220 Systems Reference Manual in Sections 1 and 3. The signals input to, and emanating from, the SCI option are described in the following text: - 64KM 64K Memory Mode. When in the 64K mode, this line is true to enable addressing of the upper 32K of memory without translating addresses in the 32K range as console ROM addresses (disables MS1K until 63K addresses). - TYR TTY Framing Error. If the Serial I/O controller detects an absence of a valid stop bit after a character, TYR goes true (low) to reset the controller (UART) and produce BKINT or BKRS if enabled. - \* BKINT Break Interrupt. When enabled, by the 2-position, SCI, BREAK switch (S2) this line indicates that the operator has pressed the TTY/CRT BREAK KEY (if installed on the device). This interrupt allows either a system reset or an interrupt depending upon the setting of the BRK MODE SCI switch. - \* BKRS Break Reset. If the BKINT condition is disabled, BKRS is held true (low) and has the same effect as pressing the reset button on the CPU-1 module. - \* IPLSW Initial Program Load Switch. Switch S4 on the microconsole (IPL), when pressed, drives this line true (low). When IPLSW is true, control is passed to the IPL ROM (on the SCI Module) to effect program loading from a specified peripheral device. - LSADD Load Start Address. On normal system start-up operation, LSADD combines with the IPL signal to select the proper ROM starting address for IPL operations. - PRRT Processor Reset. Either a power fail detect (PFD) or a manual pressing of the Reset Switch (S1), on the CPU-1 module, generates a reset to the SCI via this line. - \* CLDS Cold Start. During certain power-up sequences, the SCI forces this line true to aid in selection of the type of start-up procedure to be implemented. - \* SEMI Semiconductor Memory. When a memory request address translates as being in the upper IK (MS1K) of memory, SEMI goes true to indicate that the requested address is in the Console ROM. (Combines with ABRT- to form MEMPR- on the CPU-2 module to disable the standard memory at that address.) - · ABRT Abort. This signal is produced at the same time as SEMI and has the same definition. - SMDRY Select Memory Ready. The SMDRY signal indicates a memory read of the most significant IK of memory (MSIK). - SMBSY Select Memory Busy. Memory busy indicates that a memory read operation is in progress. SMBSY and SMDRY combine, on the CPU-2 module to generate Memory Data Ready (MDRY). - MSTR Memory Start Read. When a memory request is active, MSTR is generated to partially enable the memory read cycle. - STRD Stop Memory Read. At the beginning of a write cycle STRD goes true to end the read cycle. STRD combines with MSTR to produce SLMD. - SLMD Select Memory Data. STRD combines with MSTR to produce SLMD. SLMD begins a read cycle in the most significant 1K of memory (MS1K) only (the console ROM). - STM1 Start Memory 1. A DMA request for memory access generates STM1. This signal is used in the GA-16/220 to help generate WRTS\*. #### 2.2.6 ADDRESS BUFFER AND MS1K DETECT The address buffer converts the memory address, currently referencing the SCI memory, from the processor TA-Bus to the SCI LR-Bus lines. The MSlK Detect logic identifies the current memory address as being in the most significant lK of memory (the SCI ROM). ## 2.2.7 DMA ADDRESS LATCH The Direct Memory Access Address Latch captures the address, from the In-Bus, of the memory location being accessed by a DMA controller. When the DMA request is recognized, and granted priority to access memory, the outputs of the address latch become the processor memory address lines (TA-Bus 00 through 15). #### 2.2.8 SERIAL I/O CONTROLLER The internal Serial I/O Controller is a Universal Asynchronous Receiver/Transmitter (UART) logic chip. The UART based peripheral controller performs serial/parallel conversion of TTY/CRT input/output data. All communication with the teletype (or CRT) is accomplished through the Serial I/O Controller over the serial I/O bus via either the RS-232 (CRT) or TTY Interface Paddleboard. Data to be output to the controller arrives from the CPU via the Out-Bus. Data received from the CRT/TTY is sent to the processor via the In-Bus. All other control and data lines are defined in the following text. - RD The Receive Data. All serial data from the CRT/TTY arrives via the RD communication line. - XD Transmit Data. After the 8-bit, parallel, data has been received, from the CPU, it is serialized and transmitted, via the XD line, to the TTY/CRT. - TEST The TEST line is the standard line, monitored by the processor, to indicate the results of an I/O Test instruction. - TTYI Teletype Interrupt. If a console TTY interrupt is generated, indicating that the CRT/TTY is not busy, TTYI forces the TEST line true (low) in response to an I/O Test instruction to Device X'3F', if issued. - · TYR Console TTY Framing error. Refer to Section 2.2.5, Systems Console Interface. #### 2.2.9 I/O 3E/3F DECODE AND CONTROL The I/O 3E/3F Decode and Control network examines I/O instruction issued by the CPU to determine if that instruction is addressing the internal interrupt mask (I/O to X'3E') or the serial I/O controller (I/O to X'3F'). The signals FAP, DTP, WRIT, READ and control (CTRL) are the standard I/O interface timing and synchronization signals. If more information is required on these signals, refer to the GA=16/110/220 System Reference Manual, Section 6, Input/Output Operations. All other signals concerning the I/O 3E/3F Decode and Control network are as follows: - RTCKE Real-Time Clock Enable. An I/O control (CTRL) command to device X'3E' with bit 3 of Out-Bus true (low) causes the Real-Time Clock Interrupt (RTCKI) to be enabled via the RTCKE line. - TYIEN TTY Interrupt Enable. An I/O control (CTRL) instruction to device X'3E' with bit 5 of Out-Bus true (low) enables the TTY/CRT to interrupt when not busy. This enable is propagated via the TYIEN line. - CIEN Console Interrupt Enable. In order for the console interrupt to be effective a control instruction (CTRL) must be issued to device X'3E' with Out-Bus bit 7 true (low). This drives CIEN true (low) and sets the console TTY (CRT) interrupt mask flip-flop. - 64KM 64K Memory Mode. This line is driven true as a result of the 32K-Prog Switch (S1) being placed in PROG position and a program command setting 64K mode. 64K mode is then forced when the processor is executing an RTIV instruction or any interrupt. The I/O 3E/3F network also generates certain control signals to the Serial I/O Controller. These signals indicate that the information passing through the controller is: control data (CTR3F) to be maintained within the UART; data to be input to the CPU (READ); or data to be output to the TTY/CRT (WRIT). ## 2.2.10 TIMING NETWORK The CPU-2 timing network derives two timing signals 20 MHz+l and 20 MHz-, from the CPU-1 basic 20 MHz crystal oscillator. These two timing signals produce all timing necessary for the operation of the CPU-2 module. ## 2.2.11 PHYSICAL CONFIGURATION In order to aid in component placement, Figures 2-7 and 2-8 are supplied with corresponding Tables 2-3 and 2-4. If additional information is required concerning these items, refer to the GA-16/110/220 Systems Reference Manual, Section 3, GA-16/220 Configuration and Operation. **CIRCLED NUMBERS REFER TO TABLE 2-5.** Figure 2-7. GA-16/220 System in Compact Chassis (No MPP) Table 2-3. Connector Assignments for Compact Chassis, GA-16/220 | | Front/Module (220) | | Rear/Interface (220) | | | |----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | J1<br>J2<br>J3<br>J4<br>J5<br>J6 | Main power supply Cable interface driver (CID) I/O controllers or shorting boards. Shorting boards are used in empty slots between controllers or CID to maintain interrupt chain continuity. | J13 J14 J15 | AC input connector and system grounding terminals on power supply. Connector for optional external power supply cable. Cable to I/O expansion chassis (6-feet maximum). Paddleboards and cables interfacing | | | | J8 | MHSDC controller, if used, should<br>go into J7.<br>CPU-2 module with optional | J16<br>J17<br>J18 | controllers (in J3 through J7) to peripheral devices. | | | | J9 | System Console Interface. CPU-1 module with optional piggyback memory. | J19<br>J20 | Serial I/O paddleboard with connector to TTY or CRT also | | | | J10<br>J11 | Memory modules or Memory Parity Protect module. | | provides access to cold-start (CLDS-) jumpers and remote control lines (IPLSW-, PFD-, | | | | J12 | J12 also used for battery backup regulator board | J21 | RSET-, RUN-). Memory Service Module, if auxiliary | | | | - | Backup power supply battery pack (use regulator board in J12). | -<br>- | power supply is not used. AC cord for backup power supply. Terminals for external 12-volt battery on rear of battery pack. | | | Figure 2-8. GA-16/220 System in Jumbo Chassis (With MPP) Table 2-4. Connector Assignments for Jumbo Chassis GA-16/220 | Front/Module (220) | Rear/Interface (220) | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J1 J2 J3 J4 J5 J6 J7 J8 J8 J9 J10 Cable interface driver (CID). I/O controllers or shorting boards. Shorting boards are used in empty slots between controllers or CID to maintain interrupt chain continuity. MHSDC controller, if used, should go to J9. CPU-2 module with optional System Console Interface. CPU-1 module with optional piggyback memory. Memory modules or memory parity protect module. J13 J14 J15 J16 J17 Backup power supply battery pack (use regulator board in J18). | J18 Cable to I/O expansion chassis (6-feet maximum). Paddleboards and cables interfacing I/O controller (in J1 through J9) to peripheral devices. Serial I/O paddleboard with connector for TTY or CRT. Also provides access to cold-start (CLDS-) jumper, and remote control lines (IPLSW-, PFD-, RSET-, RUN-). Memory Service Module, if auxiliary power supply is not used. Power cable from external power supply. J31 Power cable from external power supply. System grounding terminals. AC cord for backup power supply. Terminals for external 12-volt battery on rear of battery pack. | Table 2-5. GA-16/110/220 Controls and Indicators (Sheet 1 of 6) | Key | Label | Description and Function | | | | |--------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (PS) | ON<br>OFF | The main power switch causes power to be applied to CPU and I/O controllers. Power is also applied to memory modules if memory service module is installed. | | | | | (PS) | FUSE | The fuse holder allows replacement of main power supply fuse. | | | | | (220) | 32K-<br>PGM | The 2-position switch selects memory addressing mode. When in the 32K position program addressing limit is 32K words. When in the PROGRAM position either 32K or 64K mode is selected by a program which sets the memory mode mask word and executes RTNIV (see Section 4.15.2.4 System Reference Manual). | | | | | (220) | CNSL<br>INT | Console Interrupt pushbutton, when pressed, causes a program interrupt through vector X'47' if (1) the console interrupt bit in the internal mask word is set (Section 4.15.2.1 Systems Reference Manual), and, (2) the interrupt system is enabled (refer to description of instructions INE and RISE in Section 4.13.2 and 4.10.9 Systems Reference Manual). | | | | | (220) | 15 8 | These miniature binary switches are called the console switches. | | | | | (220) | 7 0 | The console switches may be read by an RCSM or RCSR instruction in a program (Section 4.15.1 Systems Reference Manual). This capability permits writing programs which allow data entry and control via these switches. When a switch is in the position labeled OPEN, the bit is set to a 0. | | | | | (220) | DMA ACK | This indicator may blink periodically when direct memory access is occurring. It may illuminate continuously if very high DMA activity is in progress or if there is a malfunction. In a GA-16/220 system DMA activity is normally controlled by the multiple high-speed data channel (MHSDC) controller. | | | | | (220) | TTY BAUD* | The 2-position switch changes the baud rate of the built-in serial I/O controller to accommodate either a teletype (Model 33 automatic send receive, ASR, or equivalent) at 110 baud or a CRT terminal at 110 or 9600 baud. | | | | | (220) | 9600* | This screw adjustment permits fine adjustment of the 9600 baud transmission rate. It is adjusted only when the BAUD switch is in the 9600 position. | | | | | (220) | 110* | This screw adjustment permits fine adjustment of the 110 baud transmission rate. It is adjusted only when the BAUD switch is in the 110 position. | | | | | *These | *These controls not present on CPU2 board 31D02574A; refer to Appendix G. | | | | | Table 2-5. GA-16/110/220 Controls and Indicators (Sheet 2 of 6) | Key | Label | Description and Function | |----------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (1)<br>(220-<br>SCI) | BKDS | The 2-position switch enables or disables the TTY break capability. When the switch is in the break-disable (BKDS) position, TTY breaks are ignored. When in the other position, TTY break is enabled so when a TTY operator presses the BREAK key on a teletype or CRT (provided unit is equipped with this key) either a processor (CPU) reset or an interrupt occurs depending on the setting of the BKINT switch (12). | | (220-<br>SCI) | BKINT | The 2-position switch sets the break mode for TTY or CRT, provided BKDS switch II is set so that break mode is enabled. When BKINT switch is set to break-interrupt position (BKINT) a TTY break causes a non-inhibitable interrupt via vector location X'46' (provided CPU is not operating under the SCI Console ROM program or the IPL ROM). Registers and status are saved in locations in the SCI program RAM. When the switch is not in the BKINT position, a TTY break initiates a break reset which causes control to be transferred to the Console ROM and registers and status are not saved. I/O controllers are not reset. | | (220-<br>SCI) | IPL | Pushbutton initiates initial program load (IPL). When pressed, control is passed to the IPL ROM installed on the SCI module, and program loading occurs from a peripheral device. Selection of the peripheral device is accomplished by setting the IPL SEL selector switch 14 to the appropriate position for the IPL device installed with the system. This function may be remotely controlled via IPLSW line, or at auto-restart with cold start line at ground. | | (220-<br>SCI) | IPL SEL | The IPL selector switch is a 16-position rotary switch. The switch is used to preselect which I/O device will be the source of an IPL when the IPL switch (13) is pressed. (In systems illustrated in Figure 2-7 and 2-8, the device would be floppy disk or teletype.) Load-and-go operation is selectable for all devices, while load-and-stop operation may be selected for teletype, high-speed paper tape reader, or card reader. The switch positions and device selections are shown in Table 3-4. | | (220-<br>SCI) | CNSL | The 2-position switch determines both the function of the CPU reset button (16) and an auto-restart operation when power is applied. When in the console position (CNSL) the CPU and I/O are reset and control is transferred to the Console ROM. If in the other position, the status of the cold start line, CLDS, determines the operations as described for RESET pushbutton on the CPU-l module (16). | Table 2-5. GA-16/110/220 Controls and Indicators (Sheet 3 of 6) | Key | Label | Description and Function | |-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (110) | RESET | Pushbutton resets the CPU and the I/O system, and causes control to be transferred in accordance with the cold start line (CLDS-) and (on a GA-16/220) the CNSL switch 15. On a GA-16/110, the cold start line determines the function of the RESET switch as follows: cold start high: Control is transferred via auto-restart vector X'41'. cold start low: Control is transferred to the IPL ROM. On a GA-16/220, the cold start line determines these functions only if the CNSL switch 15 is not in the CNSL position. In the CNSL position, control is transferred to the console ROM on the SCI. This function may be remotely controlled via the RESET and SYRT lines, together. | | (110) | IACK | Interrupt acknowledge indicator blinks when control has passed to a routine via an interrupt vector. It normally blinks so rapidly as to be barely visible. If continuously illuminated, it indicates that the control has not returned from the interrupt processing routine, a "hung-up" condition. | | (110) | ISE | Interrupt system enabled indicator is illuminated when the ISE flip-flop is set, and means that the inhibitable interrupt system is enabled. Refer to description of instructions INE and RISE (Section 4 Systems Reference Manual). | | (110) | OMA | This indicator (also referred to as the OMA stall indicator) is illuminated when the operators monitor alarm (OMA) has timed out. The OMA must have been initially turned on by a PMA instruction (Section 4.13.7 Systems Reference Manual). When the OMA indicator illuminates, the RUN indicator (1) is extinguished and the CPU is in an idle state. To recover from an OMA, the operator must press the RESET button (16). | | (110) | FGND | Foreground indicator is illuminated when the foreground registers are used and extinguished when background registers are used. Refer to instructions BMS and FMS (Sections 4.13.1 and 4.13.2 Systems Reference Manual) for setting foreground or background register usage. | | (110) | RUN | The RUN indicator is illuminated when the CPU is in the run mode. If the WAIT indicator (22) is also illuminated, the CPU is in a wait condition as a result of executing a WAIT instruction. If MPP indicators (21) through (30) are illuminated, memory parity error has caused the stall. In order for an MPP stall to occur, the STALL switch (31) must be in the stall position. To recover, the user must RESET the system. If the run indicator is extinguished, the system is in idle. | | | Table 2 | -5. GA-16/110/220 Controls and Indicators (Sheet 4 of 6) | |-------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Key | Label | Description and Function | | (110) | RUN<br>(Cont) | NOTE: If 18-bit memories are installed without installation of MPP module, a stall condition may occur if the parity override switch (16) is not set. Refer to Section 3.2.7.1, Systems Reference Manual, and description of (16), and (18) in this table. | | | | A remote idle indicator may be implemented via the RUN line, and conversely grounding the RUN line will force the CPU into the idle condition. | | (110) | WAIT | Wait indicator illuminates when a WAIT instruction has been executed (Section 4.13.10 Systems Reference Manual). | | (110) | - | Unlabeled 2-position battery backup switch faces to the rear of CPU-1 module, and must be set prior to installation. In the backup position (down), +5VB power for the memories (including the piggyback RAM) originates in the backup power supply or from batteries (when AC power is disconnected). When the switch is not in backup position, the power is obtained from the main power supply. A memory service module must also be installed in the rear connector (as shown in Figures 2-2, 2-3, 2-5, 2-6) to obtain power from the main power supply for the 8K/4K RAM memories when the backup power supply is not used. | | (MPP) | DPT | The DMA write protect indicator, when illuminated, indicates that an attempt has been made by DMA to write into a memory area (via the high-speed data channel) which has been DMA-protected (refer to Section 5 Systems Reference Manual). | | (MPP) | МЕ | Multiple error indicator illuminates when a second error occurs before software can process a previous error. Other indicators also may be illuminated. | | (MPP) | PPT | Program write protector indicator, illuminates when a program has attempted to write data in a memory area which has been program-protected (refer to Section 5 Systems Reference Manual). | | (MPP) | LPB | Lower parity bit indicator shows the contents of parity bit for<br>the lower byte of a memory word (illuminated = 1). Content of<br>bit must be compared with the lower byte to determine if an<br>error has occurred; even parity is an error. | | 28<br>(MPP) | UPB | Upper parity bit indicator shows contents of the parity bit for the upper byte of a memory word (illuminated = 1). Content of the bit must be compared with the upper byte to determine if an error has occurred; even parity is an error. | Table 2-5. GA-16/110/220 Controls and Indicators (Sheet 5 of 6) | Key | Label | December 1 7 | |---------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Label | Description and Function | | (MPP) | DPY | DMA parity indicator illuminates when a parity error is detected during a DMA transfer. | | (MPP) | PPY | Program parity indicator illuminates when a parity error is detected when a program reads a memory location (data or instruction fetch). | | | | NOTE: Indicators (1) through (1) remain illuminated until MPP status is reset under software control. Refer to Section 5, Systems Reference Manual. | | (MPP) | STALL | The 2-position switch faces to the rear of the MPP module and is preset prior to installation. This switch determines CPU action when a DMA or CPU parity error occurs. When the switch is in STALL position, the memory bus is forced to a busy state, thereby halting the CPU. When not in the STALL position, control is passed to a routine via non-inhibitable interrupt vector X'42'. (All non-parity errors pass control via X'42' regardless of the setting of STALL switch, and a routine must determine type of error.) | | 32)<br>33)<br>(MEM) | 15<br>14<br>13 | Three 2-position switches used on both 8K and 4K memory modules to set the memory to occupy locations starting at one of eight 8K boundaries. Refer to Section 3.2.7 Systems Reference Manual for memory map and corresponding switch settings. | | (MEM) | 12 | The 2-position switch installed only on 4K memories. It selects the upper and lower 4K boundary within the 8K boundary set by switches 12, 13, and 14. Refer to Section 3.2.7, Systems Reference Manual, for memory map and corresponding switch settings. | | JS (MEM) | PAR<br>OVRD | The 2-position switch is installed only on 18-bit memories. This switch is effective only if MPP module is not installed and enables parity override which disables parity error detection when in DOWN position. When in UP position, parity error detection occurs. Action upon a parity error depends on whether or not an MPP module is installed: - When MPP module is not installed and switch is in the UP position, a parity error will cause a CPU wait condition on data fetches or repeated attempt to execute instruction fetches, and the DERR and IERR indicators will identify the error. - When an MPP module is installed, switch may be in either position and parity errors will be identified by the LPB, UPB, DPY, and PPY indicators (1) through (3) on the MPP module. Detection is enabled by PIO to the MPP module (Section 5 Systems Reference Manual). Action taken upon parity error detection then is determined by the setting of the stall switch (3) on the MPP module. | Table 2-5. GA-16/110/220 Controls and Indicators (Sheet 6 of 6) | | lable 2-3 | GA-10/110/220 Controls and indicators (Sheet 6 of 6) | |-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Key | Label | Description and Function | | (MEM) | DERR | The data error indicator illuminates (in 18-bit memories) when a parity error occurs on a data fetch. The data comes out as '0000'. This condition is cleared by a system reset or by a break reset (see description of 16 and 12).) | | 38) | IERR | This instruction error indicator (in 18-bit memories) illuminates when a parity error occurs on an instruction fetch. The instructions comes out as '0000' (WAIT). This condition is cleared by a system reset or by a break reset. | | | | NOTE: If the Memory Parity Protect (MPP) option is included in a system, neither the IERR nor DERR indicators will illuminate unless there is a high failure rate. The MPP is managing the memory under program control. | | (BAT) | - | Unlabeled indicator illuminates when power (either from AC line or from batteries) is applied to the memory modules. Light is extinguished when manual cut-off button (38) is pressed (or if batteries are exhausted) provided AC power is disconnected from the auxiliary power supply. | | (BAT) | <u>.</u> | Unlabeled pushbutton provides manual cut-off of battery power to memory modules. Pressing this button will have no effect unless AC power is disconnected from auxiliary power supply. If AC power is disconnected, pressing this button will cut off power to memories. Power will not be restored to memories until AC power is reconnected. NOTE: Application of power to auxiliary power supply is | | | | independent of built-in main power supply switch(), or other means of controlling power to external main power supply. | | (BAT) | BAT CHG<br>ADJ | This control is used to adjust the charge voltage to the battery pack to maintain a 0.5 ampere rate (maximum). Setting for 12-volt 1.5 ampere battery supplied is 13.6 volts. | | (BAT) | 5VB | This control is used to adjust the +5-volt regulator. | | (BAT) | VDD | This control is used to adjust the +12-volt regulator. | | ٠ | | | | | | | ## 2.3 SYSTEM INTERFACE Figure 2-9 depicts the general system interface signal configuration, including those signals used in I/O operations. For further I/O interfacing information, reference the GA-16/110/220 System Reference Manual, document number 88A00508A, Section 6. # 2.4 POWER SUPPLIES ## 2.4.1 COMPACT POWER SUPPLY The plug-in (compact) power supply is a switching, regulator-type providing up to 18 amps of +5VDC. The jumbo power supply provides up to 30 amps. The compact power supply operates on $115\pm10\%$ VAC. The jumbo power supply contains standard transformer taps for nominal voltages of 100, 115, 200, and 230 VAC sources $\pm$ 10%. ## 2.4.2 BACKUP POWER SUPPLY The backup power supply performs the dual functions of providing $\pm 12 \text{VDC}$ and $\pm 5 \text{VDC}$ to the memory during normal operation, and during AC input power interruption, to maintain memory contents. The backup power supply consists of two parts: - · Battery pack. - Regulator board. # 2.4.2.1 Backup Power Supply Installation - 1. Mount the battery pack on the left inside wall of the chassis. The mounting screws are the two Phillips on the side of the battery pack. They are threaded into the sidewall of the battery pack and support nothing inside the pack. The AC cable is at the top rear of the battery pack. - 2. Slide the regulator board part-way in the guides for the left-most card slot (viewed from front). Then connect the DC cable from the battery pack to the 3-prong connector on the lower area of the regulator board (with the AC cord disconnected). Figure 2-9. GA-16/110/220 Interface #### CAUTION The three pins in the connector are keyed to prevent reversed connection. However, it is possible to offset and misalign the pins and make an improper connection. 509-2-6 # 2.4.3 MEMORY SERVICE MODULE If the backup power supply is not installed in the system, the Memory Service Module (MSM) (90C02301A), must be plugged into J21 on the back of the compact chassis. The MSM (when installed) provides $\pm 12$ VDC and $\pm 5$ VDC to the memory modules. When the MSM is installed, S2 (90C02422A Sheet 7) must be closed (UP position) to supply $\pm 5$ VB to the memories (from the system $\pm 5$ V line). # 2.4.4 EXTERNAL POWER SUPPLY An external power supply, such as that used to power a standard GA-1615 I/O cage, may also be used to power the GA-16/220. This external power supply is connected to the processor cabinet via connector J-30, for a Jumbo Chassis, or via connector J-13, for a Compact Chassis. An external power supply may also be user-supplied via these same connectors. # theory of operation 3 To understand the inner workings of the GA-16/110 or GA-16/220 processor, it is necessary to fully comprehend the operation of the CPU microcode. Section 3 is intended to provide the understanding needed in this area as well as to explain the effects of this microcoding on the processor logic. # 3.1 <u>GA-16/110/220 MICROCODE</u> The GA-16/110/220 system is a microprocessor-based device relying upon the execution of a series of microcode instructions to implement each CPU instruction. These microinstructions are 34 bits in length and reside in the CROM. Each of the available microinstructions follows the format shown in Figure 3-1. For a complete list of the GA-16/110/220 microinstruction set, refer to Appendix B. | G | Br | NADDR | R/C | B-CNTL | FUNCT | Rs | Rd | |--------|--------|--------|--------|-----------------------|---------------------|--------------------|--------------------| | | | | | I I I I I I P P P P P | | | | | 3 Bits | 5 Bits | 8 Bits | D<br>H | DDDDD | D D D D.<br>B A 9 8 | D D D D<br>7 6 5 4 | D D D D<br>3 2 1 0 | Figure 3-1. 34-Bit Microinstruction The G-field controls the gating of the foreground status bit, as well as the decode of the interpretation of the destination/source register identifier bits, when included as part of the program instruction in the I register. The Branch field, (Br field) aids in the selection of the next microinstruction from the CROM. This is accomplished by ORing the Br field with the Next Address Field (NADDR field). The Read/Control bit (R/C bit) selects the data for the destination register. If this bit is a logic "1", source data is loaded into the destination register. If this bit is a logic "0", no data is loaded into the destination register. The bus-control field, (B-CNTL field) controls the gating of signals to the ZPOL indicators as well as all data flow within the processor. The function, register source, and register destination fields, (Funct, Rs, Rd fields) combine to specify all register gating internal to the CROM and the RALU as well as the source and destination registers when not specified in the program instruction. ## 3.1.1 G FIELD 111 The G field specifies the foreground (FGLP) status bit gating and determines the source and destination registers (when applicable) by decoding the contents of the I register. (Refer to Table 3-1, G-Field Decode.) | Code | | Function | |------|---------------|----------------------------| | 000 | No-op | | | 001 | F→IPD3 | | | 010 | F→IPD7 | | | 011 | F→IPD7 & IPD3 | | | 100 | | I7, I6, I5 →Rs designator | | 101 | F→IPD3 | I7, I6, I5 →Rd designator | | 110 | F→IPD7 | IlO, I9, I8→ Rd designator | | | 1 | | F→IPD3 & IPD7 Table 3-1. G-Field Decode A G-field equal to X'0' is treated by the hardware as a NO-OP. A G-code of any value other than X'0' or X'4' gates an indication of the status (on/off) of the foreground (FGLP) bit into the most-significant bit position of the specified Rs and/or Rd field, IPD3 or IPD7. I10, I9, I8 $\rightarrow$ Rs designator I7, I6, I5 $\rightarrow$ Rd designator When a G-field of X'4', X'5', X'6' or X'7' exists, gating is enabled to decode Rs and/or Rd directly from the program instruction in the I register bits I7, I6, I5 and/or bits I10, I9, I8. This allows for program selection of source and destination registers. # 3.1.2 NEXT ADDRESS AND BRANCH FIELDS (NADDR and Br) The 8-bit NADDR field is used in conjunction with the 5-bit Br field to generate a 9-bit microinstruction address (Next CROM address). This is accomplished as follows: NADDR Bits 7 6 5 4 3 2 1 0 \* Br Code Bits \* \* \* $$E_{B_{T}}^{D_{B_{T}}} E_{T_{T}}^{D_{T}} E_{T_{T}}^{D_{T}} E_{T_{T}}^{D_{T}} E_{T_{T}}^{D_{T}} = 0$$ OR'ed (NOTE: XBT bits are shown in Table 3-2) Next CROM Address Formula The Branch code is a hex number between '00' and 'lf'. The Br code selects a certain combination of bits to generate the ABT through EBT values. In Figure 3-2, all numbers represent that bit position value in the I register. For example: a Br value of X'02' indicates that a memory reference or I/O operation instruction (MR,IPL) is being executed in the register. With this Br code, EBT and DBT both equal zero, CBT will be the result of ANDING I register bit 13 with the complement of $I_{12}$ ( $\overline{12} \cdot 13$ ), BBT will be the value of $I_{11}$ and ABT is the result of OR'ing $I_{10}$ with the compliment of I register bit 13. These resultant values are then plugged into the formula for determining the CROM address bits and are OR'ed with the value in NADDR. If the microinstruction currently being executed is a Classify Branch (CLSFY, X'lB'), indicating that a new program instruction has just been fetched from memory, a special decode is necessary. A Classify Branch operation is entered each time a new instruction is placed into the I register in order to interpret that (user) instruction and determine the first CROM address in the microroutine unique to this new program instruction. In this CLSFY operation, EBT and DBT are both zeroes, CBT is identified as SC, BBT as SB and ABT as SA. These three special interpretations (SA, SB and SC) are shown at the bottom of Table 3-2, and in Table 3-3. A Br of X'00' simply forces ABT to a zero (as well as all other branch code bits) and a Br code of X'16' is unused. Mnemonics such as RUN or TOT are the sampling of that conditions status. TOT for example, would set ABT (in Br code 'lE') to a logic 'l' of the I/O test line from the peripheral controller being addressed is false. Table 3-3 is a list of these special branch combinations and include $W_1$ through $W_4$ which are used later in the text to indicate conditions of sign extension (spread) or truncation of the W register during address modification operations. Table 3-2. Branch Codes All numbers refer to "I" register bit positions | Br | EBT | DBT | CBT | BBT | ABT | Function | |-----|-----|-----|-------------------|--------------------------------------------|--------------------------------------------------------------------------------------|------------------------| | 00 | | | | | | LSB=0 | | 01 | | 1 | | 9 | 10 | SKP | | 02 | | | 12.13 | 11 | 10V13 | MR, IOL | | 03 | | 1 | | 11 | 10V9·3 | MRWI, MRWIB | | 04 | | | 3V1 | 4V3V2 | 400 | RCS,RCD,RCO | | 05 | | İ | 14 | 9 | 8 | SPO,SP1,IDX | | 06 | | | | 11 | zo | SKPB | | 07 | | | | 11 | | SKPB | | 80 | | | | 7 | P <sub>L</sub> | IOLA | | 09 | | | | | 6 | IOLA | | 0A | | | | 11 6V7 | 6 | IOL | | OB | | | | <b>7</b> V6V4 | 6V5V4 | WMD | | OC | | 4 | 3 | 2₩1 | 0 | RO, ROL | | OD | | 4 | 8 | REA** | LK | SEX,SFCM,SFCD | | 0E | | | | 11 | OF | SKPA | | OF | | | | 11 | LK | SKPB, SFBM, SFBD, SBA, | | 10 | | | | | * | SCS,RCD,RLK | | 11 | | | | | INTMP*** | LSB=1 | | 12 | | | 14 · 13 V 13 · 12 | 15.14 | 12 • (14V6) | BVE BVO | | 13 | | | | 13 14 | 12 (1470) | BYE,BYO<br>LSI+2 | | 14 | | | | 10 | 13V12 • 10 | | | 15 | | | 14 13 | <u>īö</u><br>Īö | 14V13 • 7V12 | LSI | | 16 | | | | 10 | 1471357712 | MRWIE | | 17 | | | | | DO | UNUSED | | 18 | | | | | RUN | RBOP | | 19 | | | svi | RUN | INT | | | 1A | | | | 1.011 | ENA+ | CTDV | | 1B | | | SC++ | SB++ | SA†† | STBY | | 1C | SWD | SWC | SWB | SWA | ENTR | CLSFY | | 1 D | | | 7 · (6V5V3 · 2) | $7 \cdot (6 \times 5[3 \times 1 \cdot 0])$ | $\frac{7}{7} \underbrace{(6\sqrt{5} \cdot 4\sqrt{5} \cdot \overline{3} \cdot 1)}_{}$ | REG DISPLAY | | 1E | j | | . (3.3.3 2) | , (010[011,0]) | IOT+++ | CTRL | | 1F | | 1 | | | | INCP | | ' | • | • | 1 | | STEP | WAIT, WAITA | For Br of '10' - ABT will = A logic '1' REA - W register (R) equals the A-Bus (Bits $0\rightarrow3$ ). This indicates a shift complete. \*\* INTMP - Interrupt Mode Prime. NI Interrupt. \*\*\* ENA - Enabled at A. Signal, internal to the CROM, used with multiple CROM's to indicate that at the last A clock the CROM was selected. $SA = 15V14V13 \cdot 12VSPC \cdot \overline{11} \cdot 10$ $SB = 15\sqrt{14} \cdot 13VSPC \cdot 11$ $SC = SPC V S1 \cdot (15V14 \cdot 13 \cdot 12)$ SPC = $\overline{15 \cdot 14 \cdot 13 \cdot 12} \cdot ("I" \text{ Reg} = 0XXX \text{ Instruction})$ S1 = $4 \cdot 3 \cdot 2 \cdot 1 \cdot 6 \cdot ("I" \text{ Reg} - MRWI \text{ Instruction XXIF})$ <sup>+++</sup> IOT = I/O Test signal from peripherals. Terms from RALU = ZO, PL, OF, LK REA, DO External Inputs: INTMP, RUN, SVI, INT, ENTR, SWA, SWB, SWC, SWD, IOT, STEP Table 3-3. Special Branch Logic Combinations ``` Dx - Bit 'X' output from 'D' Latch (0 or F) SA - 15V14V(13·12)V(SPC·11·10) SB - 15V(14·13)V(SPC·11) SC - SPC V (SA·SB·S1) SPC - 15·14·13·12 S1 - 4·3·2·1·0 SE - SWI V SWP V SW1 - SWA SF - SWI V SWW V SW2 - SWB SH - SE V SV V SWS - SWD SG - SW4 - SWC ``` SWX - Console Register Select Switches on SPC-16 ``` Spread ( <> ) and Truncate (11) Functions ``` ``` MR W1 - <W>9 - Extend Sign (Bit 9) W2 - |W|9 - Truncate (0 +Bit 15 +10) MRWI W3 - |W|4 - Truncate (0 +Bit 15+5) SKIP W4 - <W>8 - Extend Sign (Bit 8) ``` ### 3.1.3 READ/CONTROL FIELD (IPDH) The R/C field is a "write-into-register" control bit. If this bit is set to a logic "1" (true), the selected destination register (Rd) will be enabled to receive the output of the adder. If R/C is a logic zero (false) the Rd will be disabled. This bit is available for monitoring as the IPDH+ output of the CROM chip Z4E pin 27. ### 3.1.4 BUS-CONTROL FIELD (IPDG - IPDC) The B-CNTL field will either enable or disable the ZPOL outputs of the adder to be written into the status register (S) or will generate the signals necessary to effect the gating shown in Table 3-4. In the most significant bit of the B-CNTL field is a zero (IPDG=0), the outputs of the ZPOL status from the adder will set the corresponding bits in the status register (S) providing its bit in the B-CNTL field is set. | CROM Output term | $^{\mathtt{I}}_{\mathtt{P}}_{\mathtt{D}_{G}}$ | I <sub>PDF</sub> | I<br>PDE | I <sub>PDD</sub> | I <sub>PDC</sub> | |------------------|-----------------------------------------------|------------------|----------|------------------|------------------| | B-CNTL | 0 | X | X | X | X | | Enable/Disable | ENABLE | z <sub>0</sub> | PL | o <sub>F</sub> | L | (X = 1 to enable input to S from adder) For example, if it is desired to allow the Plus $(P_L)$ status to be gated to S, then IPDG must be a zero and IPDE must be a 'l' (B-CNTL = X'04). If IPDE were a zero, the plus indicator input to S would be disabled. If IPDG were set to a '1', then the B-CNTL field definition would be from Table 3-4. A B-CNTL of X'13' (I/O Data $\rightarrow$ RALU) would enable the proper logic terms to gate incoming I/O data into designated general-purpose register in the RALU. | Code | Function | Hex Code | |-------|-------------------------------|----------| | 10000 | MD → RALU (READ) | 10 | | 10001 | CONSOLE SW → I (CROM) | 11 | | 10010 | IVA → RALU | 12 | | 10011 | I/O DATA → RALU | 13 | | 10100 | MD → RALU (READ/MODIFY/WRITE) | 14 | | 10101 | CONSOLE SW → RALU | 15 | | 10110 | SPEC + RALU* | 16 | | 10111 | I → RALU | 17 | | | | | | 11000 | RALU - MA | 18 | | 11001 | RALU → I | 19 | | 11010 | RALU → I/O ADD. | 1A | | 11011 | RALU → I/O DATA | 1 B | | 11100 | RALU + MD | 1C | | 11101 | RALU → CNSL | 1 D | | 11110 | RALU → SYNC** | 1E | | 11111 | I - CNSL*** | 1F | Table 3-4. Bus Control # 3.1.5 FUNCTION Rs AND Rd (IPDB THROUGH IPDO) The Func, Rs and Rd fields combine to place the microinstruction into 1 of 16 general instruction groups. These instruction groups may be as simple as a register-to-register transfer operation, where data is taken from the source register and placed into the destination register, or as complex as a byte-oriented instruction where half-words of data are mixed with the contents of a register and the results placed into a specific register. The classification of a microinstruction begins with a general combination of the function field itself. The first examination will catagorize the instruction group into which the microinstruction falls. Table 3-5 lists these classifications by functions codes. <sup>\*</sup> SPEC → RALU = IPL in NI mode. IPL address to 'P' and automatic start of a Memory Cycle. <sup>\*\*</sup> Used with H.S. MPY DIV or F.P. for SPC-16 compatability. <sup>\*\*\*</sup> Requires an operators console (not available from GA at this time). | Mnemonic | Funct | Rs | Rd | Function | |----------|-------|------|----------|----------------------------------------------------| | RTR | 0 | Rs | Rd | Rs → Rd | | ADD | 1 | 1 1 | 1 | Rd + Rs → Rd | | SUB | 2 | | | Rd - Rs → Rd | | AND | 3 | | | Rd • Rs → Rd | | XOR | 4 | ♦ | | Rd ¥ Rs → Rd | | OR | 5 | Rs | | Rd V Rs → Rd | | SHG | 6 | MOD | | Shift group | | BYMR | 7 | MOD | | Byte operation | | ADWHR | 8 | WMOD | | $Rd/2+ W \rightarrow W$ | | ADWRW | 9 | WMOD | | $Rd + \{W \mid \rightarrow W$ | | ADWRP | A | WMOD | <b>]</b> | $Rd + W \rightarrow P$ | | MSC | В | MOD | Rd | Miscellaneous group | | LLW | С | | a. | $W_{U}, \alpha \rightarrow W$ | | LUW | D | | α. | $\alpha_{\bullet}^{\cup}W_{\bullet} \rightarrow W$ | | SRL | E | MOD | RMOD | Operations with P,W,S | | LGL | F | LIT | MOD | Logical Operations (Literal) | Table 3-5. Function Field General Classification NOTE: OOX = No Op. where: $X \neq 0$ to prevent both busses from loading the same register. If a microinstruction belongs to one of the first six groups (RTR, ADD, SUB, AND, XOR, OR), one of the "W" register instructions (ADWHR, ADWRW or ADWPP) or either of the microcode byte operations (LLW, LUW), no further classification is necessary. If the FUNCT field decodes as any of the remaining functions (SHG, BYMR, MSC, SRL or LGL), the Rs and/or Rd field must be examined as a modifier to determine the actual operation to be performed. ## 3.1.5 1 Stand-Alone Function Fields (No Modification) If a FUNCT/Rs/Rd field were to equal X'104', it will fall into the ADD (Rd+Rs $\rightarrow$ Rd) group of instructions. In this group, Rd (in this case "B") will be added to the Rs (in this case "A") with the results placed into the Rd (register "B"). However, if the FUNCT/Rs/Rd field were to equal X'BXX' placing the microinstruction in the miscellaneous (MSC) group, a further examination of the Rs field must be made, as it is acting as a modifier and will determine the actual operation performed. Each of the groups necessitating further interpretation for a definition of the operation to be performed, will be examined. ### 3.1.5.2 Shift Group A function field of X'6' places the microinstruction into the Shift group (SHG) of instruction. In actuality only half of the codes within this group perform shift operations; the remainder of the operations are logical/arithmetic operations. Table 3-6 summarizes the 16 operations performed within this group. The operation performed is a function of the Rs field since it is acting as a modifier. | Mnemonic | Funct | Rs | Rd | Function | | | | |----------------------------------------------------------|-------|--------------------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | SHG<br>Arithmetic<br>Operations<br>with results<br>to Rd | 6 | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | Rd | W → Rd Rd + W → Rd Rd - W → Rd Rd • W → Rd Rd ¥ W → Rd Rd V W → Rd Rd + 1 → Rd Rd - 1 → Rd | Arithmetic<br>and Logical<br>Operations | | | | | | 8<br>9<br>A<br>B<br>C<br>D<br>E | | RDF, RDF-1, + Rd RDO, RDF-1, + Rd O, RDF-1, + Rd 1, RDF-1, + Rd 1, RDF-1, + Rd RDE-0, RDF, | Right shift extend bit 15 Right shift circular Right shift, zero bit 15 Right shift, set bit 15 Left shift circular Left shift, extend bit zero Left shift, zero bit zero Left shift, set bit zero | | | Table 3-6. Shift Group Operations The first eight operations are the result of an instruction, such as an AND instruction being executed in the I register. An AND instruction would generate a FUNCT/Rs/Rd field of X'63X' to effect ANDing of Rd with the value specified in the instructions (now in W register). The result is then gated into Rd (only if R/C = 1). Rd will equate to the decoding of the X' in X'63X'. An Rs modifier of '8' through 'B' specifies a right shift operation. A code of X'68X' ( $R_{\mathrm{DF}}$ , $R_{\mathrm{DF}-1}$ $\rightarrow$ Rd) is a right shift with bit 15 ( $R_{\mathrm{DF}}$ ) extended. This will place the designated register bits 15 through 1 ( $R_{\mathrm{DF}-1}$ ) into the destination registers bits 14 through 0 and bit 15 ( $R_{\mathrm{DF}}$ ) will be placed back into the destination register bit 15 position, giving the effect of extending bit 15. The same format that is used in the right shift operations is used in the left shift operations. Left shift operations are commanded by function codes in the range X'6CX' through X'6FX'. NOTE It must be remembered that, in order to affect the link indicator in '5', the B-CNTL field must equal OXX1. # 3.1.5.3 Byte Oriented Operations (BYMR) All byte oriented operations (Function code = X'7XX') manipulate data in memory on a byte or half-word basis. | _ | Mnemonic | Funct | Rs | Rd | Function | |---|----------|-------|------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | BYMR | 7 | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | Rd | RDU, WL → W RDU, WU → W RDL, WU → W RDL, WU → W RDU, WL → Rd RDU, WU → Rd O, RDL → Rd O, O → Rd WU, RDL → W WU, RDU → W WL, RDL → W WL, RDL → W WU, RDL → Rd RDU, O → Rd RDL, RDL → Rd | | | 1 | | F | 7 | RDL.RDU → Rd | Table 3-7. Byte Oriented Operations In these byte operations, 16 bits of data will be written into the specified destination register. These 16 bits, however, are manipulated as two equal, 8-bit, blocks of data. For example, if a function field of X'71X' is specified $(R_{DU},\ W_U \to W)$ , the most-significant 8 bits of the designated register $(R_{DU})$ will be written into the upper 8 bits of the W register. At the same time, the upper 8 bits of W $(W_U)$ will be gated back into W, but they will become the lower 8 bits of the new value in W. Graphically, this would be represented as: In those cases where a zero is given in the operation field of Table 3-7, that byte will be zeroed. 509-3-1 ### 3.1.5.4 Miscellaneous Group The MSC group is appropriately named since it consists of a collection of somewhat unrelated functions. (See Table 3-8. Miscellaneous Group Operations). Mnemonic Funct | Rs Rd Function MSC В 0 Rd $W \rightarrow W$ Miscellaneous 1 $R_d + W \rightarrow W$ R<sub>d</sub> - W + W R<sub>d</sub> ⋅ W + W R<sub>d</sub> ♥ W + W 2 3 4 5 $R_d \vee W \rightarrow W$ 6 $R_d^- \rightarrow W$ 7 W → W Interrupts (to save W & ISE) 8 $R_d \forall FFFF \rightarrow R_d (R_d \rightarrow R_d \text{ register compliment})$ $M \rightarrow R_d$ 9 $S \rightarrow R_{\tilde{d}}$ A $P \rightarrow R_d$ В С $R_d \rightarrow P$ D $R_d \rightarrow S$ RTN $S15 \rightarrow ISE (64K mode)$ Ε RTRN $R15 \rightarrow ISE (32K mode)$ F TRS Table 3-8. Miscellaneous Group Operations This group is used in a multitude of operations from register compliment instructions (X'B8X') to register display, to return from interrupt instructions. (Reference Appendix B Microcode Summary.) ## 3.1.5.5 SRL Group Most operations, involving the P, W, and S registers, fall into the SRL group. This being a large group of instructions, requires both the Rs and Rd field to act as modifiers of the FUNCT field (See Table 3-9). Table 3-9. SRL Group Operations | Mnemonic | Funct | Rs | Rd | Function | |---------------------------------|-------|--------------------------------------|----|----------------------------------------------------------------------------------------------------| | SRL<br>Operations<br>with P,W,S | E | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | 0 | S - W<br>W + S - W<br>W - S - W<br>W * S - W<br>W \ S - W<br>W \ V S - W<br>W + 1 - W<br>W - 1 - W | | | • | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | 1 | P → W W + P → W W - P → W W • P → W W ♥ P → W W ∨ P → W M → W (M → W & I) M → W | | | E | 01234567012345670123456701234567 | 2 | PPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPP | SRL codes having an even number, Rd with Rs codes of 6 and 7 (e.g., $X'E60'W+1\rightarrow W$ ), are used as increment/decrement functions. SRL codes with an odd number, Rd code and Rs codes of 6 and 7 (e.g., $X'E71M\rightarrow W$ ), are used in memory transfer instructions. ## 3.1.5.6 Logical/Literal Group (LGL) The LGL group of instructions perform logical and arithmetic operations between a specified bit in a literal value and the P, W, and S registers. (See Table 3-10.) | Mnemonic | Funct | Rs | Rd | Function | |------------------------------------------------|-------|-------------------------------------------|---------------------------------|------------------------------------------------------| | LGL<br>Logical<br>Operations<br>(with P, W, S) | F | L<br>Literal<br>Value<br>Bit<br>Positions | 0<br>1<br>2<br>3<br>4<br>5<br>6 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | l l | 1 | ! 7 | ! <b>ς ¥</b> I. → ς | A B C D Table 3-10. Logical/Literal Group Operations $X'FOD' = 0 \rightarrow SL \text{ (clears SL)}$ X'FlD' = Reset ISE X'F2D' = Set ISE X'F3D' = Wait X'F4D' = PMA A function code of X'FXO' through X'FXB' will perform an arithmetic or logical operation between a literal value bit position (specified by Rs) and the corresponding bit position of the assigned register (P,W, or S). For example, if the function code is X'F31', (W V L $\rightarrow$ W) bit position 3 (the value "L") of a literal value, specified by the instruction in I, is OR'ed with bit position 3 of the value in the W register. The result is stored in W. <sup>\*</sup> Originally used to clear "S" lower (Shift Counter) Current functions: A function code of XFXC (L $\rightarrow$ W) allows loading a specified bit value, from the literal, into the matching bit position in the W register. If the function code is X'FXD' then five possible choices of operation exist: clear $S_L$ (X'FOD'), reset ISE (X'F1D'), set ISE, (X'F2D', a wait command (X'F3D') or pulse monitor alarm (X'F4D'). The last two LGL operations either truncate W (X'FXE') or modify addressing during an MR jump operation (X'FXF'). ## 3.1.5.7 ADWxx Operations These three operations (ADWHR, ADWRW and ADWRP) are utilized in bit/byte operations and during address modification sequences by working with W. - ADWHR (Rd/2 + $|W| \rightarrow W$ ) adds one half of the value in a specified register to W and places the results into W. This operation is used during bit/byte operations for selection of upper or lower byte. - ADWRW (Rd + $|W| \rightarrow W$ ) adds a specified register to the value contained in W and places the result into W. This procedure is for address modification during indexed operations. - ADWRP (Rd + $|W| \rightarrow P$ ) adds a specified index register to the value in W and places the result into the P register. This code is utilized for address modification during indexed operations. #### 3.1.5.8 LxW Operations The last two function fields, LLW (X'Cxx') and LUW (X'DXX') allow loading of a byte of microcode (Rs and Rd fields) into either W lower or W upper, respectively. This may allow loading these bytes of microcode into any register by following this operation with a register-to-register (RTR) instruction. ### 3.2 MICROCODE OPERATIONS ON DTIR All instruction manipulation and operation, within the GA-16/110/220 is controlled by the microprocessor (CROM/RALU) chipset logic. Resident within the CROM is a complete microprogram unique to each CPU instruction available in the processor repertoire. Each time a new program instruction is fetched from the CPU memory, the microprocessor executes a Classify Branch microinstruction to examine the newly fetched CPU instruction. The Classify Branch microinstruction translates specific bits within the CROM instruction register (I) to determine the type of instruction that is to be executed. This determination will allow calculation of the next address (Branch Address) within the CROM microcode necessary to locate the correct microinstruction for the next step required in the proper execution of the CPU instruction in the I register. For example purposes, a DTIR B,X'21' instruction microprogram sequence will be explained in detail. This instruction (machine language code X'lCAl') is placed into the CROM I register in the following format: The purpose of this instruction is to gate data from peripheral device address X'21' into the CPU B register. The I register is internal to the CROM; the B register is internal to the RALU. The DTIR microinstruction sequence is: | CROM Address | Mnemonic | Hex Code | Next CROM Address | Operation | |--------------|------------------------------------------|-------------|-------------------|---------------| | x'028' | CLSFY IOL (+2) IOLA(+1) DTIR INCP+1 FTCH | 0 2869 A600 | X'036' | W → I/O Add | | x'036' | | 0 0064 0000 | X'032' | (No-op) | | x'032' | | 0 0A18 0000 | X'10F' | (No-op) | | x'10F' | | 3 4007 3B90 | X'003' | I/O Data → Rd | | x'003' | | 0 6443 8E62 | X'021' | P + 1 → P, MA | | x'021' | | 0 6C53 0E61 | X'028' | MD → W,I | For a complete microcode listing, reference Appendix B. ### 3.2.1 MICROINSTRUCTION AT X'028' The first microinstruction in the DTIR instruction sequence (located at CROM address X'028') is the Classify microinstruction. The classify microinstruction begins the interpretation of the newly-fetched CPU instruction (DTIR) that is now resident in the I register. The Classify microinstruction (X ' 0 2869 A600') decodes as: | | l G | Br | NADDR | R/C | B-CNTL | FUNCT | Rs | Rd | |--------|-----|--------|-----------|-----|--------|-------|------|------| | Binary | 000 | 0 1010 | 0001 1010 | 0 | 1 1010 | 0110 | 0000 | 0000 | | Hex | | OA | | 0 | 1A | - | | | | | | ı or | i IA | | 1 14 | . 0 | | , , | The G, Br, and NADDR fields remain internal to the CROM and these signals are not available to the CPU. The G field equal to zero is a No-Op and causes no action during this microinstruction. A Br field equal to X'OA' (IOL) translates bit positions EBT, DBT, and CBT as zeros. Bit position BBT will equal the result of ADDing I register bits 11 and 6, then ORing the result with I7 (III $\cdot$ IGV17). Bit position ABT will equate to $I_6$ . This result (00010) is OR'ed with the contents of the NADDR field to select the CROM address of the next microinstruction on the sequence. | NADDR | 0001 | 1010 | | |---------------|---------|-----------|----------| | Br Result | | 00010 | | | Next CROM ADD | 0 0 0 1 | 1 0 1 1 0 | = X'036' | The remaining fields of the classify microinstruction (R/C, B-CNTL, FUNCT, Rs and Rd) generate the IPDH+ through IPDO+ outputs form the CROM/RALU. (Refer to Figure 3-2, CROM/RALU Interface CROM Address X'028'.) The outputs on the IPDX-Bus represent the binary outputs of the lower 18 bits of microcode at CROM location X'028'. IPD0 through IPD3 are the Rd designators, IPD4 through IPD7 are the Rs designators, IPD8 through IPDB indicates the function code (X'6'), IPDC through IPDG (X'1A') specify the Bus Control and IPDH is the write control (R/C) bit ('0' = no write into destination register). IPDO through IPD7 are gated from the CROM internal microcoded ROM to a microinstruction I latch, internal to the RALU, where they select the destination and source register (when applicable) within the RALU register bank. Since the R/C-bit (IPD14), in this microinstruction, is a '0' no write into Rd will occur. IPD8 through IPD8 from the CROM microcoded ROM, along with IPD0 through IPD7 (Rs and Rd) specify the microcode function field. In this example microinstruction, the function field translates to $W \rightarrow Rd$ (X'600' in bits IPD0 through IPDB). However, since IPDH+ (R/C) is a '0', all data is inhibited from being written into any destination register. This portion of the microinstruction is, therefore, treated as a No-Op. The B-CNTL segment (IPDG through IPDC) decodes as X'lA' and represents RALU $\rightarrow$ I/O Add. This B-CNTL feature is used to output the processor instruction (the DTIR) to the M-Bus (MO through MF). This field also generates the necessary gating and clock terms to output the device address code of the peripheral device being selected. The device select code is gated to the Out-Bus lines. The gating terms generated by the B-CNTL decode are a result of translations performed by the flip-flop latch arrangement at Z7B and the decode of that output by the decoders at Z8B/Z8C (refer to Figure 3-3, B-CNTL Generation). 3-16 Figure 3-3. B-CNTL Generation CROM Address X'028' (90C02422 Sheet 6) During the execution of this first microinstruction, signals Address Load Enable (ADRL-) and CROM/RALU Drive Enable (CRDE+) gate the M-Bus outputs of the CROM I register to the TA-Bus lines (TAXX-). (Refer to Figure 3-4, M-Bus to TA-Bus Gating.) The TA-Bus contents, representing the actual program instruction, (DTIR, B X'21') X'1CA1', is then gated by the I/O busy signal (IOBSY-) to the Out-Bus at the end of the current microcycle. (See Figure 3-5, TA-Bus to Out-Bus Gating.) This output allows the selected peripheral device controller to be addressed when CPUl produces the FAP- to the controllers. The timing for the microcycle is shown in Figure 3-6, CLSFY Microcycle Timing, CROM Address X'02B'. ## 3.2.2 MICROINSTRUCTIONS AT X'036' AND X'032' The second and third microinstructions in the sequence (located at CROM address X'036' and X'032') are, in themselves, NO-OPS. These two microcycles are necessary for timing and allow generation of the signals required in gating data, from the peripheral device, to the controller and from the controller onto the IN-Bus. The timing and signal interchange, for the two NO-OP instructions, is shown in Figure 3-7. Timing: No-Op Microcycles. IOBSY- remains low throughout the two NO-Op microcycles to enable the data being gated from the addressed peripheral to propagate through the controller to the IN-Bus without danger of interference from another device attempting to use the I/O Bus. Signal FAP- goes true to allow the selected controller to lock onto the bus network. Signal READ- designates the direction of data transfer (into the CPU) thereby, identifying the program instruction as a DTIR. Figure 3-4. M-Bus to TA-Bus Gating (90C02422 Sheets 4 and 5) Figure 3-5. TA-Bus to Out-Bus Gating CROM Address X'028' (90C02422 Sheet 3) Figure 3-6. CLSFY Microcycle Timing CROM Address X'028' Figure 3-7. No-Op Microcycles Signal DIBE- is driven true by signal I/O READ and remains true for the duration of the read operation. DIBE enables the IN-Bus lines to the CPU TDXX lines. Reference Figure 3-8 In-Bus to TD-Bus, Typical Gating. Figure 3-8. In-Bus to TD-Bus, Typical Gating (90C02422 Sheets 4 and 5) #### 3.2.3 MICROINSTRUCTION AT X'10F' The fourth microinstruction in the series, at CROM location X'10F', (X' 3 4007 3B90'), transfers the I/O Data to the destination register and decodes as: | | G | Br | NADDR | R/C | B-CNTL | FUNCT | Rs | Rd | | |---------------|-----|--------|-----------|-----|--------|-------|------|------|--| | Binary<br>Hex | 110 | 1 0000 | 0000 0001 | 1_ | 1 0011 | 1011 | 1001 | 0000 | | | HEY | 6 | 10 | 01 | 1 1 | 13 | В | 9 | 1 0 | | The G-field now equal to X'6', causes the Rd portion of the CROM microcode to be replaced with I register bits 10, 9, and 3 (I10, I9, I3 $\rightarrow$ Rd). This enables selection of the destination register, specified by the program instruction, currently being held in the CROM I register. In this example DTIR I register bits I10, I9, and I8 equal 100. This binary code, when placed in the Rd field, selects the B register (as the destination register) for the incoming I/O data. The G-field translation also forces the foreground bit (F) to the most-significant bit position of the destination register (F $\rightarrow$ Rd15). The $B_r$ field (X'10') sets the least-significant bit of the Br code to a logical "1" and forces all other bits of the Br to zero. The Br value OR's with the NADDR value (X"01") to force the next CROM microinstruction address of X'003'. | NADDR<br>Br result | 0000 | 0001<br>00001 | | |--------------------|------|---------------|--------| | Next CROM add | 0000 | 00011 | x'003' | The remaining bits of the microinstruction (R/C, B-CNTL, FUNCT, Rs and Rd) generate the IPDH+ through IPDO+ outputs of the CROM/RALU as shown in Figure 3-9, CROM/RALU Interface CROM address X'10F'. Figure 3-9. CROM/RALU Interface, CROM Address X'10F' (90C02422 Sheet 2) Signals IPDO through IPD7 are gated from the CROM to a microinstruction I latch (internal to the RALU) to select the destination and source registers (when applicable) within the RALU register bank. However, due to the translation of the G field of this microinstruction, bits I10, I9 and I8 instead of IPDO $\rightarrow$ IPD2 are used to select the Rd. I10, I9 and I8 equaling 100 select the B register as the destination register. These three bits are gated from the CROM to the RALU via lines MA, M9 and M8, respectively. The B-CNTL Field (equal to X'13') specifies an I/O Data $\rightarrow$ RALU operation and allows the gating of the I/O data (from In-Bus) to the RALU register inputs. Since the R/C field is set to a '1', the RALU will be enabled to accept this incoming data and place it into Rd (the B register). The necessary gating signals (IODAL- and CRRE-) are generated as shown in Figure 3-10, B-CNTL generation, CROM Address X'10F'. The timing for this microcycle is shown in Figure 3-11; DTIP Microcycle timing. With signals CRRE- true (low) and CRDE+ false (low), the incoming data on In-Bus, will be gated to the RALU destination register. This data enable (over M-Bus lines) is allowed by gating as shown in Figure 3-12, MO through MF In-Bus gating. Only with both enables (CRDE+ and CRRE-) low, will data be input from the TD-Bus to the M-Bus. The Function field (equal to X'B') places this microinstruction in the general category of Miscellaneous (MSC) instructions. Therefore, with the Rs field equal to 9 and the Rd field equal to zero, the function $M \rightarrow Rd$ is identified. (Refer to Table 3-5, Function Field General Classification and Table 3-8, Miscellaneous Group Operation.) 509-3-11 Figure 3-10. B-CNTL Generation, CROM Address X'10F' (90C02422 Sheet 6) Figure 3-11. DTIR Microcycle Timing Figure 3-12. MO through MF In-Bus Gating CROM Address X'10F' (90C02422 Sheets 5 and 6) # 3.2.4 MICROINSTRUCTION AT X'003' The next microinstruction executed is read from CROM address X'003' and translates to X' 0 6443 8E62' (Mnemonic INCP+1). (See Figure 3-13, CROM/RALU Interface, CROM Address X'003'). | | G | Br | NADDR | R/C | B-CNTL | FUNCT | Rs | Rd | |---------------|-----|--------|-----------|-----|--------|-----------|------|------| | Binary<br>Hex | 000 | 1 1001 | 0001 0000 | 1 1 | _ | 1110<br>E | 0110 | 0010 | This microinstruction is the end of the DTIR sequence and the beginning of the instruction fetch (IFTCH) cycle to obtain the next CPU instruction from the CPU memory. The G-field, equal to zero, translates as a NO-OP. The Br-field (X'19') equates CBT to the state of the Save I Switch (SVI), BBT to the condition of the Run Switch (if RUN then BBT = 1), ABT to the interrupt indicator (if INT then ABT = 4) and forces EBT and DBT to zeros. This Br-field with no interrupts, the CPU in the run mode, and no save I indication, OR's with the NADDR field to generate the next CROM address of X'021': NADDR 0001 0 000 Br Result 0 0001 Next CROM Add 0001 0 0001 = X'021' The B-CNTL Field (Reference Table 3-4. Bus Control),(X'18') translates to RALU $\rightarrow$ MA, to begin a memory cycle. This memory cycle fetches the next program instruction from CPU memory. The next program instruction address, for this example, is decoded as P + 1 due to the Funct Field (X'E') combining with Rs (X'6') and Rd (X'2') which indicates that this microinstruction is in the SRL group performing the "P+1 $\rightarrow$ P" function. The P register will accept the new value gated to it, since the read/write control (R/C) is a logic '1'. The B-CNTL field generates the terms ALMA- (RALU $\rightarrow$ Memory Address), CRDE+, and ADRL-to begin the instruction fetch cycle. (Reference Figure 3-14, B-CNTL Generation, CROM Address X'003'.) 3-31 509-3-15 Figure 3-14. B-CNTL Generation, CROM Address X'003' (90C02422 Sheet 6) All timing, for the INCP +1 microcycle, is shown in Figure 3-15. ALMA- goes true to condition a memory request, which will be generated at the beginning of the next microcycle. The term FTCH+ becomes active (from the CROM) to indicate a processor Fetch cycle has been entered. Fetch also is transmitted to the CPU-2 module (90C02429 Sheet 8) to clear I/O Reset (IOR) to the peripheral controllers (SYRT - 90C02429 Sheets 8 and 9) as shown in Figure 3-16, SYRT- Generation. 509-3-17 Figure 3-16. SYRT- Generation Signal DTP- is transferred to the controllers for I/O operations, along with D3- and POLL-. They synchronize interrupt and DMA operations. CRDE- is generated, near the end of the microcycle, and gates the new program address to the memory address (TA) lines. The value of P (P+1) is determined and loaded into the P register entirely within the CROM/RALU chipset. The P $\rightarrow$ MA gating is shown in Figure 3-17 (P $\rightarrow$ Memory Address Gating). Figure 3-17. P -> Memory Address Gating (Partial Representation) (90C02422 Sheets 5 and 6) The final instruction of the DTIR microinstruction sequence (at CROM location X'021') is actually the first full microinstruction for the transfer of the next program instruction from CPU memory to the CROM I register. This microinstruction, with the mnemonic "FTCH", is represented by X' 0 6C53 0E61' and decodes as: | | В | Br | NADDR | R/C | B-CNTL | FUNCT | Rs | Rd | |--------|-----|--------|-----------|-----|--------|-------|------|------| | Binary | 000 | 1 1011 | 0001 0100 | 1 1 | 0000 | 1110 | 0110 | 0001 | | Hex | 0 | 1B | 14 | 1 | 10 | E | 6 | 1 | As previously described, the G-field, being zero, indicates a No-OP function. The Br-field is translated to indicate a Classify Branch (X'lB'). By the interpretation of the classify branch operation, the next CROM address is dependent upon the output of the instruction register (I) that is being loaded with the new program instruction. This I register output determines (classifies) the type of program instruction to be executed and will direct the CROM to the next microinstruction necessary for the proper sequence of operations. For a further explanation of the calculation of the next CROM address on a Classify Branch operation, refer to Section 3.1.2. The R/C, B-CNTL, FUNCT, Rs and Rd fields generate the bit/signal outputs of the CROM/RALU as indicated in Figure 3-18. (CROM/RALU Interface, CROM Address X'021'.) The B-CNTL field (X'10') calls for the transmission of the data on the memory data bus (MD-Bus) to the RALU (MD $\rightarrow$ RALU) by generation of the terms MDAL, ALMA and CRRE, as shown in Figure 3-19, B-CNTL Generation, CROM Address X'021'. All timing for the microcycle is shown in Figure 3-20, Timing, FTCH Microcycle. Figure 3-19. B-CNTL Generation, CROM Address X'021' (90C02422 Sheet 6) 3-38 The memory cycle, to read the next program instruction, is begun by the generation of the memory request signal (MREQ) at the beginning of this microcycle. This signal is generated by ALMA- being true from the last microcycle and the negative going transition of CK8+. The logic for this signal is shown in Figure 3-21, MREQ. Figure 3-21. MREQ (90C02422 Sheet 8) Once the memory request is generated, memory data enters the CPU as MDXX and is transferred via the TD Bus (90C02422 Sheets 4 and 5). Once internal to the processor, the new instruction is gated over the bi-directional TD-Bus to the M-Bus (MO through MF) and into the selected registers within the CROM/RALU chipset. Reference Figure 3-22 TD to M-Bus Gating. Figure 3-22. TD to M-Bus Gating (Partial Representation) (90C02422 Sheets 4 and 5) The Funct, Rs and Rd fields combine as an SRL Class of instruction, (X"E61") to gate the new program instruction into the W register for possible address modification and into the CROM I register for interpretation/classification (M $\rightarrow$ W,I). All timing and gating to allow this data to be written into W and I is internal to the CROM/RALU Chipset. The complete timing for the DTIR microinstruction sequence is shown in Figure 3-23, Overall DTIR Microinstruction Sequence Timing. Figure 3-23. Overall DTIR Microinstruction Sequence Timing # 3.3 MEMORIES The 4K and 8K memory boards, assembly numbers 31D02410 and 31D2585, are available in the following configurations: - -01 4Kx16 Bits - -11 4Kx18 Bits - -21 8Kx16 Bits - -31 8Kx18 Bits The 16K memory board, assembly number 31D02578A01, is supplied only in a 18-bit configuration. The 32/64K memory board, assembly number 31D02644A, is available in the following configurations: ``` -nn 32Kx16 Bits no parity -nn 64Kx16 Bits byte parity -nn 64Kx18 Bits byte parity -nn 32Kx22 Bits includes optional error correction ``` The basic 64K board is depopulated to provide the 32K memory. The 22-bit memory consists of a 16-bit memory board with an error correction (ECC) module mounted piggyback on the memory board. The ECC module provides 6 bits that increase the basic 16-bit word length to 22 bits. Error correction is obtained for single-bit errors; error detection is obtained for a word with more than one error. (Refer to Section 3.3.5 for the ECC module operation.) The memory chips being utilized are 28-pin, $16K \times 2$ bit, dynamic RAMs providing an access time of 200 nanoseconds and a cycle time of 450 nanoseconds. Each memory incorporates a refresh circuit having priority over a read or write cycle. The refresh cycle refreshes a single row address every 32 µsec; therefore, all 64 rows are refreshed every 2 msec. If parity circuitry is incorporated (18-bit memories), a parity bit is generated for both upper and lower bytes of the word on a write cycle and checked on a read cycle. If a parity error is detected, the Tri-State Data Bus (TD-Bus) is forced to all zeros for that cycle. A Data Error indicator is provided. #### 3.3.1 READ TIMING LIMITS, ALL MEMORY BOARDS (FIGURE 3-24, READ CYCLE TIMING) During a read cycle, memory request (MREQ-) must remain low until memory ready (MRDY+) is sensed high, or a time frame of 2 $\mu$ sec (maximum) has lapsed. Once off, MREQ- must remain off for a minimum of 50 $\mu$ sec. The address bus (TAXX-) must be stable for a minimum of 20 nanoseconds before the leading edge of MREQ- and must be maintained stable for at least 175 nanoseconds after MREQ- occurs. The data bus (TDXX-) data, from memory, will be valid at the leading edge of MRDY+ and will remain valid until MREQ- goes false (high). #### 3.3.2 WRITE TIMING LIMITS, ALL MEMORY BOARDS The write timing limits, not using Stop Read (STRD-), are shown in Figure 3-25 with cycle timing. The tolerances for MREQ- and TAXX- are the same as in Read Timing. Memory write (MRWE-) must go true within 175 nsec (max) after MREQ- goes low. MRWE- must go high concurrently with MREQ-. MRWE- enables the tri-state data bus (TDXX-) to gate into memory. # 3.3.3 READ MODIFY WRITE (RMW) TIMING LIMITS, ALL MEMORY BOARDS Figure 3-26 details the timing necessary for a read modify write (RMW) operation. MREQ- will remain low until MRDY+ goes high (after the write portion of the memory cycle). The TDXX- lines are the same as in the read timing. The term STRD- (stop read) goes low after MDRY+ (read is complete from addressed location) and remains low until MWRE- goes low (the write operation is started). MWRE- will go low a minimum of 100 nsec after STRD- and will return to a false condition with MREQ-. The data read (TDXX-) must be sampled between the leading edges of MRDY+ and STRD-. The complete cycle must terminate within 200 nanoseconds of MREQ- going true. #### 3.3.4 REFRESH TIMING # 3.3.4.1 4K, 8K, and 16K Boards The 20 MHz systems clock is divided, by the memory board logic, by 640 to provide a $32~\mu sec$ refresh timer. Should the refresh timer become activated during a memory cycle, the refresh cycle will be enabled at the end of the memory cycle (see Figure 3-27, Refresh Timing). If a memory cycle is requested (MREQ-) during a refresh cycle, the cycle will be delayed until the completion of the refresh cycle. Each refresh cycle refreshes one of the 64 row addresses on both upper and lower 4K. #### 3.3.4.2 # 32K and 64K Boards A 32 $\mu sec$ refresh timing signal is generated on the 32/64K memory board. This refresh signal performs the functions described above for the 4K, 8K, and 16K memory boards. Figure 3-25. Write Cycle Timing Figure 3-26. Read Modify Write Timing 509-3-28 Figure 3-27. Refresh Timing # 3.4 REAL-TIME CLOCK (RTCI) INTERRUPT The GA-16/110 (CPU-1) provides Real-Time Clock interrupt capability utilizing an externally-supplied interrupt signal (clock pulse) and enable. The external RTC interrupt signal may be provided by the user, via the RTCKI+ line (90C02422 Sheet 10), on Pin 87 of connector Pl. The enable line for the RTC interrupt is labeled as RTCKI+ (ENABLE) and may be supplied via pin 76 of P-1 (90C02422 Sheet 10). The GA-16/220 (addition of CPU-2 module), provides a hardware-generated, lms, RTC interrupt clock pulse (90C02429 Sheet 4). This RTC interrupt clock pulse is derived from the system 20MHz clock oscillator. # 3.5 POWER FAIL DETECT Both GA-provided power supplies (jumbo and compact) monitor the AC primary voltages. If AC input voltage should drop below 104.5 VAC, the interrupt logic is signaled. The sensing of a loss of power drives the power-fail detect line, PFD-, true (reference Figure 3-28) to initiate a non-inhibitable interrupt through the power-fail vector address (location X'40'). NOTE When the GA-16/110/220 is powered by a user-supplied power system, the power-fail signal must be supplied to the logic via pin 89 of connector P1 (90C02422A Sheet 7). Figure 3-28. PFD Interrupt Vector Address (90C02422A Sheet 10) 509-3-29 # 3.6 ERROR CORRECTION OPTION The error correction option provides single-bit error correction and multiple-bit error detection for a 32K or 64K memory board. The error correction option consists of a single printed circuit module (31D02647A) which plugs into a 32Kx16-bit or 64Kx16-bit memory board. To perform error correction and detection, the ECC board generates and stores six check bits as each data word is written into memory. During memory read, a second group of six check bits is generated and exclusive-ORed with the check bits generated during write. If the result is zero, the data word was stored and read correctly. A single-bit error results in a non-zero result with the bit position in error specified by the decode of the result. Multiple-bit errors also generate a non-zero result from the exclusive-OR operation, but the decode does not indicate positions for the erroneous bits. #### NOTE Upon initial power up, all ECC check bits are incorrect. All memory locations must be initialized by a store operation before the error correction and detection is enabled. Failure to initialize the memory will cause false error indications. # 3.6.1 OPERATIONAL MODES Operational modes for the error correction options are established by the program. The error correction option utilizes the following operational modes: - · Error Correction OFF Disables the error correction feature. - Normal 1 Mode The ECC module generates an interrupt on both correctable (single-bit) and non-correctable (multiple-bit) errors. - Normal 2 Mode The ECC module generates an interrupt on non-correctable errors only while single-bit errors are corrected. - Write Data Only Mode Used for test or diagnostic purposes only. New check bits are generated, but not stored in memory. The original check bits remain. - Input Status Mode Read status word from ECC module if the associated memory board has an error (see below). - · Error Correction Memory Mode This mode is reserved for memory tester usage. Additional software-related information on the ECC operation is supplied in the GA-16/110/220 System Reference Manual. # 3.6.2 INPUT STATUS MODE The input status mode allows a status word to be generated by the error correction board for each memory module with an error. A status priority signal from the CPU is propagated through each error correction board. The first board with an error will trap the status priority signal. Executing a read of memory location zero will cause the error correction board to place the following status word on the data bus: Following the read command, the status priority signal is sent to the next error correction board having an error. This board also blocks propagation of the priority status signal, and responds to a CPU read of location zero. After transmitting the status priority signal, the CPU continues to read until a status word of all zeros has been received, indicating no more errors exist. NOTE Normal Mode Two, single bit errors also cause the ECC to generate a status word which can be examined utilizing the Input Status Mode. # 3.7 POWER UP/RESTART During power-up sequencing the system is reset, ISE is off, the CPU is placed in both foreground and 32K modes, and a non-inhibitable interrupt (NIIEC+) is generated. The non-inhibitable interrupt forces one of several courses of action: - 1. When the cold start line (CLDS-) is high, the processor generates an interrupt, indirect, through address X'41', the dedicated memory restart vector. (Reference Figure 3-29. Restart Vector Address Generation.) At location X'41', the starting address of the power-up subroutine should be available. For this feature to be properly implemented, a battery back-up power supply must be installed to preserve the contents of the RAM memory while AC power is unavailable. - 2. If, on power-up, the cold start line (CLDS-) is low (ground), two possibilities exist: - a. If the systems console interface (SCI) is installed and the console is active, (CNSL- is true, 90C02405A Sheet 2), a jump is forced to address X'nCOO'. Address X'nCOO' (7COO or FCOO) is the beginning address of the console ROM and allows interactive operator manual restart of the system by entering the SCI ROM program. - Access to the starting address of the console ROM is accomplished through the logic depicted in Figure 3-30. Console ROM Address Logic. The term LSADD+ is driven true and the signal IPLF- is false. This is due to the fact that the console is active (CNSL- is true). Since LSADD+ is true and IPLF- is false, the start-up address "read" from Z2D and Z2C (now disabled by IPLF-) is X'nCOO' (X'7COO' or X'FCOO'). This value is gated over the TD-Bus, through the CPU-2 module and back to the SCI via the TD lines. The value on the "TDxx' lines is the restart address (X'nCOO') and accesses the starting location in the console ROM (90CO2405A Sheets 4, 5 Z6B, Z5B, Z4B, Z3B). - b. If the SCI is installed, but the microconsole is disabled due to the console switch being out of the CNSL position, the signal IPLF- (90C02405A Sheet 2) is driven true. IPLF- being true, in conjunction with LSADD+, "reads" the setting of the IPL 16-position selector switch (S1 in Figure 3-30. Console ROM Address Logic) onto the TD-Bus. This value, which is the IPL ROM address, is routed through the CPU-2 module back to the SCI module, via the TD-Bus lines, as the address of the specific routine, within the 256-word IPL PROM, (90C02405A Sheets 4 and 5). This affects the automatic loading of the program from the selected IPL device. - c. Small, dedicated, GA-16/110's and GA-16/220's with CLDS- low and without the SCI option, automatically reload the program via the IPL PROM on the memory board (90C02277A Sheet 2). Figure 3-29. Restart Vector Address Generation (90C02422 Sheet 10) 509-3-31 Figure 3-30. Console ROM Address Logic (90C02422 and 90C02405 Sheet 2) ### 3.8 USER-DESIGNED CONSOLE INTERFACING A 16-pin connector plug (P2) has been supplied on the front edge of the CPU-1 module. This connector allows for user-designed, console interface capability. The following signals are available via P2 (reference 90C02422A Sheets 2/3): - SVI- P2-Pin 8 This is the dynamic save I control which, when active, allows continuous execution of one instruction by preventing the gating of any new instruction into the CROM I register. - ENTER- P2-Pin 7 The ENTER signal (when the CPU is in idle) allows strobing of a user designed manual data entry switches into the selected CPU register. The manual data switches may be tied to the INBUS lines. - SWA,B,C,D- P2-Pins 4,2,1,3, respectively. These four "register select" switches allow SPC-16 compatability in that they are used for hex address selection of the programmable registers A through E (X '0' through X'7'). The register address codes are the same as those used on the instruction set. - RUN+ P2-Pin 6 This line is driven high, to power an indicator, when the CPU is in the run mode. This line may also be tied to a console switch and, thereby, be used as a run command to the CPU. - STEP- P2-Pin 5 In the Idle mode: Driving this line true, via a console pushbutton, allows the CPU to fetch an instruction from a location in memory (specified in the P register), execute that instruction and increment the P register. In the run mode: automatic program execution is initiated by activating the STEP+ line. # 3.9 SERIAL I/O CONTROLLER The GA-16/220 provides serial I/O communication to either a CRT or Teletype (Model 33ASR type) via an internal (UART controller) serial I/O controller (reference 90C02429A, Sheet 2). On early model CPU2 boards, the communications baud rate is selectable, via S3, at either 9600 baud for CRT (Z8A) or 110 baud for teletype (Z9C). Selection of one, or the other, timing pulse controls the transmit and receive clock (TRC/RRC) inputs to the UART (pins 40 and 17 respectively). On later model CPU2 boards, baud rates of 0 though 9600 are selectable (see Appendix G). The serial I/O controller is assigned device address X'3F' for program selection and interrupts, via IVA X'45', the TTY not busy vector address. Hardware cabling between the controller and TTY (or CRT) is accomplished via an interface paddleboard. GA assembly 31D01843A or 2417 TTY/OSC, or the RS232 connector paddleboard (GA assembly number 31D02411A01) are used in early production processors. Later processors may include any of four adapters between the serial I/O controller and a peripheral device: - Model 1622-0021 Current loop serial I/O adapter without a loop power supply. Converts TTL levels of the UART serial I/O controller to 3-wire, 60V, 20ma current loop signals. Also provides for external monitor and control lines. Uses 31D02486A11 TTY/RS232 paddleboard. - Model 1622-0022 Same as 1622-0021, but includes a loop power supply and uses 31C02552A21 paddleboard. - Model 1622-0023 RS232 serial I/O adapter. Converts UART TTL levels to EIA RS232 levels for communications with peripheral devices. Uses 31D02486A21 TTY/RS232 paddleboard. - Model 1622-2234 Combined RS232 and current loop serial I/O adapter (without loop power supply). Converts UART TTL levels to 3-wire, 60V, 20ma current loop and RS232 signals. Provides both 3-pin current loop connector and 25-pin RS232 connector. Both current loop and RS232 devices receive same data simultaneously. One device at a time can transmit and the message can be displayed on the other. Uses paddleboard 31D02486A01. #### 3.10 EPROM PROGRAMMER The erasable, programmable read only memory (EPROM) that may be used in the Piggyback Memory (Section 2.1.9) can be reprogrammed if the GA Model 1622-0051 EPROM Programmer is available. Appendix H shows how the EPROM Programmer and an ultraviolet lamp (for erase) can be used to reprogram EPROM boards or discrete EPROM chips. # GA-16/110/220 instruction summary This appendix contains tables which summarize the instructions for the GA-16/110/220. The tables provide a quick reference to all instructions and provide look-up tables of both CAP-16 assembly code and the corresponding binary and hexadecimal instruction format. Table A-l lists the basic types of instructions, the general format of the instructions, and provides a key reference number correlating to Table A-2. Table A-2 is an alphabetical list of instructions, the corresponding hexadecimal representations, and a symbolic representation of the operations which result. Table A-3 provides additional detail concerning memory reference instructions (Reference 1 in Tables A-1 and A-2.) This table shows addressing modes, range of displacements (or effective addresses), CAP-16 Assembler codes, and corresponding binary and hexadecimal instruction formats. Table A-4 provides additional detail concerning memory referencing with indexing instructions (references 2, 3, and 4 of Tables A-1 and A-2). Table A-5 provides detailed instruction formats for standard I/O. This includes the built-in teletype controller, internal mask words, console switch register, and display of data via console data display lights. Refer to Appendix B for the ASCII character set used for teletype. If further information regarding an instruction is needed reference GA Publication 88A00508A, GA-16/110/220 System Reference Manual, Section 4. # 88A00509A-B Table A-1. General Instructions | INSTRUCTION TYPE GENERAL FORMAT CAP-16 | TABLE<br>A-2<br>REFERENCE | GENERAL FORMAT | |----------------------------------------------------------------------------------------------------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------| | Memory Reference op-code [ $\star$ ]address,[ $m_1$ ]① | . 1 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 OP CODE m OISP | | Memory Reference with Indexing op-code R,[*]address[.i][,m2]① op-code [*]address[,i][,m2] op-code b,address[,i][,m2] | 2<br>3<br>4 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 OP CODE m ' R OISP OP CODE m ' i EXT DISP OP CODE m ' i b DISP | | Skip (Extended Displacement) op-code address | 2 WORD<br>FORMAT | ONE OF ABOVE 1 1 1 1 1 1 1 ADDRESS 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 OP CODE S CODE DISP | | Register Operate<br>op-code Rd,Rs | 6 | 0 0 0 0 1 Rs Rd 1 OPERATION | | Register Operate Compare op-code Rd,Rs | 7 | 0 0 0 0 1 Rs Rd 0 OPERATION | | Register Operate Literal op-code R,value | 8<br>2 WORD - | 0 0 0 0 0 0 0 1 R 1 OPERATION | | Register Operate Literal Compare op-code R,value | 9<br>2 WORD | VALUE | | Subroutine Return Indirect op-code address | 10 | VALUE 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 1 0 1 0 | | Register Change<br>op-code R | 11 | 0 0 0 0 0 1 X X R X X X X | | Shift Left<br>op-code R | 12 | 0,0,0,0,1,1, R, 0,0,-,- | | Shift Right op-code R, count | 13 | 0, 0, 0, 0, 0, 1 - , R, - COUNT-1 | | Control op-code | 14 | 0 0 0 DECODE HEX PATTERNS IN TABLE A-2 | | <pre>Input/Output op-code R,dev-addr</pre> | 15 out { | 0 0 0 1 M R 1 0 DEV ADDR | | Control/Test<br>op-code Fun,dev-addr | CTRL<br>16 TEST | 0 0 0 1 0 FUN 0 0 DEV ADDR | | Read Console Switches op-code R,X'3E' | 17 | 0 0 0 1 M R 1 0 1 1 1 1 0 | | Multiply/Divide<br>op-code [count] | 18 MPY<br>A-72 DIV | 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, | 508-A-1 # Notes to Table A-1 | U MODE | CODE | IN | CAP-16 | STATEMENT | |--------|------|----|--------|-----------| | | | O MODE CODE IN CAP | -10 STATEMENT | | | | | |----------------|---|--------------------|---------------|-----------|---------------------|--|--| | CAP-16 | | ADDRESSING | | INSTRUCTI | ON FORMAT | | | | m <sub>1</sub> | 0 | Program-relative | 1 | word M=0 | | | | | m <sub>1</sub> | 1 | Base-relative | 1 | word m=1 | | | | | m <sub>2</sub> | 0 | Absolute | 1 | word m=0 | disp <u>≤</u> 11110 | | | | m <sub>2</sub> | 1 | Base-relative | 1 | word m=1 | disp <u>≤</u> 11110 | | | | m <sub>2</sub> | 2 | Absolute | 2 | word m=0; | disp=11111 | | | | m <sub>2</sub> | 3 | Base-relative | 2 | word m=1; | disp=11111 | | | <sup>[\*]</sup> indicates indirect addressing, causes \*field in instruction to be set=1. Table A-2. Summary of General Instructions | COMMAND | TABLE<br>A-1<br>REF. | | | 2HEX CODE | : | <sup>3</sup> OPERATION | |---------|----------------------|---|-------------|------------|-------|----------------------------------------------------------------------------------------| | ADD | 6 | 0 | 8+Rs | 2Rd+1 | . 9 | Rs+Rd-Rd:5 <sub>Z</sub> .S <sub>p</sub> .S <sub>D</sub> .S <sub>L</sub> | | ADDC | 7 | 0 | 8+Rs | 2Rd | 9 | Rs+Rd-DBUS;S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>Q</sub> ,S <sub>L</sub> | | ADDS | 11 | 0 | 7 | 2R | 8 | R+S <sub>Shift</sub> -R:S <sub>Z</sub> .S <sub>p</sub> .S <sub>O</sub> .S <sub>L</sub> | | ADDV | 8 | 0 | 1 | 2R+1 | 9 | R+(P+1)-R;S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>Q</sub> ,S <sub>L</sub> | | ADDVC | 9 | 0 | 1 | 2R | 9 | R+(P+1)-08US;SZ.Sp.SO.SL | | AND | 6 | 0 | 8+Rs | 2Rd+1 | 7 | Rd:Rs-Rd:S <sub>Z</sub> .S <sub>p</sub> | | ANDC | 7 | 0 | 8+Rs | 2Rd | 7 | RdARs+DBUS;S <sub>Z</sub> ,S <sub>p</sub> | | ANDV | 8 | 0 | 1 | 2R+1 | 7 | R∧(P+1)-R;S <sub>Z</sub> ,S <sub>p</sub> | | ANDVC | 9 | 0 | 1 | 2R | 7 | RA(P+1)-OBUS;S <sub>Z</sub> ,S <sub>p</sub> | | 8MS | 14 | 0 | 4 | 0 | 8 | 0÷S <sub>F</sub> (Use Background registers) | | CMR | 2 | Ε | x | 2R<br>2R+1 | X٠ | R-(EA)-DBUS;S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>Q</sub> ,S <sub>L</sub> | | CMPL | 11 | 0 | 7 | 2R | 0 | Complement R-R:O-S <sub>L</sub> [R initially = 0][1-S <sub>L</sub> [R initially # 0] | | CTRL | 16 | 1 | fun | dev-addr | | Controller carries out function | | DECM | 3 | F | x | 4<br>5 | χ٠ | (EA)-1+(EA);S <sub>Z</sub> .S <sub>p</sub> .S <sub>L</sub> | | DECR | 11 | 0 | 7 | 2R | 2 | R-1-R;S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>L</sub> | | DIV | 18 | 0 | 0 | A | count | BC+A+C; Remainder+8;S <sub>L</sub> | | DSPL | 11 | 0 | 5 | 2R | 4 | (No observable function on GA-16/110/220 | | DTIM | 15 | 1 | R | 80+dev-a | ıddr | Controller-*R | | DTIR | 15 | 1 | 8+R | 80+dev-a | ıddr | Controller-R | | DTOM | 15 | 1 | R | 40+dev-a | ıddr | *R-Controller | | DTOR | 15 | 1 | 8+ <b>Q</b> | 40+dev-a | ıddr | R-Controller | | EXBY | 11 | 0 | 6 | 2R | 4 | <sup>R</sup> 7-0 <sup>R</sup> 15-8 | | EXIT | 11 | 0 | 5 | 2R | 2 | R <sub>14-0</sub> -P <sub>14-0</sub> /R-P | | FMS | 14 | 0 | 4 | 0 | С | 1→S <sub>F</sub> (Use Foreground registers) | | INCM | 3 | F | X | 0 | χч | (EA)+1+(EA);S <sub>Z</sub> .S <sub>p</sub> .S <sub>L</sub> | | INCR | 11 | 0 | 7 | 2R | E | R+1 R;S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>L</sub> | | INE | 14 | 0 | 4 | 0 | 3 | I-ISE 508-A-2 | Table A-2. Summary of General Instructions (Cont'd.) | COMMAND | TABLE<br>A-1<br>REF. | 1 | | | . <sup>3</sup> OPERATION | | | |---------|----------------------|---|------|------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | INH | 14 | 0 | 4 | 0 | 2 | 0 -1 SE | | | JMP | 1 | 7 | х | x | х | EA <sub>14-0</sub> -P <sub>14-0</sub> /EA <sub>15-0</sub> -P <sub>15-0</sub> | | | JSR | 1 | 6 | x | х | х | P+1-E <sub>14-0</sub> ; ISE-E <sub>15</sub> ; EA-P <sub>14-0</sub> ; 0-ISE/P+1-E; ISE-S <sub>ISE</sub> ; EA-P; 0-ISE | | | LARS | 3 | F | x | 8<br>9 | х- | (EA)(EA+7)-A,X,Y,Z,B,C,D,E;(EA+8) <sub>15</sub> -S <sub>ISE</sub> ;(EA+8) <sub>8-0</sub> -S <sub>3-0</sub> | | | LDA | 1 | 4 | х | х | х | A(A3) | | | LDBY | 2 | 8 | x | 2R<br>2R+1 | χ | (EA) <sub>15-8</sub> -R <sub>7-0</sub> [i even] (EA) <sub>7-0</sub> -(EA)-R <sub>7-9</sub> [i odd] | | | LOR | 2 | С | x | 2R<br>2R+1 | х* | (EA)-R | | | LDV | ä | 0 | 1 | 2R+1 | 5 | (P+1)+R:S <sub>Z</sub> ,S <sub>p</sub> | | | LKR | 14 | 0 | 4 | 2 | 0 | 0-S <sub>L</sub> | | | LKS | 14 | 0 | 4 | 3 | o | i -S <sub>L</sub> | | | мру | 18 | 0 | o | 8 | count | A+C-B,C:S <sub>L</sub> | | | OR | 6 | 0 | 8+Rs | 2Rd+1 | D | RdVRs-Rd;S <sub>Z</sub> .S <sub>p</sub> | | | ORC | 7 | 0 | 8+Rs | 2Rd | 0 | RdVRs -DBUS; S <sub>Z</sub> , S <sub>p</sub> | | | ORV | 8 | 0 | 1 | 2R+1 | D | RV(P+1)-R:S <sub>Z</sub> -S <sub>P</sub> | | | ORVC | 9 | 0 | 1 | 2R | 0 | RY(P+1)-0BUS:S <sub>Z</sub> .S <sub>p</sub> | | | PMA | 14 | 0 | 4 | 4 | 0 | O-PMA; Reset OMA timer, (must he issued every 200 ms:60ms) | | | RBIT | 4 | 3 | x | 2b<br>2b+1 | 7* | • $(\overline{EA})_{b+8}$ - $S_z$ :0+ $(EA)_{b+8}$ [i even] $(\overline{EA})_b$ + $S_z$ :0+ $(EA)_b$ [i odd] | | | RCSM | 17 | ı | R | В | ε | CSW *R | | | RCSR | 17 | 1 | 8+R | В | E | CSW R | | | RCSW | 11 | 0 | 6 | 2R+I | С | (Cannot be used on GA-16/110/220; use RCSR instead) | | | RISE | 11 | 0 | 5 | 2R | 1 | R <sub>15</sub> -(SE/S <sub>ISE</sub> -(SE | | | RLK | 11 | 0 | 7 | 2R | ı | R+5R;5 <sub>7</sub> ,5 <sub>9</sub> ,5 <sub>0</sub> ,5 <u>1</u> | | | RTNIV | 10 | 0 | ı | 1 | 2 | ((EA)) <sub>14-0</sub> -P <sub>14-0</sub> ;((EA)+1) <sub>15</sub> -ISE/((EA))+P;((EA)+1) <sub>15</sub> -ISE | | | RTR | 6 | 0 | 8+Rs | 2Rd+1 | 5 | Rs -Rd:S <sub>Z</sub> -S <sub>p</sub> | | | RTRN | 11 | 0 | 5 | 2R | 3 | R <sub>14-0</sub> -P <sub>14-0</sub> ;R <sub>15</sub> -ISE / RP;S <sub>ISE</sub> -ISE | | | SARS | 3 | F | х | C | χu | A.X.Y.Z.B.C.D.E.S+(EA)(EA+8) | | | SBIT | 4 | В | х | 25<br>25+1 | χ., | $(\overline{\mathtt{EA}})_{b+8} - S_{Z}; 1 - (\mathtt{EA})_{b+8} [i \text{ even}] (\overline{\mathtt{EA}})_{b} - S_{Z}; 1 - (\mathtt{EA})_{b} [i \text{ odd}]$ | | Table A-2. Summary of General Instructions (Cont'd.) | COMMANO | TABLE<br>A-1<br>REF. | | | <sup>2</sup> HEX CODE | | <sup>3</sup> OPERATION | |---------|----------------------|---|--------|-----------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SKM | 5 | 2 | 6 7 - | х . | х | EA-P [Sp=0] P+1-P[Sp=1] | | SKN | 5 | 2 | 4 5 | x _ | X | EA-P [S <sub>Z=0</sub> ];P+1-P[S <sub>Z=1</sub> ] | | SKOF | 5 | 2 | 0 | x | x | EA-P [S <sub>0=0</sub> ];P+1-P[S <sub>0=1</sub> ];S <sub>0</sub> | | SKOT | 5 | 2 | 8 | х | X | EA-P [S <sub>0=1</sub> ]:S <sub>0</sub> P+1-P[S <sub>0=0</sub> ] XX is 2's complement of displacement when 2nd digit is odd; skip reverse | | SKP | 5 | 2 | E | x | x | EA-P [S <sub>P=1</sub> ]:P+1-P[S <sub>P=0</sub> ] (range +255 thru -256) | | SKR | 5 | 2 | 2 3 | х | х | EA-P [S <sub>L=0</sub> ];P+1-P[S <sub>L=1</sub> ] | | SKS | 5 | 2 | A<br>B | х | х | EA-P [S <sub>L=1</sub> ]!P+1-P[S <sub>L=0</sub> ] | | SKZ | 5 | 2 | C<br>D | x | X | EA+P [S <sub>Z=1</sub> ];P+1-P[S <sub>Z=0</sub> ] . | | SLC | 12 | 0 | 6 | 2R | 3 | R <sub>b</sub> -R <sub>b+1</sub> ; R <sub>15</sub> -R <sub>0</sub> ; R <sub>15</sub> -S <sub>L</sub> ; S <sub>Z</sub> , S <sub>P</sub> , S <sub>L</sub> | | SLCL | 12 | 0 | 7 | 2R | 3 | <sup>8</sup> b <sup>-8</sup> b+1; SL <sup>-8</sup> 0; <sup>8</sup> 15 <sup>-S</sup> L; S <sub>Z</sub> ,Sp,SL | | SLIO | 12 | 0 | 7 | 2 <b>R</b> | 5 | R <sub>15</sub> -S <sub>L</sub> ; R <sub>b</sub> -R <sub>b+1</sub> ; 1-R <sub>0</sub> ; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>L</sub> | | SLIZ | 12 | 0 | 7 | 2R | 4 | R <sub>15</sub> -S <sub>L</sub> ; R <sub>b</sub> -R <sub>b+1</sub> ; O-R <sub>O</sub> ; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>L</sub> | | SRA | 13 | 0 | 2 | 2R+1 | count-1 | R <sub>15</sub> -R <sub>15</sub> , R <sub>b</sub> -R <sub>b-1</sub> ;R <sub>0</sub> -S <sub>L</sub> [count], S <sub>Z</sub> ,S <sub>p</sub> ,S <sub>L</sub> | | SRC | 13 | 0 | 3 | 2R | count-1 | R <sub>O</sub> -R <sub>15</sub> ; R <sub>b</sub> -R <sub>b-1</sub> ···; R <sub>O</sub> -S <sub>L</sub> [count]; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>L</sub> | | SRCL | 13 | 0 | 3 | 2R+1 | count-1 | S <sub>L</sub> -R <sub>15</sub> ; R <sub>0</sub> -L; R <sub>b</sub> -R <sub>b-1</sub> [count]; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>L</sub> | | SRLC | 13 | 0 | 2 | 2R | count-I | $0+R_{15}:R_{b}-R_{b-1}\cdots:R_{0}-S_{1}[count];S_{7}.S_{p}.S_{1}.S_{Shift}$ [shift stops when $S_{1}=1:count-S_{Shift}$ ] | | STA | 1 | 5 | x | х | х | A-(EA) | | STBY | 2 | 9 | х | 2R<br>2R+1 | χ÷ | R <sub>7-0</sub> -(EA) <sub>15-8</sub> [i even]:R <sub>7-0</sub> -(EA) <sub>7-0</sub> [i odd] | | STR | 2 | 0 | x | 2R<br>2R+1 | х 4 | R-(EA) | | SUB | 6 | 0 | 8+Rs | 2Rd+1 | 6 | Rd-Rs-Rd; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>O</sub> ,S <sub>L</sub> | | SUBC | 7 | 0 | 8+Rs | 2Rd | 6 | Rd-Rs-OSUS; S <sub>Z</sub> ,S <sub>P</sub> ,S <sub>O</sub> ,S <sub>L</sub> | | SUBV | 8 | 0 | 1 | 2R+1 | 6 | R-(P+1)-R; S <sub>Z</sub> ,S <sub>5</sub> ,S <sub>0</sub> ,S <sub>L</sub> | | SUBVC | 9 | 0 | 1 | 2R | 6 | R-(P+1)-06US: S <sub>Z</sub> .S <sub>p</sub> .S <sub>0</sub> .S <sub>L</sub> | | SYNC | 14 | 0 | 4 | 8 | 0 | PULSE+SYNC TEST POINT | | TBIT | 4 | А | X | 2h<br>2b+1 | x4 | $(\overline{\mathtt{EA}})_{\mathfrak{b}+8}$ - $\mathtt{S}_{\overline{Z}}$ [i even] ${}_{\overline{i}}(\overline{\mathtt{EA}})_{\mathfrak{b}}$ - $\mathtt{S}_{\overline{Z}}$ [i odd] | | TEST | 16 | 1 | fun | CO+dev-ad | ldr | Function True P+2→>; Function False P+1→P | | TRAP | 14 | 0 | 0 | 1 | х | ISE+(7D) <sub>15</sub> ; I <sub>14-0</sub> +(7D) <sub>14-0</sub> ; P+(7C); (44)-P:0+ISE | Table A-2. Summary of General Instructions (Cont'd.) | COMMAND | ¹TABLE<br>A-1<br>REF. | | | THEX CODE | Ī. | OPERATION | |---------|-----------------------|---|------|------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TRS | 11 | 0 | 5 | 2R | 8 | R <sub>8</sub> -S <sub>F</sub> ; R <sub>7</sub> -S <sub>Z</sub> ; R <sub>6</sub> -S <sub>P</sub> ; R <sub>5</sub> -S <sub>O</sub> ; R <sub>4</sub> -S <sub>L</sub> ; R <sub>3-O</sub> -S <sub>Shift</sub> / | | TSR | 11 | 0 | 6 | 2R | 8 | SISE-R15: Smode-R:4: 0-R:13-9: SF-R3: SZ-R7:<br>Sp-R6: S0-R5: SL-R4: SShift-R3-0 | | TIAW | 14 | 0 | 0 | 0 | Х | P-P; Press STEP switch to do P+1-P | | XEC | 11 | 0 | 5 | 2R+1 | 0 | R-I | | XOR | 6 | 0 | 8+Rs | 2Rd+1 | 8 | Rd <del>YR</del> s→Rd; S <sub>Z</sub> ,S <sub>P</sub> | | AORC | 7 | 0 | 8+Rs | 2Rd | 3 | Rd <del>YR</del> s-OBUS; S <sub>Z</sub> .S <sub>p</sub> | | XORV | 8 | 0 | 1 | 2R+1 | 8 | R <del>V</del> (P+1)-R; S <sub>Z</sub> .S <sub>P</sub> | | XORVC | 9 | 0 | 1 | 2R | а | R¥(P+1)+DBUS; S <sub>Z</sub> .S <sub>p</sub> | | ZERO | 11 | 0 | 6 | 2R | 0 | 0- <del>-</del> R | | ZLBY | 11 | 0 | 6 | 2R | 2 | 0R:5-8 | | ZRBY | 11 | 0 | 6 | 2 <b>R</b> | 1 | <sup>0→R</sup> 7-3 | #### Notes to Table A-2 ① Numbers in Table A-1 reference column identify the general format of instructions included in Table A-2. | 2 | • • • • • • • • • • • • • • • • • • • • | 16 CONVE | | | | - ; | |---|-----------------------------------------|-----------------------------------------------|--------------------------------------|-----------|--------------------------------------|-----------------| | | CAP-16<br>MNEMONIC | BINARY<br>CODE | R<br>Rd | 2R<br>2Rd | 2R+1<br>2Rd+1 | 8+R<br>8+Rs | | | A<br>X<br>Y<br>Z<br>B<br>C<br>D | 000<br>001<br>010<br>011<br>100<br>101<br>110 | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | 02468ACE | 1<br>3<br>5<br>7<br>9<br>B<br>D<br>F | 8 9 A B C D E F | 3 CONVENTIONS USED IN OPERATION COLUMN ``` R register (usage determined by inst.) Rs source register Rd destination register EA effective address Rb bit in a register Rb+1 next bit left Rb-1 interrupt vector for I/O DBUS only a comparison is made, setting appropriate status register bits ``` | 1 | 32K/64K mode alternate operation | |-----|-------------------------------------| | 1 | alternate operation based on a | | • | condition for transfer | | 1 | condition for alternate operation | | ata | transfers are full word unless bit | | | are specifically indicated; e.g., | | R | always means contents of register | | •R | means R points to address in memory | | | (i.e., Indirect Address) | | DIVIOR VEGICIENT | STAT | US | REG: | ISTER, | S | |------------------|------|----|------|--------|---| |------------------|------|----|------|--------|---| | • | | | | |--------------------|------------------|-----------------|--------| | TERM | BIT | DESCRIPTION | V Or | | SISE | S <sub>15</sub> | ISE SAVE STATUS | ¥ E> | | SMODE | S <sub>14</sub> | 0=32K/1=64K | Λ Ar | | SF | Sg | FOREGROUND | MATI | | sz | s <sub>7</sub> | ZERO | . MATH | | S <sub>p</sub> | s <sub>6</sub> | PLUS | + Ac | | s <sub>o</sub> | s <sub>5</sub> | OVERFLOW | - Su | | s, | s <sub>4</sub> | LINK | • Mu | | S <sub>Shift</sub> | s <sub>3-0</sub> | SHIFT COUNT | : Df | | | | | | ¥ Exclusive-OR A And LOGIC SYMBOLS # MATH SYMBOLS + Add - Subtract - Multiply : Divide @Refer to Table A-4 when the Hex Code indicates one of the following: x 2R x 2R+1 x x 2b x 2b+1 x x ( ) x | CAP-16 CODI | NG FORMAT | BINARY | ADDRESSING MODE | EA CALCULATION | NEXT INSTRUCTION | |----------------|-------------------------|--------------------------------------------------------|------------------------|-----------------------|------------------| | OPCODE[ | *]address[,m,] | 15 N 13 12 11 10 9 8 7 6 5 4 3 2 1 | | | | | JMP | Refer | 0 1 1 1 Refer to example below for range | S | | | | JSR | to<br>Examples<br>Below | and transitions<br>0 1 1 0 from negative (2: | s | | | | LDA | be low | 0 1 0 0 positive values | | | | | STA | | | | | | | | -512 | 0 0 1 0 0 0 0 0 0 0 0 0 | | | | | | -1 | 0011111111111 | Program Relative | P+1+disp | P+1 | | | 0 | 0 0 0 0 0 0 0 0 0 0 0 | | | | | | +511 | | 1 | | , | | | 4911 | 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | ~ | | | Refer | *-512<br>: | 0110000000000 | | | | | to<br>Codes | *-1 | 0 1 1 1 1 1 1 1 1 1 1 | Program Relative | 40.1.1. | | | | *0 | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | (P+1+disp) | P+1 | | | *511 | 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | · | | | | 0,1<br>: | 1000000000000 | Base Relative | D+disp | P+1 | | | 1023,1 | 10111111111111111111111111111111111111 | | | | | | *0,1 | 1 1 0 0 0 0 0 0 0 0 0 0 | Base Relative | (D+disp) | P+1 | | | *1023,1 | 11111111111111111111111111111111111111 | Indirect | · | | | Ornor of ridde | oss (disa) man l | no numbers shows above on any CAC | ) 16 saldware evenessi | us which courle there | must and | Range of address (disp) may be numbers shown above or any CAP-16 address expression which equals these numbers. Table A-4. Memory Reference with Indexing, EA Calculations, Ref. 2, 3, 4 in A-1 and A-2 | OPCODE | OPERAND | 15,14,23,12 11,10,9,3 | 7,6,5,4 | 3,2,1,0 | ADDRESSING MODE ① | EA CALCULATION | |---------------------|-----------------------------------|-----------------------|----------|---------|-------------------|----------------| | | (b) [*]addr[,i][,m <sub>2</sub> ] | OP m + i | R<br>ext | DISP | | | | RBIT | b | 0 0 1 1 | | | | | | LDBY | 8 - | 1 0 0 0 | | | | | | STBY | R | 1 0 0 1 | | | | | | TBIT | b | 1 0 1 0 | | | | | | SBIT | <b>b</b> | 1 0 1 1 | | | | | | LDR | R | 1 1 0 0 | | | | | | STR | R | 1 1 0 1 | | | | | | CMR | R | 1 1 1 0 | | | | | | DECM INCM LARS SARS | | 1 1 1 1 1 | | | | | $\bigcirc$ Addressing mode and indexing are determined by M, \*, i bits as follows: - m = 0 Absolute = 1 Base \* = 0 Direct = 1 Indirect - i = 00 No index = 01 X index = 10 Y index = 11 Z index For instructions which reference bits (RBIT, SBIT, TBIT) and instructions referencing bytes (LDBY and STBY) an even index value refers to left byte, and an odd index value refers to right byte. Therefore, EA is divided by 2 for those instructions. ②Refer to sheet 3 and 4 for extension (ext.). 508-A-4 Table A-4. Memory Reference with Indexing, EA Calculations (Cont'd) Ref. 2, 3, 4 in A-1 and A-2 | OPCODE | OPERANDS | 15,14,13,12 | 11,10,9,8 | | 3,2,1,0 | ADDRESSING MODE | EA CALCULATION | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|------------|---------|-------------------------------|----------------| | | (b) [*] addr[,i][,m <sub>2</sub> ]<br> R | OP<br>CODE | m * i | { B R ext} | DISP | | | | | {addr,, } {0 0 0 2} | | 000 | | | Absolute Direct | addr-EA | | | addr, X, [0] | | 0 0 0 1 | | | | addr+X-EA | | | addr, Y, {0} | | 0 0 1 0 | | | Absolute Direct Indexed | addr+Y-EA | | | addr, $Z$ , $\{0\}$ | | 0 0 1 1 | | | | Addr+Z-EA | | | *addr,, {0}<br>*addr,0,} {0} | | 0 1 0 0 | | | Absolute Indirect | (addr)-EA | | | *addr,X, {0} | | 0 1 0 1 | | | ) | (addr)+X-EA | | | *addr,Y, {C} | | 0 1 1 0 | | | Absolute Indirect Indexed | (addr)+Y-EA | | | *addr,Z, [0] | | 0,1,1,1 | | | ) | (addr)+Z-EA | | | $ \begin{cases} addr,, \\ addr,0, \end{cases} $ | | 1 0 0 0 | | | Base-relative Direct | addr+D -EA | | | addr, X, {1} | | 1 0 0 1 | | | ) | addr+D+X-EA | | | addr Y, $\begin{Bmatrix} 1 \\ 3 \end{Bmatrix}$ | | 1 0 1 0 | | | Base-relative Direct, Indexed | addr+D+Y-EA | | | addr, $Z$ , $\begin{Bmatrix} 1 \\ 3 \end{Bmatrix}$ | | 1 0 1 1 | | | ) | addr+0+Z-EA | | | <pre> addr, () addr,</pre> | | 1 1 0 0 | | | Base Indirect | (addr+D)→EA | | | *addr,X, {1} | | 1 1 0 1 | | | ) | (addr+D)+X-EA | | | *addr,Y, {1} | | 1 1 1 0 | | | Base Indirect Indexed | (addr+D)+Y+EA | | | *addr,Z, {1} | | 1 1 1 1 | | | | (addr+0)+Z+EA | MOTES: ③ EA Calculation is determined by addressing mode. The EA is calculated from the disp field for addr values ≤ 1E. For values > 1E disp field = 1F and disp value in P+1 (2-word instruction). When $m_2$ is coded 2 or 3, disp is set to 1F and all displacement value from 0 through 65,536 is in P+1. If $m_2$ is not coded, the assembler will provide addressing mode and will determine 1 or 2-word instruction on basis of value of addr. Table A-4. Memory Reference with Indexing, EA Calculations (Cont'd) Ref. 2, 3, 4 in A-1 and A-2 | OPCOD<br>S | E | OPERANDS . [*]addr[,i][,m2] | 1 1 | 11,:0, 9, <u>9</u><br>m * i | 7,5,5,4,3,2,2,2,9 (b) (c) (R) (DISP) (ext) | ADDRESSING MODE | EA CALCULATION | |-----------------------|-----|-----------------------------|-----|-------------------------------|---------------------------------------------|-----------------|----------------| | (ext) | | | 會 | 會 | 0000 | | | | (INCM) | | x | | | 0 0 1 0 | | | | (DECM) | 2 | Y | | | 0 1 0 0 | | | | | 3 | z | | | 0 1 1 0 | | | | (LARS) | 4 | | | | 1 0 0 0 | | | | | 5 | | | | 1 0 1 0 | | | | (SARS) | 6 1 | | | | 1100 | | | | | 7 1 | | | | 1 1 1 0 | | | | For<br>addr<br>values | | 0<br>:<br>15 | | | 0 0 0 0<br>:<br>1 1 1 1 | | | #### NOTES: $<sup>\</sup>ensuremath{\ensuremath{\mathfrak{S}}}$ Range of values defining b, R, or INCM, DECM, LARS or SARS instructions and MSB of displacement are in byte 3 ⑤ Next instruction is determined by contents of disp field. If disp < 1E, next instruction is at P+1. If disp = 1F, next instruction is at P+2. Next instruction is also at P+2 when $m_2$ is coded 2 or 3. Table A-4. Memory Reference with Indexing, EA Calculations (Cont'd) Ref. 2, 3, 4 in A-1 and A-2 | OPCODE<br>S | OPERANDS | 15,14,13,121 | 1.10.3.13 | | 3,2,1,0 | ADDRESSING MODE | EA CALCULATION | |----------------|--------------------------------|--------------|-----------|--------------|--------------|-----------------|----------------| | | [*]addr[,i][,m <sub>2</sub> ]. | OP n | n * i | { b R ext} | DISP | | • | | (ext) b R | | | | 0 0 0 1 | | , | | | 1 X | | | | 0 0 1 1 | | | | | (DECM) 2 Y | | | | 0 1 0 1 | | | | | 3 Z | | | | 0 1,1 1 | | | · | | (LARS) 4 B | | | | 1 0 0 1 | | | | | 5 C | | | | 1 0 1 1<br>B | | | | | (SARS) 6 D | | | | 1 1 0 1 | | | | | 7 E | | | | 1 1 1 1<br>F | | | | | For addr ③ - { | 16 | | | | 000 | | | | values | 31 | | | | :<br>L 1 1 0 | | | | For | . 32 | | | | 1 1 1 | | | | addr ① { | 65,336 | | | | :<br>1 1 1 1 | | | Table A-5. Standard I/O Data & Instructions (Sheet 1 of 2) | TTY | DA | TA | 0 F | DEV | ADDR | 3 F | INT | VECTOR | = | 45 | |------|-----|------|------|------|------|-----|-----|--------|---|----| | Reg | to | TTY | | | DTOR | 1 | 8+R | 7 | | F | | Mem | to | TTY | | | DTOM | 1 | R | 7 | | F | | TTY | to | Reg | | | DTIR | 1 | 8+R | В | | F | | TTY | to | Mem | | | DTIM | 1 | R | В | | F | | TEST | T f | or N | ot-l | Busy | TEST | 1 | 0 | F | | F | | Set | to | Tra | nsm | it | CTRL | 1 | 0 | 3 | | F | | Set | to | Rcv | | | CTRL | 1 | 2 | 3 | | F | | Set | to | Rcv | /Eci | ho | CTRL | 1 | 4 | 3 | | F | | Set | to | Bre | ak | | CTRL | 1 | 6 | 3 | | F | Refer to Appendix B for ASCII data. # MASK DATA FOR DEV ADDR 3E ### OUTPUT INSTRUCTIONS TO DEV ADDR 3E | From Register | DTOR | 1 | 8+R | 7 | ε | |---------------|------|---|-----|---|---| | From Memory | DTOM | 1 | R | 7 | Ε | Power up disables interrupts and sets $32 \, \mathrm{K}$ mode; $32 \, \mathrm{K}$ mode can also be permanently enabled with switch on CPU. To set or clear mask bits, output a register with desired bits $\lnot 1$ or 0 (as required) as shown in following example: | MACHINE | <u>c</u> | AP-16 | FUNCTION | |---------|----------|-----------|------------------------------------------| | 0600 | ZER0 | Α | Clear Register A | | 0110 | ORV | A,X'nnnn' | Load hex equivalent of bit pattern | | nnnn | | | 2nd word formatted per desired mask data | | 187E | DTOR | A,X'3E' | Set the mask | INPUT INSTRUCTIONS TO DEV ADDR 3E TO READ CONSOLE SWITCHES Table A-5. Standard I/O Data & Instructions (Sheet 2 of 2) CONTROL INSTRUCTIONS TO DEV ADDR 3E Single Step (SSTEP) CTRL 1 1 3 E I/O Reset (IORST) CTRL 1 2 3 E Single step control instruction executable in upper 1K of memory mode in use. NI interrupt via location X'46', with P+1 and ISE saved in locations X'7E' and X'7F', will occur after first instruction outside upper 1K of memory is executed. # GA-16/110/220 microcode summary B The following microcode listing is provided as a quick reference for operations, functions, and the hex coding of each of the microinstructions contained within the standard GA-16/110/220 microprocessor (CROM) chipset. | Mnemonic | Add. | | | | M | l Co | de | | | | Next Address<br>Group | Operation | |-------------------|-------------------|------------------------|------------------------|----------------------|----------------------|------------------------|-------------------------------------------|-------------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RST | 000 | 0 | 6 | 4 | 0 | E | 0 | F | 8 | 5 | 006 | <sup>SVL</sup> 8→S | | LNI | 001 | 0 | 0 | 0 | 4 | 9 | 8 | В | В | 0 | 024 | P → MA | | INCP | 002 | 0 | 4<br>6 | 0<br>4 | 0<br>4 | 6<br>3 | 0<br>8 | E<br>E | 6<br>6 | 2<br>2 | 003<br>020 | $P + 1 \rightarrow P$ ,<br>$P + 1 \rightarrow P$ , MA | | INT | 004 | 0 | 0 | 0<br>0 | F<br>6 | A<br>3 | 0<br>2 | B<br>E | 7<br>7 | 0<br>1 | 07C<br>030 | ISE, W <sub>E→O</sub> → W<br>INT DATA → W | | IPL | 006 | 0<br>0 | 4<br>6 | 0<br>4 | 0<br>4 | 9<br>3 | 2<br>6 | O<br>E | 0<br>7 | 0<br>3 | 005<br>020 | INT DATA →<br>SPEC → P, MA | | REGISTER<br>DSPLY | 010<br>015<br>01A | 0000000000000000000000 | 76764676FEFEFEFEFEFEFE | 04040404040404040404 | 04040404040404040404 | 1939393939393939393939 | 1 F 5 D 5 D 5 D 5 D 5 D 5 D 5 D 5 D 5 D 5 | O O E 6 E 3 E B B B B B B B B B B B B B B B B B | 0 0 7 0 7 B 7 A 9 6 9 6 9 6 9 6 9 6 9 6 9 6 | 0<br>0<br>1<br>0<br>3<br>0<br>5<br>0<br>7<br>7<br>6<br>6<br>6<br>5<br>5<br>4<br>4<br>3<br>2<br>2<br>1<br>1<br>0<br>0<br>0 | 008<br>024<br>008<br>024<br>001<br>024<br>008<br>024<br>008<br>024<br>008<br>024<br>008<br>024<br>008<br>024<br>008<br>024<br>008<br>024<br>008 | CNSL + I I + DSPLY CNSL + W W + DSPLY CNSL + P P + DSPLY CNSL + S S + DSPLY CNSL + E E + DSPLY CNSL + D D + DSPLY CNSL + C C + DSPLY CNSL + C C + DSPLY CNSL + Z Z + DSPLY CNSL + Z Z + DSPLY CNSL + Y Y + DSPLY CNSL + X X + DSPLY CNSL + A A + DSPLY | | Mnemonic | Add | | | ] | M C | ode | | | | | Next Address<br>Group | Operation | |----------|-----|-----------------------|--------------------------------------|------------------|--------------------------------------|--------------------------------------|--------------------------------------|---------------------------------|---------------------------------|---------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | FTCH | 020 | 0000000 | 4<br>6<br>4<br>7<br>4<br>6<br>4<br>7 | 4 C 4 O 4 C 4 O | 0<br>5<br>0<br>0<br>0<br>5<br>0 | 9<br>3<br>9<br>1<br>9<br>3<br>9 | 2<br>0<br>2<br>0<br>2<br>7<br>2<br>0 | 0 E 0 E 0 O | 0<br>6<br>0<br>6<br>0<br>7<br>0 | 0<br>1<br>0<br>2<br>0<br>1<br>0 | 020<br>028<br>004<br>008<br>004<br>028<br>004<br>008 | INT DATA → W M-DATA → W,I INT DATA → W? M-DATA → I INT DATA → ? I → W INT DATA → M-DATA → | | CLSFY | 028 | 00000000 | 2<br>0<br>0<br>0<br>1<br>1<br>3<br>4 | 8 8 4 C 5 5 2 0 | 6<br>8<br>7<br>8<br>4<br>C<br>2<br>A | 9<br>2<br>A<br>0<br>8<br>8<br>0<br>B | A<br>0<br>0<br>0<br>0<br>0 | 6 E E O O O E | 0<br>6<br>6<br>0<br>0<br>0<br>6 | 0<br>2<br>2<br>0<br>0<br>0<br>0 | 034<br>028<br>03C<br>058<br>0A4<br>0E4<br>110 | W $\rightarrow$ I/O ADD<br>P + 1 $\rightarrow$ P<br>P + 1 $\rightarrow$ P | | SVP | 030 | 0 | E | 0 | 7 | 6 | 0 | В | В | 7 | 03A | P → E (DISP) | | IOLA | 031 | 3<br>0<br>0 | 4<br>0<br>7 | 0<br>A<br>8 | 0<br>1<br>0 | 5<br>8<br>5 | В<br>О<br>В | B<br>0<br>6 | 6<br>0<br>0 | 0<br>0<br>0 | 003<br>10C<br>003 | $R_d \rightarrow I/O$ Data $W \rightarrow I/O$ Data | | IOL | 034 | 0<br>3<br>0<br>0 | 4<br>2<br>0<br>2 | 0<br>4<br>0<br>0 | 0<br>7<br>6<br>6 | 5<br>1<br>4<br>0 | 8<br>0<br>0 | 6<br>B<br>O<br>O | 0<br>6<br>0 | 0<br>0<br>0 | 003<br>038<br>032<br>031 | $W \rightarrow I/O$ Data $R_d \rightarrow MA$ | | DTXM | 038 | 0 | 4<br>0 | 0 | 0<br>6 | 5<br>B | С<br>0 | 6<br>E | 0<br>7 | 0 | 038<br>034 | W → M-Data<br>M-Data → W | | WTD | 03A | 0<br>0 | 4<br>7 | 0<br>C | 9<br>7 | 1<br>5 | 8<br>D | 6<br>6 | 0 | 0 | 049<br>03A | W → M-ADD<br>W → DSPLY | | SKP | 03C | 0 0 0 | 3<br>1<br>3<br>1 | 8<br>8<br>C<br>C | 9<br>A<br>A<br>A | 8<br>0<br>0 | 0<br>0<br>0<br>0 | 0 0 | 0 0 0 | 0<br>0<br>0 | 04C<br>050<br>050<br>050 | | | MR | 040 | 0<br>0<br>0<br>0<br>0 | 6<br>5<br>D<br>8<br>C<br>8<br>C | 4 0 4 0 0 0 0 | 4<br>9<br>4<br>9<br>8<br>8<br>8<br>8 | 3<br>1<br>3<br>3<br>2<br>2<br>6<br>6 | 8<br>8<br>8<br>0<br>0<br>0 | F<br>F<br>A<br>9<br>B<br>B<br>B | 9<br>9<br>9<br>9<br>8<br>8<br>8 | F<br>F<br>6<br>7<br>7<br>7 | 020<br>048<br>020<br>048<br>040<br>041<br>042<br>043 | $P + W_1 + P, MA$<br>$P + W_1 + P, MA$<br>$D + W_2 + P, MA$<br>$D + W_2 + MA$<br>P + E (DISK)<br>P + E (DISK)<br>P + E (DISK)<br>P + E (DISK) | | Mnemonic | Add | | | | М | Co | de | | | | Next Address<br>Group | Operation | |----------|-----|---------------------------------|---------------------------------|--------------------------------------|-----------------------|---------------------------------|--------------------------------------|----------------------------|---------------------------------|--------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LSI | 048 | 0 0 0 | 0<br>0<br>8<br>8 | 0 0 0 | | 7<br>7 | 0<br>0<br>0<br>C | E<br>B | 7<br>9 | 3<br>0 | 054<br>052<br>052 | M-Data → W M-Data → P M-Data → A A → M-Data | | SKPA | 04C | 0 0 0 0 | 0 0 | 0<br>0<br>0 | A<br>A<br>A | 6<br>6 | 0 0 0 | | 5<br>5<br>5<br>5 | 6<br>6 | 052 | $S \cdot L_5 \rightarrow S$ $S \cdot L_5 \rightarrow S$ $S \cdot L_5 \rightarrow S$ $S \cdot L_5 \rightarrow S$ | | SKPB | 050 | 0 0 0 | 6<br>6<br>6<br>6 | 4<br>4<br>4<br>4 | 4<br>4<br>4<br>4 | 3<br>1<br>1<br>3 | 8<br>8<br>8<br>3 | F<br>B<br>B | 8<br>B<br>B | | 020<br>020<br>020<br>020<br>020 | $P+W_4 \rightarrow P, MA$<br>$P \rightarrow MA$<br>$P \rightarrow MA$<br>$P+W_4 \rightarrow P, MA$ | | RIADO | 054 | 0 | 4 | С | 9 | 5 | 8 | 6 | 0 | 0 | 04A | W + MA | | MRWI* | 055 | 0 | 0 | С | В | В | 0 | E | 7 | 1 | 05C | M-Data → W | | RBOP | 056 | 0 | 4<br>4 | 8<br>8 | E<br>F | 3 | 4<br>4 | E<br>E | 7<br>7 | 1<br>1 | 070<br>078 | M-Data → W<br>M-Data → W | | MRWI | 058 | 0<br>0<br>0 | 1<br>5<br>9<br>D | 4<br>4<br>4<br>4 | CDCD | 2<br>3<br>2<br>3 | 0<br>8<br>0<br>8 | F<br>F<br>9 | 4<br>4<br>4<br>4 | E 6 6 | 060<br>068<br>060<br>068 | $W_3 \rightarrow W$<br>$W_3 \rightarrow W$ , MA<br>$D+W_3 \rightarrow W$<br>$D+W_3 \rightarrow W$ , MA | | MRWIB | 05C | 0 0 0 | 1<br>5<br>9<br>D | 4<br>4<br>4<br>4 | C<br>D<br>C<br>D | 0<br>1<br>2<br>3 | 0<br>8<br>0<br>8 | 0<br>6<br>B<br>B | 0<br>0<br>1<br>1 | 0<br>0<br>6<br>6 | 060<br>068<br>060<br>06в | W → MA<br>D+W → W<br>D+W → W,11A | | IDX | 060 | 0<br>0<br>0<br>0<br>0 | 0<br>D<br>D<br>5<br>D<br>D | 0 C C 4 4 4 4 | A<br>A<br>D<br>D<br>D | D<br>F<br>5<br>7<br>7 | 8<br>8<br>8<br>8<br>8 | 6<br>8<br>8<br>6<br>9<br>9 | O F F O F F F | 0<br>1<br>2<br>0<br>1<br>2<br>3 | 056<br>056<br>056<br>06A<br>06A<br>06A | $W \rightarrow MA$ $X/2+W \rightarrow W, MA$ $Y/2+W \rightarrow W, MA$ $W \rightarrow MA$ $X+W \rightarrow W, MA$ $Y+W \rightarrow W, MA$ $Y+W \rightarrow W, MA$ $Z+W \rightarrow W, MA$ | | MRWIE | 068 | 0<br>0<br>2<br>2<br>0<br>0<br>0 | 1<br>1<br>C<br>C<br>1<br>1<br>2 | 4<br>4<br>0<br>0<br>4<br>4<br>5<br>8 | CCOOCCOE | B<br>B<br>5<br>7<br>B<br>3<br>1 | 0<br>0<br>0<br>0<br>0<br>0<br>4<br>4 | EEBBEEEE | 7<br>7<br>6<br>9<br>7<br>7<br>7 | 1<br>1<br>0<br>0<br>1<br>1<br>1<br>1 | 064<br>064<br>003<br>003<br>064<br>060<br>068<br>070 | M-Data + W M-Data + W Rd + M-Data M-Data + Rd M-Data + W M-Data + W M-Data + W M-Data + (RMN) M-Data + W(RMW) | | Mnemonic | Add | | | М | Cod | .e | | | ······································ | | Next Address<br>Group | Operation | |----------|-----|-------------------|--------------------------------------|----------------------------|---------------------------------|--------------------------------------|-----------------|-------------|----------------------------------------|----------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ВҮЕ | 070 | 0 0 2 2 2 2 2 2 2 | 0<br>0<br>C<br>C<br>C<br>0<br>4<br>0 | 0<br>0<br>0<br>0<br>0<br>1 | 7<br>7<br>7<br>0<br>F<br>0<br>F | 2<br>2<br>2<br>5<br>0<br>4<br>0<br>C | D D O C F 8 8 8 | E | 6<br>7<br>5<br>2<br>2<br>8<br>8 | 00000000 | 038<br>038<br>079<br>003<br>079<br>082<br>079<br>086 | W+1 $\rightarrow$ W, Ind<br>W-1 $\rightarrow$ W, Ind<br>Rdu, W <sub>u</sub> $\rightarrow$ Rd<br>Rd1, W <sub>L</sub> $\rightarrow$ M-Data<br>Rd-W $\rightarrow$ Ind<br>W·L(8÷) $\rightarrow$ Ind<br>W·L(8÷) $\rightarrow$ Ind<br>W·L(8÷) $\rightarrow$ Ind | | ADDS | 078 | 2 | С | 0 | 0 | 6 | F | 6 | 1 | 0 | 003 | W <sub>3</sub> → W | | RSM | 079 | 2 | A | 0 | 0 | 5 | 0 | 0 | 0 | 0 | 003 | M-Data → | | вчо | 07A | 2<br>2 | C<br>C | 0 | F<br>O | 2<br>5 | 0<br>C | 7<br>7 | 4<br>8 | 0 | 079<br>003 | $R_{du}, W_{L} \rightarrow Rd$<br>$Wu, RdI \rightarrow M-Data$ | | NMOD | 07C | 0 | 0 | 1 | 2 | 5 | 6 | F | 1 | D | 092 | Spec → (MA) ISER | | вчо | 07D | 2<br>2<br>2 | 0<br>4<br>0 | 1<br>0<br>1 | 1<br>F<br>1 | 4<br>0<br>C | 8<br>3<br>8 | F<br>F<br>F | 0 0 | 0 | 08A<br>079<br>08F | W•L(0+) → Ind<br>W•L(0+) → Ind<br>W•L(0+) → Ind | | LSA | 080 | 0 | C | 1 1 | 0 | 7<br>5 | 0<br>C | B<br>B | 9<br>6 | 0 | 083<br>083 | M-Data → A<br>A → M-Data | | BITE | 082 | 2 | 4 | 0 | 0 | 5 | С | F | 8 | 2 | 003 | W·L <sub>(8+)</sub> → M-Data | | WCWX | 083 | 0 | 2 | 5 | 0 | В | 8 | E | 6 | 0 | 084 | W+1 - W,MA | | LSX | 084 | 0 | C | 1 | 0 | F<br>D | 0 | B<br>B | 9<br>6 | 1 | 087<br>087 | M-Data → X<br>X → M-Data | | BITE | 086 | 2 | 4 | 0 | 0 | 5 | С | F | 8 | 1 | 003 | WVL <sub>(8+)</sub> → M-Data | | WCWY | 087 | 0 | 2 | 5 | 1 | 3 | 8 | E | 6 | 0 | 088 | W+1 → W,MA | | LSI | 088 | 0 | C | 1<br>1 | 1<br>1 | 7<br>5 | 0<br>C | B<br>B | 9<br>6 | 2 | 08B<br>08B | M-Data → Y<br>Y → M-Data | | BITO | 08A | 2 | 4 | 0 | 0 | 5 | С | F | 0 | 2 | 003 | W·L <sub>(0)</sub> → M-Data | | WCWZ | 08B | 0 | 2 | 5 | 1 | В | 8 | E | 6 | 0 | 08C | M-Data → W,MA | | LDE | 08C | 0 | C<br>C | 1<br>1 | 1 | F<br>D | 0<br>C | B<br>B | 9<br>6 | 3<br>3 | 08F<br>08F | M-Data → Z<br>Z → M-Data | | BITO | 08E | 2 | 4 | 0 | 0 | 5 | С | F | 0 | 1 | 003 | WVL(0) + M-Data | | WCWZ | 08F | 0 | 2 | 5 | 2 | 6 | 8 | E | 6 | 0 | 090 . | W+1 + W,MA | | Mnemonic | Add | | | М | Cod | e | | | | | Next Address<br>Group | Operation | |----------|-----|-------------|------------------|------------------|------------------|------------------|------------------|------------------|--------|------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------| | LSB | 090 | 0 | C<br>C | 1<br>1 | 2 2 | 7<br>5 | 0<br>C | B<br>B | 9<br>6 | 4 | 093<br>093 | M-Data → B<br>B → M-Data | | NMOD2 | 092 | 0 | 0 | 1 | 2 | D | С | 6 | 0 | 0 | 096 | W → M-Data | | WCWC | 093 | 0 | 2 | 5 | 2 | В | 8 | Е | 6 | 0 | 094 | W+1 - W,MA | | LSC | 094 | 0 | C<br>C | 1<br>1 | 2<br>2 | F<br>D | 0<br>C | B<br>B | 9 | 5<br>5 | 097<br>097 | M-Data → C<br>C → M-Data | | NMOD3 | 096 | 0 | 0 | 1 | 3 | 5 | 6 | 0 | 0 | 0 | 09A | W+1 → W,MA | | WCWD | 097 | 0 | 2 | 5 | 3 | 3 | 8 | Ε | 6 | 0 | 098 | W+1 → W,MA | | LSD | 098 | 0 | C<br>C | 1<br>1 | 3<br>2 | 7<br>5 | 0<br>C | | 9<br>6 | 6<br>6 | 09B<br>09B | M-Data → D<br>D → M-Data | | MNOD4 | 09A | 0 | 0 | 1 | 3 | D | С | В | В | 0 | 09E | P → M-Data | | MRWE | 09В | 0 | 2 | 5 | 3 | В | 8 | E | 6 | 0 | 09C | W+1 → W,MA | | LSE | 09C | 0<br>0 | C | 1 | 3 | F<br>D | 0<br>C | B<br>B | 9<br>6 | 7 | 09F<br>09F | M-Data → E<br>E → M-Data | | NMOD5 | 09E | 0 | . 6 | 0 | 7 | 7 | 2 | E | 7 | 1 | 03A | Int Data → W | | WCWS | 09F | 0 | 2 | 5 | 4 | 3 | 8 | E | 6 | 0 | 0A0 | W+1 → W → MA | | LSS | 0A0 | 0 | 4<br>4 | 0 | 0 | 7<br>5 | 0<br>C | E<br>B | 7<br>A | 5<br>0 | 003<br>003 | M-Data → S<br>S → M-Data | | STBY | 0A2 | 0 | 7<br>6 | D<br>9 | 6<br>4 | 0<br>4 | 0<br>0 | F<br>O | 3<br>0 | D<br>0 | 0B0<br>0A2 | WAIT | | SPO | 0A4 | 0<br>0<br>0 | 2<br>0<br>0<br>0 | D<br>1<br>2<br>2 | 5<br>C<br>1 | 0<br>3<br>C<br>C | 0<br>8<br>0<br>0 | O<br>E<br>F<br>F | 6<br>0 | 0<br>2<br>D<br>D | 0A8<br>0E0<br>10E<br>10E | $P+1 \rightarrow P,MA$ $0 \rightarrow S_L$ $0 \rightarrow S_L$ | | WMD | 0A8 | 0<br>0<br>0 | 8<br>0<br>7<br>6 | 2<br>1<br>B<br>9 | 4<br>5<br>6<br>4 | 6<br>8<br>0<br>4 | 0 0 0 | F | 3 | 4<br>D<br>B<br>O | 122<br>OAC<br>OBO<br>OA2 | $0 \rightarrow B$ $0 \rightarrow S_L$ WAIT $Wu, \alpha \rightarrow W$ | | SPCD | OAC | 0<br>0<br>0 | B<br>B<br>C | D<br>D<br>2<br>0 | 6<br>6<br>4<br>0 | 6<br>6<br>2<br>6 | 1<br>1<br>1<br>1 | 6<br>6<br>6 | F | 5<br>5<br>5<br>5 | 0B2<br>0B2<br>121<br>003 | $C_{E \to 0}$ , 0 + C, Ind<br>$C_{E \to 0}$ , 1 + C, Ind<br>$C_{E \to 0}$ , 0 + C, Ind<br>$C_{E \to 0}$ , 1 + C, Ind | | Mnemonic | Add | | | М | Cod | e | | | | | Next Address<br>Group | Operation | |----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------|--------------------------------------|--------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WAIT | ОВО | 0<br>0 | 7<br>6 | D<br>4 | 6<br>4 | 8 | 0<br>8 | 0<br>8 | | 0 | 0B4<br>020 | P → MA | | SFBD | 0В2 | 0 | B<br>B | D<br>D | 7<br>7 | 2 2 | 1 | 6<br>6 | | 4<br>4 | OB8<br>OB8 | $B_{E\to 0}$ , $0 \to B$ , Ind $B_{E\to 0}$ , $1 \to B$ , Ind | | WAITA | 0В4 | 0 | 7<br>6 | D<br>4 | 6<br>4 | 8 | 0<br>8 | O<br>E | | 0 2 | 0B4<br>020 | P+1 + P,MA | | SFBM | 0В6 | 0<br>1 | C<br>8 | 1 | 7<br>6 | 6<br>E | 1<br>0 | 6<br>1 | | 4 | OBB<br>OB6 | 0,B <sub>F+1</sub> → B,Ind<br>B+A + B | | SBA | 0в8 | 1 | 8<br>8 | 1 | 7<br>7 | 6<br>6 | 1 | 2<br>1 | | 4<br>4 | OBA<br>OBA | B-A → B, Ind<br>B+A → B, Ind | | CTSD | ОВА | 0 | 3 | 5 | 5 | A | 0 | E | 6 | 4 | 0AC | S+1 + S | | CTSM | ОВВ | 0 | 3 | 5 | 7 | A | 0 | E | 6 | 4 | ОВС | S+1 + S | | SFCM | OBC | 0 0 0 | B<br>B<br>B | D<br>D<br>E<br>E | 6<br>6<br>4<br>4 | E<br>E<br>2<br>2 | 1<br>1<br>1 | 6<br>6<br>6 | B<br>A | 5<br>5<br>5<br>5 | 0B6<br>0B6<br>120<br>120 | $0, C_{F+1} \rightarrow C, Ind$<br>$1, C_{F+1} \rightarrow C, Ind$<br>$0, C_{F+1} \rightarrow C, Ind$<br>$1, C_{F+1} \rightarrow C, Ind$ | | ROL | 0C0<br>0C9<br>0CA | 2<br>2<br>0<br>2<br>2<br>2<br>2<br>0<br>2<br>2<br>2<br>0<br>2<br>2<br>2<br>0<br>2<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>0<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | 000000000400000 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>6<br>6<br>1<br>6<br>6<br>6<br>6<br>6 | F0000F00F000F00 | 0<br>6<br>6<br>6<br>6<br>6<br>6<br>6 | 3<br>0<br>0<br>4<br>1<br>0<br>5<br>2<br>3<br>6<br>0<br>4<br>1<br>0 | 000000000000000 | 003<br>003<br>052<br>003<br>003<br>003<br>052<br>003<br>003<br>001<br>003<br>003<br>003<br>003 | R <sub>D</sub> -W → Ind<br>R <sub>D</sub> ·W → Ind<br>W → Ind<br>R <sub>D</sub> ⊕ W → Ind<br>R <sub>D</sub> + W → Ind<br>R <sub>D</sub> -W → R <sub>D</sub> , Ind<br>R <sub>D</sub> ·W → R <sub>D</sub> , Ind<br>W+1 → MA<br>W → R <sub>D</sub> , Ind<br>R <sub>D</sub> ⊕ W → R <sub>D</sub> , Ind<br>R <sub>D</sub> ⊕ W → R <sub>D</sub> , Ind<br>R <sub>D</sub> ⊕ W → R <sub>D</sub> , Ind<br>R <sub>D</sub> ⊕ W → R <sub>D</sub> , Ind<br>R <sub>D</sub> +W → R <sub>D</sub> , Ind<br>R <sub>D</sub> +W → R <sub>D</sub> , Ind | | Mnemonic | Add | | | м | Code | | | | | | Next Address<br>Group | Operation | |----------|-----|---------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------------|---------------------------------|--------------------------------------|----------------------------|------------------|---------------------------------|---------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SEX | ODO | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | B B C C 8 8 C 8 8 C C | D D 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0000000000000 | 6 6 6 6 6 6 6 6 6 6 | D D D D D D D D D D | 6 | A A A A 9 9 9 8 8 8 A B A B | 0000000000000 | 0E2<br>0E2<br>0E3<br>0E3<br>0E2<br>0E2<br>0E3<br>0E2<br>0E3<br>0E2<br>0E3<br>0E3 | C,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>O,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>O,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>O,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>O,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>R <sub>DO</sub> ,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>R <sub>DO</sub> ,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>R <sub>DO</sub> ,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>R <sub>DF</sub> ,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>R <sub>DF</sub> ,R <sub>DF+1</sub> +R <sub>D</sub> ,Ind<br>O,R ,Ind | | RLV | 0E0 | 0 | . 3 | 1 | 8 | 3 | 0 | E | 7 | l | 000 | M-Data → W | | IVP1 | 0E1 | 0 | 0 | 2 | 1 | 3 | 0 | E | 7 | 3 | 108 | M-Data → P | | SCS | OE2 | 0 | 3<br>6 | 5<br>4 | A<br>4 | 2<br>2 | 0<br>8 | E<br>E | 6<br>6 | 4<br>2 | 0D0<br>020 | S+1 → S<br>P+1 → P,MA | | SP1 | OE4 | 0 0 0 0 | . 1<br>1<br>1 | 5<br>1<br>1<br>2 | D<br>E<br>F<br>O | 0<br>0<br>0 | 0<br>0<br>0 | 0 0 0 | 0 | 0<br>0<br>0<br>0 | 0E8<br>0F0<br>0F8<br>100 | | | CTRL | OE8 | 0 0 0 0 0 0 | 4<br>4<br>4<br>4<br>4 | 0 0 0 0 0 | 0<br>0<br>0<br>0<br>0 | 5<br>4<br>6<br>4<br>6<br>6<br>4 | E 0 0 0 0 0 | 6 F F F F F | 0<br>1<br>8<br>2<br>4<br>8<br>4 | 0<br>D<br>6<br>D<br>6<br>5<br>D | 003<br>003<br>003<br>003<br>003<br>003<br>003 | W+SYNC ISER S·L <sub>8</sub> $\rightarrow$ S ISES S·L <sub>4</sub> $\rightarrow$ S SVL <sub>8</sub> $\rightarrow$ S PMA | | RCS | OFO | 0<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>0 | 4<br>C C E<br>8<br>8<br>C 4 | 0<br>0<br>0<br>4<br>0<br>0<br>0 | 0<br>0<br>0<br>4<br>A<br>A<br>0 | 4<br>4<br>5<br>9<br>6<br>6<br>6<br>4 | 0<br>0<br>D<br>9<br>0<br>0 | B<br>B<br>B<br>B | 6<br>C<br>E | 0 0 0 0 0 0 | | RS+RD(NO-OP) RD+PD(X+ISE) RD+DSPLY RD-I RD+P RD+P(X+ISE) RD+P(X+ISE) RD+S RD+S RS+RD(NO-OP) | | Mnemonic | Add | | | М | Cod | e | | | | | Next Address<br>Group | Operation | |----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------|----------------------------|--------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RCD | OF8 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>0 | 0000004 | 0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0 | 6<br>6<br>6<br>6<br>6<br>6<br>4 | 0<br>0<br>0<br>0<br>0<br>0 | 7<br>7<br>B<br>7 | F<br>9<br>6<br>C<br>A | 0 0 0 0 0 0 | 003<br>003<br>003<br>003<br>003<br>003<br>003<br>003 | 0,0-RD + RD RDU, RDU + RD CNSL + RDU + RD CNSL + RD CNSL + RD RDL RDE + RD RDE + RD, Ind | | RCO - | 100 | 2<br>0<br>2<br>2<br>2<br>0<br>2<br>0 | C 3 C C 3 C O | 2<br>E<br>O<br>O<br>E<br>O<br>2 | 1<br>0<br>0<br>0<br>0<br>0 | 0<br>4<br>6<br>6<br>6<br>4<br>6<br>A | D<br>O<br>D<br>D<br>O<br>O | 6<br>0<br>6<br>6<br>6<br>6<br>6<br>E | E<br>7<br>0<br>6 | 0000000 | 109<br>10A<br>003<br>003<br>003<br>102<br>003<br>10C | $R_{D-1}^{+\text{Ind}}$ $R_{DE+0}, 0 \rightarrow R_{D}, \text{Ind}$ $R_{DE+0}, 1 \rightarrow R_{D}, \text{Ind}$ $R_{D-1}^{DE+0} \rightarrow R_{D}, \text{Ind}$ $R_{D+1}^{+} \rightarrow R_{D}, \text{Ind}$ $S \rightarrow W$ | | IVP2 | 108 | 0 | 4 | 2 | 4 | 5 | 8 | 6 | 0 | 0 | 123 | W + MA | | CMPL | 109 | 2 | С | 0 | 0 | 6 | С | В | 8 | 0 | 003 | $\overline{R}_{D} \rightarrow R_{D}$ | | RLR | 10A | 2<br>2 | C<br>C | 0 | 0 | 4<br>6 | F<br>F | | 6<br>6 | 0 | 003<br>003 | $R_{D}^{+}$ Ind $R_{D+1}^{+}$ + $R_{D}^{-}$ , Ind | | ADDS1 | 10C | 0 | 0 | 0 | F | 2 | 0 | F | 3 | E | 078 | W+R <sub>D</sub> - R <sub>D</sub> , Ind | | DTIM | 10D | 0 | 4 | 0 | 6 | В | 3 | Ε | 7 | 1 | 035 | I/O Data → W | | SHI | 10E | 0 | 3 | 5 | A | 2 | 0 | F | E | 5 | 000 | SVL <sub>E</sub> → S | | DTIR | 10F | 3 | 4 | 0 | 0 | 7 | 3 | В | 9 | 0 | 003 | I/O Data + R <sub>D</sub> | | RO | 110 | 3<br>0<br>3<br>3<br>3<br>0<br>3<br>3<br>3<br>0<br>3<br>3<br>3<br>0<br>3<br>3<br>3<br>0<br>3<br>3<br>3<br>3<br>0<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3 | 0040004000400040 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0000000000000000 | 44444466436646 | F C O C C F C O C C F O C | 2<br>3<br>0<br>0<br>4<br>1<br>0<br>5<br>2<br>3<br>0<br>0<br>4<br>1<br>0<br>5<br>2<br>3<br>0<br>0<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | 00000000000 | 00000000000000 | 003<br>003<br>003<br>003<br>003<br>003<br>003<br>003<br>003<br>003 | R <sub>D</sub> - R <sub>S</sub> + Ind<br>R <sub>D</sub> · R <sub>S</sub> + Ind<br>R <sub>S</sub> + Ind<br>R <sub>D</sub> + R <sub>S</sub> + Ind<br>R <sub>D</sub> + R <sub>S</sub> + Ind<br>R <sub>D</sub> + R <sub>S</sub> + Ind<br>R <sub>D</sub> - R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> - R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> - R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind<br>R <sub>D</sub> + R <sub>S</sub> + R <sub>D</sub> , Ind | | Mnemonic | Add | | | М | Cod | e | | | | Next Address<br>Group | Operation | |----------|-----|---|---|---|--------|---|---|-----|-----|-----------------------|---------------------------------------------------------------------| | FIX | 120 | 0 | | | 4<br>0 | | | E 6 | | 020<br>003 | $P+1 \rightarrow P$ , MA<br>$R_D \rightarrow + R_S \rightarrow R_D$ | | MPY | 122 | 0 | 0 | 1 | 7 | 8 | 0 | F ( | ) [ | OBC | 0 + S <sub>L</sub> | | IVP3 | 123 | 0 | 0 | 0 | A | 7 | 0 | Е 6 | 5 3 | 123 | $M$ -Data $\rightarrow P (D_F \rightarrow ISE)$ | # GA-16/110/220 mnemonics list | | Α | | D | |--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ABRT ADR3E ADR3F ADRL ALCL ALIOA ALIOD ALMA ALMD ALSYN ASYNC | ABORT (Memory Overlay Active) CNSL SWS/Internal Mask & 64K Mode CNSL-TTY Address Load Enable ALU to Console (Register Data) RALU Output to I/O ADDR RALU Output to I/O Data RALU Output to Memory Address RALU Output to Memory Data RALU Output to SYNC SYNC Strobe | D3 DA DACK, DACK1 DACKR DCHN, DDTP DDTPR DIBE DI3 DMAEN DMAER DMAK DMAK1 | Psuedo D3 (SPC-16) Data Avail (CNSL-TTY UART) SPC-16 DMA Dack Reset SPC-16 DMA DDTP Reset Data In-Bus Enable Processor Internal D3 DMA #1 Enable DMA Error (From MPP Option) DMA 1 or 2 Ack. DMA #1 Ack. | | | В | DMAK2<br>DMC | DMA #2 Ack. DMA Active (SPC-16) | | BCK8<br>BKINT<br>BKRS<br>BUSY | Gate Delayed CK8 Break Interrupt Break Reset Memory Busy F/F for DMA(SPC-16)(CPU2) | DMCR<br>DMRQ1<br>DMRQ2<br>DPSO, DREQ | DMC Reset<br>DMA #1 Req.<br>DMA #2 Req.<br>SPC-16 DMA | | | С | DTP<br>DTP1 | SPC-16<br>Processor Internal DTP | | C1,C2,<br>C4, C8 | | | Ε | | C9<br>C8C1<br>C8C2 | DMA Timing Counter Outputs (Binary)<br>C8 and C1<br>C8 and C2 | ENTER | CNSL "enter" Sw. | | CA+<br>CA- | Processor 'A' Clock Processor 'B' Clock $(\overline{A})$ | FAP | SPC-16 | | CCK<br>CFBF | Control Clock (100 + ns. Into CA+)( $CK2+$ ) Multiple Crom Feedback | FE | Framing Error (CNSL-TTY UART) | | CIEN<br>CK1,CK2,<br>CK8 | CNSL Int. Enable Mask Processor Timing Counter Outputs | FGLP<br>FTCH | Foreground Status<br>Processor I-Fetch Indicator | | CLDS | (Binary) Cold Start | | I | | CNTL<br>CRDE<br>CRRE | SPC-16 Control to I/O Crom/RALU Drive Enable (To T.D. Bus) Crom/RALU Receive Enable (From T.D. Bus) CNSL Int (Polled) | IACK<br>IHMRQ<br>IHLD<br>IHOLD | SPC-16 Inhibit Memory Req. SPC-16 "IHLD" Internal | | CTR3F | CNSL-TTY Control Strobe CTRL X '3F' | INACK<br>INBOO thru<br>INB15 | SPC-16 "IACK" SPC-16 | | I | | N | |-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------| | INDAL Int. Data to RALU INT Interrupt Req. to Crom IOA3E I/O Addr's X'3E' Decode IOA3F I/O Addr's X'3F' Decode IOBSY I/O Busy | NC48<br>NIIE<br>NIIEC<br>NIIR1<br>NIIR2 | Not C8 or C4 N.I. Int. Enabled N.I. Int. Mode Control Ext. N.I. Int. #1 Ext. N.I. Int. #2 | | IODAL I/O Data to RALU IOR I/O Reset (CNTL X'3E' Decode) IORAD I/O 'Read' F/F | | . 0 | | IPDO thru IPDA Crom/RALU M Code Interface Bus IPDA thru IPDH Crom/RALU M Code Interface Bus | OTBOO<br>thru<br>OTB15 | SPC-16 Out Bus | | IPLSW IPL Sw. Remote IPOD3 Inhibit Pol1/D3 IPRS SPC-16 | DED. | P | | IPSI SPC-16 IPSO SPC-16 IREQ SPC-16 ISE SPC-16 | PFD<br>PMA<br>POLL<br>POLLC | Power Fail Detect Pulse Monitor Alarm SPC-16 Poll Clock ("Poll" and not "IHLD") | | ISEO ISE Control from RALU L | POLLI<br>PRRT | Internal Poll Processor Reset From -110 | | T. D. O | | R | | LR00 thru LR09 Buffered T.A. Bus (Mem. Addr.) CPU2 to SCI | RCINT<br>RCSW | Reset Cnsl. Int.<br>Read Cnsl. Sws. | | LSADD Load Start Addr. | RD<br>READ | CNSL-TTY Rcv. Data<br>SPC-16 | | MD000 thru | RESET 4<br>REST,<br>REST2, | Processor Internal Reset | | MD15 Memory Data Bus MDAL Mem. Data to RALU | REST3,<br>REST4 | Processor Internal Reset | | MDRY Mem. Data Ready MEMPR Mem. Protect MEMPY Mem. Parity Error | RI<br>RMW | Cnsl-TTY Rcv. Input (UART) Read-Modify-Write SPC-16 DMA | | MREQ Mem. Req. | ROIN<br>RSET+ | Buffered RSET- | | MS1K Most Sig. 1K Mem. Block Decode/ Latch | RSET- | Bi-directional Processor<br>Reset | | MSTR SCI Mem. Start Read MWRE Mem. Write Enable MWRT DMA Write Select (SPC-16) | RTCKE<br>RTCKI<br>RTCKI | Real-Time Ck. Enable Real-Time Ck. Input | | MYPR My Priority (Interrupt) MO thru M9 Crom/RALU Data Bus | (ENABLE) | Real-Time Ck. Enable (RTCKE) Return Indirect Vector | | MA thru MF Crom/RALU Data Bus | RUN | Processor Run Mode | S Χ | SCRCK | | XD | XMTR Data (CNSL-TTY) | |----------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------| | SEMI<br>SFEC<br>SLMD<br>SMBRY | Semiconductor Mem. System Safe Line SCI Read Sel. SCI BSY/RDY | +5VB<br>+8V<br>+10 usec | +5 (BATT B.U. Option) Crom/RALU VDD Supply TTY Paddle Board Chopper | | SMBSY<br>SPAL<br>STEP<br>STM1<br>STPCN | SCI BSY/RDY Special Input to RALU (Restart) Cnsl. Step Switch SCI Start Stop Counter Stop Mem. Read | 20MH<br>20MH+1<br>20MHZ<br>64KM | Drive<br>20MHZ System Master Clock<br>20MHZ System Master Clock<br>20MHZ System Master Clock<br>64K Mem. Mode | | STRD<br>SVI<br>SWA thru | Cnsl. 'SVI' Switch | | | | SWD<br>SWALI<br>SYNC<br>SYRT | Encoded Cnsl. Reg. Select Sws.<br>Cnsl. Sw. Data to Crom/RALU<br>SPC-16<br>SPC-16 | | | | | Т | | | | TACK<br>TAOO thru | Buffered Proc. 'A' Clock Ref. | | | | TA15<br>TBREQ | Mem. Addr. Bus<br>'B' Clock T.D. Bus Req. (CROM/<br>RALU) | • | | | TD00 thru<br>TD15<br>TEST | Mem. Data Bus<br>SPC-16 | | | | THRE | XMTR Holding Reg. Empty (CNSL-TTY UART) | | | | TRE<br>TRO | XMTR Reg. Empty (CNSL-TTY UART) XMTR Reg. Output-Serial (CNSL-TTY UART) | | | | TTYI<br>TYIEN<br>TYR | CNSL-TTY Int. CNSL-TTY Int. Enable Mask CNSL-TTY Framing Error to Master Reset (UART) | | | | | W | | | | WAIT WIPRS WRIT WRTS*, | Wait Inst. Indicator Wait for 'IPRS' SPC-16 | | | | WRTS+,<br>WRTS- | SCI Write Strobe Edge Select (*220-Ground "WRTS-" Jumper "WRTS*" to "WRTS+" 330-+5 to "WRTS" Jumper "WRTS*" to "WRTS-") | | | | | | | | # early GA-16/110/220 configurations Figures D-1 and D-2 show the configurations of the compact chassis built prior to November 1976. The major changes made in currently shipped units provide additional space between CPU-1 and CPU-2 modules to accommodate a redesigned SCI module. (See Section 3, Figure 3-2.) Tables D-1 and D-2 show connector assignments for early compact chassis in both GA-16/110 and GA-16/220 configurations. Figures D-3 and D-4 show the configurations of jumbo chassis built prior to October 1976. To provide more space between CPU-1 and CPU-2 modules to accommodate redesigned SCI module an I/O slot has been eliminated in currently shipped units. Table D-3 and D-4 shows connector assignments for early jumbo chassis in both GA-16/110 and GA-16/220 configurations. Figure D-3 shows the priority interrupt chain wiring for early compact and jumbo chassis. The circled numbers are keyed to Table 2-5, Section 2, for descriptions of controls and indicators. Figure D-1. GA-16/110 System in Compact Chassis (No MPP) Figure D-2. GA-16/220 System in Compact Chassis (No MPP) Table D-1. Connector Assignments for Compact Chassis, GA-16/110 Computer System | Front/Module | Rear/Interface | |----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | Jl Main power supply | - AC input connector and system grounding | | J2 Cable Interface Driver (CID) | J13 Holes for connector for optional external power supply cable. | | J3 J4 l/O controllers or shorting boards. J5 J6 lenpty slots between con- | J14 Cable I/O expansion chassis (6 ft. maximum). | | trollers or CID to maintain interrupt chain continuity. | J16 Paddleboards and cables interfacing | | J8 110 module with optional piggyback memory and IPL ROM. | J17 controllers (in J3 through J7) to peripheral devices. J18 | | J9 4K/8K memory module or DMT controller (no write protect). | J19 ) J20 Access to cold-start (CLDS-) memory mode | | J10 4K/8K memory modules or Mem-<br>J11 ory Parity Protect module. | (64KM+), and remote control lines<br>(IPLSW-, PFD-, RSET-, RUN-) control<br>lines. | | J12 J12 also used for battery backup regulator module. | J21 Memory Service Module if auxiliary power supply is not used. | | - Auxiliary power supply and battery pack (use regulator module in J12). | - AC cord and terminals for external 12-volt battery on rear of auxiliary power supply. | | | | Table D-2. Connector Assignments for Compact Chassis, GA-16/220 Computer System | | Front/Module | | Rear/Interface | |------------|-----------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------| | J1 | Main Power Supply | - | AC input connector and system grounding terminals on power supply. | | J2 | Cable Interface Driver (CID) | J13 | Connector for optional external power supply cable. | | J3<br>J4 | I/O controllers or shorting boards. | J14 | Cable to I/O expansion chassis (6 ft. maximum). | | J5<br>J6 | Shorting boards are used in empty slots between control-<br>lers or CID to maintain in- | J15 | ) | | 70 | terrupt chain continuity. | J16 | Paddleboards and cables interfacing | | J7 | MHSDC controller, if used, should go into J7. | J17 | controllers (in J3 through J7) to peripheral devices. | | 18 | 220 module with optional System Console Interface | J18 | | | <b>1</b> 9 | 110 module with optional piggyback memory. | J20 | Serial I/O paddleboard with connector to TTY or CRT also provides access to cold-start (CLDS-) jumpers and remote | | J10 | 4K/8K memory modules or<br>Memory Parity Protect | | control lines (IPLSW-, PFD-, RSET-, RUN-). | | J11 | Module. | J21 | Memory Service Module if auxiliary | | J12 | J12 also used for battery backup regulator module. | | power supply is not used. | | - | Auxiliary power supply and battery pack (use regulator module in J12). | | AC cord and terminals for external 12-volt battery on rear of auxiliary power supply. | Table D-3. Connector Assignments for Jumbo Chassis, GA-16/110 Computer System | | Front/Module | | Rear/Interface | |------------|------------------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------| | J1 | Cable Interface Driver (CID). | J19 | Cable to I/O expansion chassis, 6 ft. maximum. | | J2 | | J20 | 1 | | J3<br>J4 | I/O controllers or shorting boards. | J21 | | | J5<br>J6 | Shorting Boards are used in empty slots between | J22 | | | <b>J</b> 7 | controllers or CID to maintain interrupt chain | J24 | Paddleboards and cables interfacing 1/0 controllers (in J2 through J10) | | J8<br>J9 | continuity. | J25 | to peripheral devices. | | J10 | | J26 | | | J11 | 110 =================================== | J27 | | | JII | 110 module with optional piggyback memory and IPL ROM | J28 | ) | | J12 | 4K/8K memory module or DMT controller (no write protect). | J29 | Access to cold-start (CLDS-), memory mode (64KM+), and remote control lines (IPLSW-, PFD-, RSET-, RUN-). | | J13 | | J30 | Memory Service Module if auxiliary | | J14 | 4K/8K memory modules or memory parity protect | | power supply is not used. | | J15 | module. | J32 | Power cable from external power supply. | | J16 | J18 also used for battery backup regulator module. | J33 | System grounding terminals. | | J17 | | - AC cord and terminals 12-volt battery on re | | | J18 | | | power supply. | | - | Auxiliary power supply and battery pack (use regulator module in J18). | | | Table D-4. Connector Assignments for Jumbo Chassis, GA-16/220 Computer System | | Front/Module | | Rear/Interface | | |------------|--------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------|--| | Jl | Cable Interface Driver (CID). | J19 Cable to I/O expansion chassis (6 ft. maximum). | | | | Ј2 | ). | J20 | | | | J3<br>J4 | I/O controllers or shorting boards. | J21 | | | | J5 | Shorting boards are used | J22 | | | | J6 | in empty slots between controllers or CID to | J23 | Paddleboards and cables interfacing | | | J7 | maintain interrupt chain continuity. | J24 | I/O controllers (in J2 through J10) to peripheral devices. | | | J8 | Continuity. | J25 | to peripheral devices. | | | J9 | MHSDC controller, if | J26 | | | | J10 | used, should go into | Ј27 | | | | J11 | 220 module with optional | J28 | | | | | System Console Interface. | J29 | Serial I/O paddleboard with connector for TTY or CRT. Also provides access | | | J12 | 110 module with optional piggyback memory. | odule with optional to cold-start (CLDS- | | | | J13<br>J14 | 4K/8K memory modules or<br>Memory Parity Protect | J30 | Memory Service Module if auxiliary | | | J15<br>J16 | Module. (J18 also used for battery | | power supply is not used. | | | J17<br>J18 | backup regulator module. | J32 | Power cable from external power supply. | | | | Auxiliary power supply and | J33 | System grounding terminals. | | | | battery pack (use regulator module in J18). | - | AC cord and terminals for external 12-volt battery on rear of auxiliary power supply. | | | | | | | | Figure D-3. GA-16/110 System in Jumbo Chassis (with MPP) Figure D-4. GA-16/220 System in Jumbo Chassis (with MPP) Figure D-5. Typical I/O System Interrupt Chain for Early Compact Jumbo Chassis # GA-16/220 microconsole signal index | ABRT- | J3-18 | 3C1 | |------------------|----------------|-----------------| | BKINT- | J1-14 | 3 <b>C</b> 4 | | BKRS- | J1-11 | 2B4, 3C4 | | BUSS- | | 4A1, 5A1 | | | | 7112 9 2111 | | CLDS- | J3-20 | 2B1 | | CMD15+ | | 4C2 | | CMD14+ | | 4C2 | | CMD13+ | | 4C2 | | CMD12+ | | 4C2 | | CMD11+ | | 4B2 | | CMD10+ | | 4B2 | | CMD09+ | | 4B2 | | CMD08+ | | 4B2 | | CMD03+ | | 5B2 | | CMD02+ | | 5B2 | | CMD01+<br>CMD00+ | | 5B2 | | CNSL- | | 5B2<br>2B4, 3A4 | | 01.01 | | 254, 3A4 | | IPLF- | | 2A3 | | IPLS- | | 4A1, 5A1 | | IPLSW- | J1-22 | 2B4, 3B4 | | LR09+ | J1-24 | 3D4, 5A4 | | LR08+ | J1-23 | 3D4, 4C4, 5A4 | | LRO7+ | J1-21 | 4C4, 4B4, 5B4 | | LRO6+ | J1-19 | 4C4, 4B4, 5B4 | | LR05+ | J1-20 | 4C4, 4B4, 5B4 | | LR04+ | J1-17 | 4C4, 4B4, 5B4 | | LRO3+ | J1-18 | 4D4, 4B4, 5B4 | | LRO2+ | J1-15 | 4D4, 4B4, 5B4 | | LRO1+ | J1-16 | 4D4, 4B4, 5B4 | | LR00+<br>LR09- | J1-13 | 4D4, 4B4, 5B4 | | LSADD+ | J3 <b>-</b> 15 | 3D3, 5B4<br>2D4 | | LOMD ( | 33-13 | 204 ,, | | MD06- | J2-25 | 5D1 | | MD05- | J2-27 | 5C1 | | MD04- | J2-26 | 5C1 | | MD03- | J2-14 | 5B1 | | MD02- | J2-2 | 5B1 | | MD01- | J2-20 | 5B1 | | MD00- | J2 <b>-</b> 16 | 5B1 | | | | | | J2-24<br>J2-4<br>J2-22<br>J2-18 | 4D1<br>4D1<br>4C1<br>4C1<br>4B1<br>4B1<br>4B1<br>4B1<br>4D1<br>3D1, 4A1, 5A1<br>3C1, 4A1, 5A1<br>3B4<br>3B4 | |------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J3 <b>-</b> 22 | 2B4 | | | 3D1, 4A1, 5A1 | | J1-7<br>J3-17<br>J3-13<br>J3-14<br>J1-8 | 3D4<br>3C1<br>3A1<br>3B1<br>3D4 | | J2-5<br>J2-23<br>J2-3<br>J2-21<br>J2-17<br>J2-1<br>J2-13<br>J2-1 | 2D1<br>2D1<br>2D1<br>2D1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C1<br>2C | | J3-10<br>J3-9<br>J3-11 | 3A1, 4A1, 5A1<br>3A4<br>3A4<br>3D1 | | | J2-8 J2-13 J2-6 J2-24 J2-4 J2-22 J2-18 J2-28 J1-12 J1-9 J3-22 J1-7 J3-17 J3-17 J3-13 J3-14 J1-8 J2-9 J2-7 J2-11 J2-5 J2-23 J2-3 J2-21 J2-17 J2-1 J2-13 J2-1 J2-19 J1-5 | # test and verify programs The enclosed list of applicable Test and Verify programs is supplied to allow a user to order those T&V's required for each individual system configuration. The model number provided is the basic 5-digit code. To correctly order a T&V, two additional digits must be appended to this 5-digit code in the following format: #### XTXXXmf #### where: - x = Alpha or Numeric digit - m = Medium of the requested T&V - f = Format of the requested T&V The Medium of the T&V may be specified as: - L = Listing - C = Card Deck - P = Paper Tape - M = Magnetic Tape The Format may be any of the following: - S = Source Code - B = Binary Code - P = Program Generation System (PGS) - X = Mixed Source It must be noted that not all T&V's are available in all Mediums and Formats. | Model No. | Revision No. | <u>Title</u> | |---------------|--------------|------------------------------------------------| | 4TC02 | 1 | 1575/1579 Sync Data Link Comm Controller | | 4TC03 | 1 | 1578 Synch Data Link Comm Controller T&V | | 4TC05 | 1 | 1574-0001 Isochronous Comm Controller T&V | | 5T000 | 1 | GA-16 System Exerciser T&V | | 5T010 | 1 | GA-16 Signed MPY/DIV T&V | | 5T100 | 1 | GA-16 Series TTY T&V | | 5T110 | 2 | GA-16 Series Memory Parity Protect T&V | | 5T14A | 1 | GA-16 Semiconductor Memory T&V | | 5T18M | 2 | GA-16 Floating Point Processor T&V (Section 1) | | 5T200 | 1 | GA-16 Series High-Speed Paper Tape T&V | | 5T20A | 1 | GA-16 CalComp 936 (3374) Plotter T&V | | 5T30A | 1 | GA-16 H-P 7210 (3375) Plotter T&V | | 5T35A | 1 | GA-16 CalComp 3371/3372 Plotter T&V | | 5T40A | 1 | GA-16 CalComp 936 (3374) DMA T&V | | 5T600 | 1 | GA-16 Card Reader T&V | | 5T610 | 1 | GA-16 Card Punch 3314 T&V | | 5T700 | 1 | GA-16 Series Line Printer T&V | | 5T70A | 1 | GA-16 3345 DMS Disk T&V | | 5 <b>T80A</b> | 1 | GA-16 CCIF T&V | | 5T850 | 1 | GA-16 Series 3346/3347 Disk T&V | | 5T870 | 1 | GA-16 Series 3349 Floppy Disk T&V | | 5T880 | 1 | GA-16 3341/43 Disk w/Sector Bits In Label T&V | | 5T890 | 1 | GA-16 3346/3347 Double Density Disk T&V | | 5T900 | 1 | GA-16 3342 Drum T&V | | 5T950 . | 1 | GA-16 ADDS Console 980 CRT T&V | | 5TA00 | 1 | GA-16 Series 3331 Mag Tape T&V | | 5TE00 | 1 | GA-16 801 Auto Calling Unit T&V | | 5TE05 | 1 | GA-16 Hazeltine 2000 CRT T&V | | 5TE45 | 1 | GA-16 ADC/DAC T&V | | 5TE55 | 1 | GA-16 Digital Process I/O T&V | | 5TE75 | 1 | GA-16 GAARD T&V | # redesigned GA-16/110/220 processor boards This appendix provides a description of the newly designed GA-16/110 (CPU-1) and GA-16/220 (CPU-2) processor boards. These boards can be identified by the following assembly numbers: - CPU-1 Board 31D02573A - · CPU-2 Board 31D02574A The main change in the CPU-1 board is the relocation of the Battery Back-Up Power Supply Switch which is now located between board coordinates Dl and El. When this switch is in the up position, +5VB power for the memories originates from the back-up power supply or the batteries (when AC power is disconnected). When the switch is in the down position, memory power is supplied by the main power supply via the memory service module. #### NOTE The memory service module must be used when the switch is in the down position. The main change in the CPU-2 board is the removal of the two-position 110/9600 baud switch. This switch was replaced by a rotary switch which provides fifteen selectable baud rates. A STOP BIT select switch has also been added which allows a selection of a one- or two-bit "STOP BIT." Figure G-l provides a composite view of the CPU-l and CPU-2 boards containing these switches. The selectable baud rates are also shown in Figure G-l. The remaining switches and indicators have not been changed and can be found in Table 3-3 next to the key numbers (circled). Figure G-1. Redesigned GA-16/110/220 Processor Boards # EPROM programmer application The EPROM Programmer is a single board unit designed to allow data to be transferred from 220 RAM memory to EPROM memory boards utilizing TI TMS 2708JL or equivalent ultraviolet erasable EPROM parts. The Programmer will also program discrete TI TMS 2708JL, GA P/N 70A00369A02 parts. This description of the EPTOM Programmer application is based on GA Specification 82500761A. To use the EPROM Programmer, the following equipment is required: - a. A 220 computer with serial I/O device (TTY or CRT) and RAM memory capacity to contain data to be transferred to the EPROM. - b. An ultra-violet lamp to erase EROM parts. (Model UVS-54, manufactured by Ultra-Violet Products, Inc., San Gabriel, California, or equivalent.) #### H.1 MECHANICAL DESCRIPTION The Programmer board occupies one memory slot in a standard 110/220 enclosure. The board requires five inches of clearance in front of the enclosure and 1-3/4 inches above it. The board has sockets to accept two EPROM chips, the piggyback EPROM board, or the 16K EPROM board. Figures H-1, H-2, and H-3 contain installation drawings of the Programmer. Figure H-1 shows the installation for programming discrete EPROMS (70A00369A02), Figure H-2 shows the installation for programming the EPROM piggyback board (32D02532A), and Figure H-3 shows the installation for programming the 4/8/16K EPROM board (31D02566A). Figure H-1. Programming Discrete EPROMS Figure H-2. Programming Piggyback Board 31D92532A - 7. S1, PROGRAM CONTROL SWITCH 8. 16K EPROM BOARD 9. P3, P4 SOCKETS FOR PROGRAMMING CABLES - 11. BLOCK DISPLAY LEDS 12. PROGRAMMER ENABLE LED - 13. PROGRAMMING SOCKETS ON 16K EPROM BOARD Figure H-3. Programming 4/8/16K EPROM Board 31D02566A #### H.2 ELECTRICAL DESCRIPTION The Programmer board operates on the standard 110/220 memory bus. It uses 2048 addresses above the switch-selectable starting address. The starting address of the Programmer board can be selected on 4K boundaries with a hexadecimal switch, S2, mounted on the board (refer to Table H-1). The first 512 words in the Programmer are assigned to a Read-Only-Memory that contains a Write/Verify/Control program. The second 512 words are dedicated to a Control Function block. The remaining 1024 addresses are assigned to the 1K block of EPROM to be accessed (see Figure H-4 and Table H-1). Table H-l shows the distribution of the Write/Verify/Control program, the Control Functions block, and the lK block assigned to EPROM data within the Programmer for each of 16 start addresses selected by S2. #### H.2.1 CONTROL FUNCTIONS Up to 16K of EPROM may be attached to the Programmer for programming. One 1K block of EPROM to be programmed is selected (addressed) by a store instruction that places a data word in the start address of the Programmer's Control Functions block. The lower four bits of the data word stored at the address of the Control Functions block will select one of 16 possible 1K blocks of EPROM (see Figure H-4). Table H-2 provides addresses for the 16 1K blocks of EPROM. The Programmer has a manual control and indicator to allow the programming function to be enabled or disabled. The Programmer will be disabled by System Reset, Power Up Restart, or by pressing the momentary Press On, Press Off switch. Status is displayed by an indicator provided on the board; On indicates enabled. #### H.2.2 PROGRAMMING The EPROM is programmed by executing store instructions that place the data in the Programmer addresses assigned to the EPROM. This will generate a 25 volt program pulse, drive the CS/WE signal on the selected EPROM to +12 volt, and hold the Write cycle for 1 msec. #### H.2.3 ERASE Before programming, the EPROM is erased by exposing the chip through the transparent lid to high intensity ultraviolet light (wavelength 2537 angstroms). The recommended exposure is ten watt-seconds per square centimeter. This can be obtained by, for instance, 20 to 30 minutes exposure of a filterless Model UVS54 shortwave UV lamp about 2.5 centimeters above the EPROM. After erasure all bits are in the "1" state. | +2048 | | |------------------|--------------------------------------| | | 07FF <sub>16</sub> | | | | | | C. Laure I. Throw | | | Selected EPROM | | | | | +1024 | 0400 <sub>16</sub> | | . 2024 | 03FF <sub>16</sub> Control Functions | | | Write = Select lK Block of EPROM | | | Read = Status Bit 8 | | +512 | 0200 <sub>16</sub> | | | 01FF <sub>16</sub> | | | Write/Verify/Control | | | Program | | Start<br>Address | 0000 | | AUULESS | | The address boundaries shown in the Programmer map are for an S2 start address selection of 0000. Table H-1 shows address boundaries within the Programmer for each of 16 possible start addresses by S2. Figure H-4. Programmer Map Table H-1. Programmer Address Boundaries For S2 Selections | S2 Position | Control<br>From | Program<br>To | Cont<br>Function<br>From | | EP<br>From | ROM<br>To | |-------------|-----------------|---------------|--------------------------|------|------------|-----------| | 0 | 0000 | Olff | 0200 | 03FF | 0400 | 07FF | | 1 | 1000 | 11FF | 1200 | 13FF | 1400 | 17FF | | 2 | 2000 | 21FF | 2200 | 23FF | 2400 | 27FF | | 3 | 3000 | 31FF | 3200 | 33FF | 3400 | 37FF | | 4 | 4000 | 41FF | 4200 | 43FF | 4400 | 47FF | | 5 | 5000 | 51FF | 5200 | 53FF | 5400 | 57FF | | 6 | 6000 | 61FF | 6200 | 63FF | 6400 | 67FF | | 7 | 7000 | 71FF | 7200 | 73FF | 7400 | 77FF | | 8 | -8000 | 81FF | 8200 | 83FF | 84'00 | 87FF | | 9 | 9000 | 91FF | 9200 | 93FF | 9400 | 97FF | | A | A000 | Alff | A200 | A3FF | A400 | A7FF | | В | В000 | Blff | В200 | BBFF | B400 | B7FF | | С | C000 | Clff | C200 | C3FF | C400 | C7FF | | D | D000 | DIFF | D200 | D3FF | D400 | D7FF | | E | E000 | Elff | E200 | E3FF | E400 | E7FF | | F | F000 | F1FF | F200 | F3FF | F400 | F7FF | All address boundaries are in hex. Table H-2. EPROM Addressing in lK Blocks (EPROM Installed in System) (EPROM Installed on Programmer) | | (Installed on Flogrammer) | | | | | |----------------|---------------------------|--------------------------|--|--|--| | EPROM HEX ADDR | BLOCK | HEX ADDR FROM PROGRAMMER | | | | | *0000 to 03FF | 0 | Start ADDR + 400 | | | | | **0400 to 07FF | 1 | Start ADDR + 400 | | | | | **0800 to OBFF | 2 | Start ADDR + 400 | | | | | **0C00 to OFFF | 3 | Start ADDR + 400 | | | | | 1000 to 13FF | 4 | Start ADDR + 400 | | | | | 1400 to 17FF | 5 | Start ADDR + 400 | | | | | 1800 to 1BFF | 6 | Start ADDR + 400 | | | | | 1C00 to 1FFF | 7 | Start ADDR + 400 | | | | | 2000 to 23FF | 8 | Start ADDR + 400 | | | | | 2400 to 27FF | 9 | Start ADDR + 400 | | | | | 2800 to 2BFF | A | Start ADDR + 400 | | | | | 2C00 to 2FFF | В | Start ADDR + 400 | | | | | 3000 to 33FF | С | Start ADDR + 400 | | | | | 3400 to 37FF | D | Start ADDR + 400 | | | | | 3800 to 3BFF | E | Start ADDR + 400 | | | | | 3C00 to 3FFF | F | Start ADDR + 400 | | | | (X'400' is added to the start address on the Programmer board because the IK of storage directly following the Programmer start address is dedicated to the Write/Verify/Control program and the Control Functions block.) <sup>\* =</sup> Discrete EPROM Parts <sup>\*\* =</sup> Piggyback EPROM Board all = 16K EPROM Board #### H.3 PROGRAM DESCRIPTION The Control program included on the Programmer board provides five functions: Program and Verify, Erase Verify, Verify, Test 1 and Test 2. The program is initiated by transferring control from the console to the selected starting address of the Programmer board. Example 1: From console enter X000G CR where X is the 0-F hex digit selected on the starting address switch. This will result in an output to the serial I/O device 'CC?'. The desired control command can now be inputted preceded by an '\$'. The program will then ask for a block number, 'BLOCK'. The block number is a hexadecimal digit assigned to each 1K of EPROM to be accessed (refer to Table H-2). If a single block is to be accessed, enter the single hex digit. If multiple blocks are to be accessed, enter the first and last hex digits separated by a slash (see Example 2). Example 2: Single Block 1 (for EPROM addresses 400<sub>16</sub> to 07FF<sub>16</sub>) If needed, the program will then ask for a From address ('FROM'). This will be the first address of the block of data to be transferred from the 110/220 RAM memory to EPROM. #### H.3.1 PROGRAM AND VERIFY COMMAND #### Example 3: PROGRAM OUTPUT OPERATOR RESPONSE CC? \$PROG CP BLOCK 1/3 CR FROM 0400 CR If the programmer is disabled it will display: ENABLE PROG. PRESS PROG. LFCR ENABLE SW. If the programmer is enabled it will display: LFCR NONE Example 3 will result in 3K words of data starting at address $(0400)_{16}$ to be transferred to EPROM. After each 1K block has been programmed a word for word comparison is done. If no errors are found, an assurance message is printed, 'Verified Block X', and the next block will be programmed. If an error is found, the error is displayed as in Example 4. Example 4: ERROR | FROM | BLOCK | ADDR | IS | S/B | |------|-------|------|------|------| | 0406 | 1 | 006 | 1224 | 1234 | After an error message is printed the program will wait for an operator input. Space will continue to verify the rest of the block. Carriage return will cause a return to the start of the program. #### H.3.2 ERASE VERIFY COMMAND Example 5: PROGRAM OUTPUT OPERATOR RESPONSE CC? \$ERASE CR BLOCK 1/3 CF Example 5 will result in testing 3K of EPROM for erasure (all bits high). If no errors are found, an assurance message will be printed for each block 'Verified Block X'. If an error is found, the error is displayed as in Example 6. Example 6: BLOCK ADDR IS S/B 1 006 FFDF FFFF After each error message is printed the program will wait for an operator input. Space will continue the erase test. Carriage return will terminate the test and return to the start of the program. #### H.3.3 VERIFY COMMAND Example 7: PROGRAM OUTPUT OPERATOR RESPONSE CC? \$VERIFY CR BLOCK 1/3 CR FROM 400 CR Example 7 will result in 3K words starting at address $(0400)_{16}$ to be compared with 3K words of EPROM. If an error is found, it will be displayed as in Example 4. #### H.3.4 TEST COMMAND Example 8: PROGRAM OUTPUT OPERATOR RESPONSE CC? \$TEST1 CR -or-(TEST 2 CR) BLOCK 1/2 CR Example 8 will result in Blocks 1 and 2 being tested for programmability. The test programs all bits to zero in the first location then scans all other locations for zeros. If none are found, the second location is programmed to all zeros and the unprogrammed part scanned. This continues until all locations are zeroed. If no errors are found, the assurance message is printed after each block. If an error is found, the error message is printed as in Example 4. The From display is the address that was programmed to zeroes and the Block/ADDR display is the address where the error was found. If the above two addresses are the same it indicates that the word could not be zeroed or programmed. Test 1 starts at the lowest numerical address and works up. Test 2 starts at the highest address and works down. #### H.3.5 RETURN TO CONSOLE COMMAND Example 9: PROGRAM OUTPUT OPERATOR RESPONSE CC? \$CNSL (CR) Example 9 will cause program control to be returned to the console program. ## H.4 STEP-BY-STEP PROGRAMMING EXAMPLE FOR PIGGYBACK BOARD 31D02532A A program located between Hex addresses $(0400)_{16}$ and $(0B00)_{16}$ is to be transferred to a 2K piggyback EPROM board: - 1. Insure that the EPROM parts are erased by exposing them to the ultra-violet lamp for 45 minutes. - 2. Install the Programmer board in any unused memory slot in the 220 computer. Set the Hex starting address switch, S2, to any unused location (for this example, set S2 to 7). See Figure H-2, item 3 and Table H-1. The Programmer's control RDM program will now start at hex location (7000)<sub>16</sub>. Install the piggyback EPROM board on the Programmer and connect the programming cable (see Figure H-2). - 3. Apply power to the 220 system. Load and verify the program to be transferred with TTY, PTR, etc. Transfer control from the 220 Console program to the programmer control program by entering "7000G" on the keyboard. The control program will respond with "CC?". - 4. Verify that the EPROM parts are erased (all outputs high) by selecting the Erase Verify command as shown in Section 4.2 If any errors are found, erase the EPROMS again as in Step 1, above. After verifying that the EPROMS are erased, enable the Programmer and select the Program and Verify command as shown in Section 4.1. It will take about two minutes to program each 1K block. After two minutes the program will output 'Verified Block 1; (if no errors) and and after two more minutes the program will output 'Verified Block 2' and 'CC?' indicating that the programming operation is complete and no errors were found. #### H.5 STEP-BY-STEP PROGRAMMING EXAMPLE FOR DISCRETE EPROMS 70A00369A A program located between Hex addresses $(0400)_{16}$ and $(07F0)_{16}$ is to be transferred to 1K of EPROM: - 1. Insure that the EPROM parts are erased by exposing them to the ultra-violet lamp for 45 minutes. - 2. Install the Programmer board in any unused memory slot in the 220 computer. Set the Hex starting address switch, S2, to any unused location (for this Example set S2 to 7). See Figure H-1, item 3 and Table H-1. The control ROM program will now start at Hex location (7000)<sub>16</sub>. Install the EPROM chips on the programmer. Observe that Pin 1 of the chips are up as in Figure H-1. - 3. Apply power to the 220 system. Load and verify the program to be transferred with TTY, PTR, etc. Transfer control from the 220 Console program to the programmer control program by entering "7000G" on the keyboard. The control program will respond with "CC?". - 4. Verify that the EPROM parts are erased (all outputs high) by selecting the Erase Verify command as shown in Section 4.2. If any errors are found, erase the EPROMS again as in step 1, above. After verifying that the EPROMS are erased, enable the Programmer and select the Program and Verify command as shown in Section 4.1. It will take about two minutes to program each 1K block. After two minutes the program will output 'Verified Block 1' (if no errors) and 'CC?' indicating that the programming operation is complete and no errors were found. NOTE Discrete EPROMS use the low-order addresses in block 0. # H.6 STEP-BY-STEP PROGRAMMING EXAMPLE FOR THE 4/8/16K EPROM BOARD (31D02566A) A program located between Hex addresses (0000) $_{16}$ and (0FFF) $_{16}$ is to be transferred to a 4K EPROM board: - 1. Insure that the EPROM parts are erased by exposing them to the ultra-violet lamp for 30 minutes. - 2. Install the Programmer board in any unused memory slot in the 220 computer. Set the Hex starting address switch, S2, to any unused location (for this Example, set S2 to 7). See Figure H-3, item 3 and Table H-1. The control ROM program will now start at Hex location (7000)<sub>16</sub>. Install the EPROM board on the programmer and connect the programming cable (see Figures H-3, H-5 and H-6). - 3. Apply power to the 220 system. Load and verify the program to be transferred with TTY, PTR, etc. Transfer control from the 220 Console program to the programmer control program by entering "7000G" on the keyboard. The control program will respond with "CC?". - 4. Verify that the EPROM parts are erased (all outputs high) by selecting the Erase Verify command as shown in Section 4.2. If any errors are found, erase the EPROMS again as shown in step 1, above. After verifying that the EPROMS are erased, enable the Programmer and select the Program and Verify command as shown in Section 4.1. It will take about two minutes to program each 1K block. After two minutes the program will output 'Verified Block 0' (if no errors) and after two more minutes the program will output 'Verified Block 1' and so on until the last block (3) has been programmed and verified. 'CC?' will then be printed indicating that the programming operation is complete and no errors were found. | | | S1 | | S2 | | 4/8/16K<br>31D02566 | | | |---|-------|-------|-------|-------|-------|---------------------|-------|-------| | | B8-15 | 8 | 3C00 | 3800 | 3400 | 3000 | 2000 | 2800 | 2400 | 2000 | | | 3FFF | 3BFF | 37FF | 33FF | 2FFF | 2BFF | 27FF | 23FF | | | B8-15 | 7 | 1000 | 1800 | 1400 | 1000 | 0000 | 0800 | 0400 | 0000 | | - | 1FFF | lBFF | 17FF | 13FF | OFFF | OBFF | 07FF | 03FF | | | BO-7 | В0-7 | B0-7 | B0-7 | B0-7 | BO-7 | во-7 | B0-7 | | 6 | 3C00 | 3800 | 3400 | 3000 | 2000 | 2800 | 2400 | 2000 | | | 3FFF | 3BFF | 37FF | 33FF | 2FFF | 2BFF | 27FF | 23FF | | | B0-7 | B0-7 | B0-7 | B0-7 | B0-7 | B0-7 | BO-7 | во-7 | | 5 | 1000 | 1800 | 1400 | 1000 | 0000 | 0800 | 0400 | 0000 | | | 1FFF | 1BFF | 17FF | 13FF | OFFF | OBFF | 07FF | 03FF | | | A | В | D | E | F | G | J | К | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - 1. BO-7 refers to bits 0,1,2,3,4,5,6,7 - 2. 0000 refers to hex address boundaries 03FF Figure H-5. EPROM Chip Location Reference to Bit Position and Address # S2 Block Size Select | S1<br>Starting<br>Address | 0 (4 | | 9 ( | 8K) | F ( | 16K) | |---------------------------|------|-------|-------------|-------|------|---------| | Select | From | To | From | To | From | To | | 0 | 0000 | OFFF | 7 0000 | 1 ppp | | | | 1 | 1000 | 1FFF | 0000 | 1FFF | 7 | | | 2 | 2000 | 2FFF | 7 2000 | 2.000 | 0000 | 3FFF | | 3 | 3000 | 3FFF | 2000 | 3FFF | j | | | 4 | 4000 | 4FFF | -<br>] 4000 | 5FFF | | | | 5 | 5000 | 5FFF | 4000 | JEEF | | | | 6 | 6000 | 6FFF | _ | | 4000 | 7FFF | | 7 | 7000 | 7FFF | 6000 | 7FFF | | | | 8 | 8000 | 8FFF | • | | | | | 9 | 9000 | 9 FFF | 8000 | 9FFF | | | | . A | A000 | AFFF | • | | 8000 | BFFF | | В | B000 | BFFF | A000 | BFFF | | | | С | C000 | CFFF | | | | | | D | D000 | DFFF | C000 | DFFF | C000 | FFFF | | E | E000 | EFFF | | | | | | F | F000 | FFFF | E000 | FFFF | | | | | | | | | | 509-H-5 | Figure H-6. 4/8/16K EPROM Board Address Switches ## **COMMENT SHEET** | Document No. | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Title: | | Page: | | | | FROM: | | NAME: | | BUSINESS ADDRESS: | | | | | | | | | | Does this publication meet your requirements? Yes No | | If no, please explain. | | · | | · | | | | | | | | Do you wish a reply? Yes No | | Do you wish a reply? Yes No | | COMMENTS: (Describe any errors, suggested ideas, additions, or deletions etc. Please include page number.) All comments and suggestions become the property of General Automation, Inc. | | | | | | | | | | | | | | | | | | | No Postage Stamp Necessary If Mailed In the U.S.A. (See Other Side) Fold On Dotted Lines And Staple This publication serves as a reference for systems analysts, programmers and operators of General Automation systems. Your answers to the questions on the back of this form help us produce better publications for your use. FOLD First Class Permit No. 423 Anaheim, California BUSINESS REPLY MAIL NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES **POSTAGE WILL BE PAID BY** General Automation, Inc. 1055 South East Street Anaheim, California 92803 Attention: Publications Services FOLD General Automation, Inc. 1055 South East Street Anaheim, California 92803 1055 SOUTH EAST STREET, ANAHEIM, CA 92805 TELEPHONE: (714) 778-4800