Personal Computer Hardware Reference Library # IBM RT PC Hardware Technical Reference Volume I # IBM RT PC Hardware Technical Reference Volume I #### First Edition (November 1985) Changes are made periodically to the information herein; these changes will be incorporated in new editions of this publication. References in this publication to IBM products, programs, or services do not imply that IBM intends to make these available in all countries in which IBM operates. Any reference to an IBM program product in this publication is not intended to state or imply that only IBM's program product may be used. Any functionally equivalent program may be used instead. International Business Machines Corporation provides this manual "as is," without warranty of any kind, either express or implied, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this manual at any time. Products are not stocked at the address given below. Requests for copies of this product and for technical information about the system should be made to your authorized IBM RT PC dealer. A reader's comment form is provided at the back of this publication. If the form has been removed, address comments to IBM Corporation, Department 997, 11400 Burnet Road, Austin, Texas 78758. IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you. © Copyright International Business Machines Corporation 1985 #### **About This Book** #### **Purpose** This manual describes the IBM RT PC Product Family Hardware, the various units and components of the product family and how they interact. It provides information about the family system architecture, and about hardware and programming interfaces. #### **Audience** The information in this manual is for reference. It is intended for hardware and program designers, programmers, engineers, and anyone else who needs to understand the design and operation of the IBM RT PC Product Family. #### How to Use This Book This manual is composed of ten sections. Section 1, System Introduction, introduces major system components in the order they are discussed in subsequent sections. It provides an initial description and understanding of the functions of key components of the product family workstations, and how the workstations are physically configured with various components. An overview of the system architecture is included with a system block diagram which shows major partitions of the system unit elements such as the system board, processor board, memory boards, Floating-Point Accelerator board. Major system characteristics are described such as a 32-bit system unit, demand paged virtual memory system, high bandwidth interleaved memory and standard I/O. Section 2 describes the major functions of the processor board. Section 3 provides a functional description of the system memory boards. Section 4 describes the Floating-Point Accelerator board. Section 5 contains information about the system boards, with a description of the differences between each of the boards as used with its unique system unit. Section 6 provides a complete architectural description of the I/O channel. Section 7 describes the functions provided by the system IPL ROM, including a list of the various error codes displayed by diagnostic routines. Section 8 contains information about adapters from the IBM Personal Computer Family, and their compatibility or noncompatibility with the RT PC family. Section 9 provides information about the locator, keyboard, characters, keystrokes. Section 10 describes the system unit physical dimensions, power, environmental and operating requirements. Section 11 includes detailed specification information for the system processor and memory management unit components. Appendix A lists the instruction set by mnemonic and provides information for instruction execution time. A glossary of terms and a bibliography of related publications is included. An abbreviated index is included. A more complete Section Table of Contents is provided at the beginning of each section. #### **Related Information** IBM PC Network Technical Reference Manual IBM RT PC Personal Computer AT Coprocessor Technical Reference ### **Ordering Additional Copies of This Book** To order additional copies of this publication, use either of the following sources: - To order from your IBM representative, use Order Number SV21-8024. - To order from your IBM dealer, use Part Number 6489887. A binder is included with the order. ## **Contents** | Section 1. System Introduction | 1-1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | About this Section | 1-3 | | General Bystein Description | 1-4 | | IN 1 C Model 20 and Model 25 Systems 111111111111111111111111111111111111 | 1-5 | | | 1-6 | | | 1-7 | | System Board 111111111111111111111111111111111111 | 1-9 | | Bystem I circimanee | l-12 | | Dybloin Haraware Cyclylett | l-13 | | bybeem memory commenced transfer and the trans | l-18 | | Dybtom Womon y Attace Commence | l <b>-</b> 19 | | 11000BBCI Chamer to 1/ C 11001BB 2 to C convenience | l-20 | | bystem memory to recessor enamer by the services | l-21 | | 1 1000 BBOT CHAIMET to 1, 5 Batta Bas Contraction | l-22 | | 1000 to 1/ 0 Chammer Imgiment 111111111111111111111111111111111111 | l-23 | | 1 Iddiobbiling 1/10dol 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | l-26 | | Traditional Transfer of Committee of the | l <b>-3</b> 1 | | bybtem riceessor radaress rice | l-34 | | Interrupts 1 | 1-36 | | | | | Section 2. Processor Board | | | About this Section | 2-3 | | Processor Board Description | 2-4 | | Processor Board Function Overview | 2-6 | | Processor Channel Interface | 2-8 | | Memory Channel Interface | 2-11 | | Processor Board Pin Assignments | 2-16 | | | | | Section 3. System Memory Boards | 3-1 | | About this Section | 3-3 | | Memory | 3-4 | | | | | Section 4. Floating-Point Accelerator | 4-1 | | About this Section | 4-3 | | Floating-Point Accelerator | 4-4 | | 1 louding 1 oint 1 localetator | 4-13 | | Command Encount (Encount of Least Le | <b>1-4</b> 0 | | Floating-Point Accelerator Board Pin Assignments | 4-41 | |---------------------------------------------------------------|-------------| | Section 5. System Boards | 5-1 | | About this Section | 5-5 | | Model 10, Model 20, and Model 25 Common Features | 5-6 | | Model 20 and Model 25 Unique Features | 5-7 | | Model 10 Unique Features | 5-9 | | System Board I/O Address Assignments | 5-12 | | Addressing Modes | 5-14 | | Translation Modes | 5-17 | | Arbitration | 5-33 | | I/O Channel Operations | 5-37 | | Interrupt Controllers | 5-56 | | Component Reset Register A (CRRA) | 5-59 | | Component Reset Register B (CRRB) | 5-61 | | Channel Status Register (CSR) | 5-63 | | Memory Configuration Register | 5-73 | | I/O Delay Register (IDR) | 5-74 | | I/O Subsystem Adapters | 5-75 | | Keyboard, Locator, Speaker Adapter | 5-86 | | Adapter I/O Operations | 5-89 | | Adapter Commands | | | | 5-118 | | | 5-124 | | | 5-131 | | r | 5-133 | | System Board Connectors | 5-145 | | Section 6. I/O Channel | 6-1 | | About this Section | 6-3 | | Channel Features | 6-4 | | I/O Channel Signal Definitions | 6-8 | | I/O Channel Data Transfer | 6-15 | | Interrupts | 6-40 | | I/O Channel Address Maps and Assignments | 6-43 | | I/O Slot Uniqueness | 6-48 | | Connector/Pin Description and Electrical Characteristics | 6-51 | | Section 7. System IPL ROM | 7-1 | | About this Section | 7-3 | | System IPL ROM | | | Restrictions and Conventions for Externally Callable Routines | | | Section 8 System Competibility | <b>8</b> _1 | | About this Section | 8-3<br>8-4 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | Section 9. User Input and Output Devices | 9-1 | | About this Section | 9-3 | | Keyboard | 9-4 | | | 9-11 | | Operator Panel | 9-17 | | Section 10. Power | 0-1 | | | 10-3 | | Input Power | 10-4 | | Output Power | 10-5 | | Section 11. System Processor and MMU 1 | 1-1 | | About this Section | 11-7 | | System Processor | 11-8 | | Instruction Set | 1-27 | | Instruction Formats | 1-29 | | Doug and Diole mistractions | 1-31 | | Address Computation | 1-37 | | Didnoming | 1-40 | | Traps | 1-49 | | | 1-51 | | Arithmetic Operations | 1-56 | | Logical Operations | 1-67 | | | 1-73 | | Dybtem Control | 1-79 | | Input/Output 1 | 1-83 | | TO I defined | 1-85 | | Memory Management Unit | 1-92 | | Radioss Tansiadon Haraware Operation | 1-96 | | | -108 | | Control Registers 111111111111111111111111111111111111 | -113 | | Translation report and the construction of | -133 | | 1/ 0 11441455 115515111141155 111111111111 | -135 | | | -137 | | ECC Checking | -140 | | rippendia in instruction minimumes to the transfer to the transfer in the instruction | A-1 | | Instruction Set By Mnemonic | | | Privileged Instructions | | | Figures | X-1 | | Glossary | • • • • • • • • • • • • • • • • • • • • | X-7 | |----------|-----------------------------------------|------| | Index | | X-21 | ## **Section 1. System Introduction** ## **CONTENTS** | About this Section | | |-----------------------------------------------------------|------| | General System Description | 1-4 | | RT PC Model 20 and Model 25 Systems | 1-5 | | RT PC Model 10 System | 1-6 | | System Overview | 1-7 | | System Board | 1-9 | | Processor Board | 1-9 | | Memory Channel | 1-10 | | | 1-10 | | System Memory Boards | 1-10 | | Floating-Point Accelerator Board | 1-10 | | 1/ O Bubbystom | 1-11 | | 1/O Chamici | 1-11 | | Dystem I circimance | 1-12 | | bystem Hardware Overview | 1-13 | | Nomenciature | 1-13 | | Coprocessor to 1, o charmer and whemery 2, to convenience | 1-16 | | bystom momory conventions | 1-18 | | Dystem Memory Madressing Conventions | 1-19 | | 1 1000bb01 Chamier to 1, o receives Das Convention | 1-20 | | Dystem Memory to Processor Charmer Byte Positions | 1-21 | | 1 locessor Chainlet to 1/ O Data Bas Conversion | 1-22 | | 10CC to 1/ O Chaimer Angiment | 1-23 | | 1 logi anniming 1 lotte | 1-24 | | Addressing Model | 1-26 | | Addressing 1 for the Bystem 1 focessor | 1-26 | | 1/ 0 1/11 | 1-28 | | Wichiory Wap | 1-29 | | Addressing I foliation if O Chamber | 1-31 | | 1/ 0 141111 | 1-31 | | Wichioty Wap | 1-31 | | Dystelli I Toccasor Map | 1-34 | | Interrupts | 1-36 | | interrupt Levels | 1-36 | | Dystem 1100cbsor 11ap | 1-36 | | Interrupt Level Assignment | 1-37 | | System Processor Interrupt Processing | 1-37 | ## **About this Section** This section contains an introduction to the IBM RT PC System. The differences between the Model 10, the Model 20, and the Model 25 are described. The components that reside on the system board are discussed along with a description of how they transfer data throughout the system. ## **General System Description** The IBM RT PC Product Family is a family of workstations supporting both stand-alone and clustered configurations. Each workstation offers significant computational power, coupled to all points addressable displays. The workstations have a common family appearance, use the same software and user interface. A wide range of options and adapters are offered for the workstations, such as data communications, color displays, quality printers, graphic printers, and color plotters. The workstation family consists of three models. Each has growth capabilities. The RT PC Model 20 and Model 25 systems consist of a small floor standing console and an ergonomically packaged display monitor. The second system, the RT PC Model 10 system, is a table-top workstation. ## **RT PC Model 20 and Model 25 Systems** The IBM RT PC Model 20 and Model 25 Systems are 32-bit system units packaged in a small floor standing console. A Model 20 or a Model 25 can be configured by selecting one of the following displays and its appropriate adapter board: - A 12 inch IBM PC Green Monochrome Display - A 12 inch Advanced Monochrome Graphics Display - A 14 inch IBM PC-AT Enhanced Color Graphics Display. The system unit console contains the system board, power supply, fixed-disk drives, and diskette drives. The system board has unique pluggable slots for the processor board, the Floating-Point Accelerator board, and for two memory boards with addressing for up to 16M-bytes of main memory. In addition, eight slots are provided for optional I/O adapters. Two of these eight slots only accommodate adapters from the IBM PC-1 and the PC-XT. The remaining six slots accommodate RT PC adapters, PC-1 and PC-XT adapters, and PC-AT adapters identified in this manual. A special Coprocessor board, Intel 80286 based, is available as an option for the Model 20 and Model 25 systems. This board allows most existing PC applications to run on RT PC. The IBM Personal Computer AT 512 KB Memory Expansion Option can be used with this board. The system unit accommodates up to five 5.25-inch storage device drives. Four full-high positions are provided, with one position configured to accept either one or two 5.25-inch half-high diskette drives. The other three positions accommodate a maximum of three fixed-disk drives. ## **RT PC Model 10 System** The IBM RT PC Model 10 System is a 32-bit system unit packaged in a console designed for table top operation. A Model 10 System can be configured by selecting one of the following displays and its appropriate adapter: - A 12 inch IBM PC Green Monochrome Display - A 12 inch Advanced Monochrome Graphics Display - A 14 inch IBM PC-AT Enhanced Color Graphics Display. The system unit console contains the system board, power supply, fixed-disk drive and diskette drive. The system board has unique pluggable slots for the processor board, Floating-Point Accelerator, and two memory boards, with addressing for up to of 16M-bytes of system memory. In addition, six slots are provided for optional I/O adapters. One of these slots only accommodates adapters from the IBM PC and XT computers, while the remaining five accommodate RT PC adapters, PC-1 and PC-XT adapters, and IBM PC-AT adapters identified in this manual. A special Coprocessor board, Intel 80286 based, is available as an option for the Model 10 system. This board allows most existing PC applications to run on RT PC. The IBM Personal Computer AT 512 KB Memory Expansion Option can be used with this board. The Model 10 system unit console accommodates one full high 5.25-inch fixed-disk drive and one half-high 5.25-inch diskette drive. ## **System Overview** The Model 10, Model 20, and the Model 25 are virtual memory 32-bit workstations. All models use the same processor board, system memory boards, optional Floating-Point Accelerator, and I/O adapters. A unique system board is used in each model, and differs only in the number of I/O slots provided and in the built-in RS232C serial port capability. The following section provides an overview of the RT PC system architecture. This section contains information for the Model 10, Model 20, and the Model 25. Features unique only to Model 20 and Model 25 are also described. Figure 1-1. System Board Block Diagram Note: \* = Model 20 and Model 25 only ## **System Board** The RT PC system board contains the I/O subsystem, I/O channel, and connectors for the processor board, system memory boards, and optional Floating-Point Accelerator. Unique system boards are used for the Model 10, Model 20 and Model 25, and differ only in the number of I/O slots provided and in the built-in RS232C serial port capability. The same processor board, system memory boards, Floating-Point Accelerator, and I/O adapters are used in both models. #### **Processor Board** The processor board plugs into the system board and contains the following major components: - A 32-bit microprocessor - A memory management unit - A 64K-byte read-only memory (ROM) for initial program load (IPL) - Reference and change bits for virtual memory management - Memory channel and processor channel control and interface logic. The RT PC processor board includes a system processor and a memory management unit (MMU). Both components use Very Large Scale Integration (VLSI) technology. These two components form a 32-bit virtual memory processor unit, providing advanced memory management functions. The system processor provides sixteen 32-bit general purpose registers and 118 instructions. All internal address and data paths are 32 bits. The MMU provides virtual memory address translation functions, memory control, and error correct code (ECC) functions. The basic processor board clock rate is 170 nanoseconds. The processor board also contains 64K-bytes of read-only memory (ROM) used for initial program load (IPL) and initial diagnostic functions. Five bipolar gate arrays and miscellaneous TTL logic are used for memory channel and processor channel interface. A bipolar (Random Access Memory (RAM) is used for the reference and change bits associated with virtual memory management support. The processor board connects to both the memory channel and the processor channel. The memory channel connects only to system memory boards, with the processor channel connecting to both the I/O subsystem and the optional Floating-Point Accelerator. #### **Memory Channel** The memory channel connects system memory to the processor board. This channel provides a multiplexed address bus, a data bus, and control signals. The address bus supports up to 16M-bytes of system memory. The data bus provides 32 bits of data and 8 bits of error correcting code (ECC). The memory channel is capable of supplying 4 bytes of data every 170 nanoseconds, resulting in a bandwidth of 23.5 megabytes per second. #### **Processor Channel** The processor channel connects the processor board to the I/O subsystem and the optional Floating-Point Accelerator. This channel provides a multiplexed 32-bit address and data bus, plus control signals to allow access of system memory through the memory management unit by the I/O subsystem. This channel also allows transfer of floating point data and control from the processor board to the Floating-Point Accelerator. External interrupt lines are provided for use by the I/O subsystem. #### **System Memory Boards** System memory boards plug into the memory channel on the system board and contain the address and buffer logic. Memory on a board is divided into two banks, with one bank containing only even addresses, and the second bank containing only odd addresses. Interleaving of memory in this manner provides improved memory bandwidth to the processor board. Each memory word contains 32 bits of data and 8 bits of error correcting codes (ECC). The ECC allows correction of single bit errors and detection of all double bit errors. TTL logic is used for address and data buffers on the system memory boards. #### Floating-Point Accelerator Board The optional Floating-Point Accelerator board plugs into the processor channel on the system board and contains the following components: - NS32081 Floating-Point Accelerator - Floating point register sets - Interface and control logic. A National NS32081 Floating-Point Accelerator is used for floating point applications. Additional interface and control logic on the Floating-Point Accelerator Board allows floating point operations to be executed in parallel with other computations on the processor board. #### I/O Subsystem The I/O subsystem, located on the system board, consists of logic on the system board, and provides the following functions: - I/O Channel Controller. The I/O channel controller converts the 32-bit processor channel to a standard 16-bit and 8-bit I/O channel. - System Direct Memory Access (DMA) Controller. The system DMA controller consists of two Intel 8237 modules. They are used to provide 7 independent DMA channels. An eighth DMA channel exists for the optional RT PC 286 Coprocessor. - Interrupt Controller. Two Intel 8259 modules are used to provide 15 levels of priority interrupts. - Translation Control Logic. The translation control logic determines the mapping of addresses from the I/O channel to system memory. - Keyboard/Locator Controller. An Intel 8051 microprocessor and 8255 peripheral interface are used for the keyboard controller. The 8051 microprocessor handles keyboard, locator (mouse or tablet) and speaker communications independent of the processor board. - Real-Time Clock. A Motorola 146818 CMOS module is used for the real-time clock. The real-time clock is battery-powered and provides both time of day information and nonvolatile memory of certain system configuration information. - RS232C Serial Port Logic. The Model 20, and the Model 25 units provide logic on the system board for two RS232C serial ports. The Model 10 unit does not provide these serial ports. #### I/O Channel The I/O channel provides a 16-bit and 8-bit data bus for attachment of standard I/O adapters. The Model 20, and the Model 25 units provide six 16-bit slots and two 8-bit slots, with the Model 10 unit providing five 16-bit slots and one 8-bit slot. ## **System Performance** The RT PC processor board operates at a 170 nanosecond cycle time. Execution time for instructions is contained in Appendix A. The memory channel can supply 4 bytes of data every 170 nanoseconds, which results in a bandwidth of 23.5M-bytes per second. Memory refresh operations are controlled by the memory management unit (MMU), and normally occur during idle memory cycles. Typical refresh interference is about one percent of the available memory bandwidth. ## **System Hardware Overview** The RT PC system hardware includes the system board, processor board, memory boards and Floating-Point Accelerator. #### **Nomenclature** This section discusses the conventions used on the processor channel and the conventions used on the I/O channel. The I/O Channel Controller (IOCC) provides the interconnection between the two different conventions. #### Notes: - 1. MSB = Most Significant Bit - 2. LSB = Least Significant Bit #### **Data Names and Bit Conventions** The RT PC system hardware includes both unique 32-bit system processor features and standard 16-bit I/O channel features. Standard System 370 terminology is used when discussing address quantities, data quantities, and bit numbering related to the 32-bit components. Standard vendor notation is used for the 16-bit I/O channel features. The following terminology is used for the 32-bit components: - Word A word is four consecutive bytes, or 32 consecutive bits. - Halfword A halfword is two consecutive bytes, or 16 consecutive bits. - Byte A byte is eight consecutive bits. The following bit numbering is used for the 32-bit components: The following terminology is used when discussing address and data quantities related to the 16-bit I/O channel: - Doubleword A doubleword is four consecutive bytes, or 32 consecutive bits. - Word A word is two consecutive bytes, or 16 bits. - Byte A byte is eight consecutive bits. The following bit order is used for the 16-bit components: #### **Hexadecimal Notation** The notation X 'value' is used for all hexadecimal numbers. For example, X'A123' is the 16-bit hexadecimal value A123. #### **Processor Channel Bit Convention** The processor channel bit convention is as follows: Figure 1-2. Processor Channel Bit Convention #### I/O Channel Bit Convention The I/O channel data bus uses the following convention for 8 bits. Figure 1-3. I/O Channel 8-Bit Convention The I/O channel data bus uses the following convention for 16 bits. Figure 1-4. I/O Channel 16-Bit Convention #### **Processor Channel Byte Convention** The processor channel uses the following convention. Figure 1-5. Processor Channel Byte Convention #### I/O Channel Byte Convention The I/O channel uses the following convention for a 2 byte (16 bit) channel: Figure 1-6. I/O Channel Byte Convention ### Coprocessor to I/O Channel and Memory Byte Conventions When the Coprocessor is attached to the I/O channel, its byte reversal characteristics must be considered. Programmers transferring data between the processor channel and the Coprocessor registers must understand this convention. The following diagram shows the value X'1A2B' in the AX register of the Coprocessor. When the AX register value X'1A2B' is sent to the I/O channel data bus, it will be as follows: The Coprocessor stores the least significant byte in the even address and stores the most significant byte in the odd address. ## **System Memory Conventions** System memory is part of the 32-bit features in RT PC, and uses the following conventions: Word A word is four consecutive bytes or 32 consecutive bits. A halfword is two consecutive bytes, or 16 consecutive bits. Halfword **Byte** A byte is eight consecutive bits. A word address boundary is an address where the two least Word address boundary significant address bits are zero (XX00). A halfword address boundary is an address where the least Halfword address boundary significant bit is zero (XXX0). Even halfword address An even halfword address is an address where the two least significant address bits are zero (XX00). Odd halfword address An odd halfword address is an address where the two least significant address bits are one and zero (XX01). Even byte address boundary An even byte address is an address where the least significant address bit is zero (XXX0). An odd byte address is an address where the least significant **Odd byte address boundary** address bit is one (XXX1). ## **System Memory Addressing Conventions** Figure 1-7. System Memory to I/O Channel Convention ## **Processor Channel to I/O Address Bus Convention** Figure 1-8. I/O Channel Address Bus Mapping Bits 0-7 of the processor channel select the I/O channel as decribed in "Addressing Model" on page 1-26. The low-order 24 bits are used as the I/O channel address. ## **System Memory to Processor Channel Byte Positions** The following figure shows data movement between system memory and the processor channel. Figure 1-9. System Memory to Processor Channel Bytes The IOCC always reads a word from system memory. Byte A is always aligned on a word address boundary. The processor channel contents are the same for the following: - A word read - An even halfword read (AB) - An odd halfword read (CD) - Any single byte read. ## Processor Channel to I/O Data Bus Conversion Figure 1-10. Processor Channel to I/O Data Bus Mapping For a 16-bit transfer, the IOCC receives byte A (bits 0-7) from the processor channel and sends them to byte A (bits 7-0) on the I/O channel data bus. Simultaneously, the IOCC receives byte B (bits 8-15) from the processor channel and sends them to byte B (bits 15-8) on the I/O channel data bus. The actual I/O channel data bus format is as follows. Figure 1-11. I/O Channel Data Bus If processor channel bytes C and D were also requested, the IOCC would multiplex them onto the 16-bit I/O data bus. The IOCC sends processor channel byte C (bits 16-23) to I/O channel data bus A (bits 7-0) and processor channel byte D (bits 24-31) to I/O channel data bus byte B (bits 15-8). ## **IOCC to I/O Channel Alignment** The I/O and memory maps on the I/O channel are a collection of 8-bit (byte) addressable elements. There are 16,777,216 such addressable elements within each map. Each transaction over the RT PC I/O Channel(Programmed Input/Output or Direct Memory Access) is capable of transferring 2 bytes (16 bits) of data. The number of bytes actually transferred over the channel during one channel cycle is determined jointly by both the adapter initiating the operation and the target adapter. The transfer defaults to a single byte if one of the adapters is an 8-bit adapter. Transfers of more than 16 bits are accommodated by multiple I/O channel operations. Both the processor channel and I/O channel have control signals which indicate the amount of data transferred during the current transaction. Depending on the source initiating the transaction, one set of control signals dictates the transfer size while the other set will simply reflect that requirement. On all system processor PIO operations, the actual data pattern transferred over the I/O channel and the number of channel cycles required is dependent on the amount of data transferred as well as the width of the selected I/O adapter. This means if the number of bytes transferred by one system processor instruction is larger (2 or 4 bytes) than the data width (1 or 2 bytes) of the selected I/O adapter the IOCC automatically performs multiple I/O operations. For example, a 32 bit microprocessor PIO operation to: - An 8-bit wide adapter requires the IOCC to perform four distinct channel cycles with each cycle transferring 8 bits of data. - An 16-bit wide adapter requires the IOCC to perform two distinct channel cycles with each cycle transferring 16 bits of data. Boundary alignment is strictly enforced on all transfers through the IOCC. The low order address bits are modified by the IOCC such that the resulting address conforms to the definitions stated in "System Memory Conventions" on page 1-18. The IOCC forces address bits A(1,0) to 00 on all 32-bit transfers through IOCC for system processor PIO. Similarly, the IOCC forces address bit A(0) to 0 on all halfword transfers through IOCC. On the I/O channel a 2-byte transfer is flagged through the use of the 'Byte High Enable' (SBHE) signal. The selected I/O adapter signals its data bus width through the 'IOCS16' or 'MEMC16' signal for a 16 bit adapter to either the I/O map or memory map respectively. On the processor channel, the transfer size information is encoded within 'DAB 2, 3' of the address cycle with data being positioned according to the value of the address bus. For a I/O channel byte transfer the two least significant address bits determine which one of the four bytes within the processor channel word participates in the transfer. Likewise for I/O channel word operations, the second least significant address bit determines which of the two halfwords within the processor channel is selected (with the least significant address bit not used). The mapping within the IOCC of 8- and 16-bit adapters onto the 32-bit processor channel is accomplished through the multiplexer network on the I/O channel. The IOCC positions data correctly on the I/O channel for system processor PIO operations for 8- and 16-bit adapters on the initial I/O channel cycles based solely on the low order address bits and the transfer size. If the adapter's response indicated a width less than the transfer size then subsequent cycles are required. For these multiple cycles, the multiplexer control is a function of the cycle and adapter width. The IOCC activates the 'SBHE' signal for 16 and 32 bit PIO transfers. This signal is not changed through the duration of the entire operation (1, 2, or 4 I/O channel cycles). Data alignment through the IOCC, and on both the processor channel and I/O channel, is independent of the device location initiating the operation (I/O or processor channel attached). Alignment is dependent only on the address and size of the transfer. Data is aligned identically for 16-, and 8-bit data flowing from the processor channel to the I/O channel on either a system processor write or DMA read. Data is also aligned identically for 32-, 16-, and 8-bit transfers flowing from the I/O channel to the system processor on either a I/O DMA write or a system processor read. #### **Programming Note** The IOCC permits the programmer to perform a doubleword (32 bit) read or write to a byte wide adapter on the I/O channel. The IOCC converts this single transaction into either 2 or 4 I/O channel operations depending on the amount of data transferred and the characteristics of the selected adapter (16 or 8 bits). If the operation is directed to the memory map on the I/O channel, the IOCC increases the address between consecutive channel transfers. If the operation is directed to the I/O map on the I/O channel, the IOCC holds the address constant between consecutive channel transfers. This facility can not be used without knowledge by the programmer of the characteristics of the addressed adapter. In particular, the adapter must be capable of handling back-to-back operations without violating any timing restrictions it may have. The responsibility for knowing the characteristics of the I/O adapter and not violating these restrictions resides with the programmer. If a I/O adapter requests one byte (byte D), the processor channel presents the byte as shown in Figure 1-7 on page 1-19. The IOCC aligns the byte as shown below. This allows the adapter to get the byte in one cycle according to its data width. #### **DATA ALIGNMENT** REQUIRED FOR Figure 1-12. Data Alignment for 8- and 16-Bit Adapters ## **Addressing Model** This section describes the addressing model of the RT PC system board. The addressing model is described from the point of view that the IOCC is attached to the processor channel. This section further describes how the addresses move through the IOCC and what action the IOCC will take on addresses generated from both the processor channel and I/O channel. Detailed descriptions of hardware implementation found in other sections of this document are referred to throughout this section. The nomenclature used in this section for bit numbering and data naming are described in "Nomenclature" on page 1-13. The system processor communicates with the system through the processor channel. The processor channel has both I/O and memory address space (maps) that are accessible from either the I/O channel or the system processor. The memory map on the processor channel is further divided into real and virtual accesses. The I/O Channel Controller (IOCC) is a device on the processor channel. The system processor has access to the I/O adapters through the IOCC and, conversely, I/O adapters have access to the system memory. The I/O channel has both I/O and memory maps. The following two sections describe the system processor's view of the I/O channel maps and an adapter's view of both the I/O channel and processor channel maps. The term segment is used in the following sections to describe various address spaces on the processor channel. The most significant four bits of the 32-bit address on the processor channel select one of sixteen areas, which are referred to as segments. These segments are numbered zero through fifteen and are called segments 0 through F. Segment F is assigned to the IOCC and is further decoded in the IOCC to select between the I/O channel I/O map and the I/O channel memory map as described in "I/O MAP" on page 1-28 and "Memory Map" on page 1-29. #### **Addressing From the System Processor** This section covers access to both of the address maps on the I/O channel as viewed from the program executing system processor instructions. The view that the system processor has of these address maps is shown in Figure 1-13 on page 1-30. The RT PC system configuration has four devices attached to the processor channel. These devices, along with their characteristics, are: #### **System Processor** The system processor can initiate an operation over the processor channel through the execution of the following commands: - I/O read and write (IOR and IOW) instructions to control registers, translation buffers, and segment registers in the memory management unit. - Load or store instructions to system memory, IOCC control registers, the I/O channel, or the floating point accelerator. Use of the IOR and IOW instructions is described in "Input/Output" on page 11-83 and "Control Registers" on page 11-113. The various load and store instructions are described in "Load and Store Instructions" on page 11-31. The system processor does not have any registers that are addressable over the processor channel. Thus, it never responds to processor channel requests. #### **Memory Management Unit** The memory management unit (MMU) cannot initiate a processor channel operation. That is, it cannot generate an address. The memory management unit will either supply data in response to a read request or will receive data on a write operation. It responds to I/O space (IOR, IOW) operation for control functions and memory space (Memory Read, Write) for memory references. #### Floating-Point Accelerator Option The Floating-Point Accelerator cannot initiate a processor channel operation. That is, it cannot generate an address. The Floating-Point Accelerator is always the target of an address. Thus, it will either supply data in response to a read request, or it will receive data on a write operation. It responds to memory space (Memory Read, Write) operations for referencing segment 'FF' of the address map. #### **IOCC** The IOCC can both initiate operations on the processor channel as well as be the target of processor channel operations. IOCC initiates processor channel operations as a result of a DMA operation on the I/O channel. Furthermore, it is the target of a processor channel operation resulting from LOAD and STORE instructions executing in the system processor or from a system processor instruction fetch. The IOCC responds only to processor channel address cycles which are referencing segment 'F0' or 'F4' of either the real or virtual address map. All references to the I/O map on the processor channel are ignored. For system processor access to the I/O channel (to either the I/O map or the memory map) the IOCC performs the number of I/O cycles (1,2, or 4) required to transfer the data. This is possible because the I/O adapter identifies its data width when selected. The IOCC first aligns the address to the appropriate boundary as indicated by the size of the transfer (for instance, forcing word or double word) address by modifying address bits A(1) and/or A(0) as required. Since boundary alignment is strictly enforced, the address used for the second and subsequent channel cycles will differ from the first by the 2 low order address bits. Refer to "System Memory Conventions" on page 1-18. The IOCC supports system processor access to the I/O channel address map for both data (Memory Read, Write) and instructions. The rest of this section discusses access to the I/O map and memory map of the I/O channel. Refer to Figure 1-13 on page 1-30 and Figure 1-15 on page 1-34. #### I/O MAP Access to the I/O address map of the I/O channel is through the first 16 M-bytes of the segment 'F'. Access to this map is controlled by the state of the I/O Map Access Authority (IMAA) latch. Access attempts to the I/O address map of the I/O channel in unprivileged state with the IMAA set to privileged state are not allowed by the IOCC. A protection violation error will be reported. Refer to the "Channel Status Register (CSR)" on page 5-63. Access to the I/O address map of the I/O channel in privileged state is allowed regardless of the state of the IMAA. Note: Access to the channel status register (CSR) within the IOCC is restricted to privileged state only. The IOCC supports byte (8 bits), word (16 bits), and doubleword (32 bits) access to the I/O address map. The IOCC activates a control signal on the I/O channel to indicate the transfer size as stated by the system processor instruction executed. If the I/O adapter is not capable of transferring the requested number of bytes, multiple accesses are made to the same address until the requested amount of data has been transferred. One characteristic of the system processor structure is that non-adjacent (order of execution) Read/Write instructions to external devices (memory management unit or IOCC) can (and often do) arrive at the device as if they were adjacent. That is, the programmer cannot guarantee the time period between consecutive accesses to an adapter simply by inserting some instructions between the two I/O channel references. The effect of this is that the I/O adapter may receive I/O commands at a rate faster than it can process them. The IOCC is not capable of ascertaining any performance limitations relative to 'wait' time between consecutive I/O operation associated with a given address in the I/O space. Thus, the responsibility for knowing the characteristics of the I/O adapter and not violating these restrictions resides with the programmer. In order to assist software in generating wait time for those adapters that require a minimum time delay between consecutive accesses, a 'NOP like' I/O command has been provided that can be inserted between the I/O instructions to the adapter. Access to this I/O delay register between otherwise sequential accesses to I/O subsystem and I/O channel adapter options prevents the possible loss of data. The system board devices which should use this mechanism are: 8237s, 8259s, real time clock (RTC), and the keyboard adapter. Boundary alignment is strictly enforced on the I/O channel. That is, the IOCC may alter the low order address bits as received from the processor channel before they are applied to the I/O channel. Refer to "IOCC to I/O Channel Alignment" on page 1-23. #### **Memory Map** Access to the memory address map of the I/O channel is through to the fifth 16M-bytes of segment 'F'. Access to this map is controlled by the state of the Memory Map Access Authority (MMAA) latch. Access attempts to the I/O channel memory address map in unprivileged state with the MMAA set to privileged state are not allowed by the IOCC, and a "protection violation" error will be reported. Access to the memory address map of the I/O Channel in privileged state is allowed regardless of the state of the MMAA. The IOCC supports byte (8 bits), word (16 bits), and doubleword (32 bits) access to the memory address map. The IOCC activates a control signal on the I/O channel to indicate the transfer size as stated by the system processor instruction executed. If the I/O adapter is not capable of transferring the requested number of bytes, multiple access will be made to consecutive addresses until the requested data has been transferred. However, since none of the I/O subsystems use any portion of the memory address map, this function is not supported on the system board. Boundary alignment is strictly enforced on the I/O channel. That is, the IOCC may alter the low order address bits as received from the processor channel before they are applied to the I/O channel. Refer to "IOCC to I/O Channel Alignment" on page 1-23. Figure 1-13. System Processor Access to Address Maps. This diagram shows the view of the I/O channel, I/O and memory maps from the system processor and the access authority control. ## Addressing From the I/O Channel This section covers access to the maps on the I/O channel as well as access to system memory as viewed from an adapter on the I/O channel. The view that a alternate controller has of memory and its access path is shown in Figure 1-14 on page 1-33. The IOCC responds to addresses originating on the I/O channel. I/O addresses are restricted to the I/O subsystem facilities. The I/O address is not propagated onto the processor channel. Access to the I/O subsystem by I/O adapters is controlled by three channel access control bits. Memory addresses to which the IOCC will respond are under program control. The IOCC does not contain any facilities within the memory map, but it will respond to the I/O channel operation on behalf of the processor channel. #### I/O MAP An I/O adapter cannot access the I/O address map on the processor channel. However, it can access the other adapters on the I/O channel in the I/O map. Most of the registers internal to the IOCC can be accessed from an alternate controller adapter operating in region mode. These registers are in the I/O map and are addressed with the IOR or IOW control lines. Access to this I/O map from the system processor can be controlled through the IMAA latch. A separate set of control latches must be used to control access by alternate controller adapters. **Note:** Alternate controller adapters cannot address (and, therefore, cannot access) the channel status register (CSR) or the translation control word (TCW) RAM. #### **Memory Map** The I/O channel architecture of RT PC permits a variety of adapter types to exist in the memory map: - · Memory board options - I/O adapters with RAM addressable in the memory map - I/O adapters with internal registers addressable in the memory map - IOCC which permits access to system memory by alternate controller adapters. RT PC system architecture requires the physical location of Random Access Memory (RAM) in the I/O memory map be transparent to the alternate controller adapter referencing it. For example, if performance of the 286 Coprocessor is important, then RAM should be located on the I/O channel. However, if low entry cost is desired, the 286 Coprocessor can execute out of system memory. The application program is to be unaware (except for time dependent code) of the physical location of the memory out of which it is executing. When a memory address is placed on the I/O channel, it is examined by all adapters, including the IOCC, to determine if the address is within the range covered by the adapter. If a match is found by one adapter, it responds with the appropriate channel control signals. In order to maintain the integrity of the data and to avoid damage to the channel interface circuitry, it is important that only one adapter responds to a given address. One of the primary functions of the IOCC is to provide access to system memory. Thus, the IOCC must examine each reference to the memory map on the I/O channel to determine if the address was intended for system memory. The effect is that this requirement places an unusual burden on the IOCC not commonly found in I/O adapters. In general, I/O adapters have a fixed address range in the memory map to which they respond. The address range to which the IOCC responds is variable in that it can differ for alternate controller and DMA devices as well as vary with application. This selection is controlled by the values written into the IOCC translation mechanism by the software. Refer to the section on IOCC translation mechanism. All addresses in the memory map applied to the I/O channel by adapters are processed by the IOCC under control of its TCW. This translation mechanism is a programmable facility controlling target memory location, memory protection, defining access mode, and reformatting the address. The central element of this mechanism is a 1K x 16 bit RAM. Figure 1-14. Access to System Memory Maps from IOCC. This diagram shows how an I/O channel adapter views the system memory map IOCC address translation. ## **System Processor Address Map** The system processor can directly address two completely independent address spaces. The address spaces are referred to as memory and I/O. Access to these maps by the system processor is controlled by the nature of the instruction being executed (I/O or Memory Load/Store) and memory mode (real or virtual). The I/O address is 24 bits, while the system address is 32 bits. The address maps from the perspective of the system processor are given in Figure 1-13 on page 1-30 and Figure 1-14 on page 1-33. **Note:** Even though the system processor supports a 32-bit real memory address, the RT PC system is limited to a 24-bit real memory address. | Address Range | Size | Device | |-------------------|---------|--------------------------------------------| | 00 0000 - 7F FFFF | 8 MB | Not Defined | | 80 0000 - 80 FFFF | 64 KB | Processor Channel Device<br>Initialization | | 81 0000 - 81 FFFF | 64 KB | Memory Management Unit | | 82 0000 - FF FFFF | 8064 KB | Not Defined | Figure 1-15. System Processor Address I/O Map | Address Range | Size | Device | |-----------------------|--------|----------------------------| | 0000 0000 - 00FF FFFF | 16 MB | Memory Management Unit | | 0100 0000 - EFFF FFFF | | Not Defined | | F000 0000 - F0FF FFFF | 16 MB | I/O Channel I/O Map | | F100 0000 - F3FF FFFF | 48 MB | Reserved | | F400 0000 - F4FF FFFF | 16 MB | I/O Channel Memory Map | | F500 0000 - FEFF FFFF | 158 MB | Reserved | | FF00 0000 - FFFF FFFF | 16 MB | Floating Point Accelerator | Figure 1-16. System Processor Real Memory Address Map | Address Range | Size | Device | |-----------------------|--------|----------------------------| | 0000 0000 - EFFF FFFF | 4 GB | Memory Management Unit | | F000 0000 - F0FF FFFF | 16 MB | I/O Channel I/O Map | | F100 0000 - F3FF FFFF | 48 MB | Reserved | | F400 0000 - F4FF FFFF | 16 MB | I/O Channel Memory Map | | F500 0000 - FEFF FFFF | 158 MB | Reserved | | FF00 0000 - FFFF FFFF | 16 MB | Floating-Point Accelerator | Figure 1-17. System Processor Virtual Memory Address Map ### **Interrupts** The interrupt facility permits the system processor to change its status at the request of some other system element. The interrupting sources are: - Software generated interrupt request from system processor's interrupt request buffer - System component on the processor channel - I/O adapters on the I/O channel. This request is generated when an I/O adapter reaches some condition established by software or the occurrence of some error condition. All interrupts are fielded and processed by the system processor. The interrupt processing consists of saving the current program status and establishing the program status for the routine servicing the interrupt. Interrupt handling by the system processor is described in "Interrupts" on page 11-19. ### **Interrupt Levels** The system processor supports 5 levels of external interrupts. Normally, interrupts are serviced in a fixed priority sequence with interrupt level 0 having the highest priority and level 4 having the lowest. The I/O channel supports 11 levels of interrupt request. The I/O subsystem uses 4 levels in addition to those on the I/O channel. The IOCC interrupt controller (refer to "Interrupt Controllers" on page 5-56) maps the 11 I/O channel interrupts and 4 system board interrupts onto two system processor interrupt levels. It also provides the ability to mask off individual interrupt signals. ### **System Processor Trap** The system processor interrupt mechanism supports a second class of interrupts referred to as the I/O Trap. Activation of the 'I/O Trap' signal causes the system processor to do a program status word (PSW) exchange to the machine check level. The memory management unit activates the 'I/O Trap' signal upon detection of uncorrectable ECC errors (or, optionally, on all ECC errors) or upon detection of an 'Early Power-Off Warning' signal from the power supply. ### **Interrupt Level Assignment** The assignment of the five system processor interrupt request signals and the trap signal are as follows: | Interrupt<br>Level | Assignment | |--------------------|---------------------------------------------------| | 0 | System Attention Interrupt Sequence from Keyboard | | 1 | Real Time Clock Interrupt | | 2 | IOCC Errors | | 2 | Memory Management Unit Program Check | | 3 | I/O Channel Levels | | 4 | I/O Channel Levels | | Trap | Memory Management Unit Machine Check | | Trap | Early Power Off Warning | Figure 1-18. Interrupt Level Assignment ### **System Processor Interrupt Processing** The system processor accomplishes the interrupt handler function through a combination of: - Hardware within the IOCC - Interrupt control logic within the system processor - Software executing in the system processor. The interrupts are fielded directly by the system processor. If the interrupt mechanism within the system processor is enabled, and the interrupt request is at a higher level than is currently being processed by the system processor, a PSW exchange is initiated. If the new interrupt level can be reached by multiple external events, the interrupt service must then determine the interrupting source. If the new level is one assigned to the I/O channel, the interrupt service routine must first read the interrupt controller to determine the active I/O channel interrupts and, second, must read the adapter's status register. Note: The information format of the status registers, and the addresses of these registers, are adapter dependent. The interrupt routine issues the required commands to the adapter to turn off the interrupt signal, and it executes on the 'interrupt' level. The routine's last task is to return control to the interrupted level. Further processing of the interrupt request is done on a lower interrupt level, permitting other I/O interrupts to be serviced. Once the source and reason for the interrupt has been identified, the interrupt service program issues the required instructions to satisfy the condition within the I/O adapter. This routine normally executes on an interrupt level of lower priority than that on which the adapter was interrupted. The interrupt service program must be aware that multiple I/O adapters may have active interrupt requests pending at the same time. Thus, satisfying the requirements of one adapter may not be sufficient to cause the interrupt request (I/O channel signal) to go inactive. This condition is likely to occur on I/O channel levels. To save time, the interrupt service routine reads the interrupt controller before exiting the interrupt level. # **Section 2. Processor Board** ### CONTENTS | bout this Section | 2-3 | |---------------------------------------|------| | rocessor Board Description | 2-4 | | System Processor | 2-4 | | Memory Management Unit (MMU) | 2-4 | | Reference/Change (R/C) Array | 2-5 | | System Initial Program Load (IPL) ROM | 2-5 | | rocessor Board Function Overview | 2-6 | | rocessor Channel Interface | 2-8 | | lemory Channel Interface | 2-11 | | Signal Line Definition | 2-11 | | Arbitration | 2-15 | | Using the Hardware LEDs | 2-15 | | rocessor Board Pin Assignments | 2-16 | ### **About this Section** This section contains information about the processor board used by the IBM RT PC system and how it interfaces with the rest of the system. Included in this section is a description of the processor channel signal lines. ## **Processor Board Description** The RT PC processor board includes an IBM designed, custom logic proprietary 32-bit microprocessor and memory management unit (MMU). Features of these VLSI chips follow. #### **System Processor** The system processor is a single chip microprocessor that is mounted in a 175-pin package. The processor includes: - A 32-bit processor on a single chip - Very Large Scale Integration (VLSI) custom logic design - A 32-bit address and data quantities - Single cycle execution of most register-to-register instructions - High memory bandwidth for CPU and I/O - High performance virtual memory support - Privileged and unprivileged states for system integrity - A 32-bit timer facility - Extensive error checking including: - Power On Reset (POR) microcode diagnostic - Programming errors (illegal instructions, invalid addresses) - Hardware errors (parity errors, timeout). Detailed information on the system processor is provided in Section 11. ### **Memory Management Unit (MMU)** The memory management unit implements a single level memory address translation architecture. The MMU contains all hardware required for address translation, translation lookaside buffer (TLB) management, and automatic reload on TLB miss. The MMU is packaged in a 175-pin package. The MMU features include: - Interfaces to the 32-bit microprocessor - Performs virtual address translation - A 40-bit virtual address - Supports 2K and 4K page sizes - Provides internal ECC logic for system memory - Provides memory control to external system memory and IPL ROM - Supports up to 16M-bytes of system memory - Provides control of and access to reference and change bits. Detailed information on the memory management unit is provided in Section 11. #### Reference/Change (R/C) Array The R/C array is a 16K x 1 static RAM. The R/C array stores the reference and change bits associated with pages in memory. Access and use of the R/C array is described in "Reference And Change Bits" on page 11-111. #### System Initial Program Load (IPL) ROM The system IPL ROM contains basic hardware tests which are run everytime the hardware is turned on. Functions provided by the system IPL are described in "System IPL ROM" on page 7-4. #### **Processor Board Function Overview** The processor board, as depicted in Figure 2-1 is divided into two major functional units and two interfaces. The system processor and the memory management unit are the two major components on the board. Six additional IBM custom designed modules are used on the processor board to create the external interface. The two processor board interface dataflow blocks are shown in: - Processor Channel Interface see "Processor Channel Interface" on page 2-8. - Memory Channel Interface see "Memory Channel Interface" on page 2-11. The interface dataflow blocks are shown in Figure 2-2 on page 2-7. Figure 2-1. Processor Board Data Flow Figure 2-2. Processor Board Interfaces #### **Processor Channel Interface** The processor channel interface connects the RT PC processor board with the I/O subsystem and the Floating-Point Accelerator slot. It is a multiplexed 32-bit interface with appropriate signals to control programmed I/O (PIO) and direct memory access (DMA) sequences. Miscellaneous processor control lines such as interrupts and power on reset are also part of this channel section. Common lines on the channel connect to both the IOCC and the Floating-Point Accelerator (FPA) board. Processor board input control lines include resistive pullups and may be driven with open collector drivers. The processor channel interface is illustrated in Figure 2-3 on page 2-9. Figure 2-3. Processor Channel Interface Figure 2-4 illustrates interconnection of the processor board, IOCC, and the Floating-Point Accelerator slot. Figure 2-4. Processor Channel Interconnections ## **Memory Channel Interface** The memory channel interface connects the RT PC processor board with the system memory boards. This interface provides a multiplexed address bus that supports up to 16M-bytes of system memory, and a separate 40-bit data bus that contains 32 bits of data and 8 bits of error correcting code (ECC) check information. The processor board contains address decode logic used to select the appropriate memory board based on the system memory address. This logic recognizes system memory board sizes of 512K-bytes, 2M-bytes, and 8M-bytes. Other memory board sizes are supported, with an unused address space between the memory board size and the next larger size recognized by the processor board. For example, with 1M-byte memory boards, addresses X'000000' to X'0FFFFF' are assigned to the first memory board, and addresses X'100000' to X'1FFFFF' are unused. If a second 1M-byte memory board is used, it is assigned addresses X'200000' to X'2FFFFF'. See "Memory Board Slots" on page 3-5 for restrictions on the slot assignments for multiple memory boards ### **Signal Line Definition** This interface comprises 71 signal signals and includes the following: #### **Data Address Bus** The 'data address bus' (DAB) is used to transmit address, data, and control between the processor and the I/O subsystem or Floating-Point Accelerator board. Refer to Figure 2-5 on page 2-12 for the data bus format. #### **ADDRESS** Figure 2-5. Data Bus Format #### **Address Extension** The 'address extension' provides subaddressing or control functions within the IOCC or Floating-Point Accelerator board devices. #### +Exception 'Exception' is an error response to PIO commands or DMA requests and indicates the operation cannot be executed or did not execute correctly. #### +Tag The processor channel allows up to two PIO commands to be executing concurrently; two commands are not required to complete in the same order they were initiated. To link commands and (completion) replies, a 'tag' bit is supplied when a command is issued. This 'tag' is to be returned along with the return status to indicate the PIO command currently completing. #### -I/O Cycle The 'I/O cycle' signal is activated whenever a PIO command is accepted. #### -Data Strobe 'Data strobe' is used as a clock to signal that valid address or data is on the data bus. #### -PIO Request The 'PIO request' signal is activated on queued PIO commands to I/O channel devices or I/O channel memory to signal the arbiter that the Coprocessor should be dearbitrated. #### -Ready The 'ready' signal signals completion of channel operations. #### -Busy The 'busy' signal holds I/O cycle active. While active, no further (nondiagnostic) PIO commands are accepted from the processor. #### -FPA Busy The 'FPA busy' signal causes a (busy) rejection of PIO commands directed to the Floating-Point Accelerator slot. #### -DMA Request The 'DMA request' signal initiates a DMA memory cycle. #### -DMA Cycle The 'DMA cycle' is the response to a DMA REQUEST. #### -Addr Gate 'Addr gate' controls tri-state drivers within the IOCC gating the I/O channel address onto the data bus. #### -Data Gate The 'data gate' signal controls tri-state drivers within the IOCC and Floating-Point Accelerator board for gating data or exception status onto the data bus. #### -Channel Error The 'channel error' signal is activated when a transmission error occurred from the IOCC or Floating-Point Accelerator board to the system. #### -Interrupt These 5'-interrupt' signals are wired to the processor interrupt inputs for levels 0 - 4. ### -Trap The '-trap' signal is wired to the processor 'trap' input and may be used for functions such as early power-off warning. The 'trap' signal is edge sensitive. #### -System Reset The '-system reset' signal resets the system processor, and produces a 'channel reset' when the processor finishes its diagnostics. System memory is not disrupted by this signal. #### -Channel Reset The '-channel reset' signal is activated whenever a 'channel reset' is issued. This normally occurs on power up or after a processor error timeout. #### -POR 'Power-on reset' is active during power on and is deactivated (100-500 ms) following all voltages becoming valid. #### -HRQ The '-HRQ' signal is activated by the IOCC arbiter to request usage of the IOCC data path and the I/O channel. #### -HLDA 'HLDA' is the processor response to HRQ. #### -Channel End The '-channel end' signal is activated following presentation of ready. The low to high transition of this signal may be used as an indication of the end of the command. #### -Timer In The 'timer in' signal drives the processor timer. #### **Arbitration** The various operations (PIO, DMA) performed or controlled by the IOCC are competitive in nature and require shared usage of the data flow hardware. Additionally, these functions are independent and asynchronous to each other. #### **PIO Sequences** PIO sequences are initiated by processor LOAD and STORE instructions. #### **DMA Sequences** DMA operations are initiated by the IOCC to gain access to system memory when the HRQ signal to the processor is activated. #### Using the Hardware LEDs The following procedure gives information on how the hardware uses system LEDs. - 1. Enable the LEDs by accessing ROM. This is done with a read to ROM. - 2. Read the R/C array. The last byte of the R/C array address equals the value of the LEDs. decimal numbers only. (For example, for the address X'811014', the LEDs would display the number 14. After the number has been displayed the LEDs can be blanked with a FF.) - 3. Disable the LEDs by writing to the R/C array. ## **Processor Board Pin Assignments** The following tables contain the processor board slot pin assignments. Figure 2-6. 100 Pin Processor Channel Interface Slot | I/O Pin | Signal Name | I/O | |---------|--------------|--------| | A 1 | +5 Vdc | Power | | A 2 | +5 Vdc | Power | | A 3 | +ADR/DATA 00 | I/O | | A 4 | +ADD/DATA 01 | I/O | | A 5 | +ADR/DATA 02 | I/O | | A 6 | +ADD/DATA 03 | I/O | | A 7 | +ADR/DATA 04 | I/O | | A 8 | +ADD/DATA 05 | I/O | | A 9 | +ADR/DATA 06 | I/O | | A 10 | +ADD/DATA 07 | I/O | | A 11 | +ADR/DATA 08 | I/O | | A 12 | +ADD/DATA 09 | I/O | | A 13 | Gnd | Ground | | A 14 | +ADR/DATA 10 | I/O | | A 15 | +ADD/DATA 11 | I/O | | A 16 | +ADR/DATA 12 | I/O | | A 17 | +ADD/DATA 13 | I/O | | A 18 | +ADR/DATA 14 | I/O | | A 19 | +ADD/DATA 15 | I/O | | A 20 | +ADR/DATA 16 | I/O | | A 21 | +ADD/DATA 17 | I/O | | A 22 | +ADR/DATA 18 | I/O | | A 23 | +ADD/DATA 19 | I/O | | A 24 | GND | Ground | | A 25 | GND | Ground | Figure 2-7 (Part 1 of 2). Processor Channel Interface Slot (A-Side) | I/O Pin | Signal Name | I/O | |---------|--------------|--------| | A 26 | +ADD/DATA 20 | I/O | | A 27 | +ADR/DATA 21 | I/O | | A 28 | +ADD/DATA 22 | I/O | | A 29 | +ADR/DATA 23 | I/O | | A 30 | +ADD/DATA 24 | I/O | | A 31 | +ADR/DATA 25 | I/O | | A 32 | +ADD/DATA 26 | I/O | | A 33 | +ADR/DATA 27 | I/O | | A 34 | +ADD/DATA 28 | I/O | | A 35 | +ADR/DATA 29 | I/O | | A 36 | +ADR/DATA 30 | I/O | | A 37 | GND | Ground | | A 38 | +ADD/DATA 31 | I/O | | A 39 | Reserved | _ | | A 40 | -RSC HOLD | 0 | | A 41 | -IREQ 0 | 0 | | A 42 | -IREQ 2 | 0 | | A 43 | -IREQ 4 | 0 | | A 44 | Reserved | | | A 45 | +Panel Ind 0 | I | | A 46 | +Panel Ind 2 | I | | A 47 | +Panel Ind 4 | I | | A 48 | +Panel Ind 6 | I | | A 49 | +5 Vdc | Power | | A 50 | +5 Vdc | Power | Figure 2-7 (Part 2 of 2). Processor Channel Interface Slot (A-Side) | I/O Pin | Signal Name | I/O | |---------|----------------|--------| | B 1 | GND | Ground | | B 2 | GND | Ground | | B 3 | +ADR EXT 4 | I | | B 4 | +ADD EXT 5 | I | | B 5 | +ADR EXT 6 | I | | B 6 | +ADD EXT 7 | I | | B 7 | -FPA ID 5 | 0 | | B 8 | -Channel End | I | | B 9 | -System Reset | 0 | | B 10 | +Parity 0 | I/O | | B 11 | -Channel Reset | I | | B 12 | -POR | 0 | | B 13 | GND | Ground | | B 14 | -IOCC Busy | 0 | | B 15 | -Ready | 0 | | B 16 | -Channel Error | I | | B 17 | -I/O Cycle | I | | B 18 | +Seg Sel | 0 | | B 19 | +Parity 1 | I/O | | B 20 | -Address Gate | I | | B 21 | -Data Gate | I | | B 22 | -FPA ID 6 | О | | B 23 | -Data Strobe | I | | B 24 | +5 Vdc | Power | | B 25 | +5 Vdc | Power | Figure 2-8 (Part 1 of 2). Processor Channel Interface Slot (B-Side) | I/O Pin | Signal Name | I/O | |---------|--------------|--------| | B 26 | -DMA Req | 0 | | B 27 | -HRQ | O | | B 28 | -HLDA | I | | B 29 | +Parity 2 | I/O | | B 30 | -DMA Cycle | I | | B 31 | -FPA ID 7 | О | | B 32 | -FPA Busy | О | | B 33 | -Tag | I/O | | B 34 | -5 Vdc | Power | | B 35 | +Exception | I/O | | B 36 | -Timer In | О | | B 37 | GND | Ground | | B 38 | +Parity 3 | I/O | | B 39 | -PIO Request | I | | B 40 | Reserved | | | B 41 | -IREQ 1 | 0 | | B 42 | -IREQ 3 | О | | B 43 | Reserved | | | B 44 | -I/O Trap | 0 | | B 45 | +Panel Ind 1 | I | | B 46 | +Panel Ind 3 | I | | B 47 | +Panel Ind 5 | I | | B 48 | +Panel Ind 7 | I | | B 49 | Gnd | Ground | | B 50 | Gnd | Ground | Figure 2-8 (Part 2 of 2). Processor Channel Interface Slot (B-Side) Figure 2-9. 100 Pin Memory Channel Interface Slot | I/O Pin | Signal Name | I/O | |---------|---------------|--------| | C 1 | +5 Vdc | Power | | C 2 | +5 Vdc | Power | | C 3 | Cnfg 0 Slot C | 0 | | C 4 | Cnfg 1 Slot C | О | | C 5 | -Fast Refresh | 0 | | C 6 | Reserved | | | C 7 | DATA 00 | I/O | | C 8 | DATA 02 | I/O | | C 9 | DATA 04 | I/O | | C 10 | DATA 06 | I/O | | C 11 | DATA 08 | I/O | | C 12 | DATA 10 | I/O | | C 13 | Gnd | Ground | | C 14 | Reserved | | | C 15 | DATA 12 | I/O | | C 16 | DATA 14 | I/O | | C 17 | DATA 16 | I/O | | C 18 | DATA 18 | I/O | | C 19 | DATA 20 | I/O | | C 20 | DATA 22 | I/O | | C 21 | DATA 24 | I/O | | C 22 | DATA 26 | I/O | | C 23 | DATA 28 | I/O | | C 24 | GND | Ground | | C 25 | GND | Ground | Figure 2-10 (Part 1 of 2). Memory Channel Interface Slot (C-Side) | I/O Pin | Signal Name | I/O | |---------|--------------|--------| | C 26 | DATA 30 | I/O | | C 27 | DATA 32 | I/O | | C 28 | DATA 34 | I/O | | C 29 | DATA 36 | I/O | | C 30 | DATA 38 | I/O | | C 31 | ADR A-9 | I | | C 32 | ADR A-7 | I | | C 33 | ADR A-5 | I | | C 34 | ADR A-3 | I | | C 35 | ADR A-1 | I | | C 36 | ADR B-9 | I | | C 37 | GND | Ground | | C 38 | ADR B-7 | Ι | | C 39 | ADR B-5 | I | | C 40 | ADR B-3 | I | | C 41 | ADR B-1 | I | | C 42 | RAS A Slot C | I | | C 43 | CAS A | I | | C 44 | WRT A | Ι | | C 45 | BEN A Slot C | I | | C 46 | RAS B Slot C | I | | C 47 | CAS B | I | | C 48 | WRT B | I | | C 49 | +5 Vdc | Power | | C 50 | +5 Vdc | Power | Figure 2-10 (Part 2 of 2). Memory Channel Interface Slot (C-Side) | I/O Pin | Signal Name | I/O | |---------|---------------|--------| | D 1 | GND | Ground | | D 2 | GND | Ground | | D 3 | Cnfg 0 Slot D | о . | | D 4 | Cnfg 1 Slot D | 0 | | D 5 | Reserved | l — | | D 6 | Reserved | | | D 7 | DATA 01 | I/O | | D 8 | DATA 03 | I/O | | D 9 | DATA 05 | I/O | | D 10 | DATA 07 | I/O | | D 11 | DATA 09 | I/O | | D 12 | DATA 11 | I/O | | D 13 | Gnd | Ground | | D 14 | +Address (4) | I | | D 15 | DATA 13 | I/O | | D 16 | DATA 15 | I/O | | D 17 | DATA 17 | I/O | | D 18 | DATA 19 | I/O | | D 19 | DATA 21 | I/O | | D 20 | DATA 23 | I/O | | D 21 | DATA 25 | I/O | | D 22 | DATA 27 | I/O | | D 23 | DATA 29 | I/O | | D 24 | +5 Vdc | Power | | D 25 | +5 Vdc | Power | Figure 2-11 (Part 1 of 2). Memory Channel Interface Slot (D-Side) | I/O Pin | Signal Name | I/O | |---------|--------------|--------| | D 26 | DATA 31 | I/O | | D 27 | DATA 33 | I/O | | D 28 | DATA 35 | I/O | | D 29 | DATA 37 | I/O | | D 30 | DATA 39 | I/O | | D 31 | ADR A-8 | I | | D 32 | ADR A-6 | I | | D 33 | ADR A-4 | I | | D 34 | ADR A-2 | I | | D 35 | ADR A-0 | I | | D 36 | ADR B-8 | I | | D 37 | GND | Ground | | D 38 | ADR B-6 | I | | D 39 | ADR B-4 | I | | D 40 | ADR B-2 | Ι | | D 41 | ADR B-0 | I | | D 42 | RAS A Slot D | I | | D 43 | Refresh | I | | D 44 | Address (2) | I | | D 45 | BEN A Slot D | I | | D 46 | RAS B Slot D | I | | D 47 | BEN B Slot C | I | | D 48 | BEN B Slot D | I | | D 49 | GND | Ground | | D 50 | GND | Ground | Figure 2-11 (Part 2 of 2). Memory Channel Interface Slot (D-Side) # **Section 3. System Memory Boards** # **CONTENTS** | bout this Section | 3-3 | |-------------------------------------------|------| | lemory | 3-4 | | Features | 3-4 | | Memory Board Slots | 3-5 | | Signal Definitions | 3-6 | | Configurations | 3-8 | | Bank Addressing Control for 1M-Byte Board | 3-9 | | Transceiver Control | 3-9 | | Absolute Maximum Ratings | 3-10 | | DC Characteristics | 3-11 | | AC Characteristics | 3-12 | | Timing Waveforms | 3-14 | | Slot Pin Assignments | 3-18 | # **About this Section** This section contains information about the memory boards used by the IBM RT PC system. The memory board slots are defined and various memory configurations are listed. Also shown are the timing waveforms for the memory read and write cycles. # **Memory** The memory board contains two memory arrays. Each array is configured to be 40 bits wide and either 128K or 256K address positions deep. These configurations yield board sizes of 1M-bytes and 2M-bytes respectively. The board interface consists of nine multiplexed address lines and four control lines for each array. There are 40 bidirectional data lines and 2 input control lines which are shared between the two arrays. It is the responsibility of the external control logic to ensure that there are no data bus usage conflicts between the two arrays. ### **Features** 40 Bit Data Interface (32-bit data, 8-bit Two Way Interleaving ECC) High Density (1MB, 2MB) Single +5V Supply 23.5MB/Sec. Bandwidth 175ns Array Access Time 98% **Availability** # **Memory Board Slots** The system board contains two memory board slots. When a mixture of different memory boards is used, the larger boards must be plugged in slot C as shown in the following table. | Config. | System Ram | Slot C | Slot D | |---------|------------|--------|--------| | 1 | 1.0 MB | 1.0 MB | | | 2 | 2.0 MB | 1.0 MB | 1.0 MB | | 3 | 2.0 MB | 2.0 MB | | | 4 | 3.0 MB | 2.0 MB | 1.0 MB | | 5 | 4.0 MB | 2.0 MB | 2.0 MB | # **Signal Definitions** RAS A : Row Address Strobe for Array A RAS B : Row Address Strobe for Array B CAS A : Column Address Strobe for Array A CAS B : Column Address Strobe for Array B WRT A : Write Enable and Bus Direction for Array A WRT B : Write Enable and Bus Direction for Array B BEN A : Bus Enable for Array A BEN B : Bus Enable for Array B ADR A (0-8) : Address Lines 0-8 for Array A (0 is LSB) ADR B (0-8) : Address Lines 0-8 for Array B (0 is LSB) DATA (00-39) : Data Lines 00-39 for Array A and Array В CNFG (0-2) : Board Identification Jumpers BAB 0 : Bank Address Bit 0 Refresh : Refesh Rate Signal Figure 3-1. Memory Board Logical Dataflow # **Configurations** The following tables list the various configurations for the memory boards. # **Configuration Identification Table** | CNFG 2 | CNFG 1 | CNFG 0 | Definition | |--------|--------|--------|------------| | 0 | 1 | 1 | Reserved | | 1 | 1 | 1 | Reserved | | 0 | 1 | 0 | Reserved | | 1 | 1 | 0 | 512K-bytes | | 0 | 0 | 1 | 1M-bytes | | 1 | 0 | 1 | 2M-bytes | | 0 | 0 | 0 | 4M-bytes | | 1 | 0 | 0 | 8M-bytes | ### Note: 0 = Tab pin grounded on the board 1 = Tab pin open (no connection) ### **Bank Addressing Control for 1M-Byte Board** The following bank addressing description is implemented independently for both memory arrays on the board. The eight least significant address bits (ADRA 0-7 and ADRB 0-7) are used to provide the 256 row and 256 column addresses (64K address space) to each bank of memory chips. Bank address bit 0 and the Refresh (REF) signal are used to select between the two banks of each memory array. The REF input signal to the board is shared between the two arrays on the board. The REF signal (along with Bank Address Bit 0) is routed through transparent latches. There is a separate set of latches for array A and array B and the latches are clocked at the beginning of a memory cycle with the rising edge of the RAS signal for that array. The latched values are then decoded and used to gate the incoming RAS signal to the proper memory bank. The REF and BAB 0 signals have the same input timing requirements as the row address inputs. The logic required for band addressing is implemented independently for each memory array on the board. The decode logic used for bank addressing is described by the following table. | RAS | REF | BAB 0 | Bank Activated (By RAS Signal) | |-----|-----|-------|------------------------------------| | 0 | X | X | None | | 1 | 0 | 1 | Bank 0 (1st bank of 64K x 4 chips) | | 1 | 0 | 0 | Bank 1 (2nd bank of 64K x 4 chips) | | 1 | 1 | X | Bank 0 and 1 (all banks Refresh) | ### **Transceiver Control** | Ben | WRT | Transceiver | Data Direction | |-----|-----|-------------|--------------------------| | 1 | X | Disabled | N. A. | | 0 | 0 | Enabled | Memory array → board tab | | 0 | 1 | Enabled | Board tab → memory array | Note: The transceiver control logic is implemented independently for each memory array on the board. # **Absolute Maximum Ratings** | Parameter | Limits | Unit | Notes | |-------------------------------|--------------|------|-------| | Operating temperature (TA) | 0 to +70 | ٥C | | | Storage temperature (TS) | -55 to +125 | °C | 1 | | Supply voltage (VCC) | -0.5 to +7.0 | V | 1,2 | | Voltage on any pin except VCC | -1.0 to +7.0 | V | 1,2 | ### **Notes:** - 1. These are stress ratings only. Functional operation at these limits is not implied. - 2. Voltages relative to VSS. # **DC** Characteristics $TA = 0 \text{ to } +70 \, {}^{\circ}\text{C}$ | | | L | IMITS | | | | |-----------------------------------------------------------------------------|--------------------------|-------------------------|---------|--------------------------|-------------|-------------------| | Parameter | Symbol | Min | Typical | Max | Unit | Test<br>Condition | | Supply Voltages | VCC<br>VSS | 4.75<br>0 | 5.0 | 5.25 | V<br>V | All Voltages | | High Input Voltage Low Input Voltage High Output Voltage Low Output Voltage | VIH<br>VIL<br>VOH<br>VOL | 2.0<br>-1.0<br>2.4<br>0 | | 5.5<br>0.8<br>VCC<br>0.4 | V<br>V<br>V | Referenced to VSS | | High Input Current | ІІН | | | 200 | μΑ | Except RAS | | IIH for RAS Signal | IIHR | | | 500 | μΑ | | | Low Input Current | IIL | · | | -1.8 | mA | Except RAS | | IIL for RAS Signal | IILR | | | -10.0 | mA | | | High Output Current | ЮН | | | -10 | mA | | | Low Output Current | IOL | | | 4 | mA | | | AVG Full Operating Supply Current both Arrays Active | ICC1 | | | 7200 | mA | | | AVG Standby Power<br>Supply Current both Arrays<br>Standby | ICC2 | | | 2000 | mA | | | Input Capacitance Data I/O Lines | CIND | | | 40 | pF | | | Input Capacitance BEN Lines | CINB | | | 160 | pF | | | Input Capacitance All Other Lines | CINC | | | 25 | pF | | # **AC Characteristics** | | | I | IMITS | | | |------------------------------|------------------|-----|-------|------|-------| | Parameter | Symbol | Min | Max | Unit | Notes | | Read or write cycle time | t <sub>RC</sub> | 290 | | ns | | | Access time from RAS | t <sub>RAC</sub> | | 175 | ns | 1,2 | | Access time from CAS | t <sub>CAC</sub> | - | 100 | ns | 1,2 | | RAS precharge time | t <sub>RP</sub> | 120 | | ns | | | RAS pulse width | t <sub>RAS</sub> | 165 | 10000 | ns | | | CAS Pulse width | t <sub>CAS</sub> | 90 | 10000 | ns | | | RAS to CAS delay time | t <sub>RCD</sub> | 55 | 75 | ns | 3 | | ROW address setup time | t <sub>ASR</sub> | 15 | | ns | | | ROW address hold time | t <sub>RAH</sub> | 30 | | ns | | | Column address setup time | t <sub>ASC</sub> | 15 | | ns | | | Column address hold time | t <sub>CAH</sub> | 60 | | ns | | | COL address hold time to RAS | t <sub>AR</sub> | 135 | | ns | | | Read command setup time | t <sub>RCS</sub> | 25 | · | ns | | | Read command hold time | t <sub>RCH</sub> | 25 | : | ns | | | Write command setup time | t <sub>wcs</sub> | 40 | | ns | | | Write command hold time | twch | 60 | | ns | | | Write command hold to RAS | t <sub>WCR</sub> | 135 | | ns | | | Write command pulse width | t <sub>wp</sub> | 75 | | ns | | | Data in setup time | t <sub>DS</sub> | 10 | | ns | 2 | | Data in hold time | t <sub>DH</sub> | 60 | | ns | | | Data out hold time | t <sub>DOH</sub> | 0 | | ns | | | Data in hold time to RAS | t <sub>DRH</sub> | 135 | | ns | | | RAS hold time | t <sub>RSH</sub> | 90 | | ns | | | | | I | LIMITS | | | |---------------------------|-------------------|-----|--------|----|---| | CAS hold time | t <sub>CSH</sub> | 165 | | ns | | | CAS to RAS precharge time | t <sub>CRP</sub> | 25 | | ns | | | CAS precharge time | t <sub>CPN</sub> | 40 | | ns | | | Output buffer turn on | t <sub>ON</sub> | | 40 | ns | | | Output buffer turn off | t <sub>OFF</sub> | - | 30 | ns | | | Refresh period of A0 - A6 | t <sub>REF1</sub> | | 2 | ms | 4 | | Refresh period of A0 - A7 | t <sub>REF2</sub> | | 4 | ms | 4 | ### **Notes:** - 1. Measured with a load equivalent to 2 TTL loads and 100pF. - 2. These parameters are valid when data transceivers are properly enabled. - 3. $t_{RCD}$ (max) is for reference only. For $t_{RCD} < T_{RCD}$ (max) the access time (from RAS) = $t_{RAC}$ . For $t_{RCD} > t_{RCD}$ (max) the access time (from RAS) = $t_{RCD} + t_{CAC}$ . - 4. The memory board meets either $t_{REF}$ or $t_{REF2}$ , the external controller is required to meet both specifications. ### **Timing Waveforms** All timings for Read, Write, and Refresh cycles are provided by an external memory controller. Read-Modify-Write cycles are not supported. The address inputs (ADRA (0-8) and ADRB (0-8)) are numbered with bit 0 being the least significant. The Refresh (REF) and Bank Address Bit 0 (BAB 0) input lines for bank addressing are valid during the row address valid time. The external controller provides refresh for the lower 128 Row Addresses (ADRA (0-6) and ADRB (0-6)) every 2 milliseconds, and refresh for the lower 256 Row Addresses (ADRA (0-7) and ADRB (0-7)) every 4 milliseconds. RAS only refresh cycles are used to perform the refresh operation. The timing marks in the following timing waveforms are referred at two points. The lower point represents +0.8 volts and the upper point indicates +2.0 volts. The timing waveforms in this section show only one array, but are required for both arrays. It is the responsibility of the external memory control logic to ensure that there are no data bus usage conflicts. The following timing waveforms are included in this section: - Read cycle - · Write cycle - Refresh cycle. # **Read Cycle** Figure 3-2. Memory Board Read Cycle Timing Waveform # Write Cycle Figure 3-3. Memory Board Write Cycle Timing Waveform # **Refresh Cycle** Figure 3-4. Memory Board Refresh Cycle Timing Waveform # **Slot Pin Assignments** The following figures show the memory board slot pin assignments. Figure 3-5. 100 Pin Memory Board Slot | I/O Pin | Signal Name | I/O | |---------|-------------|--------| | A 1 | +5 Vdc | Power | | A 2 | GND | Ground | | A 3 | RAS A | I | | A 4 | CAS A | I | | A 5 | WRT A | I | | A 6 | BEN A | I | | A 7 | RAS B | I | | A 8 | CAS B | I | | A 9 | WRT B | I | | A 10 | BEN B | I | | A 11 | GND | Ground | | A 12 | ADR A-0 | I | | A 13 | ADR A-2 | I | | A 14 | ADR A-4 | I | | A 15 | ADR A-6 | I | | A 16 | ADR A-8 | I | | A 17 | GND | Ground | | A 18 | +5 Vdc | Power | | A 19 | ADR B-0 | I | | A 20 | ADR B-2 | I | | A 21 | ADR B-4 | I | | A 22 | ADR B-6 | I | | A 23 | ADR B-8 | I | | A 24 | RESERVED | | | A 25 | GND | Ground | Figure 3-6 (Part 1 of 2). Memory Board Slot (A-Side) | I/O Pin | Signal Name | I/O | |---------|-------------|--------| | A 26 | DATA 00 | I/O | | A 27 | DATA 02 | I/O | | A 28 | DATA 04 | I/O | | A 29 | DATA 06 | I/O | | A 30 | DATA 08 | I/O | | A 31 | DATA 10 | I/O | | A 32 | GND | Ground | | A 33 | +5 Vdc | Power | | A 34 | DATA 12 | I/O | | A 35 | DATA 14 | I/O | | A 36 | DATA 16 | I/O | | A 37 | DATA 18 | I/O | | A 38 | DATA 20 | I/O | | A 39 | DATA 22 | I/O | | A 40 | DATA 24 | I/O | | A 41 | GND | Ground | | A 42 | DATA 26 | I/O | | A 43 | DATA 28 | I/O | | A 44 | DATA 30 | I/O | | A 45 | DATA 32 | I/O | | A 46 | DATA 34 | I/O | | A 47 | DATA 36 | I/O | | A 48 | DATA 38 | I/O | | A 49 | GND | Ground | | A 50 | +5 Vdc | Power | Figure 3-6 (Part 2 of 2). Memory Board Slot (A-Side) | I/O Pin | Signal Name | I/O | |---------|--------------------|-------------------| | B 1 | +5 Vdc | Power | | B 2 | GND | Ground | | B 3 | Refresh Rate | 0 | | B 4 | Cnfg 0 | 0 | | B 5 | Cnfg 1 | 0 | | B 6 | Cnfg 2 | О | | B 7 | Reserved | | | B 8 | Refresh | I | | B 9 | Bank Address Bit 1 | I | | B 10 | Bank Address Bit 0 | I | | B 11 | GND | Ground | | B 12 | ADR A-1 | I | | B 13 | ADR A-3 | I | | B 14 | ADR A-5 | I | | B 15 | ADR A-7 | I | | B 16 | ADR A-9 | I | | B 17 | GND | Ground | | B 18 | +5 Vdc | Power | | B 19 | ADR B-1 | Ι | | B 20 | ADR B-3 | I | | B 21 | ADR B-5 | Ι | | B 22 | ADR B-7 | ${}^{\mathbf{I}}$ | | B.23. | ADR B-9 | I | | B 24 | Reserved | - <u>-</u> | | B 25 | GND | Ground | Figure 3-7 (Part 1 of 2). Memory Board Slot (B-Side). | I/O Pin Signal Name | | I/O | | |---------------------|--------------|--------|--| | B 26 | DATA 01 | I/O | | | B 27 | DATA 03 | I/O | | | B 28 | DATA 05 | I/O | | | B 29 | DATA 07 | I/O | | | B 30 | DATA 09 | I/O | | | B 31 | DATA 11 | I/O | | | B 32 | GND | Ground | | | B 33 | +5 Vdc | Power | | | B 34 | DATA 13 | I/O | | | B 35 | DATA 15 | I/O | | | B 36 | DATA 17 | I/O | | | B 37 | DATA: 19 | I/O | | | B 38 | DATA 21 | I/O | | | B 39 | DATA 23 | I/O | | | B 40 | DATA 25 | I/O | | | B 41 | GND | Ground | | | B 42 | DATA 27 | I/O | | | B 43 | DATA 29 | I/O | | | B 44 | DATA 31 | I/O | | | B 45 | DATA 33 | I/O | | | B 46 | DATA 35 | I/O | | | B 47 | DATA 37 | I/O | | | B 48 | DATA 39 | I/O | | | B 49 | GND | Ground | | | B 50 | +5 Vdc Power | | | Figure 3-7 (Part 2 of 2). Memory Board Slot (B-Side). # **Section 4. Floating-Point Accelerator** # **CONTENTS** | About this Section | -3 | |---------------------------------------------------------|----| | Cloating-Point Accelerator | -4 | | Block Diagram | -4 | | Data Formats | -5 | | Register Sets4 | -6 | | Description | -7 | | FPA Status Register (FPSR) | -9 | | FPA Exception Register (FPER)4- | 12 | | Command Encoding (Effective Address of Load or Store)4- | 13 | | Floating-Point Commands 4- | 13 | | FPA Coding Example 4- | 39 | | Programming Considerations 4- | 40 | | Floating-Point Accelerator Board Pin Assignments 4- | 41 | # **About this Section** This section describes the programmer's view of the Floating-Point Accelerator board. Many users will not require this level of information. Application programmers may require the Application Program Interface found in the AIX Operating System Technical Reference. Floating point data representations and operation definitions are defined in the IEEE Standard 754 for Binary Floating-Point Arithmetic and are not detailed here. # **Floating-Point Accelerator** The RT PC Floating-Point Accelerator (FPA) is an optional system unit feature which can be installed in either the Model 10, Model 20, or Model 25. It utilizes a dedicated slot on the system board. Operands may be stored on the FPA and operations may be initiated by issuing processor load and store instructions. The FPA operates independently of the system unit so that the system unit and FPA operations can overlap. The board implements a subset of the IEEE revision 10.1 floating point standard. Software is required to fully implement the standard. The board employs the National Semiconductor NS32081 floating point module, utilizing only the external memory functions of the part. # **Block Diagram** Figure 4-1 on page 4-5 is a block diagram of the Floating-Point Accelerator board. When the system unit executes either a load or store instruction having any address in segment FF. the processor board routes the address and any associated data to the FPA over the 32 bit bus. The FPA decodes the command from the address. PROCESSOR CHANNEL Figure 4-1. Floating-Point Accelerator Block Diagram ### **Data Formats** The FPA supports 2 floating-point data formats; the 32-bit single and the 64 bit double, as shown in Figure 4-2 on page 4-6 and Figure 4-3 on page 4-6. Figure 4-2. Single Precision Format Figure 4-3. Double Precision Format The Floating-Point Accelerator performs arithmetic in both formats, converts between formats, and converts to and from the system processor's twos complement binary format. ### **Register Sets** The register file contains 32 sets of 32 bit wide registers. Each set contains 16 registers. Long operands are stored with the high order 32 bits at an even register address and with the low 32 bits at the next higher odd register address. Context switching is achieved by issuing the Task Switch Unlock command which loads the Task ID register. Registers X'0 through D' are general purpose; register X'E' is the floating-point status register (FPSR) and register X'F' is the floating-point exception register (FPER). Figure 4-4 on page 4-7 shows the registers and how they are paired for long operands. Notice that there is a FPSR and a FPER in each of the 32 sets. Figure 4-4. Floating Point Registers # **Description** All transfers of commands and data between the system processor and the FPA are initiated by the system processor and accomplished by Store and Load instructions using memory mapped I/O. Memory addresses starting with X'FF' are decoded by the FPA as commands to it, and are ignored by other devices on the processor channel. The remaining 24 bits of the 32-bit memory address are used as the FPA command. If there is data associated with the command, it is transferred in the 32 bit data packet associated with the Store or Load instruction. If the command requires no data, the data packet is discarded. The system processor address and FPA command format is shown in Figure 4-5 on page 4-8 Figure 4-5. FPA Command Format Bits 0 through 7 are the FPA address and are fixed at X'FF'. Bits 8 through 11 are reserved and must be 0. Bits 12 and 13 indicate if the data packet is to be used and whether it is to go into the register indicated by OP1 or OP2. Bits 14 and 15 are format bits which can be regarded as an extension of the command field, bits 16 through 21. Notice that the format bits assume values 00, 01, and 10 only. #### **Data Source Field Definitions** | Bits<br>12-13 | Function | | | |---------------|-------------------------------|--|--| | 00 | Non immediate data | | | | 01 | Immediate data to OP2 address | | | | 10 | Immediate data to OP1 address | | | | 11 | Reserved | | | #### **Format Field Definitions** | Bits<br>14-15 | Function | |---------------|------------------------| | 00 | Format 0 - FPU type 9 | | 01 | Format 1 - FPU type 11 | | 10 | Format 2 - Non FPU | | 11 | Reserved | Bits 0 through 3 do not actually reach the FPA and bits 4 through 7 become an address extension. Bits 0 through 7 are replaced with the 8-bit processor channel control word providing FPA control and exception reporting. The two operand fields, OP1 and OP2, specify the FPA source and destination addresses, respectively. Most floating-point instructions are unprivileged instructions. Task Switch/Unlock, Lock, and Read Status/Clear Exception are valid only in privileged state. Normally, the FPA should be used in the virtual mode of operation in which program checks (exception conditions) are reported on both Load and Store instructions. FPA exceptions are caused by parity errors, illegal commands or operands, or various data situations, such as overflow. The FPA can be used in the real mode of operation if certain rigorous programming restrictions are followed (see "Programming Considerations" on page 4-40). ### **FPA Status Register (FPSR)** The FPA status register, shown in Figure 4-6 is a hardware register used to control the FPA operation, (such as rounding mode) and to identify various exception conditions. The last state of the status register is saved in register X'E' of the active register set by a Read Status Register instruction. Figure 4-6. Floating Point Status Registers Bits 0 through 15 and 20 through 31 may be written or read by status register commands. Bits 21, 22, 25, 27, and 29 through 31, however, may change during the operations of the FPA. Bits 16 through 19 cannot be written by the programmer. ### **Status Register Definitions** | Bits | Function | |-------|-------------------------------------------------------------------------------------------------------------------------------------| | 0-11 | Useable by software; bits 0 through 9 utilized by IBM software. | | 12-15 | Reserved for hardware uses. | | 16 | Permanent 0. | | 17 | 1 = Aborted Command | | | Board was reset while busy; set by hardware; reset only by RDSCX command. Does not cause program check. See command list for RDSCX. | | 18 | Bus Exception | | | 1 = Program check due to bus parity error on last FPA command. Set by hardware; reset by RDSCX. Nonmaskable. | #### 19 Task Exception 1 = Task Exception; set by hardware, indicates that an FPA exception is causing a program check, reset by RDSCX. Set on last command if a type 7 exception is detected, set on second to last command if bit 20 is 0 and an enabled or ungatable exception type 1-6 occurs. (See bits 26 through 28 and 29 through 31.) #### 20 Program Check Disable 1 = Program checks disabled on exception types 1-6. (See bits 29 through 31.) Normally set to 0. #### 21-22 N. Z: These bits hold the results of the last compare operation: N Z 21 22 - 1 | 0 OP1>0P2 - 1 | 1 (Software may reserve this state for unordered.) ### 23-24 Rounding Mode Control: 23 24 - 0 | 0 Round (nearest) - 0 | 1 Truncate (towards zero) - $1 \mid 0$ Ceiling (towards $+ \infty$ ) - 1 | 1 Floor (towards $\infty$ ) ### 25 Inexact Flag: - 1 = Inexact result occurred since this bit was written to zero. - 0 = No inexact result since bit was written to zero. #### 26 Inexact Enable - 1 = No result produced on inexact result. Also program check occurs if Bit 20 = 0. - 0 = No program check occurs, results rounded per bits 23-24. ### 27 Underflow Flag - 1 = Underflow occurred since this bit was written to zero. - 0 =No underflow since this bit was written to zero. 28 **Underflow Enable** 1 = No result produced on UF; and program check occurs if Bit 20 = 0. 0 = No program check occurs and result set to 0 on UF. #### 29-31 **Exception Type** These bits are changed on each command performed except WTFR, RDFR, RDSTR, RDSCX regardless of bits 20, 26 or 28. | Type | 29 30 31 | | |------|-----------|--------------------------------------------| | 0 | 0 0 0 | No Exception | | 1 | 0 0 1 | Underflow – See above | | 2 | 0 1 0 | Overflow - result register unchanged | | 3 | 0 1 1 | Divide by zero - result register unchanged | | 4 | 1 0 0 | Reserved | | 5 | 1 0 1 | Operand Error — result register unchanged | | 6 | 1 1 0 | Inexact result – see above | | 7 | 1 1 1 | Illegal Command – reset only with RDSCX; | | | | Nonmaskable | Note: Conversion of very large floating-point numbers to word may result in an exception. If this occurs, it results in exception type 2 rather than 5. # **FPA Exception Register (FPER)** When an exception is reported, Register X'F' of the selected register group will contain the following information about the last command taken from the 8 bit processor channel control word and the command. | Bit | Meaning | |------|--------------------------------------------------------| | 0 | 0 | | 1 | 0 = Load; $1 = Store$ | | 2 | 1 | | 3 | 0 | | 4 | 1 = Storage Protect Enabled (not used by FPA) | | 5 | 0 = Real Mode; 1 = Virtual Mode | | 6 | 0 = Privileged State; 1 = Nonprivileged (Normal State) | | 7 | Reserved | | 8-31 | Bits 8-31 of the command. | # **Command Encoding (Effective Address of Load or Store)** Binary weighted bits specifying one of the 16 active short registers or 8 active $r_1, r_2$ long registers pairs as operand 1 or 2. $R_1,R_2$ 32-bit register for operand 1, operand 2, or result, specified by $r_1, r_2$ . $(R_1), (R_2)$ Contents of register $R_1$ , $R_2$ . Ι 32 bits of immediate data associated with a store type command. $RP_1,RP_2$ 64-bit register pair for operand 1, operand 2, or result, specified by $r_1, r_2$ . $(RP_1)$ , $(RP_2)$ Contents of register pair RP<sub>1</sub>,RP<sub>2</sub>. Su Indicates that exception will result if system not in supervisory state. Ld Load type instruction. St Store instruction. Boxed area Bits 12-31 of the address of the load or store instruction. Bits 0-11 are always X'FF0'. Replaces the content of. # **Floating-Point Commands** The floating-point commands are described and listed in alphabetical order. Some other commands, not documented here, are legal but redundant, and are not supported. ### **Absolute Short (ABSS)** | 0001 | 1101 | 01r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |------|------|---------------------------------|----------------|----------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $| (R_1) | \rightarrow R_2$ ## **Absolute Immediate Short (ABSIS)** | 1001 | 1101 | 01r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> ( | 00 | |------|------|---------------------------------|----------------|---------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $$I \rightarrow R_1$$ $| (R_1) | \rightarrow R_2$ $(R_1)$ preserved #### **Absolute Long (ABSL)** | ſ | 0001 | | 1101 | 00r <sub>1</sub> r <sub>1</sub> | | $r_10r_2r_2$ | r <sub>2</sub> 000 | | |---|------|----|------|---------------------------------|----|--------------|--------------------|----| | 1 | 2 1 | 15 | 1 | 9 | 23 | 2 | 7 | 31 | St $$|(RP_1)| \rightarrow RP_2$$ #### **Absolute Immediate Long (ABSIL)** St $$I \rightarrow R_1$$ (32 bits - high half of 64) $| (RP_1) | \rightarrow RP_2$ $(RP_1)$ preserved ## Add Short (ADDS) St $$(R_1) + (R_2) \rightarrow R_2$$ #### Add Immediate Short (ADDIS) St $$I \rightarrow R_1$$ $(R_1) + (R_2) \rightarrow R_2$ #### **Add Short Immediate (ADDSI)** $$I \rightarrow R_2$$ St $(R_1) + (R_2) \rightarrow R_2$ #### Add Long (ADDL) | | 0001 | 0000 | 00r <sub>1</sub> r <sub>1</sub> | $r_10r_2r_2$ | $r_2000$ | | |----|------|------|---------------------------------|--------------|----------|----| | 12 | 1: | 5 | 19 | 23 | 27 | 31 | St $$(RP_1) + (RP_2) \rightarrow RP_2$$ #### **Add Immediate Long (ADDIL)** St $$I \rightarrow R_1$$ (32 bits — high half of 64) $(RP_1) + (RP_2) \rightarrow RP_2$ #### **Add Long Immediate (ADDLI)** St $$I \rightarrow R_2$$ (32 bits — high half of 64) $(RP_1) + (RP_2) \rightarrow RP_2$ #### **Compare Short (COMS)** | 000 | 01 | 0010 | 01r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> r <sub>1</sub> r | $r_2r_2$ $r_2r_2$ | XX | |-----|----|------|---------------------------------|---------------------------------|-------------------|----| | 12 | 15 | 19 | 9 | 23 | 27 | 31 | St (R<sub>1</sub>) compared to (R<sub>2</sub>) Status register N, Z set (see status register bits 21-22) #### **Compare Immediate Short (COMIS)** | 10 | 001 | 0010 | $01r_1r_1$ | $r_1r_1r_2r_2$ | $r_2r_2XX$ | | |----|-----|------|------------|----------------|------------|----| | 12 | 15 | 5 1 | 9 | 23 | 27 | 31 | St $I \rightarrow R_1$ (R<sub>1</sub>) compared to (R<sub>2</sub>) Status register N, Z set (see status register bits 21-22) #### **Compare Long (COML)** St (RP<sub>1</sub>) compared to (RP<sub>2</sub>) Status register N, Z set (see status register bits 21-22) ## **Compare Immediate Long (COMIL)** | 1001 | T | 0010 | 00r <sub>1</sub> r <sub>1</sub> | | $r_10r_2r_2$ | | r <sub>2</sub> 0XX | | |------|----|------|---------------------------------|----|--------------|---|--------------------|----| | 12 | 15 | 19 | ) | 23 | | 2 | 7 | 31 | St $I \rightarrow R_1$ (32 bits — high half of 64) $(RP_1)$ compared to $(RP_2)$ Status register N, Z set (see status register bits 21-22) #### **Convert Short To Long (CSL)** | | 0000 | | 0110 | 11r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> | $r_1r_2r_2$ | r <sub>2</sub> 000 | | |---|------|----|------|---------------------------------|----------------|-------------|--------------------|----| | • | 12 | 15 | 19 | 9 | 23 | 2' | 7 | 31 | St $(R_1)$ (32 bits) converted to long format (64 Bits) $(R_1)$ preserved Result $\rightarrow RP_2$ #### **Convert Immediate Short To Long (CISL)** | 1000 | | 0110 | 11r <sub>1</sub> r <sub>1</sub> | 1 | $r_1 r_1 r_2 r_2$ | r <sub>2</sub> 000 | $\Box$ | |------|----|------|---------------------------------|----|-------------------|--------------------|--------| | 12 | 15 | 19 | ) | 23 | 2 | 7 | 31 | St $I \rightarrow R_1$ (32 bits) (R<sub>1</sub>) converted to long format (64 bits) (R<sub>1</sub>) preserved Result $\rightarrow RP_2$ #### **Convert Long To Short (CLS)** | 00 | 00 | 0101 | 10r <sub>1</sub> r <sub>1</sub> | | $r_1 0 r_2 r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | | |----|----|------|---------------------------------|----|-----------------|----|----------------------------------|----| | 12 | 15 | 1 | 9 | 23 | | 27 | | 31 | St (RP<sub>1</sub>) converted to short format (32 bits) (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ ## **Convert Immediate Long To Short (CILS)** | | 1000 | | 0101 | 10r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> | $0r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |---|------|----|------|---------------------------------|----------------|-----------|----------------------------------|----| | 1 | 12 | 15 | 19 | | 23 | 27 | 7 | 31 | St $I \rightarrow R_1$ (32 bits — high half of 64) $(RP_1)$ converted to short format $(RP_1)$ preserved $Result \rightarrow R_2$ #### **Convert Word To Short (CWS)** | 0000 | | 0001 | 11r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |------|----|------|---------------------------------|----|----------------|----------------------------------|----| | 12 | 15 | 1 | 9 | 23 | | 27 | 31 | St $(R_1)$ converted to short float format $(R_1)$ preserved Result $\rightarrow R_2$ #### **Convert Immediate Word To Short (CIWS)** | 1000 | 0001 | 11r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |------|------|---------------------------------|----------------|----------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $I \rightarrow R_1$ (32 bit integer) (R<sub>1</sub>) converted to short float format (R<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Convert Word To Long (CWL)** | | 0000 | | 0000 | 11r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | r <sub>2</sub> 000 | | |---|------|----|------|---------------------------------|----|----------------|--------------------|----| | 1 | 2 | 15 | 19 | 9 | 23 | | 27 | 31 | St (R<sub>1</sub>) converted to long float format (R<sub>1</sub>) preserved Result $\rightarrow RP_2$ ## Convert Immediate Word To Long (CIWL) | | 1000 | | 0000 | | 11r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | | r <sub>2</sub> 000 | | | |---|------|----|------|---|---------------------------------|----------------|---|--------------------|----|---| | 1 | 2 | 15 | 19 | 9 | 2: | 3 | 2 | 7 | 31 | i | St $I \rightarrow R_1$ (32 Bit Integer) $(R_1)$ converted to long float format $(R_1)$ preserved Result $\rightarrow RP_2$ ## **Copy Short (COPS)** | 0001 | 0001 | $01r_1r_1$ | $r_1r_1r_2r_2$ | $r_2r_2C$ | 00 | |------|------|------------|----------------|-----------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $(R_1) \rightarrow R_2$ #### Copy Long (COPL) St $$(RP_1) \rightarrow RP_2$$ #### **Divide Short (DIVS)** St $$(R_2) \div (R_1) \rightarrow R_2$$ ## **Divide Immediate Short (DIVIS)** | 1001 | 1000 | $01r_1r_1$ | $r_1r_1r_2r_2$ | $r_2r_20$ | 00 | |------|------|------------|----------------|-----------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $$I \rightarrow R_1$$ $(R_2) \div (R_1) \rightarrow R_2$ #### **Divide Short Immediate (DIVSI)** | 0101 | 1000 | 01r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> ( | 00 | |------|------|---------------------------------|----------------|---------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $$I \rightarrow R_2$$ $(R_2) \div (R_1) \rightarrow R_2$ #### Divide Long (DIVL) St $$(RP_2) \div (RP_1) \rightarrow RP_2$$ ## Divide Immediate Long (DIVIL) St $$I \rightarrow R_1$$ (32 bits — high half of 64) $(RP_2) \div (RP_1) \rightarrow RP_2$ ## **Divide Long Immediate (DIVLI)** | 010 | )1 | 1000 | 00r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> 01 | $r_2r_2$ | r <sub>2</sub> 000 | |-----|----|------|---------------------------------|-------------------|----------|--------------------| | 12 | 15 | 19 | ) | 23 | 27 | 31 | St $$I \rightarrow R_2$$ (32 bits — high half of 64) $(RP_2) \div (RP_1) \rightarrow RP_2$ #### Floor Short To Word (FSW) | 000 | 00 | 1111 | 11r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2$ | $r_2$ $r_2r_2$ | 00 | |-----|----|------|---------------------------------|-------------|----------------|----| | 12 | 15 | 19 | ) | 23 | 27 | 31 | St (R<sub>1</sub>) converted to integer and floored (R<sub>1</sub>) preserved Result $\rightarrow R_2$ #### Floor Immediate Short To Word (FISW) | 10 | 000 1 | 111 | 11r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | | $r_2 r_2 00$ | | |----|-------|-----|---------------------------------|----------------|----|--------------|----| | 12 | 15 | 19 | 23 | 3 | 27 | | 31 | St $I \rightarrow R_1$ $(R_1)$ converted to integer and floored to 32 bits $(R_1)$ preserved $Result \rightarrow R_2$ #### Floor Long To Word (FLW) | 0000 | | 1110 | 11r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> ( | 0r <sub>2</sub> r <sub>2</sub> | r <sub>2</sub> r <sub>2</sub> 00 | | |------|----|------|---------------------------------|------------------|--------------------------------|----------------------------------|----| | 12 | 15 | 19 | 9 | 23 | 2 | 7 | 31 | St $(RP_1)$ converted to integer and floored to 32 bits $(RP_1)$ preserved $Result \rightarrow R_2$ #### Floor Immediate Long To Word (FILW) | | 1000 | 1110 | 11r <sub>1</sub> r <sub>1</sub> | $r_10r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | ] | |---|-------|------|---------------------------------|--------------|----------------------------------|---------| | 1 | .2 1: | 5 19 | ) 2 | .3 2 | 7 3 | -<br>31 | St $I \rightarrow R_1$ (32 bits - high half of 64) (RP<sub>1</sub>) converted to integer and floored to 32 bits (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ ## Lock Floating Point (LOCKFP) - Privileged Instruction | 00 | 10 | 0111 | 0000 | 0000 | 0000 | | |----|----|------|------|------|------|----| | 12 | 15 | 19 | ) 2 | 23 | 27 | 31 | St, Su Locks out all instructions except TSKSWU, RDSCX, LOCKFP (Type 7 exception generated upon receiving a locked out instruction). ## **Multiply Short (MULS)** St $(R_1) \times (R_2) \rightarrow R_2$ ## **Multiply Immediate Short (MULIS)** | 1001 | 1100 | 01r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> ( | 00 | |------|------|---------------------------------|----------------|---------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $$I \rightarrow R_1$$ $(R_1) \times (R_2) \rightarrow R_2$ ## **Multiply Short Immediate (MULSI)** | 0101 | 1100 | 01r <sub>1</sub> r <sub>1</sub> | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 0 | 0 | |------|------|---------------------------------|----------------|---------------------------------|----| | 12 | 15 | 19 | 23 | 27 | 31 | St $$I \rightarrow R_2$$ $(R_2) \times (R_1) \rightarrow R_2$ #### Multiply Long (MULL) | 0001 | | 1100 | 00r <sub>1</sub> r <sub>1</sub> | | $r_10r_2r_2$ | r <sub>2</sub> 000 | | |------|----|------|---------------------------------|----|--------------|--------------------|----| | 12 | 15 | 19 | ) | 23 | 2 | .7 | 31 | St $$(RP_1) \times (RP_2) \rightarrow RP_2$$ #### **Multiply Immediate Long (MULIL)** | 100 | 01 | 1100 | 00r <sub>1</sub> r <sub>1</sub> | | $r_10r_2r_2$ | r <sub>2</sub> 000 | | |-----|----|------|---------------------------------|----|--------------|--------------------|----| | 12 | 15 | 19 | ) | 23 | | 27 | 31 | St $$I \rightarrow R_1$$ (32 bits – high half of 64) $(RP_1) \times (RP_2) \rightarrow RP_2$ #### **Multiply Long Immediate (MULLI)** St $$I \rightarrow R_2$$ (32 Bits – high half of 64) $(RP_1) \times (RP_2) \rightarrow RP_2$ #### **Negate Short (NEGS)** St $$(R_1) \times (-1) \rightarrow R_2$$ ## **Negate Immediate Short (NEGIS)** | | 1001 | 0101 | | 01r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | | |----|------|------|----|---------------------------------|----|----------------|----|----------------------------------|----| | 12 | 2 1: | 5 | 19 | | 23 | | 27 | | 31 | St $$I \rightarrow R_1$$ $(R_1) \times (-1) \rightarrow R_2$ $(R_1)$ preserved #### **Negate Long (NEGL)** St $$(RP_1) \times (-1) \rightarrow RP_2$$ #### **Negate Immediate Long (NEGIL)** St $$I \rightarrow R_1$$ (32 bits - high half of 64) $(RP_1) \times (-1) \rightarrow RP_2$ $(RP_1)$ preserved #### **Read Float Register (RDFR)** | 0010 | 1111 | 00r <sub>1</sub> r <sub>1</sub> | r <sub>1</sub> r <sub>1</sub> 00 | 0000 | | |------|------|---------------------------------|----------------------------------|------|---------| | 12 | 15 | 19 | 23 | 27 | _<br>31 | Ld (R<sub>1</sub>) $$\rightarrow$$ CPU (for 64 bits perform second RDFR at R<sub>1</sub> + 1) #### Read Exception Register (RDER) Ld $$(Reg X'F') (FPER) \rightarrow CPU (see FPER description)$$ #### **Read Status Register (RDSTR)** Ld Hardware status $\rightarrow$ Reg X'E' then (Reg X'E') $\rightarrow$ CPU ## Read Status Clear Exception (RDSCX) - Privileged Instruction | 00 | 10 | 1101 | 1111 | 1011 | 1 | 1000 | |----|----|------|------|------|----|------| | 12 | 15 | 19 | 2 | 3 | 27 | 31 | Ld, Su Hardware status → CPU → REG X'E' of active register set - Program check conditions and associated status bits reset - Only used at initialization or following an exception. #### **Round Short To Word (RSW)** | 0001 | | 0100 | 01r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | | |------|----|------|---------------------------------|----|----------------|----|----------------------------------|----| | 12 | 15 | 19 | 9 | 23 | | 27 | | 31 | St $(R_1)$ converted to integer and rounded to 32 bits $(R_1)$ preserved Result $\rightarrow R_2$ ## **Round Immediate Short To Word (RISW)** | 10 | 01 | 0100 | 01r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |----|----|------|---------------------------------|----|----------------|----------------------------------|----| | 12 | 15 | 19 | ) | 23 | | 27 | 31 | St $I \rightarrow R_1$ (R<sub>1</sub>) converted to integer and rounded to 32 bits (R<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Round Long To Word (RLW)** | 0001 | | 0100 | 0 | 1r <sub>1</sub> r <sub>1</sub> | $r_10r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | 1 | |------|----|------|---|--------------------------------|--------------|----|----------------------------------|------------| | 12 | 15 | 1 | 9 | 23 | 3 | 27 | | <u>3</u> 1 | St (RP<sub>1</sub>) converted to integer and rounded to 32 bits (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ ## Round Immediate Long To Word (RILW) | | 1001 | 0100 | $01r_1r_1$ | $\mathbf{r}_1$ | $0r_2r_2$ | $r_2r_200$ | | |----|------|------|------------|----------------|-----------|------------|---| | 12 | 15 | 19 | 9 | 23 | 27 | 3 | 1 | St $I \rightarrow R_1$ (32 bits - high half of 64) (RP<sub>1</sub>) converted to integer and rounded to 32 bits (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Subtract Short (SUBS)** | 0001 | T | 0100 | $01r_{1}r_{1}$ | $r_1r_1r_2r_2$ | | $r_2r_200$ | |------|----|------|----------------|----------------|----|------------| | 12 | 15 | 19 | ) | 23 | 27 | 31 | St $$(R_2) - (R_1) \rightarrow R_2$$ #### **Subtract Immediate Short (SUBIS)** St $$I \rightarrow R_1$$ $(R_2) - (R_1) \rightarrow R_2$ #### **Subtract Short Immediate (SUBSI)** | 0101 | | 0100 | 01r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | | |------|----|------|---------------------------------|----|----------------|----|----------------------------------|----| | 12 | 15 | 19 | ) | 23 | | 27 | | 31 | St $$I \rightarrow R_2$$ $(R_2) - (R_1) \rightarrow R_2$ #### **Subtract Long (SUBL)** St $$(RP_2) - (RP_1) \rightarrow RP_2$$ #### **Subtract Immediate Long (SUBIL)** St $$I \rightarrow R_1$$ (32 bits — high half of 64) $(RP_2) - (RP_1) \rightarrow RP_2$ #### **Subtract Long Immediate (SUBLI)** | 01 | 01 | 0100 | $00r_{1}r_{1}$ | $r_10r_2r_2$ | r <sub>2</sub> 000 | |----|----|------|----------------|--------------|--------------------| | 12 | 15 | 19 | 23 | 3 2 | 7 31 | St $$I \rightarrow R_2$$ (32 bits — high half of 64) $(RP_2) - (RP_1) \rightarrow RP_2$ #### Task Switch Unlock (TSKSWU) - Privileged Instruction | 00 | 10 | 0011 | 1111 | | 1011 | 1000 | | |----|----|------|------|----|------|------|----| | 12 | 15 | 1 | 9 | 23 | 27 | | 31 | St, Su - I Bits $27-31 \rightarrow TASK$ ID REG (See Figure 1) - Task Status (register X'E') → hardware status logic - FPA board "unlocks" allowing operation on new task with previous status restored. #### **Truncate Short To Word (TSW)** $(R_1)$ converted to integer and truncated to 32 bits (R<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Truncate Immediate Short To Word (TISW)** | 10 | 00 | 1011 | 11r <sub>1</sub> r <sub>1</sub> | | $r_1r_1r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | |----|----|------|---------------------------------|----|----------------|----------------------------------| | 12 | 15 | 19 | ) | 23 | 2' | 7 31 | $I \rightarrow R_1$ (R<sub>1</sub>) converted to integer and truncated to 32 bits (R<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Truncate Long To Word (TLW)** | | 0000 | | 1010 | 11r <sub>1</sub> r <sub>1</sub> | | $r_10r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | | |----|------|----|------|---------------------------------|----|--------------|----|----------------------------------|--------| | 1: | 2 | 15 | 19 | 9 | 23 | | 27 | | <br>31 | (RP<sub>1</sub>) converted to integer and truncated to 32 bits (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ #### **Truncate Immediate Long To Word (TILW)** | ſ | 1000 | 1010 | 11r <sub>1</sub> r | 1 | $r_10r_2r_2$ | r <sub>2</sub> r <sub>2</sub> 00 | | |---|------|------|--------------------|----|--------------|----------------------------------|----| | 1 | 2 1 | 5 1 | 9 | 23 | 2 | 7 | 31 | St $I \rightarrow R_1$ (32 bits - high half of 64) (RP<sub>1</sub>) converted to integer and truncated to 32 bits (RP<sub>1</sub>) preserved Result $\rightarrow R_2$ #### Write Float Register (WTFR) | 00 | 10 | 0101 | 0000 | $00r_2r_2$ | | r <sub>2</sub> r <sub>2</sub> 00 | |----|----|------|------|------------|----|----------------------------------| | 12 | 15 | 19 | 23 | 3 | 27 | 31 | St $I \rightarrow R_2$ (valid $R_2 = X'$ 0-D') (for long operands write high 32 bits at $R_2$ ; perform WTFR again with low 32 bits at $R_2 + 1$ ) #### Write Status Register (WTSTR) | 0100 | | 0011 | 1111 | | 1011 | 1000 | | |------|----|------|------|----|------|------|----| | 12 | 15 | 19 | 9 | 23 | 2 | 7 | 31 | St I → Active Status Register (X'E') I → Hardware Status Logic. (Some bits unwritable — see status register description) ## **FPA Coding Example** Assume that general registers 8 and 9 contain two single precision floating-point numbers which are to be added together. The result is left in general register 2 in the same format. General register 15 is used for building the floating-point commands. Floating-point registers 2 and 3 will hold the operands. | cau | 15,0xFF02 | /* upper half of write float register | /* | |-----|--------------|-------------------------------------------------------------------------------|----| | st | 8,0x5008(15) | /* general register 8 to float register 2 | /* | | cau | 15,0xFF05 | /* upper half of Add Short Immediate | /* | | st | 9,0x04C8(15) | /* general register 9 to float register 3, 2 added to 3, result in 3 | /* | | cau | 15,0xFF03 | /* Read float register command field. Will borrow so use FF03 instead of FF02 | /* | | I | 2,0xF0C0(15) | /* Float register 3 to general register 2 | /* | ## **Programming Considerations** - Exception type 5 (operand error) results if (1) a numeric operation is performed using reserved operands (infinity, not-a-number, or denormalized numbers) or (2) result would yield reserved operand or (3) both operands of divide are zero. The results register is not changed in these cases. - Illegal command exception (type 7) occurs on all illegally coded FPA opcodes or when "locked out" instructions are received. - A RDSTR instruction should always precede a TSKSWU or LOCK FP to update Hardware to RAM register file. - Each register set (Task) must be initialized with the sequence TSKSWU, RDSCX, WTSTR. Power on state is "locked." - Wait 6.5 µsec after power on reset or any channel reset before issuing more commands. - The program check handler should issue RDSCX following program check; repeat until successful or time out. - Numeric exceptions (types 1-6) cause program check on the command following the one with the numeric exception. The second instruction is not executed. - The FPA cannot produce the IEEE "unordered" result on comparisons of not-a-numbers. - Once a program check occurs, any other instructions except RDSCX will cause program check with the status register unchanged unless a bus error occurs. - The system is normally used in the virtual mode of operation. If real mode operation is required, the following software restrictions apply: - 1. Any FPA or IOCC instruction must be followed by an instruction which uses the result of that load before a subsequent FPA instruction is executed. - 2. Any FPA store instruction must be followed by at least one store or two loads which reference system memory before a subsequent FPA instruction is executed. - 3. Any FPA or IOCC instruction which follows an FPA load must be preceded by an instruction which uses the result of that load. # Floating-Point Accelerator Board Pin Assignments The following tables contain the Floating-Point Accelerator board slot pin assignments. The 'R' pins correspond to the 'A' socket pins (component side). Figure 4-7. 100 Pin FPA Board Slot | I/O Pin | Signal Name I/O | |---------|-----------------| | R 1 | +5 Vdc | | R 2 | +5 Vdc | | R 3 | +ADR/DATA 00 | | R 4 | +ADR/DATA 01 | | R 5 | +ADR/DATA 02 | | R 6 | +ADR/DATA 03 | | R 7 | +ADR/DATA 04 | | R 8 | +ADR/DATA 05 | | R 9 | +ADR/DATA 06 | | R 10 | +ADR/DATA 07 | | R 11 | +ADR/DATA 08 | | R 12 | +ADR/DATA 09 | | R 13 | Gnd | | R 14 | +ADR/DATA 10 | | R 15 | +ADR/DATA 11 | | R 16 | +ADR/DATA 12 | | R 17 | +ADR/DATA 13 | | R 18 | +ADR/DATA 14 | | R 19 | +ADR/DATA 15 | | R 20 | +ADR/DATA 16 | | R 21 | +ADR/DATA 17 | | R 22 | +ADR/DATA 18 | | R 23 | +ADR/DATA 19 | | R 24 | GND | | R 25 | GND | Figure 4-8 (Part 1 of 2). Floating-Point Accelerator Slot (R-Side) | I/O Pin | Signal Name | I/O | |---------|-------------|------| | R 26 | +ADR/DATA | 20 | | R 27 | +ADR/DATA | 21 | | R 28 | +ADR/DATA | . 22 | | R 29 | +ADR/DATA | 23 | | R 30 | +ADR/DATA | 24 | | R 31 | +ADR/DATA | 25 | | R 32 | +ADR/DATA | 26 | | R 33 | +ADR/DATA | 27 | | R 34 | +ADR/DATA | 28 | | R 35 | +ADR/DATA | 29 | | R 36 | +ADR/DATA | 30 | | R 37 | GND | | | R 38 | +ADR/DATA | 31 | | R 39 | Reserved | | | R 40 | -RSC HOLD | | | R 41 | -IREQ 0 | | | R 42 | -IREQ 2 | | | R 43 | -IREQ 4 | | | R 44 | -IREQ 6 | | | R 45 | Reserved | | | R 46 | Reserved | | | R 47 | GND | | | R 48 | GND | | | R 49 | +5 Vdc | | | R 50 | +5 Vdc | - | Figure 4-8 (Part 2 of 2). Floating-Point Accelerator Slot (R-Side) | I/O Pin | Signal Name I/O | |------------|-----------------| | S 1 | +5 Vdc | | S 2 | +5 Vdc | | S 3 | +ADR EXT 4 | | S 4 | +ADD EXT 5 | | S 5 | +ADR EXT 6 | | S 6 | +ADD EXT 7 | | S 7 | -FPA ID 5 | | S 8 | -Channel End | | <b>S</b> 9 | GND | | S 10 | +Parity 0 | | S 11 | -Channel Reset | | S 12 | -POR | | S 13 | GND | | S 14 | -Busy | | S 15 | -Ready | | S 16 | -Channel Error | | S 17 | -I/O Cycle | | S 18 | -IOCC Active | | S 19 | +Parity 1 | | S 20 | GND | | S 21 | -Data Gate | | S 22 | -FPA ID 6 | | S 23 | -Data Strobe | | S 24 | GND | | S 25 | GND | Figure 4-9 (Part 1 of 2). Floating-Point Accelerator Slot (S-Side) | I/O Pin | Signal Name | I/O | |---------|---------------|-----| | S 26 | -Timer In | | | S 27 | -HLDA | | | S 28 | -HRQ | | | S 29 | +Parity 2 | | | S 30 | GND | | | S 31 | -FPA ID 7 | | | S 32 | -FPA Busy | | | S 33 | +Tag | | | S 34 | GND | | | S 35 | +Exception | | | S 36 | -Sys Reset | | | S 37 | GND | | | S 38 | +Parity 3 | | | S 39 | -PIO Request | | | S 40 | -Address Gate | | | S 41 | -IREQ 1 | | | S 42 | -IREQ 3 | | | S 43 | -IREQ 5 | | | S 44 | -I/O Trap | | | S 45 | -DMA Req | | | S 46 | -DMA Cycle | | | S 47 | GND | | | S 48 | GND | | | S 49 | +5 Vdc | | | S 50 | +5 Vdc | | Figure 4-9 (Part 2 of 2). Floating-Point Accelerator Slot (S-Side) # **Section 5. System Boards** ## **CONTENTS** | About this Section | 5-5 | |------------------------------------------------|------| | Model 10 Model 20 and Model 25 Common Features | 5-6 | | Model 20 and Model 25 Unique Features | 5-7 | | Model 10 Unique Features | 5-9 | | System Board I/O Address Assignments | 3-12 | | Addressing Modes | 5-14 | | System Processor Accesses | 5-14 | | DMA Addressing Modes | 2-12 | | Translation Modes | 5-17 | | Arbitration | 5-33 | | System Arbiter Operation | 5-33 | | Single Cycle | 5-34 | | Burst Cycles | 5-34 | | Buffer Mode DMA | 5-34 | | Burst and Ruffer Mode DMA | 5-36 | | I/O Channel Operations | 5-37 | | Fast and Slow Channel Operations | 5-37 | | Single and Multicycle Channel Operations | 5-37 | | DMA | 5-39 | | 8237 DMA Controller 1 | 5-41 | | 8237 DMA Controller 2 | 5-46 | | Alternate Controllers | 5-52 | | Refresh | 5-53 | | Buffer Register | 5-54 | | Interrupt Controllers | 5-56 | | Interrupt Priority | 5-57 | | Diagnostic Interrupt Activate Register | 5-58 | | Component Reset Register A (CRRA) | 5-59 | | Component Reset Register B (CRRB) | 5-61 | | Channel Status Register (CSR) | 5-63 | | Miscellaneous CSR Errors | 5-71 | | CSR Bit Status | 5-72 | | Memory Configuration Register | 5-73 | | I/O Delay Register (IDR) | 5-74 | | I/O Subsystem Adapters | 5-75 | | Real Time Clock | 5-75 | | Serial Ports | 5-76 | | | 5-77 | | Programmed I/O and DMA Modes | | | External Registers | 5-79 | | DMA Initialization Sequence | 5-83 | | RS232C Interface | 5-84 | | Keyboard, Locator, Speaker Adapter | 5-86 | | Keynoard, Locator, Speaker Adapter | 5 30 | | System Software Interface | . 5-86 | |------------------------------------------------------------------------|---------| | Intel 8255 Programmable Peripheral Interface | 5_86 | | Intel 8051 Microcontroller Functions | . 5-86 | | Keyboard Interface | 5-87 | | Locator Interface | . 5-87 | | Speaker Interface | . 5-87 | | RAS and Security Functions Provided by the Adapter | . 5-88 | | Adapter I/O Operations | 5-89 | | IOW and IOR Operations | 5-91 | | Adapter Reset Operation | . 5-96 | | Adapter Initiated Interrupt Request - ID Codes | 5-97 | | Adapter Commands | 5_99 | | Extended Command Descriptions | 5-107 | | Adapter Shared RAM | 5 111 | | Modes and Status Bits in Shared RAM | 5-112 | | Read Only Shared RAM | 5_115 | | RAS Logs in Shared RAM | 5-116 | | Adapter Speaker Control | 5_118 | | Sharing of Speaker Input With Coprocessor | 5 110 | | Speaker Frequency Control | 5-118 | | Speaker Duration Control | 5-120 | | Speaker Volume Control | 5 121 | | Speaker Command Queue Description | 5-121 | | Keystroke Click Description | 5-122 | | Adapter RAS and Security Functions | 5-124 | | Keylock Switch Support | 5 124 | | Detection of Special Keystroke Sequences | 5-124 | | Diagnostic wraps | 5 126 | | Adapter Self-Test After a Power-On, System, or Adapter Reset | 5-126 | | Diagnose Functions Executed on System Command | 5_127 | | Adapter Informational Codes Returned to System | 5-127 | | Adapter Error Codes Returned to System | 5-128 | | Adapter Device Support Notes | 5-131 | | Keyboard Commands | 5-131 | | Keyboard Outputs | 5_131 | | Locator Device Support Notes | 5-132 | | Adapter Design Notes | 5_133 | | 8051 Pin Assignment | 5-137 | | 8255 Pin Assignment | 5 120 | | Channel I/O Device Address Bit Decoding | 5-140 | | 8U31 KAM Allocation | 5 1 1 1 | | Adapter and Keyboard Initialization Procedure System Roard Connectors | 5-141 | | System Board Connectors | 5-145 | | Keyboard Connector | 5_145 | | Locator Device Connector | 5-146 | | | | | Power and Connectors | 5-147 | |----------------------------------------------|-------| | Model 20 and Model 25 Battery Connector | 5-151 | | Model 20 and Model 25 Battery Connector | 5 151 | | Model 20 and Model 25 Serial Port Connectors | 3-131 | # **About this Section** This section contains information about the Model 10, Model 20, and Model 25 system boards. The various addressing modes and translation modes are discussed. Direct Memory Access is described and the keyboard adapter operations are described in detail. # Model 10, Model 20, and Model 25 Common Features #### Components - Eight channel direct memory access (DMA) - DMA address translation - Fifteen-level interrupt - Keyboard, locator, speaker adapter - Real-time clock with CMOS RAM and battery backup - Processor to I/O channel conversion - System control registers. #### Attachments - Processor board slot - Floating-Point Accelerator option slot - Two system memory slots - Keyboard and speaker - Locator - Operator panel. # **Model 20 and Model 25 Unique Features** The Model 20 and Model 25 system boards fit vertically in the base of the system unit and is approximately 29.2 by 43.2 centimeters (11.5 by 17 inches). It is a multilayer board with internal ground and +5 Vdc planes, plus 4 signal planes using a 2 land per channel design. It has the additional feature of 2 RS232C serial ports with DMA transmit capability. There are 8 I/O slots on the Model 20 and Model 25 system boards. - Six with a 62-pin and a 40-pin board-edge slot - Two with a 62-pin board-edge slot. | Slot | Unique | Connectors | Assignment | |------|--------|---------------|--------------------------| | 1 | No | 62-Pin/40-Pin | Disk/Diskette<br>Adapter | | 2 | No | 62-Pin/40-Pin | Option | | 3 | No | 62-Pin | Option | | 4 | No | 62-Pin/40-Pin | Option | | 5 | No | 62-Pin/40-Pin | Option | | 6 | No | 62-Pin | Option | | 7 | No | 62-Pin/40-Pin | Option | | 8 | Yes | 62-Pin/40-Pin | Coprocessor/Option | Figure 5-1. Model 20 and Model 25 Connector Locations # **Model 10 Unique Features** The Model 10 system board fits horizontally in the base of the system unit and is approximately 30.5 by 35.5 centimeters (12 by 14 inches). It is a multilayer board with internal ground and +5 Vdc planes, plus 4 signal planes using a 2 land per channel design. There are 6 I/O slots on the Model 10 system board. - Five with a 62-pin and a 40-pin board-edge slot - One with a 62-pin board-edge slot. | Slot | Unique | Connectors | Assignment | |------|--------|---------------|--------------------------| | 1 | No | 62-Pin | Option | | 2 | No | 62-Pin/40-Pin | Option | | 3 | No | 62-Pin/40-Pin | Option | | 4 | No | 62-Pin/40-Pin | Option | | 5 | Yes | 62-Pin/40-Pin | Coprocessor/Option | | 6 | No | 62-Pin/40-Pin | Disk/Diskette<br>Adapter | Figure 5-2. Model 10 Connector Locations Figure 5-3. RT PC Address/Data Flow Diagram # **System Board I/O Address Assignments** All of the control registers, real time clock, keyboard adapter, and TCWs on the system board are accessed by load and store instructions from the system processor. Each of these facilities is assigned a unique address in I/O channel I/O address space as shown in Figure 5-4. Notice that all of these facilities exist in segment 'F' in the system address map. | I | /O | Channel | Address | Rit | |---|----|---------|---------|-----| | | | | Auu C33 | DIL | | 2 | 11 | | | Facility | Access<br>Read/ | System<br>Address | |-----------|-------------|-------------|---------------------|--------------|-----------------|-------------------| | 3 | 65 | 87 | 0 Facility Name | Size | Write | radics | | 0000 00x0 | 1000 000 | 0 0000 00rr | Z8530 (Serial Port) | 8 Bit | R/W | F0008000-F0008003 | | 0000 00x0 | 1000 0000 | 0 0010 00xx | CH A Ext Reg | 8 Bit | R/W | F0008020 | | 0000 00x0 | 1000 0000 | 0 0100 00xx | CH B Ext Reg | 8 Bit | R/W | F0008040 | | 0000 00x0 | 1000 0000 | 0 0110 00xx | 8530 Intack | 8 Bit | R | F0008060 | | 0000 00x0 | 1000 000 | 0 1110 00xx | I/O Delay Reg(IDR) | 8 Bit | W | F00080E0 | | 0000 00x0 | 0 1000 0100 | 0 Oxxx xrrr | Keyboard Adapter | 8/16 Bit | R/W | F008400-F0008407 | | | | 2.00 | DTG | 0 <b>D</b> * | D /117 | F0000000 F000000 | | | 1000 1000 | | RTC | 8 Bit | R/W | F0008800-F000883F | | | 1000 1000 | | 8237 #1 | 8 Bit | R/W | F0008840-F000884F | | | 1000 1000 | | 8237 #2 | 8 Bit | R/W | F0008860-F000887F | | | | 0 100x xxxr | 8259 #1 | 8 Bit | R/W | F0008880-F0008881 | | | | 0 101x xxxr | 8259 #2 | 8 Bit | R/W | F00088A0-F00088A1 | | | | 0 110x xxxx | DMA Reg - DBR | 8 Bit | R/W | F00088C0 | | 0000 00x0 | ) 1000 100 | 0 111x xxxx | DMA Reg - DMR | 8 Bit | R/W | F00088E0 | | | | | | | | | | 0000 00x0 | 1000 110 | 0 0000 00xx | CH 8 Enable Reg | 8 Bit | R/W | F0008C00 | | 0000 00x0 | 1000 110 | 0 0010 00xx | Control Reg - CCR | 8 Bit | R/W | F0008C20 | | 0000 00x0 | 1000 110 | 0 0100 00xx | CRRA Reg | 8 Bit | R/W | F0008C40 | | 0000 00x0 | 1000 110 | 0 0110 00xx | CRRB Reg | 8 Bit | R/W | F0008C60 | Figure 5-4 (Part 1 of 2). System Board I/O Address Map | I/C | Channel Addr | ess Bit | | | | | | |-----------------------------------------------|----------------|----------------|------|-------------------|----------------|----------------|-------------------| | | | | | | Facility | Access | System | | 2 | 11<br>65 | 87 | 0 | Facility Name | Size | Read/<br>Write | Address | | 0000 00x0 1000 1100 1000 00xx Memory Config R | | | | | 8 Bit | R | F0008C80 | | 000 | 00 00x0 1000 1 | 100 1010 | 00xx | DIA Reg | 8 Bit | W | F0008CA0 | | 000 | 00 00x1 0000 0 | **** **** **** | n | TCW | 16 <b>B</b> it | D/W | E0010000 E00107EE | | | | | _ | = <del>-</del> ·· | | R/W | F0010000-F00107FE | | 000 | 00 00x1 0000 1 | XXX XXXX X | XXXX | CSR | 32 Bit | R/W | F0010800 | Figure 5-4 (Part 2 of 2). System Board I/O Address Map Note: x = don't care condition r = an address line decoded by the corresponding facility # **Addressing Modes** The RT PC system board is capable of responding to two different sources of addresses. The first of these is from the processor channel. Most accesses are from this source, but the system board is also able to respond to accesses from alternate controllers residing on the I/O channel. In most cases, access from an alternate controller is destined for system memory and is passed on to the processor channel, but operations are allowed to registers on the system board under some circumstances. ## **System Processor Accesses** System processor accesses to system board registers or the I/O channel pass through the IOCC (Input/Output Channel Converter) on the system board. Portions of the IOCC monitor this process and in some cases alter the progress of the transfer. The following is a description of how the system board handles accesses from the processor channel. #### **Real and Virtual Modes** The system board makes no address distinction between the real and virtual operating modes of the system. Although slight differences occur in the way the data is transferred, neither the data itself nor the address will be treated differently whether operating in real or virtual mode. ### Privileged and Unprivileged States The system processor may be operated in privileged or unprivileged states. Although the system board does not alter addressing based on the privileged state, it may be programmed to operate in a mode that differentiates between these states for access protection purposes. Privileged state is the higher of the two privilege levels. The channel control register on the system board controls access to adapters on the system board itself and on the I/O channel. ### I/O and Memory Map Access The channel control register (CCR) is part of the system board's access authorization mechanism. CCR bits 3 and 4 control accesses from the processor channel to the I/O channel and other registers on the system board. These two bits independently control access to the 64K-bytes of I/O address space and the 16M-bytes of memory address space on the I/O channel. These same bits also determine the minimum privilege level a program must be operating at in order to allow the transfer to take place. If an access violates this minimum privilege requirement, the transfer is not allowed and a protection violation error is reported. | Privilege Access States Allowed IMP MMP (Privileged/Unprivileged) | | | | | | |-------------------------------------------------------------------|--------------------------|------------------------------------------------|--|--|--| | 0 | X | I/O map accessible only in privileged state | | | | | 1 | X | I/O map accessible from either state | | | | | X | 0 | Memory map accessible only in privileged state | | | | | X | 1 | Memory map accessible from either state | | | | | X = I | X = Don't care condition | | | | | Figure 5-5. Channel Control Register (Address X'008C20') # **DMA Addressing Modes** Two types of DMA (Direct Memory Access) are used within the system. They are DMA devices and alternate controllers. Refer to "I/O Channel Data Transfer" on page 6-15 for a complete description of DMA and its modes of operation. The IOCC supports both types of DMA and provides several mechanisms which aid each type in a unique way. #### **Translation** The function of the translation mechanism of the IOCC is to: - Add the appropriate number of additional high order address bits to the address supplied by either DMA device or alternate controller to form the required 32-bit address. - Relocate within system memory selected memory references by DMA controllers on the I/O channel. - Provide the IOCC control logic with knowledge of whether the memory reference is directed to system memory or I/O channel attached memory. The translation of addresses within the IOCC is performed under the control of a block of control words residing within the channel. These translation control words (TCWs) contain both address translation data and control information. The translation control mechanism supports a maximum of eight DMA channels with 64 TCW entries per channel in page mode and 512 TCW entries (shared by all channels) in region mode. The TCWs are at address X'010000' through X'0107FE'. | Mode Combi | inations | | | | | |---------------------|-----------------|------------------|-------|-------------------|------------------------------------| | System/<br>Alt Cntl | Page/<br>Region | Real/<br>Virtual | Valid | Error<br>Detected | Comments | | System | Page | Real | Yes | | | | System | Page | Virtual | No | No | Uses Real Mode | | System | Region | Real | No | Yes | 'Invalid DMA | | System | Region | Virtual | No | Yes | Operation' 'Invalid DMA Operation' | | Alt Cntl | Page | Real | Yes | | _ | | Alt Cntl | Page | Virtual | No | No | Uses Real Mode | | Alt Cntl | Region | Real | Yes | | | | Alt Cntl | Region | Virtual | Yes | | | Figure 5-6. DMA Addressing Mode Combinations ## **Translation Modes** The translation control word (TCW) mechanism supports two distinct translation modes, page and region. Each of these two DMA modes are tailored for a particular type of operation. Page mode is used primarily for DMA devices using the system DMA controller. These devices are usually block structured and transfer data relatively infrequently. The diskette adapter is an example of these devices. The maximum transfer size for page mode devices is 64K-bytes (16-bit devices are limited to 128K-bytes). Region mode is used only by alternate controllers which need to address or transfer more than 64K-bytes at a time. Region mode allows the adapter to transfer data anywhere within the 16M-byte address space. Region mode also allows the adapter to perform data transfers to adapters in the 64K-byte I/O address space. ### Page Mode In page mode each TCW entry maps a 2K-byte memory area on the I/O channel to a 2K-byte page in the system memory real map. This mode uses the upper 128K-bytes of addressability in the memory map of the I/O channel as a window into system memory. Alternate controllers accessing this area have their access translated to the appropriate address. System DMA controller accesses are treated as if all accesses involve the upper 128K-bytes, thus forming a full 24-bit address from the 16-bits output by the system DMA controller (See Figure 5-7 on page 5-18). This mode can be used by either the system DMA controller or by alternate controllers. A control bit of the selected TCW entry permits the system DMA controller to target the operation for either I/O channel attached memory or system memory. Thus, an address originally targeted somewhere in the upper 128K-byte area of the 16M-byte address map may be translated to anywhere in the 16M-byte address range either of system memory or I/O channel attached RAM. (The IOCC will not invoke the translation facility for a transfer by an alternate controller to the I/O channel). ### **Region Mode** In region mode each TCW entry maps a 32K-byte region on the I/O channel to a 32K-byte region of system memory. The access may be either real or virtual, depending on a control bit within the TCW entry. In this mode the entire 16M-byte I/O channel memory map can be selectively mapped onto either the real or virtual map of system memory. This mode is used only by alternate controllers. Attempts to use region mode by DMA devices operating under system DMA controllers will be reported as "Invalid DMA Operations". Figure 5-6 on page 5-16 lists all mode combinations and shows which are valid from a hardware point of view. The two entries dealing with virtual page mode are not supported but are not detected or reported as errors. The transfer takes place but data is directed to memory segment '00XXXXXXX' instead of 'E0XXXXXXX'. Figure 5-7. Address Translation (Page Mode) Real Address Format Figure 5-8. Address Translation (Region Mode) Real Address Format Figure 5-9. Address Translation (Region Mode) Virtual Address Format Selection of page or region mode is under control of the DMA Mode Register (DMR). This register permits mode control for all channels to be under program control. DMA channel 8 operates only in region mode. **CHANNEL DATA MODE REGISTER** | DMA Mode<br>Bit | DMA Translation Mode Used | |-----------------|-------------------------------| | 0 | Page mode (2K-byte blocks) | | 1 | Region mode (32K-byte blocks) | Figure 5-10. DMA Mode Register (System Address X'F00088E0') #### **Translated Address Format** The memory address width on the I/O channel is 24 bits while the memory address width at the processor channel is 32 bits. The address supplied by the system DMA controller is 16 bits and the address supplied by an alternate controller is 24 bits. The IOCC mechanism forms the appropriate address length from the address supplied by the adapter (16 or 24 bits). This process involves a combination of prefix concatenation and overlays. The translation process is applied to all addresses received from an adapter (16- or 24-bits). #### Real and Virtual Modes The IOCC supports real and virtual memory accesses to system memory. These modes differ in the manner in which the address is formed and in control signals activated during the transfer of the address to the processor channel. #### Real The real address format is used by both system DMA controllers and alternate controllers to form a 24-bit address when accessing system memory in real mode. For alternate controllers using region mode, the IOCC uses the low order 15 bits received from the adapter and replaces the upper 9 bits with a translated value. For either alternate controllers or system DMA controller using page mode. the IOCC uses the low order 11 address bits supplied and concatenates a 13-bit prefix to form a 24-bit address. In either case, the resulting address is sent to system memory with the Memory Management translate function turned off. #### Virtual The virtual address format is used to form a 32-bit address when accessing system memory in virtual mode. This addressing format can be used only by alternate controllers operating in region mode. The IOCC forms a 32-bit address by concatenating a 17-bit prefix onto the low order 15-bits of address supplied by the adapter. The resulting address is sent to system memory with the memory management unit translate function bit turned on. Figure 5-11 on page 5-23 through Figure 5-14 on page 5-26 show how the translation mechanism of the IOCC bridges the gap between the DMA source address on the I/O channel and the resulting target address sent to the processor channel for each addressing mode and address source. #### **32-BIT REAL SYSTEM ADDRESS** Figure 5-11. System DMA - Page Mode (8-Bit Channel) Translated Address Formation #### **32-BIT REAL SYSTEM ADDRESS** Figure 5-12. System DMA - Page Mode (16-Bit Channel) Translated Address Formation Figure 5-13. Alternate Controller - Page Mode Translated Address Formation Figure 5-14. Alternate Controller-Region Mode Translated Address Formation ### **Translation Control Words** The translation control word (TCW) entries associated with a given DMA adapter must cover the entire address range which that adapter is capable of addressing. The address range covered by one TCW entry is dependent on the mode setting for that channel. In region mode each TCW entry covers 32K-bytes while in page mode each TCW entry covers 2K-bytes. | Start<br>Hex Address | End<br>Hex Address | Used by<br>Channel | Control<br>Word Usage | |----------------------|--------------------|--------------------|-----------------------| | 010000 | 01007E | Channel 0 | Page mode | | 010080 | 0100FE | Channel 1 | Page mode | | 010100 | 01017E | Channel 2 | Page mode | | 010180 | 0101FE | Channel 3 | Page mode | | 010200 | 01027E | Reserved | Reserved | | 010280 | 0102FE | Channel 5 | Page mode | | 010300 | 01037E | Channel 6 | Page mode | | 010380 | 0103FE | Channel 7 | Page mode | | 010400 | 0107FE | All channels | Region mode | Figure 5-15. Translation Control Word (TCW) Port Addresses | Control Word Binary Port Address | Channel<br>Number | Entry<br>Number | |----------------------------------|-------------------|-----------------| | 0000 0001 0000 0000 0000 0000 | 0 | 0 | | 0000 0000 0010 | 0 | 1 | | 0000 0000 0100 | 0 | 2 | | 0000 0000 0110 | 0 | 3 | | | | | | 0000 0111 1110 | 0 | 63 | | 0000 1000 0000 | 1 | 0 | | 0001 1000 0000 | 2 | 0 | | 0001 0000 0000 | 3 | 0 | | 0010 0000 0000 | Reserved | 0 | | 0010 1000 0000 | 5 | 0 | | <b>♦</b> 0011 0000 0000 | 6 | 0 | | 0000 0001 0000 0011 1000 0000 | 7 | 0 | | 0000 0001 0000 0100 0000 0000 | Region<br>Mode | 0 | | | For<br>All | | | 0000 0001 0000 0111 1111 1110 | Channels | 511 | Figure 5-16. Translation Control Word (TCW) Binary Port Address Each element of the TCW is 16 bits wide. Figure 5-17 on page 5-29 shows the format of the TCW. Unlike other 16-bit registers, the TCW words are the same as the processor register image. The high and low order bytes of the word are not reversed as they pass through the IOCC. #### PROCESSOR REGISTER DATA IMAGE 15 | 14 | 13 | 12 | 11 | 3 2 0 10 9 7 **TCW WORD DEFINITION** 15 14 13 0 12 11 10 9 8 7 6 5 4 3 2 P12 | P11 | P10 | P09 | P08 | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 VIR LIOC **TRANSLATION PREFIX BITS 00 - 12 RESERVED** I/O CHANNEL DESTINATION VIRTUAL ACCESS Figure 5-17. TCW Format #### **Access Control** This field consists of the virtual access and I/O channel destination bits. It permits the software to select the target memory unit (system memory or I/O channel attached) which is used in the current operation and the memory management unit transfer type. Bit 14 (IOC) defines system memory or I/O channel access while bit 15 (VIR) differentiates between real or virtual address formats. The definition of this field is as follows: | Control 1 | Bits | Resulting A | ction | |-----------|------|-------------------------------------------------------------|-----------------------------------------------------------------| | VIR | IOC | System DMA<br>Controller | Alternate Controller | | 0 | 0 | Translate to real address format and send to system memory. | Translate to real address format and send to system memory. | | 11 | 0 | Translate to real address format and send to system memory. | Translate to virtual address format and send to system memory. | | X | 1 | Translate to real address format and send to I/O channel. | No action by IOCC alternate controller, uses unchanged address. | X = Don't care condition Figure 5-18. Virtual Access and I/O Channel Destination Bits #### DMA Access Authorization The Channel Control Register (CCR) controls part of the system board's access protection mechanism. Three CCR bits (5, 6, 7) control accesses from alternate controllers to certain registers and adapters on the system board. Access to adapters or memory located on the I/O channel by alternate controllers cannot be prevented. Alternate controller access to system memory is controlled by the translation mechanism. (Alternate controllers cannot access the translation control word or the channel status register.) <sup>&</sup>lt;sup>1</sup> System DMA controller ignores the virtual bit state. Figure 5-19. Channel Control Register (Address X'008C20') | | Access<br>DSA | | Alternate Controller Access Allowed or Denied | Affected<br>Address<br>Range | |-----|---------------|---|-----------------------------------------------|------------------------------| | 0 | x | X | Allow access to control registers | 008CY0 | | . 1 | X | X | Do not allow access to control registers | 008CY0 | | 0 | 0 | X | Allow access to I/O subsystem adapters | 0088YY | | 0 | 1 | X | Do not allow access to I/O subsystem adapters | 0088YY | | 0 | <b>X</b> | 0 | Allow access to keyboard adapter | 00840Y | | 0 | X | 1 | Do not allow access to keyboard adapter | 00840Y | X = Don't care condition Figure 5-20. DMA Access Bits Y = Several possible addresses ### **Arbitration** System arbitration is handled by the system arbiter which resides on the system board. It is a custom design for the RT PC system. The system arbiter is assisted by the arbitration mechanism of two 8237 DMA controllers for DMA operations. The system arbiter function sets priorities and grants requests for using the I/O channel. The following is a list of entities capable of requesting I/O channel usage. They are listed in descending priority. - 8237 DMA controller 1 - Refresh for I/O channel dynamic RAM - Processor Input/Output (PIO) - 8237 DMA controller 2 - Coprocessor. ## **System Arbiter Operation** The processor board is the default owner of the system arbiter. The processor board performs read and write operations to the system board registers and the I/O channel while the system arbiter is reset. The system arbiter must be enabled to arbitrate and grant requests to use the I/O channel. Refresh (refer to "Refresh" on page 5-53) and the 8237's (refer to "DMA" on page 5-39) must be enabled by system software before they can request the use of the I/O channel from the system arbiter. When the system arbiter receives a request to use the I/O channel, it must first be granted control of the I/O channel by the processor board or be in control of the I/O channel. After the processor board grants control of the I/O channel to the system arbiter, the system arbiter grants control of the I/O channel to the requestor. The linear arbitration priority scheme is; 8237 DMA controller 1, Refresh, PIO, 8237 DMA controller 2 and Coprocessor. The highest priority device requesting the channel is granted control when the channel is released by another device. When a device gains control of the channel it cannot be preempted (except for Coprocessor). Devices should not keep control of the channel for more than 8 microseconds to prevent locking out other devices. The Coprocessor has the capability of utilizing the I/O channel for extended amounts of time. Once the Coprocessor receives control of the I/O channel, it can keep control until it is finished or until the arbiter requests the Coprocessor to relinquish the channel by removing its acknowledge. The acknowledge to the Coprocessor is never taken away until after the Coprocessor has activated the '-Master' signal on the I/O channel. See "I/O Slot Uniqueness" on page 6-48 and "Coprocessor Arbitration" on page 6-50 for more information. When the system arbiter is disabled it will allow PIOs and only make a request to the processor board for use of the I/O channel for refresh. All DMA requests to the system arbiter are ignored when it is disabled. The arbiter is placed in the disabled mode by writing to the channel reset register B (CRRB). See "Component Reset Register B (CRRB)" on page 5-61 The system arbiter is disabled when the memory management unit sends an exception reply on a DMA transfer. This forces a reset to the system DMA controllers and causes the 8237's to relinquish the I/O channel to allow software the opportunity to rectify the problem if the exception was caused by the 8237. In the event the exception was caused by the Coprocessor, the Coprocessor acknowledge is deactivated. The Coprocessor should get off the I/O channel as soon as possible. The system arbiter is also disabled when POR signal goes active or when the processor board resets the IOCC. The arbitration mechanism of the 8237 DMA controller assists the system arbiter. Individual DMA requests are monitored and priorities set by the 8237's. When the 8237 receives an acknowledgment from the system arbiter, the 8237 determines which DACK to grant. Activating the DACK line grants the I/O channel to the requestor. ## **Single Cycle** Single cycle operations on the I/O channel are the standard method for data transfer. This insures that correct system operation is maintained and that all adapters and options have timely access to the I/O channel. ## **Burst Cycles** Burst cycles are supported and achieved by an alternate controller keeping the DMA request active after gaining control of the I/O channel (DACK active). However, due to refresh requirements of the I/O channel attached memory, the alternate controller cannot hold the channel for more than 8 microseconds. If this restriction is violated correct system operation cannot be guaranteed. When a DMA adapter starts its DMA cycle, (or cycles) it does not know how many microseconds are left until another requestor requires the I/O channel. ## **Buffer Mode DMA** Buffer mode DMA is achieved by an alternate controller keeping the DMA request active after gaining control of the I/O channel (DRQ active) until the cycle is finished. Buffer mode DMA allows alternate controllers to transfer 4 bytes in a single DMA request cycle. This is achieved by the appropriate DMA channel bit being enabled in the DMA buffer register. See "Buffer Register" on page 5-54. The IOCC uses this data buffer register bit to generate the correct responses to the I/O channel and the processor channel for buffer mode DMA transfers. This I/O channel feature reduces the processor channel traffic. In buffer mode DMA, the alternate controller does two 2-byte I/O channel cycles to or from the IOCC for each 4-byte cycle on the processor channel or with system memory. Buffer mode DMA operations can be real or virtual transfers and must be 4 bytes wide. All buffer mode DMA operations must start on double word boundaries with SA0=0 and SA1=0. The first I/O channel cycle is done with SA0=0 and SA1=0. The next I/O channel cycle is done at the next higher word address SA0=0 and SA1=1. Buffer mode DMA reads are initiated the same as single cycle DMA reads. In buffered mode the IOCC initiates a 4-byte system memory read. 'I/O CH RDY' will go not ready until the data is available. When the data is available the alternate controller reads the first 2 bytes at the double word boundary. The alternate controller increments the address by one word and multiplexes the second 2 bytes to the I/O channel where they are read by the alternate controller. This completes a buffer mode DMA read. The alternate controller must now conform to the DMA timings to get off the I/O channel. #### **Notes:** - 1. On the first read cycle, 'I/O CH RDY' not ready must be used correctly. On the second read cycle, the alternate controller must conform to all appropriate default timings, address valid, memory access and address hold times for correct operation. - 2. Reading from an address with SA0 = 0 and SA1 = 1 just prior to reading the same address with SA0 = 0 and SA1 = 0 causes the alternate controller to receive bad data with no error condition generated. Reads to an address with SAO = 1 results in an error condition. Buffer mode DMA writes are initiated the same way as single cycle DMA writes. In buffered mode. the alternate controller writes the first two bytes of data to an address at a double word boundary. The IOCC latches the address on the I/O channel address bus (LA and SA bits), and latch the 2-bytes of data in the IOCC when '-MEMW' goes positive. No data is transferred to system memory at this time. 'I/O CH RDY' will not go ready and the cycle executes at the default cycle time. The alternate controller increases the address on the I/O channel by one word to set up the IOCC for the next write. The IOCC must multiplex the second two bytes to the buffer so that four bytes are ready for the write to system memory. This time when '-MEMW' goes positive, 'I/O CH RDY' will go not ready until the data is written into system memory. When 'I/O CH RDY' goes ready. the alternate controller has completed a buffer mode DMA write. The alternate controller must conform to default cycle write timings through out this cycle. **Note:** Writing from an address with SA0 = 0 and SA1 = 1 just prior to writing the same address with SA0 = 0 and SA1 = 0 causes the alternate controller to send bad data with no error condition generated. Reads to an address with SA0 = 1 results in an error condition. ## **Burst and Buffer Mode DMA** Burst and buffer mode DMA can be used together by an alternate controller. All rules governing both burst cycles and buffered mode DMA must be strictly adhered to. The alternate controller must not hold the I/O channel for more than 8 microseconds or correct system operation cannot be guaranteed. # I/O Channel Operations The system board accepts commands from the processor board and converts those commands to memory and I/O channel operations. For a detailed description of the I/O channel, see Section 6. ## **Fast and Slow Channel Operations** A fast channel operation occurs when a 16-bit memory device activates the I/O channel signal '-MEMCS16' on a memory operation or a 16-bit I/O device activates '-IOCS16' on an I/O operation. A fast channel operation results in an I/O channel cycle with the read/write control signal being active for 350 nanoseconds. Slow channel cycles occur when the I/O channel signals '-MEMCS16' and '-IOCS16' are inactive on memory or I/O operations. The read/write channel control signals for slow channel operations are active for 650 nanoseconds. # **Single and Multicycle Channel Operations** The processor board can request 8, 16, and 32-bit data transfers from the I/O subsystems or the I/O channel. - Eight-bit transfers to 8-bit adapters result in a single I/O channel cycle - Eight-bit transfers to 16-bit adapters result in a single I/O channel cycle - Sixteen-bit transfers to 16-bit adapters result in a single I/O channel cycle - Sixteen-bit transfers to 8-bit adapters are converted to two 8-bit transfers by the system board. - Thirty two-bit transfers to 8-bit devices are converted to four 8-bit transfers - Thirty two-bit transfers to 16-bit devices are converted to two 16-bit transfers. The system board increases I/O channel address bits SA0 and SA1 by one on 8-bit multicycle memory operations and by two on 16-bit multicycle memory operations. SAO and SA1 are not increased on multicycle transfers to devices in the I/O address space. Figure 5-21. Processor Board to System Board Data Interface | ADDESS<br>SA1 SA0 | | TYPE<br>TRANSFER | DATA BYTE<br>TRANSFERED | PLACE | NEL DATA<br>EMENT<br>7 0 | |-------------------|------------------|----------------------------------|-------------------------|------------------|--------------------------| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 8-BIT<br>8-BIT<br>8-BIT<br>8-BIT | A<br>B<br>C<br>D | -<br>B<br>-<br>D | A<br>B<br>C<br>D | | 0 | 0 | 16-BIT<br>16-BIT | A B<br>C D | B<br>D | A<br>C | Figure 5-22. Single Cycle Operation Data Placement | INIT | TAL * | MEMORY<br>TRANSFERS | | I/O<br>TRANSFERS | | DATA DVT | I/O CHANNEL DATA PLACEMEN | | | | | |------|-------|---------------------|-----------------|------------------|-----|----------|---------------------------|------------|--------|---|--| | SA1 | SA0 | TYPE<br>TRANSFER | CYCLE<br>NUMBER | SA1 | SA0 | SA1 | SA0 | TRANSFERED | 15 8 | | | | 0 | 0 | 32-BIT | 1 2 | 0 | 0 | 0 | 0 | A B<br>C D | B<br>D | A | | | 15 | | ACEMENT<br>7 0 | | |------|--------|----------------|---| | | B<br>D | A | | | J LL | سستس | سننسا | J | Figure 5-23. Multicycle Operation to 16-Bit Device <sup>\*</sup> ADDRESS SUPPLIED BY PROCESSOR BOARD | | | | MEMORY I/O<br>TRANSFERS TRANSFERS | | | 1/O CHANNEL | | | | | |----------------------|---|------------------|-----------------------------------|------------------|-------------|-------------|-------------|-------------------------|------------------|------------------| | INITIAL *<br>SA1 SA0 | | TYPE<br>TRANSFER | CYCLE<br>NUMBER | SA1 SA0 | | SA1 | SA0 | DATA BYTE<br>TRANSFERED | DATA PLACEMENT | | | 0 | 0 | 16-BIT | 1 2 | 0 | 0 | 0 | 0 | A<br>B | -<br>B | A<br>B | | 1 | 0 | 16-BIT | 1<br>2 | 1 1 | 0<br>1 | 1 1 | 0 | C<br>D | -<br>D | C<br>D | | 0 | 0 | 32-BIT | 1<br>2<br>3<br>4 | 0<br>0<br>1<br>1 | 0<br>1<br>0 | 0<br>0<br>0 | 0<br>0<br>0 | A<br>B<br>C<br>D | -<br>B<br>-<br>D | A<br>B<br>C<br>D | <sup>\*</sup>ADDRESS SUPPLIED BY PROCESSOR BOARD Figure 5-24. Multicycle Operation to 8-Bit Device ### **DMA** The RT PC system supports eight channels of Direct Memory Access (DMA). It supports 7 channels through the use of two 8237 DMA controllers. With the assistance of the translation control word mechanism, all DMA channels can transfer data throughout the 16M-byte address spaces of system memory and I/O channel attached memory. The two 8237's must be enabled before they can be programmed. At power on time, the 8237's are disabled. The 8237 ignores commands until it is enabled. Bits 3 and 4 of the component reset register B enable and disable the 8237's. Refer to "I/O Channel Data Transfer" on page 6-15 for more information on DMA. Figure 5-25. Component Reset Register B (Address X'F0008C60') The 8237 memory to memory operation is not supported by the system board. Active high DACK lines are not supported. Bits 0, 1, and 7 of the 8237's status/command register must be programmed to 0. All internal locations, especially the mode registers, of the 8237 DMA controllers should be loaded with some value when power is turned on. Detailed information on the use of the 8237 DMA controller can be found in the *Intel Component Data Catalog* and is not repeated here. DMA channels 0-3 are supported by 8237 DMA controller 1. DMA channels 0-3 support 8-bit DMA devices. See "DMA Types" on page 6-16 for a description of DMA devices. DMA channels 0-3 also support 16-bit alternate controllers. DMA channels 5-7 are supported by 8237 DMA controller 2. DMA channels 5-7 support 16-bit DMA devices and 16-bit alternate controllers. DMA channel 4 is not used. DMA channel 8 supports only alternate controllers. DMA channel 8 is only available on the Coprocessor slot. It replaces DMA channel 7 in that slot and does not operate the same as DMA channels 0-3 and 5-7. See "I/O Slot Uniqueness" on page 6-48 and "Coprocessor Arbitration" on page 6-50 for a description of operation. All alternate controllers must be connected to SD0 - SD15 (16-bit) and use '-SBHE'. Alternate controllers can transfer 8- or 16-bits of data. The even bytes of data must be on SD0 - SD7 and the odd bytes on SD8 - SD15. ### 8237 DMA Controller 1 In DMA device mode, channels 0 through 3 transfer data between 8-bit DMA devices and 8-bit and 16-bit I/O channel attached memory or system memory. In alternate controller mode, channels 0 through 3 transfer data between 16-bit I/O devices and 16-bit I/O channel attached memory or system memory. Refer to Figure 5-7 on page 5-18 through Figure 5-14 on page 5-26 for determination of address format for programming of the current address (base address). The current count (base word count) refers to the number of bytes to be transferred. | Address | Command | |----------|----------------------------------| | 00 88 40 | Channel 2 current address | | 00 88 41 | Channel 2 current count | | 00 88 42 | Channel 1 current address | | 00 88 43 | Channel 1 current count | | 00 88 44 | Channel 0 current address | | 00 88 45 | Channel 0 current count | | 00 88 46 | Channel 3 current address | | 00 88 47 | Channel 3 current count | | 00 88 48 | Status/command | | 00 88 49 | Write request register | | 00 88 4A | Write mask register 1 | | 00 88 4B | Write mode register | | 00 88 4C | Clear byte pointer flip/flop | | 00 88 4D | Read temp reg/write master clear | | 00 88 4E | Clear mask register (8237A-5) | | 00 88 4F | Write mask register 2 | Figure 5-26. 8237 DMA Controller #1 Control Register Addresses Figure 5-27. 8237 DMA Controller 1 Write Mode Register (Address X'00884B') Figure 5-28. 8237 DMA Controller 1 Request Register(Address X'008849') Figure 5-29. 8237 DMA Controller 1 Mask Register 1 (Address X'00884A') Figure 5-30. 8237 DMA Controller 1 Mask Register 2 (Address X'00884F') Figure 5-31. 8237 DMA Controller 1 Status Register (Address X'008848') **Note:** The status/command register serves as two registers. In read mode, it is a status register. In write mode, it is a command register. Figure 5-32. 8237 DMA Controller 1 Command Register (Address X'008848') ### 8237 DMA Controller 2 DMA channel 4 is not supported by the system board. Channels 5 through 7 transfer data between 16-bit DMA adapters and 16-bit I/O channel attached memory or system memory. Channels 5 through 7 can only transfer data on even boundaries. Refer to Figure 5-7 on page 5-18 through Figure 5-14 on page 5-26 for determination of address format for programming the current address (base address). The current count (base word count) refers to the number of 16-bit words to be transferred. | Command | |----------------------------------| | Channel 4 current address* | | Channel 4 current count* | | Channel 5 current address | | Channel 5 current count | | Channel 6 current address | | Channel 6 current count | | Channel 7 current address | | Channel 7 current count | | Status/command | | Write request register | | Write mask register 1 | | Write mode register | | Clear byte pointer flip/flop | | Read temp reg/write master clear | | Clear mask register (8237A-5) | | Write mask register 2 | | | \* Channel 4 not supported. Figure 5-33. 8237 DMA Controller 2 Control Register Addresses Figure 5-34. 8237 DMA Controller 2 Mode Register (Address X'008876') Figure 5-35. 8237 DMA Controller 2 Request Register (Address X'008872') Figure 5-36. 8237 DMA Controller 2 Mask Register 1 (Address X'008874') Figure 5-37. 8237 DMA Controller 2 Mask Register 2 (Address X'00887E') Figure 5-38. 8237 DMA Controller 2 Status Register (Address X'008870') **Note:** The status/command register serves as two registers. In read mode, it is a status register. In write mode, it is a command register. Figure 5-39. 8237 DMA Controller 2 Command Register (Address X'008870') ### **Alternate Controllers** The system board allows 16-bit processors or DMA controllers on the I/O channel (alternate controllers) to gain control of the I/O channel. Alternate controllers can transfer data to system memory, I/O channel attached devices, and some system board registers. Access to system memory or channel attached memory is determined by the translation control word mechanism. See "Translation Modes" on page 5-17 for details of the translation mechanism. No address translation occurs for alternate controller operations to devices in the I/O channel attached memory space. Some system board registers can be protected from access from alternate controllers. See "DMA Access Authorization" on page 5-30 for information on system board register access protection mechanism. The channel status register and translation control word matrix cannot be accessed by alternate controllers. Alternate controllers connected to DMA channels 0-3 and 5-7 requires the channel in which the alternate controller is connected to be programmed in 'cascade' mode. See "DMA Types" on page 6-16 for details of alternate controller operation. DMA channel 8 must be enabled by writing to the channel 8 enable register when using an alternate controller on DMA channel 8. Figure 5-40. Channel 8 Enable Register(Address X'008C00') ### Refresh The system board provides refresh for I/O channel attached dynamic memory devices. Refresh can be enabled or disabled by writing to the channel control register. The refresh rate of one memory cycle every 6.4 or 14.9 microseconds can be selected by writing to the channel control register. Up to 16 refresh times can be buffered by the system board. This provides a maximum of 255 msec. latency. After 5 refreshes are buffered, refresh request is posted to the system arbiter. Figure 5-41. Channel Control Register (Address X'008C20') ## **Buffer Register** The buffer register can be read by or written to by the system processor or alternate controllers in the region mode. This register defines the bits enabled for each DMA channel. Only alternate controllers can do buffered mode transfers. Attempts by DMA devices to do buffered DMA transfers results in DMA exception errors. The Coprocessor may not use buffered mode. When power is turned on, all bits in the buffer register must be set to the zero state. #### Note: Any bit = 1 Buffer mode enabled Any bit = 0 Buffer mode disabled. Figure 5-42. Buffer Register (Address X'0088C0') ## **Interrupt Controllers** The system board uses two 8259A interrupt controllers. These interrupt controllers support 11 interrupt request lines on the I/O channel and an additional 4 from sources on the system board. The 15 interrupt signals are divided into two groups. Each group of interrupt signals are processed by an 8259A controller which is attached to system processor interrupt level 3 or 4. The 8259A interrupt controllers are run in the following mode: - Single (not cascaded) - Edge triggered - Polled. The 8259A accepts two types of command words from the processor. They are: - Initialization Command Words (ICW1, ICW2, ICW3, ICW4) - Operation Command Words (OCW1, OCW2, OCW3) These are used for the initialization and operation of 8259A. See Figure 5-4 on page 5-12 for command word addresses. The 8259A has three internal registers that are directly associated with the interrupt request signals. Interrupt Request Register (IRR) is an 8-bit register which contains the levels that are requesting service. The highest level is reset from the IRR when an interrupt is acknowledged (polled) and being serviced. The interrupt mask register (IMR) stores the mask bits for the interrupt lines to be masked in the IRR. A read OCW1 command will read the state of the IMR. The in-service register (ISR) is an 8-bit register which contains the priority levels that are being serviced. A priority level is added to the ISR when a POLL command is issued and a priority level is removed or when End Of Interrupt (EOI) command is issued. The nonspecific EOI command resets the highest priority level while the specific EOI command resets a specified priority level. # **Interrupt Priority** | 8259<br>Level | I/O Channel Interrupt Lvl | I/O Adapter | System Processo<br>Interrupt Level | |---------------|---------------------------|---------------------|------------------------------------| | 0 | 0 (Sys. Brd.) | 8237 Terminal Count | .3 | | 1 | 10 | I/O Channel IRQ 10 | 3 | | 2 | 9 | I/O Channel IRQ 9 | 3 | | 3 | 3 | I/O Channel IRQ 3 | 3 | | 4 | 4 | I/O Channel IRQ 4 | 3 | | 5 | 1 (Sys. Brd.) | Keyboard Controller | 3 | | 6 | 2 (Sys. Brd.) | 8530 Serial Port | 3 | | 7 | 7 | I/O Channel IRQ 7 | 3 | | | | | | Figure 5-43. 8259 #1 | 8259<br>Level | I/O Channel<br>Interrupt Lvl | I/O Adapter | System Processor<br>Interrupt Level | |---------------|------------------------------|-------------------------|-------------------------------------| | 0 | 8 (Sys. Brd.) | Reserved | 4 | | 1 | 11 | I/O Channel IRQ 11 | 4 | | 2 | 14 | I/O Channel IRQ 14 | 4 | | 3 | 12 | I/O Channel IRQ 12 | 4 | | 4 | 6 | I/O Channel IRQ 6 | 4 | | 5 | 5 | I/O Channel IRQ 5 | 4 | | 6 | 15 | I/O Channel IRQ 15 | 4 | | 7 | 13 (Svs. Brd.) | Serial Port Ex Ct1 IRPT | <b>3</b> 4 | Figure 5-44. 8259 #2 ## **Diagnostic Interrupt Activate Register** A Diagnostic Interrupt Activate (DIA) write command to the DIA register sets all 16 positions of the interrupt register to the activate (interrupting) state and holds them. A subsequent write with data bit 0 reset (0) releases the interrupt requests. DIA tests all of the interrupt levels. Figure 5-45. Diagnostic Interrupt Activate Register (Address X'008CA0') # **Component Reset Register A (CRRA)** The outputs of this 8-bit register drives the resets to the system board I/O channel slots. The net effect of this register is to give each I/O channel slot the capability to be individually reset by software. This register can be read or written to by the processor board or an alternate controller operating in region mode. -Power On Reset going active causes the CRRA to activate all resets to the I/O channel slots. | Bit | Bit Definition | Comment | |-----|----------------|-----------------------------------------------------------| | 7 | I/O Slot 8 | (Model 20 and Model 25 only) 0 = disabled 1 = enabled | | 6 | I/O Slot 7 | (Model 20 and Model 25 only) $0 = disabled$ $1 = enabled$ | | 5 | I/O Slot 6 | 0 = disabled<br>1 = enabled | | 4 | I/O Slot 5 | 0 = disabled<br>1 = enabled | | 3 | I/O Slot 4 | 0 = disabled<br>1 = enabled | | 2 | I/O Slot 3 | 0 = disabled<br>1 = enabled | | 1 | I/O Slot 2 | 0 = disabled<br>1 = enabled | | 0 | I/O Slot 1 | 0 = disabled<br>1 = enabled | Figure 5-46. Component Reset Register A (Address X'008C40') # **Component Reset Register B (CRRB)** The outputs of this 8-bit register drives the reset to the serial ports, keyboard adapter, 8237's and the system arbiter. This register can be read or written by the processor board or any alternate controller programmed in region mode. This register activates all resets during POR and a processor initiated reset. | Bit | Bit Definition | Comment | |-----|-----------------------|-----------------------------| | 7 | Reserved | | | 6 | Reserved | | | 5 | Arbiter | 0 = disabled<br>1 = enabled | | 4 | DMAC2 (Channel 5 - 7) | 0 = disabled<br>1 = enabled | | 3 | DMAC1 (Channel 0 - 3) | 0 = disabled<br>1 = enabled | | 2 | 8051 | 0 = disabled<br>1 = enabled | | 1 | RS232C I/F | 0 = disabled<br>1 = enabled | | 0 | 8530 | 0 = disabled<br>1 = enabled | Figure 5-47. Component Reset Register B (Address X'008C60') # **Channel Status Register (CSR)** This 32-bit register captures the status of the system board error conditions. This register can be read or written only by the processor board. Writes to the CSR resets all valid status bits. Note: Reserved CSR bits are always 1 on CSR reads. The CSR register resides on the processor channel and is cleared by POR. | Processor Reg<br>Data Image | CSR<br>Bit | Bit Definition | CSR Bit<br>Acronym | Initial State At Power On | |-----------------------------|------------|----------------------|--------------------|---------------------------| | MSB 0 | 31 | Exception Reported | EXR | 0 | | 1 | 30 | Interrupt Pending | INTP | 0 | | 2 | 29 | Reserved | R | 1 | | 3 | 28 | EPOW | EPOW | 0 | | 4 | 27 | Soft Reset | SRST | 0 | | 5 | 26 | System Attention | SAT | 0 | | 6 | 25 | Reserved | R | 1 | | 7 | 24 | PIO Error | PER | 0 | | 8 | 23 | DMA Error-Channel 0 | DE0 | 0 | | 9 | 22 | DMA Error-Channel 1 | DE1 | 0 | | 10 | 21 | DMA Error-Channel 2 | DE2 | 0 | | 11 | 20 | DMA Error-Channel 3 | DE3 | 0 | | 12 | 19 | DMA Error-Channel 5 | DE5 | 0 | | 13 | 18 | DMA Error-Channel 6 | DE6 | 0 | | 14 | 17 | DMA Error-Channel 7 | DE7 | 0 | | 15 | 16 | DMA Error-Channel 8 | DE8 | 0 | | 16 | 15 | PIO/DMA | P/D | 0 | | 17 | 14 | Protection Violation | PVIO | 0 | | 18 | 13 | Invalid Operation | INVOP | 0 | Figure 5-48 (Part 1 of 2). CSR - Channel Status Register Address (X'010800') | Processor Reg<br>Data Image | CSR<br>Bit | Bit Definition | CSR Bit<br>Acronym | Initial State At Power On | |-----------------------------|------------|------------------------|--------------------|---------------------------| | 19 | 14 | I/O Channel Check | IOCK | 0 | | 20 | 11 | DMA Exception | DEXK | 0 | | 21 | 10 | Channel Reset Captured | CRC | 0 | | 22 | 9 | System Board Busy | SBB | 0 | | 23 | 8 | PIO Request Pending | PRP | 0 | | 24 | 7 | Reserved | R | 1 | | 25 | 6 | Reserved | R | 1 | | 26 | 5 | Reserved | R | 1 | | 27 | 4 | Reserved | R | 1 | | 28 | 3 | Reserved | R | 1 | | 29 | 2 | Reserved | R | 1 | | 30 | 1 | Reserved | R | 1 | | LSB 31 | 0 | Reserved | R | 1 | Figure 5-48 (Part 2 of 2). CSR - Channel Status Register Address (X'010800') This section describes the error and interrupt conditions that occur within the IOCC. Each error or interrupt condition and the resulting response by the IOCC is described. When an error is detected by the IOCC, a CSR bit is set to indicate which interface initiated the operation. A bit is also set indicating that the CSR contains valid error status, and that the processor interrupt is pending. If a second error is detected before software can clear the status word, the CSR will reflect the conditions of the first error and the error type. The channel status register is defined as follows: - **Bits 0-7** Reserved. The state of these bits are undefined and not guaranteed to be the same on successive CSR read commands. - Bit 8 PIO Request Pending. This bit is set when a reset or error occurs while a PIO to the IOCC is pending on the processor channel. If this bit is set when an processor timeout occurs, it indicates that the IOCC may have caused the error. - Bit 9 System Board Busy. This bit indicates that the IOCC was busy when a reset or error occurred. On reset it implicates the IOCC in the case of a processor timeout. - **Bit 10** Channel Reset Captured. This bit is set if the processor detects a hardware error while the IOCC had detected no errors. If this bit is set, then bits 16-31 reflect the IOCC state at the time the processor detects the error. When this bit is set, the state of bits 16 -31 is frozen as if an error had occurred. - **Bit 11** DMA Exception. This bit is set if an exception reply is received by the IOCC during a DMA operation. Status on the active DMA channel is also latched when this error occurs. Cause: Processor board returns an exception to a DMA adapter request to system memory. Action: DMA Exception - 1. Send level 2 processor interrupt - 2. Latch CSR bits - DMA error for active channel = 1 - PIO/DMA operation = 0 - Interrupt pending = 1 - 3. Reset DMA controllers. Bit 12 I/O Channel Check. This bit is set when the I/O channel check line is asserted by a device on the I/O channel. When this happens, the status of any PIO or DMA channel activity is latched. Cause: A device on the I/O channel asserts the I/O channel check line. #### Action: - 1. PIO read to I/O channel in progress - Send exception reply - Latch CSR bits: - PIO error = 1 - PIO/DMA operation = 1 - I/O channel check = 1 - Exception reported = 1 - 2. PIO real/virtual write in progress - Send level 2 processor interrupt - Latch CSR bits - PIO error = 1 - PIO/DMA error = 1 - Interrupt pending = 1 - I/O channel check = 1 - 3. DMA operation in progress - Send level 2 processor interrupt - Latch CSR bits - DMA error for active channel = 1 - PIO/DMA Operation = 0 - Interrupt pending = 1 - I/O channel check = 1. Note: The current I/O channel cycle will terminate normally. **Bit 13** Invalid Operation. This bit is set when an invalid PIO request occurs, or when a DMA adapter attempts an invalid operation (due to an invalid DMA setup). An example of this error is a DMA device attempting to use region mode. Status of the offending DMA channel is latched when this error occurs. #### Cause: - 1. Undefined PIO operation - 2. A DMA device attempts to use region mode - A DMA device attempts to use buffered mode #### Action: - 1. Undefined PIO Operation - Send exception reply - Latch CSR bits: - PIO error = 1 - PIO/DMA operation = 1 - Invalid operation = 1 - Exception reported = 1 - 2. DMA device error - Send level 2 processor interrupt - Latch CSR bits - DMA error for active channel = 1 - PIO/DMA operation = 0 - Interrupt pending = 1 - Invalid operation = 1. Note: Operation cancelled. Rit 14 Protection Violation. This bit is set when a PIO command attempts to access a privileged level register from unprivileged state or when a alternate controller in region mode attempts access to a protected system board I/O address. #### Cause: - 1. PIO access to a privileged register from unprivileged state. - 2. Attempt by an alternate controller operating in region mode to access I/O subsystem registers while CCR channel access bits prohibit it. #### **Action:** - 1. PIO read or virtual write induced error - Send exception reply - Latch CSR bits: - PIO error = 1 - PIO/DMA operation = 1 - Protection violation = 1 - Exception reported = 1 - 2. PIO real write in progress - Send level 2 processor interrupt - Latch CSR bits - PIO error = 1 - PIO/DMA operation = 1 - Interrupt pending = 1 - Protection violation = 1 - 3. Alternate controller protection violation - Send level 2 processor interrupt - Latch CSR bits - DMA error for active channel = 1 - PIO/DMA operation = 0 - Interrupt pending = 1 - Protection violation = 1 Note: Operation cancelled. - PIO/DMA. This bit qualifies whether error status latched on the first occurrence of an error was due to a PIO or DMA operation. This bit is set when the first error was due to a PIO operation. - **Bits 16-23** DMA Error 8-5, 3-0. These bits indicate the active DMA channel during an error. These bits are not locked after the first error. - Bit 24 PIO Error. This bit indicates an error during a PIO command. This bit is not locked after the first error. - **Bit 25** Reserved. This bit is reserved and not guaranteed to be the same on successive CSR read commands. - System Attention Sequence from Keyboard. This bit is set when the system attention interrupt key sequence is detected by the keyboard controller. When active, this bit causes a processor level 0 interrupt. Cause: System attention keystroke sequence detected by keyboard adapter. #### Action: - 1. Activate processor level 0 interrupt - 2. System attention CSR bit = 1 (CSR is not locked). **Bit 27** Soft Reset. This bit is set when the soft reset key sequence is detected by the keyboard controller. When active, this bit causes a system reset. This bit provides the IPL software with the ability to differentiate between a power on reset and a soft reset. Cause: Soft reset keystroke sequence detected by keyboard adapter. #### **Action:** - 1. Activate processor reset - 2. Soft reset CSR bit = 1 (CSR is not locked until processor resets IOCC) - 3. Processor resets IOCC - 4. All current IOCC interface activity is cancelled - 5. The CSR is frozen, logging current activity, if any. - Exception reported bit is reset - Interrupt pending bit is reset - Channel reset capture = 1 if no previous errors - PIO operation pending bit may be set - Executing PIO operation is cancelled if: - PIO error bit = 0 - PIO/DMA bit = 1 - System board busy bit = 1 - Executing DMA operation is cancelled if: - DMA error bit = 1 for active channel - PIO/DMA operation bit = 0 - System board busy bit = 1. (If DMA activity was on the processor channel at the time of the processor initiated reset). Bit 28 Early Power Off Warning. This bit indicates a fault was detected in the AC power supply. When active, this bit causes a TRAP interrupt. A minimum of 2 ms. of good machine operation is guaranteed following detection of this signal. Cause: Power supply detected loss of ac power #### Action: - 1. Activate trap signal - Set EPOW CSR bit (CSR is not locked). - **Bit 29** Reserved. This bit is reserved and not guaranteed to be the same on successive CSR read commands. - **Bit 30** Interrupt Pending. This bit indicates the IOCC has detected an error condition and generated an interrupt to the processor. This bit is not set for errors reported with exception replies. - **Bit 31** Exception Reported. This bit indicates the IOCC has detected an error and reported it via the processor's exception mechanism. This bit is not set if the error is reported by interrupt. ### **Miscellaneous CSR Errors** ### **Processor Initiated Reset** #### Cause: Unrecoverable error detected on processor board. #### Action: - 1. Processor resets IOCC - All current IOCC interface activity is cancelled - 3. The CSR is locked, logging current activity, if any. - Exception reported bit = 0 - Interrupt pending bit = 0 - PIO operation pending bit = 1 - Channel reset captured = 1 - If PIO operation is cancelled; - PIO error bit = 0 - PIO/DMA operation bit = 1 - System board busy bit = 1 - If DMA operation is cancelled, DMA error for active channel = 1 - PIO/DMA operation bit = 1 - System board bit = 1 ### **CSR Bit Status** These CSR bits are not affected by CSR locked status - Interrupt pending - **Exception** reported - PIO error - DMA error (Channels 0 8) - **EPOW** - Soft Reset - System attention These CSR bits are locked when an error occurs. - PIO/DMA Operation - Protection violation - I/O channel check - DMA exception - Channel reset captured - PIO request pending - PIO request pending - System board busy. # **Memory Configuration Register** The 8-bit memory configuration register (MCR) provides the size and refresh rate information obtained from the configuration bits on the system memory boards. The MCR can be read by the system processor, or by an alternate controller in region mode. The MCR is at system address X'F0008C80'. Figure 5-49. Memory Configuration Register ## Bit #### **Definition** - Reserved, always = 1. - 6-4 Memory board size in slot D. These three bits specify the following memory board sizes. - 4MB memory board - 1MB memory board - 010 Reserved - 011 Reserved - 100 8MB memory board - 101 2MB memory board - 110 512KB memory board - No memory board. - Refresh rate. If bit 7 is 0, system memory is refreshed every 7.0 usec. If bit 7 is 1, system memory is refreshed every 13.8 usec. - **2-0** Memory board size in slot C. These three bits specify the memory board sizes shown above. # I/O Delay Register (IDR) The I/O delay register is not physically implemented. Writes to the I/O delay register result in the execution of a slow PIO cycle with data being lost. This register is provided for software to supply a mechanism to create reliable timing delays. This register can be written by the processor board or an alternate controller in region mode. The IDR is located at address X'0080E0'. Writes to the I/O delay register results in delays of approximately 1 microsecond per byte transferred. This provides the following delays for each type of store instruction executed to the IDR by the system processor. - Store character (1 byte transfer) 1 $\mu$ sec. - Store halfword (2 byte transfer) 2 $\mu$ sec. - Store word (4 byte transfer) 4 $\mu$ sec. # I/O Subsystem Adapters The I/O subsystem adapters which reside on the system board are described in this section. ### **Real Time Clock** The RT PC system uses the MC146818 real time clock module to provide the real time clock function and provide 50 bytes of nonvolatile RAM. The real time clock runs on the battery when the system is turned off and runs on the power supply when the system is turned on. The oscillator input to the real time clock is 32.768 KHz. The clock out, square wave, and interrupt request outputs are programmable. The clock output is set to 32.768 KHz. The square wave output is programmed for 1.024 KHz and is used by the system processor interval timer. The interrupt request output is programmable and is connected to the system processor interrupt level 1. The nonvolatile RAM stores system configuration information. The I/O address space of this module is X '008800' through '00883F' and is shown in the following table. | Hex Address | Туре | Comments | |-------------|------|------------------| | 008800 | R/W | Seconds | | 008801 | R/W | Seconds Alarm | | 008802 | R/W | Minutes | | 008803 | R/W | Minutes Alarm | | 008804 | R/W | Hours | | 008805 | R/W | Hours Alarm | | 008806 | R/W | Day of Week | | 008807 | R/W | Date of Month | | 008808 | R/W | Month | | 008809 | R/W | Year | | 00880A | R/W | Register A | | 00880B | R/W | Register B | | 00880C | R/- | Register C | | 00880D | R/- | Register D | | | | | | 00880E | R/W | Non Volatile RAM | | Through | | 50 Bytes | | 00883F | R/W | Non Volatile RAM | Figure 5-50. Real Time Clock Address Map For more information on the real time clock read the Motorola specifications on the MC146818. ## **Serial Ports** Two asynchronous serial ports are contained on the Model 20 and Model 25 system boards; they are referred to as channel A and channel B. The serial ports attach to the low order byte (7-0) of the I/O channel and are isolated from the external I/O channel through the use of tri-state buffers. Both serial ports are contained within one Z8530 Serial Communications Controller (SCC). The Z8530 requires one control register for each serial port external to the Z8530 itself. These external registers contain control and status information relative to the serial interface. Each serial port can transmit and receive data in programmed I/O mode or transmit data in Direct Memory Access (DMA) mode. Each serial port also has an EIA RS-232C-like interface. See "RS232C Interface" on page 5-84. ## Z8530 Module The functional description of the Z8530 module is not discussed in this document; only major points of interest about the Z8530 are given here. For more information about the Z8530 refer to: - 1. Zilog Data Book 1982/83 - 2. Z8030/Z8530 SCC Serial Communication Controller Technical Manual 1983. As stated earlier both serial ports are contained within the Z8530 module and each serial port is designed to run in asynchronous mode only. Capabilities of the serial ports include: - Two independent full-duplex channels - Five-, 6-, 7-, or 8-bits per character - One, 1.5 or 2 stop bits - Odd, even or no parity - Break detection and generation - Parity, overrun, and framing error detection - Transmit or receive up to 19,200 bits per second - Baud rate generator in each channel. The Z8530 is connected to the lower two address bits (0-1). Address bit 0 is connected to the A/B pin of the Z8530 and address bit 1 is connected to the D/C pin of the Z8530. The addresses associated with the two serial ports are given in Figure 5-51 on page 5-78. The Z8530 has two TTL-compatible clock signals connected to it. The first clock signal is connected to the PCLK pin, and runs at a rate of 3.58 MHz. The second clock signal, which runs at a rate of 3.072 MHz, is connected to the RTxCA and RTxCB pins of the Z8530 module. The serial ports use the baud rate generator in each of the channels in the Z8530, so this 3.072 MHz clock drives the baud rate generator in each of the channels in the Z8530. Write register 11, which controls the different clocking schemes of the Z8530, should be set to a specific value for the serial ports to operate properly. | Address | Facility | |----------|-------------------------------------| | 00 80 00 | Z8530 Serial Port Channel B Control | | 00 80 02 | Z8530 Serial Port Channel B Data | | 00 80 01 | Z8530 Serial Port Channel A Control | | 00 80 03 | Z8530 Serial Port Channel A Data | | 00 80 20 | External Register A | | 00 80 40 | External Register B | | 00 80 60 | Z8530 Intack | Figure 5-51. Serial Port Address Map This specific value is: Figure 5-52. Write Register 11 Bit 7 is set to a logic level 0 since the RTxCA and RTxCB pins are connected to a TTL-compatible signal and not a quartz crystal. Bits 6 and 5 are set to 1 and 0 respectively since the baud rate generator of the Z8530 drives the receive clock. Bits 4 and 3 are set to 1 and 0 respectively since the baud rate generator of the 28530 drives the transmit clock. The TRxCA and TRxCB pins are not connected, so the values in bits 2, 1, and 0 are only recommended. Write register 11 is described in detail in Section 3.11 "Clocking Options" in the Z8530 Technical Manual. Another register to observe is write register 14. Bit 1 in write register 14 must be set to 0 since the baud rate generator is used to drive the transmit and receive clocks. How to use the baud rate generator is described in Section 3.9 "Baud Rate Generator" in the Z8530 Technical Manual. **Note:** Since the baud rate generator is driven by a 3.072 MHz clock, the higher times clock modes can't be used for the higher transmit and receive data rates. The Z8530 module is reset when both its RD and WR pins are driven to a logic level 0 at the same time. This reset is forced active by writing a 0 into bit-0 of the component reset register B. The reset is forced inactive by writing a 1 into bit-0 of the component reset register B. The serial ports generate two interrupts, one by the external registers, which will be discussed later, and one by the Z8530. The interrupt generated by the Z8530 occurs on any condition that normally causes the Z8530 to generate an interrupt. This is described in Section 3.4 "Interrupts" in the Z8530 Technical Manual. The interrupt coming from the Z8530 is on level 6 of the first 8259. A special note about the Z8530 interrupt is the INTACK pin on the Z8530. One of the steps in clearing an interrupt within the Z8530 is to drive the INTACK pin to a logic level 0 and then drive the RD pin to a logic level 0. This step is done by driving a certain address onto the address bus and performing a programmed I/O read to the Z8530. This address is given in Figure 5-51 on page 5-78. Other pins of interest to the interrupt function of the Z8530 are IEI and IEO. The IEI pin is always held at a logic level 1, and IEO is not connected. The serial ports can also transmit data in DMA mode, so the Z8530 must be put into DMA mode. The W/REQA pin generates the DMA request for channel A and the W/REQB pin generates the DMA request for channel B. Write register 1 must be set up a certain way for the Z8530 to perform in DMA mode. This is described in Section 3.5 "Block Transfer" in the Z8530 Technical Manual. The last item observed on the Z8530 is that pins DTR/REQA, DTR/REQB, SYNCA, and SYNCB are all not connected. ## **Programmed I/O and DMA Modes** As mentioned earlier, the serial ports can transmit and receive data in programmed I/O mode or transmit data in DMA mode. Each serial port channel has two DMA channels as a DMA device assigned to it. Channel A of the serial ports can transmit data in DMA mode, using either DMA channel 0 or DMA channel 2. Channel B of the serial ports can transmit data in DMA mode using either DMA channel 1 or DMA channel 3. The external registers determine which serial port channel uses which one of the DMA channels; this is described later. Not only must the serial ports be initialized to perform DMA operations, but the translation control mechanism and the DMA control mechanism must also be initialized. When the serial ports are used in DMA mode, they operate on an 8-bit DMA channel. ## **External Registers** Each serial port has one, 8-bit external register that is not contained within the Z8530 module. These two external registers are identical except one is used for channel A and the other one is used for channel B. The addresses for external register A and external register B are shown in Figure 5-51 on page 5-78. The external registers have three main functions. They control part of the RS232C-like interface, they generate an interrupt for the serial port, and they enable the correct DMA channel for each serial port. The external register maintains three of the RS232C-like interface signals. The external register determines whether Data Terminal Ready (DTR) is active or inactive, monitors DTR, monitors Data Set Ready (DSR), and monitors Ring Indicate (RI). One interrupt to the interrupt controller can be generated by either or both of the external registers; this interrupt is on level 7 of the second 8259. Essentially, external registers A and B can generate an interrupt. These two interrupts are 'OR'ed together to form one interrupt signal going to the interrupt controller. An interrupt is generated when one of the following conditions occur on the RS232C-like interface: DSR changes state from 0 to 1 or from 1 to 0 Channel A RI becomes active, changes from 0 to 1 Channel A Channel B DSR changes state from 0 to 1 or from 1 to 0 RI becomes active, changes from 0 to 1. Channel B An interrupt is also generated for the following conditions if the serial ports are using DMA: Terminal count is reached on the DMA channel being used Channel A Channel B Terminal count is reached on the DMA channel being used. Figure 5-53 on page 5-83 and Figure 5-54 on page 5-83 shows how the external registers A and B are arranged. The bit definition of each register follows: ### **Read Function Channel A** - If this bit is a 1, DTR for channel A is active. If this bit is a 0, DTR is inactive. Bit 0 - If this bit is a 1, DSR for channel A is active. If this bit is a 0, DSR is inactive. Bit 1 - If this bit is a 1, RI for channel A is active. If this bit is a 0, RI is inactive. Bit 2 - If this bit is a 0, DSR has changed state or RI has become active on channel A. If this bit Bit 3 is a 0 and bit-5 of write function channel A is a 1, an interrupt is generated. If this bit is a 1. DSR or RI have not changed value. - If this bit is a 0, terminal count has been reached during a DMA operation to channel A Bit 4 of the serial ports. If this bit is a 0 and bit-5 of write function channel A is a 1, an interrupt is generated. If this bit is a 1, terminal count has not occurred. - Bit 5 Unused - Bit 6 Unused - Bit 7 Unused ## Write Function Channel A - Bit 0 Setting this bit to a 1 activates DTR for channel A. Setting this bit to a 0 turns off DTR. - Bit 1 Setting this bit to a 1, enables serial port channel A to use DMA channel 0 for transmitting data. Setting this bit to a 0 disables DMA channel 0. - Bit 2 Setting this bit to a 1 enables serial port channel A to use DMA channel 2 for transmitting data. Setting this bit to a 0 disables DMA channel 2. - Bit 3 A programmed I/O write of a 1 to this bit clears the interrupt generated by DSR or RI. A programmed I/O write of a 0 to this bit causes no change. - Bit 4 A programmed I/O write of a 1 to this bit clears the interrupt generated when terminal count is reached during a DMA operation. A programmed I/O write of a 0 to this bit causes no change. - Bit 5 Setting this bit to a 1 enables an interrupt caused by DSR, RI, or terminal count to be driven to the interrupt controller. Setting this bit to a 0 disables an interrupt from being driven to the interrupt controller. - Bit 6 Unused: - Bit 7 Unused ## **Read Function Channel B** - Bit 0 If this bit is a 1, DTR for channel B is active. If this bit is a 0, DTR is inactive. - Bit 1 If this bit is a 1, DSR for channel B is active. If this bit is a 0, DSR is inactive. - Bit 2 If this bit is a 1, RI for channel B is active. If this bit is a 0, RI is inactive. - Bit 3 If this bit is a 0, DSR has changed state or RI has become active on channel B. If this bit is a 0 and bit-5 of write function channel B is a 1, an interrupt is generated. If this bit is a 1, DSR or RI have not changed value. - Bit 4 If this bit is a 0, terminal count has been reached during a DMA operation to channel B of the serial ports. If this bit is a 0 and bit-5 of write function channel B is a 1, an interrupt is generated. If this bit is a 1, terminal has not occurred. - Bit 5 Unused - Unused Bit 6 - Bit 7 Unused ## Write Function Channel B - Bit 0 Setting this bit to a 1 activates DTR for channel B. Setting this bit to a 0 turns off DTR. - Bit 1 Setting this bit to a 1, enables serial port channel B to use DMA channel 1 for transmitting data. Setting this bit to a 0 disables DMA channel 1. - Bit 2 Setting this bit to a 1 enables serial port channel B to use DMA channel 3 for transmitting data. Setting this bit to a 0 disables DMA channel 3. - Bit 3 A programmed I/O write of a 1 to this bit clears the interrupt generated by DSR or RI. A programmed I/O write of a 0 to this bit causes no change. - Bit 4 A programmed I/O write of a 1 to this bit clears the interrupt generated when terminal count is reached during a DMA operation. A programmed I/O write of a 0 to this bit causes no change. - Bit 5 Setting this bit to a 1 enables an interrupt caused by DSR, RI, or terminal count to be driven to the interrupt controller. Setting this bit to a 0 disables an interrupt from being driven to the interrupt controller. - Bit 6 Unused - Bit 7 Unused The external registers can be reset by activating bit-1 of the component reset register B (setting bit 1 to a 0). When this bit is active: - DTRA and DTRB become inactive - All of the DMA channels to the serial ports are disabled - All of the causes of the external register interrupts are cleared - The enable for generating an interrupt for both external registers is disabled. In terms of bits for both registers: #### **Read Function** Bit 0 is set to 0. Bits 3 and 4 are set to 1. #### Write Function Bits 0, 1, and 2 are set to 0. Bit 5 is set to 0. Deactivating bit 1 (setting bit 1 to a 1) of the component reset register B releases the reset to the external registers. ## **DMA Initialization Sequence** When the serial ports are being initialized to operate in DMA mode, a special initialization sequence must be followed to insure that the DMA works properly. There are four steps and they must be done in this order: - 1. Completely initialize the serial ports, the translation control mechanism, and the DMA control mechanism, but keep the DMA channel being used disabled in the external register of the serial ports, keep the DMA channel being used masked in the mask register of the 8237, and leave bit 7 (WAIT/DMA request enable) of write register 1 in the Z8530 disabled. - 2. Enable the DMA channel being used in the external register of the serial ports. - 3. Unmask the DMA channel being used in the mask register of the 8237. - 4. Enable bit 7 of write register 1 in the Z8530. The sequence described above must be performed to allow the DMA control mechanism to see the DMA request transition from an inactive state to an active state. | Bit | Read<br>Function | Write<br>Function | |-----|------------------|-------------------| | 0 | DTRA | DTRA | | 1 | DSRA | EN DMA 0 | | 2 | RIA | EN DMA 2 | | 3 | - EXT IRQ | EXT IRQ Reset | | 4 | - TC IRQ | Reset TC IRQ | | 5 | Reserved | EN IRQ | | 6 | Reserved | Reserved | | 7 | Reserved | Reserved | Figure 5-53. External Register A | Bit | Read<br>Function | Write<br>Function | |-----|------------------|-------------------| | 0 | DTRB | DTRB | | 1 | DSRB | EN DMA 1 | | 2 | RIB | EN DMA 3 | | 3 | - EXT IRQ | EXT IRQ Reset | | 4 | - TC IRQ | Reset TC IRQ | | 5 | Reserved | EN IRQ | | 6 | Reserved | Reserved | | 7 | Reserved | Reserved | Figure 5-54. External Register B ## **RS232C Interface** Each serial port supports the following RS232C interface signals: - Transmit Data (TXD) - Receive Data (RXD) - Data Terminal Ready (DTR) - Data Set Ready (DSR) - Clear to Send (CTS) - Request to Send (RTS) - Data Carrier Detect (DCD) - Ring Indicator (RI) - Signal Ground The serial ports use Texas Instrument SN75150 line drivers and SN75154 line receivers for its RS232C-like interface. Each serial port has a ten pin connector on the system board, and the pin configuration for channel A's connector is identical to channel B's connector. The serial port connector is shown in Figure 5-55 on page 5-85. The view given is as if someone were facing the two system board serial port connectors. Note: From this view the channel B connector is to the left of the channel A connector. | 1 2 3 4 5 | 1 2 3 4 5 | |-------------------------|-------------------------| | * * * * *<br>6 7 8 9 10 | * * * * *<br>6 7 8 9 10 | | Channel B Connector | Channel A Connector | | Pin | Signal | |-----|---------------| | 1 | TXD | | 2 | DTR | | 3 | RTS | | 4 | RI | | 5 | No Connection | | 6 | RXD | | 7 | DSR | | 8 | CTS | | 9 | DCD | | 10 | Signal Ground | Figure 5-55. Serial Port Connectors Note: The two connectors are identical. ## Keyboard, Locator, Speaker Adapter The keyboard, locator, and speaker adapter (referred to hereafter as the adapter) contains an Intel 8051 single chip microcontroller programmed to support a serial keyboard interface, a locator device with a full duplex serial interface (UART), and a speaker. The adapter interfaces bidirectionally to the I/O channel through an 8-bit Intel 8255A programmable peripheral interface chip, and a 6-bit command register. The adapter supports the keylock switch which inhibits input from the keyboard and locator devices. The adapter also performs a multikeystroke detection, which directly initiates a system reset or a system attention interrupt, depending on the sequence detected. The adapter resides on the system board. The system board provides the connectors to the keyboard, locator device, speaker, and keylock switch. ## **System Software Interface** System-to-adapter communications are over the two low-order data bus bytes (bits SD0-15) utilizing I/O write operations. Adapter-to-system communications are initiated by the adapter raising an interrupt level request. Data transfers to the system are over the low-order data bus byte (bits SD0-7) utilizing I/O read operations. Additionally, an adapter selective reset may be initiated by the system using an I/O write sequence. ## **Intel 8255 Programmable Peripheral Interface** The Intel 8255A (referred to hereafter as 8255) is a general purpose programmable I/O chip used to interface the Intel 8051 to the system and as a diagnostic sensing port. The 8255 is configured to operate in mode 2 with Ports B and C (lower) defined as inputs. Port A provides a bidirectional bus with the 8051, while Port C (upper) provides the necessary hand-shake controls. ## **Intel 8051 Microcontroller Functions** The adapter generally does not interpret information passing between the system and the keyboard or locator. That information is simply passed through the adapter. The 8051 receives data from the keyboard or locator, validates it, and passes it on to the system. The 8051 receives device commands from the system and passes them on to the selected device. The 8051 also receives commands from the system which are validated and executed by the 8051, such as reading and writing shared RAM. The 8051 has 128 bytes of Random Access Memory (RAM). Commands are defined which allow the system to read or write a selected set of these bytes. This shared RAM contains status and mode control information, Reliability, Availability and Serviceability (RAS) activity and error logs, and device control parameters. ## **Keyboard Interface** The adapter receives a frame of data serial by bit from the keyboard, validates the frame, buffers up to 5 bytes, and presents the data to the system as a byte of data in the 8255 input buffer. The adapter interrupts the system when data is placed in the interface buffer. The system sends keyboard commands to the keyboard by writing to the adapter's command register and 8255 output buffer. The 8051 imbeds the data byte in a frame, then sends the frame serial by bit to the keyboard with odd parity. The 11-bit framing protocol and keyboard commands are defined in the keyboard section of this manual. Scan codes received from the keyboard are passed on to the system in their original form, the adapter performs no translation. Keystrokes received while the buffer is full (overrun) are lost. ## **Locator Interface** The adapter contains a duplex serial port operating in an 11-bit UART framing protocol that communicates with a locator device. The adapter buffers up to 2 reports of locator device data. The system sends commands through the adapter to the locator. The data reports and commands are defined in the locator section in this manual. Reports received from the locator are passed on to the system in their original form, the adapter does not alter the report byte content. Reports received while the buffer is full (overrun) are lost. ## **Speaker Interface** The keyboard contains a small speaker, which can be driven from either the adapter or the Coprocessor. The adapter always has control of the volume. Frequency and duration parameters are controlled by either the adapter or the Coprocessor through an OR circuit. System software must ensure that only one path is active at a time. The adapter provides an automatic click tone through the speaker for every keystroke at a default frequency and duration. The adapter buffers one set of frequency and duration parameters while a current tone is active. ## RAS and Security Functions Provided by the Adapter The adapter is able to force system attention interrupt and system reset signals to the system. These signals are initiated by two unique three-keystroke sequences. The system attention interrupt default keystroke sequence may be redefined or disabled by system software. The system reset keystroke sequence cannot be altered, and is always active with two exceptions: - When the keylock switch is on - The system software has disabled the keyboard interface or keyboard scanning. The adapter monitors a signal from an external keylock switch. When the switch is on, all input from the keyboard or locator is suppressed in the adapter, including the special keystroke sequences. System IPL Read Only Memory (ROM) code interrogates the state of the keylock switch during its power-on initialization and takes appropriate action if found on. Individual activity counters maintain counts of frames received and transmitted thru the keyboard and locator ports. Retry counters accumulate counts of keyboard retries performed. Individual error counters accumulate the number of hard errors for the keyboard and locator. The keyboard and speaker ports may be diagnostically wrapped or sensed at the signal points which leave the system board. No external wrap connectors are required. Also, UART port signals may be diagnostically sensed. The 8051 performs a self-test function after a system reset. Self-tests may also be performed on command from the system. The adapter initiates retry operations with the keyboard on transmit and receive errors. The number of retries performed may be redefined by system software. The adapter returns 8051-detected error conditions to the system where additional error recovery procedures may be performed. ## **Adapter I/O Operations** System software communicates with the adapter's 8255 using memory mapped reads and writes. Configuring the 8255 and enabling or disabling interrupt requests is done with a write operation to the 8255. The adapter hardware reset function is performed by writing to the system's component reset register B. Communications between the system software and the adapter's 8051 can be initiated by either party. The system can send 2 bytes of command and data to the adapter. The adapter has two modes of transferring data to the system, non blocked (single byte) and blocked (multiple bytes in sequence). The adapter signals the system when it has information to transfer with an interrupt request, if enabled. Alternatively, the system disables the interrupt request and polls the 8255 for data. The following paragraphs list the specific, detailed steps used for communications between the system software and the adapter's 8051. ### **System Initiated Transfer to Adapter** - 1. System verifies that 8255 output buffer is not full (by testing its internal flag) - 2. System sets an internal programming flag indicating 8255 output buffer full (OBF); (system should reset flag in an acknowledgement interrupt handler) - System issues I/O Write to adapter with command and data bytes - 8255 sets OBF [PC7=0], which initiates an 8051 interrupt - 8051 interrupt reads the command register (command must be read before data) - 8051 interrupt reads the data from 8255 PA reg - 8255 resets OBF [PC7=1], dropping interrupt to 8051 - 8051 interrupt posts command and data to a work queue - 9. 8051 exits interrupt level - 10. 8051 command execution work queue initiates an interrupt request to system signifying execution status of the command: - ID 0 = Informational (cmnd accepted or rejected) - ID 3 = Returning requested byte - ID 4 = Requested block transfer ready ### **Adapter Initiated Transfer to System** - 1. 8051 waits for IBF=0 (input buffer empty) by testing PC5 - 8051 writes interrupt ID to 8255 PC bits 2-0 (PC must be written before PA) - 3. 8051 writes data byte to 8255 PA reg (input buffer) - 4. 8255 sets IBF (input buffer full) which raises IRQ to system - System accepts interrupt request - 6. System reads interrupt ID from 8255 PC reg (PC must be read before PA); if ID='100', then go to block Transfer chart - 7. System reads data byte from 8255 PA reg (Input Buffer) - 8. 8255 resets IBF (input buffer empty) which drops IRQ - 9. System processes information and exits interrupt level ### Adapter Initiated Block Transfer to System This sequence transfers multiple bytes of the following types of information: - Locator data when in blocking mode - Adapter shared RAM dump - **RAS Logs dump** - 1. 8051 waits for IBF=0 - 2. 8051 writes interrupt ID '100' to PC bits 2-0 - 3. 8051 writes block length (byte count) to 8255 PA Input Buffer - 8255 sets IBF=1 which raises IRQ to system - 5. 8051 waits for IBF=0 - System accepts interrupt request - System reads interrupt ID '100' from 8255 PC reg - 8. System reads count from 8255 PA reg - 9. 8255 resets IBF which drops IRQ - 10. System waits (polls) for IRQ to be set (either by sensing IRQ internally in the system processor, or by reading 8255 PC bit 5) - 11. 8051 writes interrupt ID appropriate to data to 8255 PC bits 2-0 ('010' or '011') - 12. 8051 writes data byte to 8255 PA Input Buffer - 13. 8255 sets IBF=1 which sets PC5 and raises IRQ to System (if enabled). - 14. 8051 waits for IBF=0 - 15. System reads interrupt ID from 8255 PC reg - 16. System reads data byte from 8255 PA reg - 17. 8255 resets IBF which resets PC5 which drops IRQ - 18. Repeat previous 8 steps for the number of data bytes indicated by count - 19. System processes information and exits interrupt level. # **IOW and IOR Operations** The following chart lists the defined I/O operations to the adapter: | Host<br>OP'N | I/O<br>Address | Function | Comments | |--------------|----------------|------------------------|------------------------------------------------| | IOR | 8404 | Read 8255 PA | Input buffer returned | | IOR | 8405 | Read 8255 PB | Diagnostic sense | | IOR | 8406 | Read 8255 PC | Low 3 bits = interrupt ID | | IOW | 8400 | Write 8255 PA | Command and data latched for execution by 8051 | | IOW | 8407 | Configure 8255 | Required data = X'C3' | | IOW | 8407 | Enable IRQ | Required data = X'09' | | IOW | 8407 | Disable IRQ | Required data = X'08' | | IOW | 8C60 | Activate adapter reset | Required data = b'xxxx x0xx' | | Host<br>OP'N | I/O<br>Address | Function | Comments | |--------------|----------------|-----------------------|------------------------------| | IOW | 8C60 | Release adapter reset | Required data = b'xxxx x1xx' | ### Read 8255 PA Input Buffer | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|-----------------| | | | | | | IOR | 8404 | | PA Input Buffer | #### Action The 8-bit 8255 PA input buffer contents are returned to system software. 8255 PC bit 3 is reset, which drops IRQ to the system processor, and frees the 8255 PA input buffer. #### Pre-condition The 8255 PA input buffer is valid only when the 8255 PC bit 3=1, which initiates an interrupt request to the system processor. #### **Comments** The meaning of the returned byte is determined by the interrupt ID in PC bits 2-0, which must have previously been read. ### Read 8255 PB Port | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOR | 8405 | | Port B Inputs | #### Action The following 8 signals wired into the 8255 Port B are sensed and returned to system software: - Bit 7 = + Cpspkr/speaker frequency - Bit 6 = +Speaker volume bit 1 - Bit 5 = +Speaker volume bit 0 - Bits 4-1 = Diagnostic sense of non-adapter system board signals • Bit 0 = UART RXD signal Pre-condition (None) **Comments** This operation is primarily intended for diagnostic purposes. It may be issued at any time to dynamically sense the state of the 8 signals listed. ## Read 8255 PC Register | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|-----------------| | | | | | | IOR | 8406 | | PC Reg Contents | #### Action The 8-bit 8255 PC register content is returned to system software. PC bit 7 indicates whether PA output buffer is full (0) or empty (1). PC bit 5 indicates whether PA input buffer is full (1) or empty (0). PC bits 6 & 4 are used for hand-shaking controls between the 8255 and the 8051 and can be ignored. PC bit 3 is the interrupt request line to the system processor. PC bits 2-0 define 8 possible interrupt identifier codes for the PA input buffer as follows: | PC 7-0 (binary) | Interrupt<br>ID | | |-----------------|-----------------|--| | | | | | xx1x i000 | 0 | | | xx1x i001 | 1 | | | xx1x i010 | 2 | | | xx1x i011 | 3 | | | xx1x i100 | 4 | | | xx1x i101 | 5 | | | xx1x i110 | 6 | | | xx1x i111 | 7 | | Where x = don't care bits i = 1 if IRQ enabled, or 0 if disabled Refer to "Adapter Initiated Interrupt Request - ID Codes" on page 5-97 for an explanation of the interrupt ID's. #### Pre-condition PC Reg bits 2-0 are valid only if PC bit 5=1. The 8255 resets PC bit 5 when the PA input buffer is read. #### **Comments** This operation determines why interrupt request was initiated by the adapter and how the PA input buffer should be interpreted. This operation must be issued prior to reading the PA input buffer. This operation may also be used prior to writing to the PA output buffer to determine if it is full or empty. ### Write 8255 PA Output Buffer | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8400 | 8051 Command | 8051 Data | #### Action Two bytes of data are written to the adapter as follows (bit 15 is most significant bit): - Bits 15-14 Should be 00 - Bits 13-8 Latched in adapter command register - BITS 7-0 Latched in 8255 PA output buffer The 8255 resets PC bit 7 (to 0) indicating that the PA output buffer is full, which initiates an interrupt request to the 8051. When enabled, the 8051 interrupt handler reads the low 5 bits from the command reg (bits 12-8), then the 8 bits from the 8255 PA output buffer (bits 7-0). The 8255 sets PC bit 7, (to 1) indicating that the PA output buffer is now empty. The 13-bit command and data is posted to an 8051 internal queue for subsequent execution. #### Pre-condition The 8255 PA output buffer must be empty. This is determined by interrogating 8255 PC bit 7: 0 = full, 1 = empty. #### **Comments** The 13-bit command and data combinations are described in "Adapter Commands" on page 5-99. The subsequent 8051 execution handler will acknowledge the command by initiating an appropriate Interrupt ID. ### Configure 8255 | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8407 | | X'C3' | #### Action The 8255 resets its internal registers (Control, PA, PB, PC). Then the data byte is loaded into the 8255 control register, setting the 8255 to operate as follows: - PA is a bidirectional port with an output buffer and an input buffer. - PB is an input-only sensing port for diagnostic use. - PC bits 7-4 are handshaking controls for PA to the 8051. - PC bit 5 = 8255 input buffer full - PC bit 3 is an interrupt request to the system processor. - PC bits 2-0 are input-only sensing pins set by the 8051. #### Pre-condition The 8051 is held in its reset state while this configure is being done. #### Comments This operation is normally issued after the adapter has been reset, either by a reset adapter operation, system reset, or power-on. ### **Enable IRO** | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8407 | | X'09' | #### Action The 8255 PC bit 3 initiates an interrupt request to the system processor when the PA input buffer has been loaded by the 8051. #### Pre-condition The 8255 must be properly configured. #### Comments This operation is normally issued after the 8255 has been configured, and after interrupt request had previously been disabled. ## Disable IRQ | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8407 | | X'08' | Action The 8255 PC bit 3 cannot initiate an interrupt request to the system processor. Pre-condition (None) Comments This operation suspends system software and adapter communications. Adapter and device operations are not directly affected. Overrun conditions may occur if the suspension lasts longer than the buffering capability of the devices attached, such as the keyboard and locator. ## **Adapter Reset Operation** Resetting the adapter is a two-step process, the reset must be activated, then released. The minimum time that the reset must be active is 10 microseconds. There is no maximum time. ## **Activate Adapter Reset** | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8C60 | | b'xxxx x0xx' | Action The selective reset to the adapter is raised and held active. The 8051 is held reset. (The 8255 is only reset by power-on.) Pre-condition (None) **Comments** The adapter is held reset until a subsequent release adapter reset operation is performed. ### **Release Adapter Reset** | Op | Addr | High-Data Byte | Low-Data Byte | |-----|------|----------------|---------------| | | | | | | IOW | 8C60 | | b'xxxx x1xx' | #### Action The selective reset to the adapter is dropped. The 8051 performs its internal self-testing and initialization. At the completion of the 8051 self-testing, a completion code is posted to shared RAM address X'1C' and to the system with an interrupt ID 6. ### Pre-condition The adapter's selective reset was activated either by an activate adapter reset operation, or by a system reset, or by a power-on. The 8255 must be configured before reset is released. #### Comments The 8051 performs its self-test and initializes RAM to the defined defaults. Refer to "Adapter and Keyboard Initialization Procedure" on page 5-142 for the recommended procedure to initialize the adapter and keyboard. ## **Adapter Initiated Interrupt Request - ID Codes** When the adapter (8051) has information to pass to the system, a 3-bit identification code is placed in the 8255 PC register bits 2-0 and a data byte in the PA input register. Then an interrupt request is raised to the system, if enabled. The following chart lists the interrupt ID codes, and their meanings: | Interrupt<br>ID Number | Interrupt Meaning | Data Byte<br>Contents | |------------------------|-----------------------------|-----------------------| | 0 | Informational interrupt | Information code* | | 1 | Byte received from keyboard | Received byte | | Interrupt<br>ID Number | Interrupt Meaning | Data Byte<br>Contents | |------------------------|------------------------------------|-----------------------| | | | | | 2 | Byte received from UART device | Received byte | | 3 | Returning byte requested by system | Requested byte | | 4 | Block transfer ready | Byte count | | 5 | Unassigned | | | 6 | 8051 self-test performed | Completion code | | 7 | 8051 detected an error condition | Error code** | <sup>\*</sup> Refer to "Adapter Informational Codes Returned to System" on page 5-127. <sup>\*\*</sup> Refer to "Adapter Error Codes Returned to System" on page 5-128. ## **Adapter Commands** Commands interpreted by the 8051 are initiated by the system via an I/O write to the 8255 PA register (output buffer). Command byte bits 4-0 are latched in the adapter's command register and are decoded by the 8051 to determine the meaning of the data byte latched in the 8255 PA register. Command byte bits 7-5 are diagnostic controls with bit 5 latched in an extension to the command register. The diagnostic control bits must normally be 000. ## **Command Byte Decodes** The following chart lists the command byte decodes: | Cmnd Byte<br>7654 3210 | Command Function | Data Byte Function | |------------------------|----------------------------------------|----------------------------------------------------| | | | | | 0000 0000 | Select extended command set | Extended command (see next chart) | | 0000 0001 | Write to keyboard | Byte to be transmitted to keyboard | | 0000 0010 | Write to speaker | Tone duration low-byte (number of 1/128 sec ticks) | | 0000 0011 | Write UART - control (no response) | Byte transmitted to UART device | | 0000 0100 | Write UART - query (response expected) | Byte transmitted to UART device | | 0000 0101 | Set UART baud rate | Baud rate counter value (default is 9600 BPS) | | 0000 0110 | Initialize UART framing | Odd/even parity control and blocking factor | | Cmnd Byte<br>7654 3210 | Command Function | Data Byte Function | |------------------------|-------------------------------------|-----------------------------------------------------------------------------------| | 0000 0111 | Set speaker duration | Tone duration high-byte | | 0000 1000 | Set speaker freq-hi | Frequency counter high-byte | | 0000 1001 | Set speaker freq-low | Frequency counter low-byte | | 0000 1010 | Unassigned | | | 0000 1011 | Unassigned | | | 0000 1100 | Diagnostic write keyboard port pins | Bit 6 to Kbd data out<br>pin Bit 7 to Kbd clock<br>out pin | | 0000 1101 | Unassigned | | | 0000 1110 | Unassigned | | | 0000 1111 | Unassigned | | | 0001 RRRR | Write shared RAM | Byte is written to 8051 shared RAM (low order 4 cmnd bits select shared RAM addr) | ## **Extended Command Decodes** The extended command set is decoded by the 8051 from the data byte latched in the 8255 PA Register when the command register = X'00'. The following chart lists the data byte decodes for the extended command set: | Data<br>Byte | Extended Command Function | |--------------|-----------------------------------------------------------------------------------------------------------------------| | 00-1F | Read shared RAM (low order 5 bits = shared RAM addr) | | 2M | Reset mode bit $M (M = 0-F Hex)$ | | 3M | Set mode bit $M (M = 0-F Hex)$ | | 40-43 | Initialize speaker volume: 40 = Off, 41 = Low, 42 = Medium, 43 = High | | 44 | Terminate speaker & reset duration | | 45-4F | Unassigned | | 50 | Invalid | | 51-53 | Set scan count for system attention keystroke sequence 51 = 1 Keystroke 52 = 2 Keystrokes 53 = 3 Keystrokes (default) | | 54-5F | Invalid | | 60-6F | Diagnose functions: | | 60 | Execute 8051 soft reset - force abnormal end code 'A0' | | 61 | Force system reset | | 62 | Force system attention interrupt | | 63-6F | Unassigned diagnostics | | Data<br>Byte | Extended Command Function | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 70 | Diagnostic sense keyboard & UART port pins returned byte: Bit 0 = UART RXD pin Bit 2 = Keyboard clock in pin Bit 3 = Keylock switch pin Bit 5 = Keyboard data in pin | | 71-7F | Unassigned diagnostics | | 80 | Dump adapter shared RAM addr 00-0F | | 81 | Dump adapter shared RAM addr 10-1F | | 82 | Dump RAS logs and reset activity and error counters | | 83 | Dump RAS logs without counter reset | | 84-8F | Unassigned | | 90 | Restore initial conditions | | 91-DF | Unassigned | | E0-EF | Read 8051 release marker (low order 4 bits = byte offset into 16-byte release marker) | | FX | NOP - adapter only returns an ACK interrupt to system $(X = Don't care)$ | ### Select Extended Command Set (X'00') The adapter interprets the data byte as an extended command which does not require an associated parameter. Refer to the specific extended command description. ## Write to Keyboard (X'01') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: Command accepted Command rejected - Adapter is busy with a previous transmission to the keyboard (S3=1) Command rejected - Keylock switch is on and M13=1 Command rejected - Keyboard interface is disabled (M11=0) Command rejected - Associated data byte is invalid If the command is accepted, then the associated data byte is transmitted to the keyboard. The associated data byte transmitted to the keyboard must not be the keyboard resend command as defined by shared RAM address '03'. ## Write to Speaker (X'02') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: Command accepted - Speaker started Command accepted - Parameters queued Command rejected - invalid duration specified Command rejected - invalid frequency count value specified Command rejected - Speaker queue full (S7=1) If the speaker queue is full, the command is rejected with code '4A', otherwise the associated data byte is written to SRAM address '02' as the pending duration-low and S7 is set on to indicate that speaker parameters have been queued. (It is assumed that pending duration-high and pending frequency have been previously set in SRAM addresses '01', '15', and '16', respectively.) If the speaker facilities are busy (S0=1 or S1=1), the command is accepted with a parameters queued acknowledgement. When the facilities become available, these queued parameters are validated and activated. If speaker facilities are currently available, S7 is set off. The pending frequency and duration parameters are validated and, if invalid, an appropriate command reject code is returned. Valid speaker parameters are activated and the command is accepted with a speaker started acknowledgement. (Refer to "Adapter Speaker Control" on page 5-118. ### Write to UART Device (X'03' and X'04') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: | UU | Command accepted | |----|-------------------------------------------------------------------------| | 42 | Command rejected - Keylock switch is on and M13=1 | | 4B | Command rejected - UART interface is disabled (M12=0) | | 4C | Command rejected - Adapter is busy with a previous write to UART (S4=1) | If the command is accepted, the associated data byte is transmitted to the UART (locator) device. The adapter has dual internal buffers for blocking reports received from a locator device. Each buffer has a 6-byte length to receive a device report up to 6 bytes long. One buffer can be transmitting to the system while the other is receiving a report from the device. If the device attempts to start a third report while the two buffers are busy, that third report (and all subsequent ones) are discarded until a buffer is available. Mode bit M5 specifies whether blocking of received reports is active or inactive. When inactive (M5=0), a byte received from the device is passed on to the system. When blocking is active (M5=1), report bytes received are buffered and blocked according to the blocking factor in SRAM address X'19'. Blocked report bytes are only transferred to the system when the complete report has been received by the adapter. If the adapter detects a parity error on a report byte being received from the locator, the adapter discards that report. Write UART - Control (X'03') All UART device commands not having a defined response must be issued with the Write UART - Control command to the adapter. (See 5-132 for particular device information concerning this command.) Write UART - QUERY (X'04') All UART device commands having a defined response must be issued with the Write UART - Query command to the adapter. An error has occurred if a device command requiring a response is sent, and no response is received within 25 milliseconds. The adapter returns the device error code X'EA' to the system. (See 5-132 for particular device information concerning this command.) ## Set UART Baud Rate (X'05') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating acceptance of the command. The associated data byte is written to SRAM address '1B' and is a counter value used to control the UART transmit and receive baud rate. The valid rate is determined by the UART device plugged. The default rate is 9600 bits per second. The counter value in SRAM address '1B' is related to the baud rate according to the formula: Where: Counter value = positive number rounded to an integer < 256 Osc = 8051 Oscillator frequency (Hz) Baud = desired baud rate (bits per second) For an assumed Osc value of 9.216 MHz, valid baud rates and corresponding counter values can be tabulated as follows: | Counter (dec) | |---------------| | | | 254 | | 251 | | 246 | | 236 | | 216 | | 176 | | 96 | | | ## Initialize UART Framing (X'06') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted4E Command rejected - invalid framing parameter If the command is accepted, the associated data byte is written to SRAM address '19'. It controls the parity generation and checking for UART transmission and reception, and specifies the number of bytes in the report received from the UART device. The framing parameter is defined as follows: Bit 7: 1= odd parity (default); 0= even parity Bits 6-3: Must be zeros Bits 2-0: Blocking factor; valid values are 2, 3, 4 (default), 5, or 6 Note: The blocking factor must match the report length of the locator device when blocking is active (M5=1). ## Set Speaker Duration - High Byte (X'07') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted #### **4A** Command rejected - Speaker queue full (S7=1) If the command is accepted, then the associated data byte is written to SRAM address '01' as the pending speaker duration - high byte. No validation of the duration value is performed until the speaker parameters are activated. Refer to "Adapter Speaker Control" on page 5-118. ## Set Speaker Frequency - High/Low Byte (X'08' and X'09') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: Command accepted 00 Command rejected - Speaker queue full (S7=1) **4A** If the command is accepted, the associated data byte is written to SRAM address '15' for high byte command X'08', or SRAM address '16' for low byte command X'09', as the pending speaker frequency. No validation of the frequency value is performed until the speaker parameters are activated. (Refer to "Adapter Speaker Control" on page 5-118.) ## Diagnostic Write Keyboard Port Pins (X'0C') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted 51 Command rejected - illegal mode (M10=0) This command is executed only in diagnostic mode. Data byte bit 7 is written to the keyboard clock line and data byte bit 6 is written to the keyboard data line. These values are kept on the indicated keyboard interface lines until the interface is cleared, or a subsequent diagnostic write keyboard port pins alters them. ## Write Shared RAM (X'1R') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating acceptance of the command. The associated data byte is written to the SRAM address specified by the low 4 bits of the command byte, which address the read/write shared RAM addresses X'00' through X'0F'. ## **Extended Command Descriptions** ### Read Shared RAM (X'00' - X'1F') The adapter acknowledges the command by returning an interrupt ID 3 and an associated data byte containing the contents of the SRAM address specified by bits 4-0 of the extended command byte. The command permits system software to read any single byte of read/write or read-only shared RAM addresses '00' through '1F'. ### Reset Mode Bit (X'20' - X'2F') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted 51 Command rejected - illegal mode (M10=0) If the command is accepted, the designated mode bit in shared RAM is cleared (set to 0). The mode bit is determined by the decimal value of the extended command byte bits 3-0. Resetting of mode bit M11 may only be done while in diagnostic mode (M10=1), else the command is rejected. ### **Set Mode Bit (X'30' - X'3F')** The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating acceptance of the command. The designated mode bit in shared RAM is set to 1. The mode bit affected is determined by the decimal value of the extended command byte bits 3-0. ## Initialize Speaker Volume (X'40' - X'43') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating acceptance of the command. The speaker volume controls, and the associated mode bits 8 and 9, are set according to the specific command: | X'40' | Speaker volume = Off; $M9,M8 = 00$ | |-------|---------------------------------------| | X'41' | Speaker volume = Low; $M9,M8 = 01$ | | X'42' | Speaker volume = Medium; $M9,M8 = 10$ | | X'43' | Speaker volume = High; $M9,M8 = 11$ | The volume controls remain set until altered by a subsequent initialize speaker volume command, set and reset of mode bits 8 or 9, or an adapter reset. Volume commands are immediately executed, volume is not a queued parameter. ## Terminate Speaker and Reset Duration (X'44') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating the current state of the speaker: Speaker was already inactive (S1=0); no action taken O3 Speaker was active and has been terminated Speaker termination clears status bits S0 and S1, clears the speaker duration ticks in SRAM addresses 13 and 14, and quiesces the adapter's speaker frequency input signal (allowing other features to control the speaker frequency). Status bit S7 is set off, indicating no speaker command queued. Any values in SRAM addresses '01', '02', '15', and '16' are not affected. ## Set Scan Count for System Attention Keystroke Sequence (X'5S') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational Code indicating acceptance or rejection of the command: 00 Command accepted 50 Command rejected - invalid count specified If the command is accepted, the indicated scan count S is set in SRAM address '17' and the system attention keystroke sequence state is reset. The extended command byte bits 3-0 are interpreted as a scan count for the system attention keystroke sequence. Valid values for S are: 1, 2, 3 (default). ### Execute 8051 Soft Reset (X'60') If the adapter is not in diagnostic mode (M10=0), the command is rejected by returning an interrupt ID 0 with an informational code of X'51', illegal mode. If the adapter is in diagnostic mode (M10=1), then an abnormal end code condition is forced. An interrupt ID 7 with an abnormal end code of X'A0' is returned to the system, plus two additional bytes, each with an interrupt ID 7. The adapter will then re-initialize the 8051, perform the self-tests, and report the self-test completion code with an interrupt ID 6. At the conclusion of this command, the adapter is in normal operations with SRAM set to the defined defaults and the device interfaces cleared. (Refer to 5-128) for abnormal end codes. ## Force System Reset (X'61') If the adapter is not in diagnostic mode (M10=0), the command is rejected by returning an interrupt ID 0 with an informational code of X'51', illegal mode. If the adapter is in diagnostic mode (M10=1), an immediate system reset is forced. This command performs the identical function initiated by the system reset special keystroke sequence. Note: System software issuing this command will be terminated! ## Force System Attention Interrupt (X'62') If the adapter is not in diagnostic mode (M10=0), the command is rejected by returning an interrupt ID 0 with an informational code of X'51', illegal mode. If the adapter is in diagnostic mode (M10=1), an immediate system attention interrupt is forced. This command performs the identical function initiated by the system attention special keystroke sequence except that a scan code is not queued, nor placed in SRAM address '1A'. This command ends by returning an interrupt ID 0 with an informational code of X'00'. ### Diagnostic Sense Keyboard and UART Port Pins (X'70') If the adapter is not in diagnostic mode (M10=0), the command is rejected by returning an interrupt ID 0 with an informational code of X'51', illegal mode. If the adapter is in diagnostic mode (M10=1), then an interrupt ID 3 is returned with an associated data byte defined as follows: **Bit 0** = UART Receive Data (RXD) input signal Bit 1 = 0 Bit 2 = Keyboard Clock In input signal Bit 3 = Keylock Switch input signal Bit 4 = 0 Bit 5 = Keyboard Data In input signal Bit 6 = 0Bit 7 = 0 ### Dump Adapter Shared RAM (X'80' and X'81') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted 60 Command rejected - RAM queue is busy with prior dump command If the command is accepted, then a 16-byte block of shared RAM is queued for transmission to the system. Command X'80' queues the read/write SRAM addresses X'00' - '0F'; command X'81' queues the read-only" SRAM addresses X'10' - '1F'. When the queued block is ready for transmission to the system, an interrupt ID 4 with an associated data byte containing the byte-count (16) is returned. Then each SRAM byte is returned, in sequence, with an interrupt ID 3. Subsequent dump adapter SRAM or dump RAS log commands are rejected until the currently queued block has been transmitted. ## Dump RAS Logs...With/Without Reset (X'82' and X'83') The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code indicating acceptance or rejection of the command: 00 Command accepted 60 Command rejected - RAM queue is busy with prior dump command If the command is accepted, then a 12-byte block of RAS logs information (SRAM addresses X'20' - '2B') is queued for transmission to the system. When the queued block is ready for transmission to the system, an interrupt ID 4 with an associated data byte containing the byte-count (12) is returned. Then each SRAM byte is returned, in sequence, with an interrupt ID 3. After the block has been transmitted. SRAM addresses X'20' - '2B' are zeroed if the operation was initiated with Command X'82'. Otherwise, SRAM is not affected. Subsequent dump adapter SRAM or dump RAS logs commands are rejected until the currently queued block has been transmitted. ## **Restore Initial Conditions (X'90')** The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating completion of the command. Shared RAM addresses X'00' thru X'1B' are initialized to the defined default conditions. The speaker command queue is cleared and any active speaker operation is terminated. All queued keyboard and locator input data is cleared and the respective interface controls reset to initial conditions. This command does not affect RAS logs nor the attached keyboard and locator devices. The 8051 self-tests are not performed. This command will not clear certain types of information which may be, or have been, queued for transmission to the system (such as error code, status report informational code, requested RAM block). ### Read 8051 Release Marker (X'E0' - X'EF') The adapter acknowledges the command by returning an interrupt ID 3 and an associated data byte containing the contents of the selected release marker byte in 8051 ROM. The particular byte is specified by bits 3-0 of the extended command byte. Each command allows system software to read the corresponding single byte of the 16-byte release marker field defined as follows: | Bytes $0 - 2$ : $VVV =$ | Version number of 8051 code (3-character ASCII) | | |-------------------------|-------------------------------------------------------------|--| | Bytes 3 - 7: YYDDD = | Date of 8051 Version, Year & Julian Day (5-character ASCII) | | | Bytes 8 - 11: SSSS = | Reserved field (binary zeroes) | | | Bytes 12 - 13: KK = | Reserved field (binary zeroes) | | | Bytes 14 - 15: ZZ = | Check sum on entire 8051 ROM (16-bit binary number) | | | NOP (X'F0' - X'FF') | | | The adapter acknowledges receipt of the command with an interrupt ID 0 and an informational code of X'00' indicating acceptance of the command. The low 4 bits of the extended command byte are ignored. This command performs no other function. # **Adapter Shared RAM** | SRAM<br>Address | Read/Write Shared RAM Data | Number of Bytes | Initialized<br>Value | |-----------------|------------------------------------------------------------------------------|-----------------|----------------------| | 00 | Keyboard acknowledge byte | 1 | FA | | 01 - 02 | Pending speaker duration ticks | 2 | 0000 | | 03 | Keyboard resend command | 1 | FE | | 04 | Keyboard break code | 1 | F0 | | 05 | Maximum retry count before a keyboard hard error is reported | 1 | 08 | | 06 | Keyboard echo command | 1 | EE | | 07 | Click duration | 1 | 36 | | 08 | Click Suppress Scan Code 1 | 1 | 12 | | 09 | Click Suppress Scan Code 2 | 1 | 59 | | 0A | Click Suppress Scan Code 3 | 1 | 39 | | 0B - 0C | Click frequency - high/low | 2 | 0896 | | 0D | Keystroke initiate system attention - scan 1 Also click suppress scan code 4 | 1 | 11 | | SRAM<br>Address | Read/Write Shared RAM Data | Number of Bytes | Initialized<br>Value | |-----------------|------------------------------------------------------------------------------|-----------------|----------------------| | 0E | Keystroke initiate system attention - scan 2 Also click suppress scan code 5 | .1 | 19 | | 0F | Keystroke initiate system attention - scan 3 (default = any scan match) | 1 | FF | # Modes and Status Bits in Shared RAM | SRAM<br>Address<br>Bit<br> | M/S<br>Bit# | Adapter Mode and Status Bits | Initialized<br>Value | |----------------------------|-------------|--------------------------------------------------------------------------------|----------------------| | 10.0 | M0 | Report receipt of keyboard acknowledgment byte with an informational interrupt | 0=No | | 10.1 | M1 | Report completion of UART transmit with an informational interrupt | 0=No | | 10.2 | M2 | Report keylock switch change with an informational interrupt | 0=No | | 10.3 | M3 | Report completion of speaker tone with an informational interrupt | 1=Yes | | SRAM<br>Address<br>Bit | M/S<br>Bit# | Adapter Mode and Status Bits | Initialized<br>Value | |------------------------|-------------|------------------------------------------------------|----------------------| | 10.4 | M4 | Unassigned | 0 | | 10.5 | M5 | Blocking of received UART bytes is active | 1=Yes | | 10.6 | M6 | System attention keystroke sequence search is active | 1=Yes | | 10.7 | M7 | Suppress click for defined scan code set | 0=No | | 11.0 | <b>M</b> 8 | Speaker volume bit 0 | 0=MED | | 11.1 | M9 | Speaker volume bit 1 | 1=MED | | 11.2 | M10 | Diagnostic mode is in effect | 0=No | | 11.3 | M11 : | Keyboard interface is enabled with clear | 1=Yes | | 11.4 | M12 | UART interface is enabled with clear | 0=No | | 11.5 | M13 | Honor keylock switch | 1=Yes | | 11.6 | M14 | Inhibit keystroke auto-click | 0=No | | 11.7 | M15 | Ignore UART input | 0=No | | 12.0 | S0 | Speaker frequency timer busy | 0 | | SRAM<br>Address<br>Bit | M/S<br>Bit# | Adapter Mode and Status Bits | Initialized<br>Value | |------------------------|-------------|------------------------------|----------------------| | 12.1 | <b>S</b> 1 | Timeout timer busy | 0 | | 12.2 | S2 | Keylock switch is set | (sw val) | | 12.3 | <b>S</b> 3 | Keyboard transmit is busy | 0 | | 12.4 | <b>S</b> 4 | UART transmit is busy | 0 | | 12.5 | <b>S</b> 5 | Click busy | 0 | | 12.6 | <b>S</b> 6 | Unassigned | 0 | | 12.7 | <b>S</b> 7 | Speaker queue full | 0 | ## **Notes:** - 1. Mode bits may be altered using the set/reset mode bit command. Status bits are read-only. Mode bits 0-3 enable the corresponding bits in the status report informational codes (refer to 5-128). - 2. Setting mode bit 11 or 12 clears the keyboard or UART interface, respectively, even if the mode bit was already set. Mode bit 11 may be cleared only in diagnostic mode. The keyboard interface should not normally be disabled. - 3. Mode bit 15 = 1 causes the adapter to discard all data received by the UART port. # **Read Only Shared RAM** | SRAM<br>Address | Read Only Shared RAM Data | Number of Bytes | Initialized<br>Value | |-----------------|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------------| | 13 - 14 | Active speaker duration ticks remaining | 2 | 0000 | | 15 - 16 | Pending speaker frequency - high/low | 2 | 0000 | | 17 | Scan count for system attention keystroke sequence (maximum number of scan codes is 3) | 1 | 03 | | 18 | Keystroke sequence state High 4 bits = system attention sequence state Low 4 bits = system reset sequence state | 1 | 00 | | 19 | UART framing: MSB = odd/even parity control (1=odd) Low 3 bits = blocking factor (2 to 6 valid) | 1 | 84 | | 1A | System attention scan code - actual third byte received in a 3-byte sequence | 1 | 00 | | 1B | UART baud rate (counter reload value) defaults to 9600 bps. See note3. | 1 | FB | | 1C | Actual 8051 self-test completion code (value indicated is for the good machine). See note 2. | 1 | AE | | 1D - 1E | 8051 abnormal end information | 2 | 0000 | | 1F | Error code for most recent interrupt ID 7. See note 1. | 1 | 00 | ## **Notes:** - 1. Refer to "Adapter Error Codes Returned to System" on page 5-128. - 2. Refer to the "Adapter Self-Test After a Power-On, System, or Adapter Reset" on page 5-126. - 3. Refer to the "Set UART Baud Rate" on 5-104. # **RAS Logs in Shared RAM** | SRAM<br>Address | Read Only Shared RAM Data - RAS Logs | Number of Bytes | |-----------------|-----------------------------------------------------------------------------------------|-----------------| | 20 - 21 | Number of keyboard frames received divided by 16 (not a keystroke count) | 2 | | 22 - 23 | Number of keyboard receive retries performed (includes those resulting in hard errors) | 2 | | 24 | Number of keyboard receive hard errors | 1 | | 25 | Number of keyboard frames transmitted | 1 | | 26 | Number of keyboard transmit retries performed (includes those resulting in hard errors) | 1 | | 27 | Number of keyboard transmit hard errors | 1 | | 28 - 29 | Number of UART frames (bytes) received divided by 16 | 2 | | 2A | Number of UART frames transmitted | 1 | | 2B | Number of UART receive errors (number of frames received with bad parity) | 1 | ## **Notes:** - 1. Logs are read-only via the dump RAS logs commands. All counters are cleared upon completion of the dump RAS logs with reset command, or an 8051 reset. - 2. Each counter is an 8-bit or 16-bit binary value. Due to the large number of keyboard or UART frames received, those two counters are incremented only once per 16 frames received. # **Adapter Speaker Control** The speaker resides in the keyboard. However, the speaker is not controlled by the keyboard. It is completely controlled and powered by two signal wires through the keyboard cable to the system board. The speaker interface on the system board contains circuits to control the volume of the frequency signal. Both the adapter and the system's Coprocessor feature have access to that speaker interface, but only the adapter controls volume. The adapter implements the logical speaker functions used by system software, including frequency, duration, and volume parameters. The speaker functions are command-driven and queued. The adapter also implements a keystroke click tone for the keyboard. # **Sharing of Speaker Input With Coprocessor** The Coprocessor can activate the speaker signal through the interface circuits on the system board. This is a digital oscillator signal that is changing state at the rate for which the speaker is to be driven. This signal is 'ORed' with a similar signal from the adapter. The quiescent state of the signal is a high voltage level (logical 1). Either the adapter or Coprocessor can pull it low. No form of interlocking is provided to prevent one source from driving the speaker signal while the other source is driving it. The Coprocessor has no access to the volume control circuits in the speaker interface. # **Speaker Frequency Control** The speaker frequency is set by system software. Commands send a 2-byte count value to the adapter. The adapter uses the count value to initialize internal counters, which control a speaker frequency signal driving the adapter's input to the speaker interface 'OR' circuit. System software sends the count value to the adapter using the set speaker frequency commands with high byte and low byte values sent separately. The permissible range of the count value provides a speaker input frequency range from a maximum of 12.019 Hz to a minimum of 23 Hz. The 2-byte count value used by the adapter is related to the generated speaker frequency according to the following formulas: ## Where: Cx = Count value, high byte Ct = Count value, low byte log = Base 2 logarithm function F = Desired speaker frequency (Hz) OSC = 8051 oscillator frequency (Hz) [N] = The exponent on the number 2 where the brackets mean that N is to be rounded to an integer and if [N] > 0, then use [N], else use 0 K0 = 3.7 (a constant) K1 = 9.25 (another constant) #### Limitations: Cx = Element of the set: (1, 2, 4, 8, 16, 32, 64) Ct = Integer in the range [19, 255] for Cx = 1 or, in the range [120, 255] otherwise ## Exception: A Cx value of 0 provides a silent tone. See the following note. Example: For the assumed OSC frequency of 9.216 MHz, the formulas for Cx and Ct can be simplified and tabulated as follows: | Frequency Range (Hz) | Cx (Dec) | Ct Formula | | |----------------------|----------|----------------------|--| | | | | | | 23 - 45 | 64 | ( 6000 / F) - 9.31 | | | 46 - 90 | 32 | ( 12000 / F) - 9.37 | | | 91 - 181 | 16 | ( 24000 / F) - 9.48 | | | 182 - 362 | 8 | (48000 / F) - 9.71 | | | 363 - 724 | 4 | (96000 / F) - 10.18 | | | 725 - 1432 | 2 | (192000 / F) - 11.10 | | | 1433 - 12019 | 1 | (384000 / F) - 12.95 | | **Note:** A timed period of silence may be obtained by setting the frequency count value to 0. Specifically, if the frequency - high byte Cx = 0, then the low byte Ct is ignored. The speaker operation is executed exactly as for any valid frequency, except that the frequency signal pin from the 8051 to the speaker is held in its quiescent state. # **Speaker Duration Control** A speaker tone duration is specified by the system as the number of duration ticks where each duration tick is 1/128 of a second. Duration ticks are specified as a 15-bit number with a permissible range from 0 to 32,767, X'0000' through X'7FFF'. The actual number of duration ticks is one greater than the number specified, providing a tone duration from 7.8 milliseconds to 256 seconds. System software must first specify the tone duration-high byte, then issue the write to speaker command specifying the duration-low byte. # **Speaker Volume Control** The adapter controls the speaker volume for both the adapter's use of the speaker and the Coprocessor feature's use. System software must ensure that only one source is driving the frequency control. In either case, system software must use the adapter function to specify speaker volume. Four levels of volume are available: off, low, medium, and high. The adapter initializes itself after a reset to medium. System software may alter this setting at any time. The adapter retains the last setting in 8051 shared RAM mode bits 8 and 9 as follows: | M9, 8 | Volume | |-------|------------------| | | | | 00 | Off | | 01 | Low | | 10 | Medium (Default) | | 11 | High | # **Speaker Command Queue Description** Execution of the Write to Speaker command is queued if the speaker facilities are busy doing a click or a previous speaker command. Speaker commands are rejected if a Write to Speaker is currently queued. The queue consists of one set of parameters, frequency and duration. When speaker parameters are written to the adapter, they are initially pending. They become active when speaker facilities are available. A keystroke click occurs only if speaker facilities are immediately available. The click is not queued. Speaker volume is a global parameter under user control. As such, it is not queued. Speaker Volume commands are immediately executed. ## **Speaker Command Queue Operation** Commands to set frequency (high and low bytes) and duration (high byte) place these parameters in the queue as pending. The commands are rejected if the queue is full. The Write to Speaker command places the duration (low byte) parameter in the queue, with an implied request to activate the speaker using the pending parameters. The command is rejected if the queue is full. Normal response to Write to Speaker is either speaker started or parameters queued. ## **Speaker Command Queue Implementation** Speaker command queueing uses the following adapter resources: SRAM Address 01-02 = Pending duration high/low (Active duration is maintained in SRAM Address 13-14) • SRAM Address 15-16 = Pending frequency high/low (Active frequency kept in private RAM) - Status bit S7 defined as speaker queue full - Status report informational code bit 3: set on if speaker parameters (frequency or duration) are invalid... - When a keystroke click occurs (frequency only) - When the pending speaker command is dequeued. Note: Parameters are not validated until actually activated. # **Keystroke Click Description** The keyboard does not provide an acoustical feedback for a key being depressed. Instead, the adapter provides a keystroke auto-click function which generates a click tone whenever a valid scan code is received from the keyboard. The resulting clicks only represent a replacement for a mechanically generated keyboard click. The adapter-generated click only means that the adapter has received a valid scan code and queued it to the system. The click cannot be interpreted to mean that the system software has received the keystroke. ## **Keystroke Click Operation** The keystroke auto-click function defaults to active. It can be disabled by setting mode bit M14 on. The click defaults to a 301 Hz tone for 1.68 milliseconds. The click frequency and duration can be specified by system software. A keystroke click is initiated only when the adapter receives the make of any valid scan code and queues it to the system. Valid scan codes are those in the range X'01' thru X'9F'. If the byte received from the keyboard is a break code, then the next byte received will not initiate a click. If the keystroke queue is full when a keyboard byte is received, the adapter replaces the last byte in the queue with the overrun code X'00', discards the current byte received, and does not initiate a click. #### **Keystroke Click Implementation** Keystroke auto-click uses the following adapter resources: - SRAM Address X'07' = Click duration - SRAM Address X'0B-0C' = Click frequency - Mode Bit M14 defined as inhibit keystroke auto-click - Status report informational code bit 3 is set on if the click frequency in SRAM is invalid when the keystroke auto-click is initiated The click duration is specified by SRAM address X'07' as a count of 30.52 microsecond ticks. The count in SRAM is an 8-bit number. The actual number of duration ticks is one greater than the number specified in SRAM, providing a range of click durations from 30.52 microseconds to 7.8 microseconds in 30.52 microsecond increments. The click frequency is specified by SRAM addresses X'0B' and X'0C'. These two bytes are used as the frequency counter values Cx and Ct, respectively. They are interpreted by the adapter exactly as for any other speaker frequency. They must adhere to the same rules as specified in the paragraph "Speaker Frequency Control". Cx=0 is invalid, click cannot be the silent tone. If an invalid click frequency is written to SRAM and the adapter attempts to click due to a keystroke, no click occurs. An unsolicited status report informational code byte with bit 3 on is posted to the system. ## Click Suppression for Defined Scan Code Set The keystroke auto-click function may be suppressed for a definable set of five scan codes by setting mode bit M7 = 1. The default set of scan codes is defined by the five SRAM addresses X '08' through '0A', '0D' and '0E'. (The last two locations also define the system attention sequence.) A scan code may be deleted from the suppress set by setting its corresponding SRAM location to X 'FF'. ## **Keystroke Click Interference With Other Speaker Operations** No click occurs if the adapter's speaker facilities are busy with a previous speaker command when a click is initiated. Conversely, if the speaker is busy with a click and the system issues a Write to Speaker command, then the parameters for that command are queued and activated when the click completes. The adapter has no knowledge of the Coprocessor using the speaker. Consequently, if the Coprocessor is using the speaker and the adapter issues a click, the sound observed is a collision of the Coprocessor-generated tone and the click tone. # **Adapter RAS and Security Functions** The following are RAS and security functions supported by the adapter. # **Keylock Switch Support** When the keylock switch is on, the adapter does the following: - Inhibit keyboard input - Inhibit UART device input (from locator) - Inhibit writes to the keyboard and UART devices. The adapter conditionally informs the system of changes in the keylock switch setting with a status report informational code (refer to 5-128). System software can override the keylock switch on by resetting mode bit 13 (M13=0). Note: When the system is turned on, system ROM code queries the the keylock switch state during initialization and takes appropriate action if found on. # **Detection of Special Keystroke Sequences** As keystrokes pass from the keyboard to the system through the adapter, the adapter searches for two special sequences of scan codes. One sequence causes the adapter to initiate a system reset and the second sequence initiates a system attention interrupt. The scan codes received by the adapter are always presented to the system with an interrupt ID 1. ## **Initiate System Reset** The adapter searches incoming keystrokes for the special sequence as follows: - 1. Scan Code X'11' - 2. Scan Code X'19' - 3. Scan Code X'62' The first two keys must be make/break type. The first two scan codes may appear in either order. When the sequence is detected, an immediate system reset is initiated. The sequence search is always active (except when the keylock switch is on). However, if system software has disabled the keyboard interface with M11=0, or has issued a command to the keyboard which disables scanning, no keystrokes are received by the adapter and the sequence search is effectively disabled. ## **Initiate System Attention Interrupt** The adapter searches incoming keystrokes for the special sequence whose default is as follows: - 1. Scan Code X'11' - 2. Scan Code X'19' - 3. Match on any scan code other than X'62' The first two keys must be make/break type. When the sequence is detected, an immediate system attention interrupt is initiated. The sequence search can be disabled by system software setting mode bit M6 off. When enabled, the sequence search is always active (except when the keylock switch is on, or if system software has disabled the keyboard interface with M11=0, or has disabled keyboard scanning). The system can alter the keystroke sequence searched, and the length of the sequence can be 1, 2, or 3 keystrokes. Read/write SRAM defines the three scan codes. - If the sequence length is 2 or 3, then the first two scan codes may appear in either order. - If the sequence length is 3 and scan 3 in SRAM = 'FF' (default conditions), then the sequence detection is satisfied when any third scan code is received (other than a break code). - The third scan code received of a length-3 sequence is always placed in Read-Only SRAM address X'1A' before the system attention interrupt is initiated by the adapter. # **Diagnostic Wraps** Certain adapter port signals are diagnostically sensed through the following mechanisms: - Extended command X'70' - · Reading 8255 PB Port. Adapter command byte bit 5 = 1 causes the UART TxD signal to be wrapped to the UART RxD on the system board 8051 pins. To wrap a byte, use adapter command Write UART - Control (X'23') with any desired data byte. That data byte will then be read at the UART RxD pin and posted to the system with an interrupt ID 2. # Adapter Self-Test After a Power-On, System, or Adapter Reset The following 8051 facilities are tested: - ROM check-sum - RAM - Internal registers. As the tests in this self-test series are executed, a bit-significant completion code is generated. The code is initialized to 51 and, as each test completes, the corresponding bit is complemented if the test was successful. Tests are executed and bits are complemented from most to least significant with bit meanings as follows: | Bit 7: | Reset initiation indicator | 1 = initiated by hardware reset* | |--------|-----------------------------|----------------------------------| | Bit 6: | Accumulator and PSW test | 0 = test passed ok | | Bit 5: | ROM check sum test | 1 = test passed ok | | Bit 4: | RAM test with AA data | 0 = test passed ok | | Bit 3: | RAM test with 55 data | 1 = test passed ok | | Bit 2: | RAM test - addressing | 1 = test passed ok | | Bit 1: | RAM test with 00 data | 1 = test passed ok | | Bit 0: | Control regs check sum test | 0 = test passed ok | | | | | Thus, if all tests pass successfully, the resultant completion code is X'AE'. The completion code is stored in read-only shared RAM address X '1C' and posted to the system in the 8255 with an interrupt ID 6. <sup>\*</sup> A hardware reset is initiated by a system power-on, system reset, or adapter reset. If bit 7 = 0, then the self-test was initiated by the 8051 having ended abnormally. (Refer to 5-128.) # **Diagnose Functions Executed on System Command** - Execute 8051 soft reset (extended command X'60'), force abnormal end code X'A0', perform self-tests, and report the completion code with an interrupt ID 6 - Force system reset (extended command X'61') - Force system attention interrupt (extended command X'62'). # **Adapter Informational Codes Returned to System** The data byte associated with interrupt ID 0 is an informational code. Informational codes are classified as: - Acknowledgment - Command reject - · Status report. ## **Acknowledgement Informational Codes** One of the following codes is returned as the data byte associated with interrupt ID 0 to acknowledge receipt of an adapter command from the system. - 00 = host cmnd ack - 01 = speaker started - 02 = speaker inactive - 03 = speaker terminated - 04 = speaker parameters queued ## **Command Reject Informational Codes** If the adapter rejects a command from the system, it returns one of the following codes as the data byte associated with Interrupt ID 0. | <b>Command Handler Issuing:</b> | |---------------------------------| | | | Write Keyboard OP | | Write Keyboard OP, and | | Write UART OP | | Write Keyboard OP | | Write Keyboard OP | | Write Speaker OP | | Write Speaker OP | | Write Speaker OP | | Write UART OP | | Write UART OP | | | 4D = invalid baud 4E = invalid framing 50 = invalid count 51 = illegal mode 60 = RAM queue busy Set UART Baud Rate OP Initialize UART Framing OP Set Sequence a Length OP Diagnose OP, and Diagnostic Sense OP Dump RAM Block OP 7F = undefined op ## **Status Report Informational Codes** The adapter may send an unsolicited status report informational code to the system with interrupt ID 0. A status report is distinguished from acknowledgement and command reject codes by having the most significant bit of the byte set on. The remaining bits of the status report byte are bit-significant. The bits are defined as follows: Bit 7 = 1 (Status Report Identifier) Bit 6 = speaker tone completed conditioned by M3=1 Bit 5 = keyboard returned ack conditioned by M0=1 Bit 4 = keylock switch changed conditioned by M2=1 Bit 3 = invalid speaker parameter (click or queued freq or dura) Bit 2 = UART transmit complete conditioned by M1=1 Bit $1 = RAS \log near$ overflow Bit $0 = RAS \log overflowed$ . # **Adapter Error Codes Returned to System** The data byte associated with interrupt ID 7 is an error code. Error codes are classified as: - · Abnormal end codes - · Device error codes. ## **Abnormal End Codes** ## Explanation The adapter has detected an unrecoverable error condition and terminated normal operations. The data byte (abnormal end code) provides the nature of the specific condition detected. When the abnormal end code has been read by the system, two additional bytes are provided by the adapter with an interrupt ID 7 which define the 8051 microcode address which detected the condition. After the microcode address has been transferred to the system, or if the 8051 times out waiting for the system, the 8051 will re-initialize itself and attempt to restore normal operations. The 8051 shared RAM is reset to its default state. After the soft reset self-test has been performed by the 8051, the completion code is reported with an interrupt ID 6. The high order bit of the completion code will be off, indicating a soft reset of the 8051 rather than a hardware initiated reset. ## System Action Required When the system software detects an abnormal end code, it should prepare to receive the subsequent two codes (8051 address). That information should be logged as an incident. Re-initialize the 8051 shared RAM, if any of the defaults had been previously altered. If an abnormal end code immediately re-occurs, the system should issue an adapter reset operation. #### Codes A0 = Diagnose initiated 8051 Soft Reset A1 = Work queue low decode A3 = Host transmit queue decode A4 = Incr RAS log decode A6 = Wild branch A7 = System reset failed #### **Device Error Codes** ## Explanation An unexpected condition has been detected by the 8051 microcode at a device interface. The problem may not be with the device itself. The Adapter will attempt to continue normal operations. ## System Action Required The device error code information should be logged as an incident. The system may have to issue some kind of device reset command to try and clear the condition. A particular device error code may suggest a recovery procedure. If the condition persists, the system should issue an adapter reset operation. #### Codes ## E0 = Keyboard Transmit Timeout Adapter has started to transmit a frame to the keyboard. Transmission of that frame exceeded the maximum allowed time. The keyboard interface has been cleared and re-enabled. The keyboard Echo command could be issued to test the circuits to the keyboard and back. If the condition continues, the keyboard may have been unplugged. ## E1 = Keyboard Receive Timeout The adapter has started to receive a frame from the keyboard. Reception of that frame exceeded the maximum allowed time. The keyboard interface has been cleared and re-enabled if Mode bit 11 = 1. The keyboard Echo command could be issued to test the circuits to the keyboard and back. If the condition continues, the keyboard may have been unplugged. #### E2 = Kbd Ack Not Received An acknowledgement response was expected from the last transmission to the keyboard, but something other than an acknowledgement was received. The actual keyboard response byte has been queued to the system. The most likely problem is that the keyboard rejected the command or parameter byte sent to it. ## E3 = Unexpected Kbd Ack Received An unexpected acknowledgement response was received from the keyboard. It was unexpected because a prior transmission had not been performed by the adapter. ## E4 = Hard Error on Kbd Frame Receive The adapter has unsuccessfully performed the maximum number of keyboard frame receive retries. The frame received has a solid framing error. The keyboard interface is enabled for further communication. #### E5 = Hard Error on Kbd Frame Transmit The adapter has unsuccessfully performed the maximum number of keyboard frame transmit retries. The keyboard has responded with a solid error condition (resend) due to the keyboard receiving an invalid frame. The keyboard interface is enabled for further communication. #### E6 = Khd Clock Pin Not Plus (See following E7 explanation) #### E7 = Kbd Clock Pin Not Minus The adapter has attempted to release or hold the clock signal to the keyboard. The read-back of the clock line signal did not verify. If this condition persists, it may indicate a failed interface circuit. It may also be due to spurious noise on the cable, or the keyboard may have been unplugged. The adapter attempts to continue the operation. ## E8 = UART Interrupt Without TIRI A serial port interrupt occurred without a transmit or receive identifier. The interrupt is ignored and processing continues. #### E9 = UART Transmit Timeout The 8051 serial port buffer was loaded for transmission to the UART device. Transmission exceeded the maximum allowed time. Processing continues. A UART device wrap command could be issued. If the condition continues, the UART device may have been unplugged, or the 8051 serial port is bad. ## EA = UART Ack Timeout The 8051 serial port transmitted the byte to the UART device. The device did not respond within the maximum allowed time. Processing continues. Other device commands could be issued. If no response, the device may have been unplugged. # **Adapter Device Support Notes** The information in this section supplements that in the respective keyboard and locator sections of this manual. ## **Keyboard Commands** Resend (X'FE') The system should not issue this command. The function is handled internally by the adapter's retry facility. Echo (X EE') The adapter passes the keyboard response to the system. # **Keyboard Outputs** Resend (X'FE') The adapter intercepts this output and handles it in the adapter's retry facility. The X'FE' is not passed on to the system. Command Reject (X'FC') The adapter posts the X'E2' device error code and the byte received from the keyboard (X'FC') to the system. Acknowledgment (X'FA') The adapter intercepts this output and reports the occurrence of the acknowledgment only if mode bit 0 = 1. Overrun (X'00) The adapter also returns an overrun (X'00') if keystrokes fill the adapter's 5-byte FIFO queue. # **Locator Device Support Notes** Adapter Command: Write UART - Control (X'03') All UART device commands not having a defined response must be issued with the Write UART -Control command to the adapter. This includes the following mouse commands: - Enable - Disable - Set wrap mode - Reset wrap mode - Reset exponential scaling - Set sampling speed - Set incremental stream mode - Set remote data mode. Adapter Command: Write UART - Query (X'04') All UART device commands having a defined response must be issued with the Write UART -Ouery adapter command. The following mouse commands, with the required mode bit 5 setting, should be issued with the Write UART - Query adapter command: - Reset (M5=1) - Read configuration (M5=0) - Read X, Y data (M5=1) - Ouery status (M5=1). The blocking factor in shared RAM address X'19' must define a 4-byte report for the mouse. When the mouse is in wrap mode, subsequent bytes to be wrapped to the mouse must be written to the adapter using Write UART - Query with M5=0. While in wrap mode, the mouse accepts any parity value and returns the parity bit to the adapter as received. The system can control how the adapter generates parity sent to the mouse (and checks the parity returned from the Mouse) by setting shared RAM address X'19' (MSB) appropriately. # **Adapter Design Notes** Figure 5-56 on page 5-134 shows the adapter components and the system interface. The Model 10, Model 20, and Model 25 use a 9.216 MHz oscillator to drive the 8051 oscillator input. Figure 5-57 on page 5-135 shows the interface logic for keyboard and speaker signals between the 8051 and the connector to the keyboard. (The speaker is mounted within the keyboard covers.) Figure 5-58 on page 5-136 shows the interface logic for locator signals between the 8051 and the connector to the locator. Also shown in the interface figures are the points where signals are wrapped to the 8255 Port B inputs for diagnostic sensing. Figure 5-56. Adapter Logic and System Interface Figure 5-57. Adapter-to-Keyboard Connector Interface Figure 5-58. Adapter-to-Locator Connector Interface # 8051 Pin Assignment | Pin<br>Number | Port/Bit | In/<br>Out | 8051<br>Function | Adapter Function | |---------------|----------|--------------|------------------|------------------------------------------| | | | | | | | 39 | 0.0 | В | | +I/O buffer bit 0 | | 38 | 0.1 | В | | +I/O buffer bit 1 | | 37 | 0.2 | В | | +I/O buffer bit 2 | | 36 | 0.3 | $\mathbf{B}$ | | +I/O buffer bit 3 | | 35 | 0.4 | B | | +I/O buffer bit 4 | | 34 | 0.5 | В | | +I/O buffer bit 5 | | 33 | 0.6 | В | | +I/O buffer bit 6 | | 32 | 0.7 | В | | +I/O buffer bit 7 | | 1 | 1.0 | ·I | | +System data bus bit 8 buffered | | 2 | 1.1 | I | | +System data bus bit 9 buffered | | 3 | 1.2 | I | | +System data bus bit 10 buffered | | 4 | 1.3 | I | | +System data bus bit 11 buffered | | 5 | 1.4 | I | | +System data bus bit 12 buffered | | 6 | 1.5 | I | | +Keylock switch | | 7 | 1.6 | Ο | | +Speaker volume bit 0 | | 8 | 1.7 | O | | +Speaker volume bit 1 | | 21 | 2.0 | O | | +8255 PC bit $0 = $ interrupt ID bit $0$ | | 22 | 2.1 | O | | +8255 PC bit $1 = $ interrupt ID bit $1$ | | 23 | 2.2 | Ο | | +8255 PC bit 2 = interrupt ID bit 2 | | 24 | 2.3 | О | | -Initiate system reset | | 25 | 2.4 | 0 | | -Strobe to input buffer | | 26 | 2.5 | I | | +Input buffer full | | 27 | 2.6 | 0 | | -Gate output buffer to 8051 | | 28 | 2.7 | Ο | | +Speaker frequency | | 10 | 3.0 | <b>I</b> | RXD | UART (locator) receive data bit | | 11 | 3.1 | O | TXD | UART (locator) transmit data bit | | 12 | 3.2 | I | -INTO | +Keyboard clock in | | Pin<br>Number | Port/<br>Bit | In/<br>Out | 8051<br>Function | Adapter Function | |---------------|--------------|------------|------------------|--------------------------------------| | | | | | | | 13 | 3.3 | <b>I</b> . | -INT1 | -Output buffer full | | 14 | 3.4 | I | T0 | 32,768 Hz clock | | 15 | 3.5 | . I | (T1) | +Keyboard data in | | 16 | 3.6 | O O | (WR) | +Keyboard data out | | 17 | 3.7 | • | (RD) | +Keyboard clock out | | 9 | | I | RST | +8051 reset | | 18 | | I | XTAL2 | Oscillator | | 19 | | I | XTAL1 | | | 20 | | P | VSS | Ground | | 29 | | 0 | (PSEN) | -Initiate system attention interrupt | | 30 | | 0 | ALE | | | 31 | | I | -EA | +5V | | 40 | | P | VCC | +5V | # 8255 Pin Assignment | Pin<br>Number | Port/<br>Bit | In/<br>Out | 8255<br>Function | Adapter Connection | |---------------|--------------|------------|------------------|------------------------| | | | | | | | 34 | | I | D0 | +System data bus bit 0 | | 33 | . * | · 1 | <b>D</b> 1 | +System data bus bit 1 | | 32 | | I | D2 | +System data bus bit 2 | | 31 | | I | D3 | +System data bus bit 3 | | 30 | | I | D4 | +System data bus bit 4 | | 29 | | I | D5 | +System data bus bit 5 | | 28 | | I | D6 | +System data bus bit 6 | | 27 | | I | <b>D</b> 7 | +System data bus bit 7 | | Pin<br>Number | Port/<br>Bit | In/<br>Out<br> | 8255<br>Function | Adapter Connection | |---------------|--------------|----------------|------------------|-----------------------------------| | 4 | PA.0 | В | | +I/O buffer bit 0 | | 3 | PA.1 | В | | +I/O buffer bit 1 | | 2 | PA.2 | В | | +I/O buffer bit 2 | | 1 | PA.3 | В | | +I/O buffer bit 3 | | 40 | PA.4 | В | | +I/O buffer bit 4 | | 39 | PA.5 | В | | +I/O buffer bit 5 | | 38 | PA.6 | В | | +I/O buffer bit 6 | | 37 | PA.7 | В | | +I/O buffer bit 7 | | 18 | PB.0 | Ī | | +UART receive (RxD) | | 19 | PB.1 | I | | +TXDA (system BD serial port A) | | 20 | PB.2 | I | | +RXDA (system BD serial port A) | | 21 | PB.3 | I | | -Timer in (system BD signal) | | 22 | PB.4 | I | | -Interrupt 1 (system BD signal) | | 23 | PB.5 | I | | +Speaker volume bit 0 | | 24 | <b>PB.6</b> | I | | +Speaker volume bit 1 | | 25 | PB.7 | I | | +CPSpeaker/speaker frequency | | 14 | PC.0 | I | | +Interrupt ID bit 0 | | 15 | PC.1 | I | | +Interrupt ID bit 1 | | 16 | PC.2 | I | | +Interrupt ID bit 2 | | 17 | PC.3 | O | INTR | +IRQ | | 13 | PC.4 | I | -STB | -Strobe 8051 data to input buffer | | 12 | PC.5 | Ο | IBF | +Input buffer full | | 11 | PC.6 | I | -ACK | -Gate output buffer to 8051 | | 10 | PC.7 | Ο | -OBF | -Output buffer full | | 6 | | Ι | -CS | -Keyboard chip select | | 5 | | I | -RD | -IOR | | 36 | | I | -WR | -IOW | | 9 | | I | <b>A</b> 0 | +Channel address bit 13 | | 8 | | Ī | A1 | +Channel address bit 14 | | 7 | | P | GND | Ground | | Pin | Port/ | In/ | 8255 | Adapter Connection | |--------|-------|-----|----------|--------------------| | Number | Bit | Out | Function | | | 26 | | P | VCC | +5V | | 35 | | I | RST | +Power on reset | # Channel I/O Device Address Bit Decoding ## Read/Write I/O Subsystem Keyboard Adapter | | MSB | LSI | В | |--------------|---------|--------------------|----------------------------------------| | | | 11 | | | | 543 | 2 1098 7654 3210 | | | | | | | | I/O Address: | 1000 | 0 0100 0000 ORPP | = X'840-' | | Where: PI | P = 825 | PORT ADDRESSING | FOR I/O READ & WRITE | | | PP | IOR | IOW | | | | | | | | 00: | Read PA Reg | Write PA Rea | | | | Read PB Reg | <del>-</del> | | | | Read PC Reg | | | | | | Write Control | | | 11. | Tilegai | write control | | | PA | is defined to be | the adapter data reg. | | | | | the low-order data byte. | | R | = Ada | oter command regis | ster control | | | R | IOR | IOW | | | | | | | | 1: | No Action | No Action | | | 0: | No Action | Latch High Byte in<br>Adapter Register | **Note:** A normal 2-byte write operation to the adapter would have RPP = 000, to I/O address X'8400'. This loads the command and data bytes in their respective registers. ## Selective Reset I/O Subsystem Keyboard Adapter An I/O write to address X'8C60' will set or reset the 8051 selective reset latch. Data bit 2 determines whether the latch is set or reset . . . SET: Data bit=0RST: Data bit=1 When the latch is set, the 8051 is held in a reset condition; when the latch is reset, the 8051 performs its self-test and initialization. Note: The 8255 is only reset with an actual power-on. # **8051 RAM Allocation** | Absolute<br>RAM | Shared<br>RAM | | Number | |-----------------|---------------|--------------------------|----------| | Address | Address | Usage | of Bytes | | | | | | | 00-07 | | Reg Bank 0 | 8 | | 08-0F | | Reg Bank 1 | 8 | | 10-17 | | Reg Bank 2 | 8 | | 18-1F | | Reg Bank 3 | 8 | | 20-2B | | Work Area | 12 | | 2C-2E | 10-12 | 24-Bit Shared Bit Space | 3 | | 2F-3B | 13-1F | Shared (R.O.) Byte Space | 13 | | | | | | | Absolute<br>RAM<br>Address | Shared<br>RAM<br>Address | Usage | Number of Bytes | |----------------------------|--------------------------|---------------------------|-----------------| | 3C-4B | 00-0F | Shared (R/W) Byte Space | 16 | | 4C-57 | 20-2B | RAS Logs | 12 | | 58-63 | | UART Current Receive | 12 | | 64-68 | | Blocks<br>Keystroke Queue | 5 | | 69-7F | | Stack | 23 | | | | Total | 128 | # **Adapter and Keyboard Initialization Procedure** The following are the recommended steps for initializing the adapter and keyboard after a system reset occurs. ## 1. Activate Adapter Reset The 8051 reset is activated by power on, system reset, or system software directly activating the bit in the CRRB register. Additionally, power on causes a POR to the 8255. ## 2. Configure 8255 Write the adapter operation config 8255 to properly configure the 8255 for communication with the 8051. ## 3. Enable Host Interrupt IRQ Write the adapter operation enable IRQ to allow the interrupt request line to the system processor to be activated when the adapter is initiating a transfer to the system. Note: This step may be done at some later time if interrupts cannot be handled yet. Data transfers in subsequent steps will be either interrupt-driven, or polled. ## 4. Variable Delay Td The variable delay td allows the keyboard to execute its power-on reset tests, and quiesce clock and data lines before the 8051 interface to the keyboard is active. The delay Td is determined by the relation: If the time since system POR is greater than about 2.5 seconds, then no delay is necessary. ## 5. Release Adapter Reset Releasing 8051 Reset in CRRB allows the 8051 to run its self-test and initialization. ## 6. Wait for Adapter Initialization Response After the 8051 self-test and initialization is completed, the completion code is posted to the 8255. This should occur within 100 msec of the release above. ## 7. Validate Adapter Self-Test Completion Code The expected GOOD MACHINE data value is X'AE' with interrupt ID 6. ## 8. Reset the Keyboard Issue the adapter command to reset the keyboard. The expected adapter command response is X'00' with interrupt ID 0. If the response is X'42', the keylock switch is on and the adapter cannot write to or receive from the keyboard. ## 9. Wait for Keyboard Initialization Response Wait for 3 data bytes from the keyboard, which should be received within 600 msec. Note: If the first or only byte returned is a device error code (X'E0'), the keyboard is probably unplugged. ## 10. Validate Keyboard Reset All data bytes should have been returned with an ID 1. Data bytes should be as follows: X'AA' Keyboard BAT completion code X'BF' Keyboard ID - 1st byte Keyboard ID - 2nd byte X'Bt' Where: t = keyboard type (see keyboard specification for valid types). The adapter and keyboard are now Initialized to their defined defaults. # **System Board Connectors** # **Keyboard Connector** The following figure shows the keyboard connector (receptacle) on the system board. | PIN | SIGNAL | |-------|----------------------| | 1 | +5 VOLTS | | 2 | KEYBOARD DATA | | 3 | SPEAKER SIGNAL | | . 4 : | SPEAKER RETURN (+5V) | | 5 | GROUND | | 6 | KEYBOARD CLOCK | Figure 5-59. Keyboard Connector # **Locator Device Connector** The following figure shows the locator connector (receptacle) on the system board. | PIN | SIGNAL | | |-----|---------------------|--| | 1 | GROUND | | | 2 | TRANSMIT TO DEVICE | | | 3 | +12 V | | | 4 | -12 V | | | 5 | +5 V | | | 6 | RECEIVE FROM DEVICE | | Figure 5-60. Locator Connector # **Power and Connectors** | PIN | SIGNAL | |-----|--------| | 1 | +5 V | | 2 | +5 V | | 3 | +5 V | | 4 | +5 V | | 5 | GROUND | | 6 | GROUND | | 7 | GROUND | | 8 | GROUND | Figure 5-61. Model 20 and Model 25 Power Supply Connector (J1) | PIN | SIGNAL | | | |-----|--------|--|--| | 1 | +5 V | | | | 2 | +5 V | | | | 3 | +5 V | | | | 4 | +5 V | | | | 5 | GROUND | | | | 6 | GROUND | | | | 7 | GROUND | | | | 8 | GROUND | | | Figure 5-62. Model 20 and Model 25 Power Supply Connector (J2) | PIN | SIGNAL | | | |-----|---------------|--|--| | 1 | EPOW | | | | 2 | NO CONNECTION | | | | 3 | POR | | | | 4 | -12 V | | | | 5 | +12 V | | | | 6 | -5 V | | | | 7 | GROUND | | | | 8 | GROUND | | | | 9 | GROUND | | | Figure 5-63. Model 20 and Model 25 Power Supply Signal Connector (J3) | PIN | SIGNAL | |-----|----------------| | 1 | DATA 06 | | 2 | DATA 04 | | 3 | GROUND | | 4 | +5 V | | 5 | DATA 05 | | 6 | DATA 07 | | 7 | GROUND | | 8 | DATA 02 | | 9 | DATA 01 | | 10 | DATA 03 | | 11 | POWER GOOD | | 12 | DATA 00 | | 13 | KEYLOCK | | 14 | BATTERY BACKUP | Figure 5-64. Model 20 and Model 25 Operator Panel Connector # Model 20 and Model 25 Battery Connector The Model 20 and Model 25 battery connector is not located on the system board. The battery plugs into the operator panel for easy access. See "Model 20 and Model 25 Battery Connector" on page 9-19. ### Model 20 and Model 25 Serial Port Connectors | PIN | SIGNAL | | | | |-----|---------------------|--|--|--| | 1 | Transmit Data | | | | | 2 | Data Terminal Ready | | | | | 3 | Request to Send | | | | | 4 | Ring Indicate | | | | | 5 | No Connection | | | | | 6 | Receive Data | | | | | 7 | Data Set Ready | | | | | 8 | Clear to Send | | | | | 9 | Data Carrier | | | | | 10 | Signal Ground | | | | | | | | | | Figure 5-65. Model 20 and Model 25 Serial Port Connectors | PIN | SIGNAL | PIN | SIGNAL | PIN | SIGNAL | PIN | SIGNAL | |-----|--------|-----|--------|-----|--------|-----|--------| | 1 | +5 V | 2 | +5 V | 3 | +5 V | 4 | +5 V | | 5 | +5 V | 6 | +5 V | 7 | +5 V | 8 | +5 V | | 9 | +12 V | 10 | -5 V | 11 | NC | 12 | NC | | 13 | -12 V | 14 | NC | 15 | NC | .16 | NC | | 17 | GND | 18 | GND | 19 | GND | 20 | GND | | 21 | GND | 22 | GND | 23 | GND | 24 | GND | Figure 5-66. Model 10 Power Supply Connector (J1) | PIN | SIGNAL | | | |-----|---------------|--|--| | 1 | GROUND | | | | 2 | KEY | | | | 3 | NO CONNECTION | | | | 4 | POR | | | | 5 | EPOW | | | | 6 | POWER GOOD | | | | 7 | NO CONNECTION | | | | 8 | RESERVED | | | TR 249 Figure 5-67. Model 10 Power Supply Signal Connector (J3) | PIN | SIGNAL | |-----|----------------| | 1 | DATA 06 | | 2 | DATA 04 | | 3 | GROUND | | 4 | +5 V | | 5 | DATA 05 | | 6 | DATA 07 | | 7 | GROUND | | 8 | DATA 02 | | 9 | DATA 01 | | 10 | DATA 03 | | 11 | POWER GOOD | | 12 | DATA 00 | | 13 | KEYLOCK | | 14 | BATTERY BACKUP | Figure 5-68. Model 10 Operator Panel Connector | PIN | SIGNAL | | | |-----|--------------------|--|--| | 1 | POWER FROM BATTERY | | | | 2 | KEY | | | | 3 | NO CONNECTION | | | | 4 | GROUND | | | Figure 5-69. Model 10 Battery Connector # Section 6.I/O Channel ### **CONTENTS** | Channel Features | |---------------------------------------------------------------| | I/O Channel Conventions | | O Channel Signal Definitions | | O Channel Data Transfer 6-15 | | System Processor | | Input/Output Channel Controller (IOCC) | | Direct Memory Access (DMA) | | System DMA Controller | | DMA Types 6-16 | | Alternate Controller Operation | | RT PC Coprocessor 6-17 | | Device 6-17 | | I/O Channel Cycle Default Timings 6-18 | | Timing Diagrams 6-26 | | nterrupts | | I/O Channel Interrupt Operations | | Nonshared Interrupts | | Shared Interrupts | | O Channel Address Maps and Assignments | | Memory Address Map | | I/O Address Map | | DMA Channels | | Interrupt Levels | | O Slot Uniqueness | | Coprocessor Arbitration | | Connector/Pin Description and Electrical Characteristics 6-51 | # **About this Section** This section describes the architecture of the I/O channel in detail. It provides information about the I/O channel signals and describes the channel operations that are required to transfer data. ### **Channel Features** The RT PC I/O Channel features a 62-pin I/O connector that accommodates some IBM PC adapters. It also has a 40-pin connector that accommodates some PC-AT adapters. There are two additional +5Vdc and two additional ground pins on the 40-pin connector to support high wattage adapters. - A 16M-byte memory address space - A 64K-byte I/O address space - A 16-bit data bus - Supports 8 or 16 bit devices - A multiple controller arbitration - 8 DMA channels - Eleven maskable interrupts - A nonmaskable interrupt ### I/O Channel Conventions ### **Signal Levels** Signals are high-active unless the signal name is preceded by the symbol "-", which implies that the signal is low-active. # Most and Least Significant Bits | | | MSB | LSB | |----------------|--------------|-------------|-----| | <b>ADDRESS</b> | PC-1, PC-XT | <b>SA19</b> | SA0 | | | RT PC, PC-AT | LA23 | SA0 | | DATA | PC-1, PC-XT | SD7 | SD0 | | | RT PC, PC-AT | SD15 | SD0 | Note: Only those adapters identified in this manual are usable in the RT PC system. ### **Byte Alignment** = 8 Bits 1 Byte 1 Word = 16 Bits = 2 Bytes1 Double Word = 32 Bits = 4 Bytes Byte Organization | Byte Address | SAO | -SBHE | Bits 7-0 | |--------------|-----|-------|----------| | 000000 | 0 | 1 | Byte 0 | | 000001 | 1 ' | 0 | Byte 1 | | 000002 | 0 | 1 | Byte 2 | ### • Word Organization Even byte data (SAO = 0) is carried on SDO-SD7. Odd byte data (SAO = 1) is carried on SD8-SD15. | Word<br>Address | SA1 | SAO | -SBHE | Bits 15-8 | Bits 7-0 | |------------------|-----|-----|-------|------------------|------------------| | 000000<br>000002 | 0 | 0 | 0 | Byte 1<br>Byte 3 | Byte 0<br>Byte 2 | # **Addressing Scheme** | Device Addressed | essed Bit Assignments Address Space | | |------------------|-------------------------------------|-----------------------| | I/O Adapters | SA15-SA0 | 64K I/O Address Space | | Memory | SA19-SA0 | 1 MEG Memory Space | Figure 6-1. 62-Pin PC Adapters | Device Addressed | Bit Assignments | Address Space | |------------------|---------------------------------------|-----------------------------------------------| | I/O Adapters | SA15-SA0 | 64K I/O Address Space | | 8 Bit Memory | SA19-SA0<br>SA16-SA0 and<br>LA23-LA17 | 0-1 MEG Memory Space<br>1-16 MEG Memory Space | | 16 Bit Memory | SA16-SA0 and<br>LA23-LA17 | 0-16 MEG Memory Space | Figure 6-2. 98 and 102 Pin PC-AT or RT PC Adapters # I/O Channel Signal Definitions #### SA0 - SA19 System address bits SA0-SA19 are used by the current DMA controller to address system memory or any other device, I/O adapter or memory on the I/O channel. The DMA Controller must hold these address lines stable during the entire data transfer cycle. Note: See "I/O Channel Data Transfer" on page 6-15 for definition of terms. During I/O cycles address bits SA16-SA19 will be "0000" and address bits SA0-SA15 will be used to access a 64K I/O space. During memory cycles all 20 address bits will be used to access the low 1 megabyte of memory address space. SA17-SA19 must be received by 8-bit memories and they must be driven by any DMA Controller which must transfer data with them. #### LA17 - LA23 I/O channel address bits LA17-LA23 are used with SA0-SA16 to extend the I/O Channel memory address space to 16 megabytes. Sixteen bit memory devices must receive LA17-LA23, and all DMA Controllers must drive them. During I/O cycles the LA address bits are all 0. The DMA controller must hold these address lines stable during the entire data transfer cycle. Note: The RT PC system board drives all (SA0-SA19 and LA17-LA23) address signals through the entire channel cycle. BALE is not driven by the RT PC system board. However, the line is implemented for adapters that need it. Application Note: Some system boards may not latch these signals and they do not stay valid through the entire channel cycle. Any device receiving these signals must use BALE to latch these I/O channel addresses. A transparent latch (such as 74ALS573) is required. (See BALE.) #### BALE Address latch enable is used to latch valid addresses from a system board or DMA controller that does not latch addresses LA17-LA23. These addresses are valid and should be latched on the falling edge of BALE. For all DMA controller cycles the system board IOCC will drive BALE high, allowing addresses LA17-LA23 to "pass-through" the transparent latch. (See Application Note on page 6-8.) #### -SBHE Bus high enable indicates a data transfer on the high byte of the 16 bit data bus (SD8-SD15) and is used with SA0 to distinguish between odd byte, even byte and word transfers. (See Figure 6-3 on page 6-10.) #### AEN Address enable is active (high) on the I/O channel during all DMA device cycles on the I/O channel. For all other alternate controller cycles the IOCC will drive it (low). Note: AEN must be used as part of the device select decode for all I/O space cycles. Since -IOR or -IOW is active during DMA adapter operations (which is a memory space operation), AEN must prevent false selects during these cycles. I/O space selects should be enabled only when AEN is low. #### SD0 - SD15 The system data lines transfer data between adapters or options and memory. The DMA adapter sends data on write cycles and the memory sends data on read cycles. Refer to Figure 6-3 on page 6-10 for details of transfers between 8 and 16 bit devices. **Note:** 8-bit devices must attach to the low order byte (SD0-SD7) on the channel. | Transfer Type | -SBHE | SA0 | | SD8-SI | D15 | SD0-SD7 | | |---------------------------|-------|-----|---------|--------|-----------------|---------|----| | 8-bit DMA Device *3 and | 1 | 0 | | X | | Even | | | 8-bit Device | 0 | 1 | | X | | Odd | | | 8-bit DMA Device *3 and | 1 | 0 | | X | | Even | | | 16-bit Device | 0 | 1 | (Read) | Odd | <del></del> | T | *1 | | | 0 | 1 | (Write) | T | < | Odd | *1 | | 16-bit DMA Controller and | 0 | 0 | | X | | Even | | | 8-bit Device | 0 | 1 | (Read) | T | < | Odd | *2 | | | 0 | 1 | (Write) | Odd | <del>&gt;</del> | T | *2 | | | 1 | 0 | | X | | Even | | | | 1 | 1 | | T | | T | | | 16-bit DMA Controller and | 0 | 0 | | Odd | | Even | | | 16-bit Device | 0 | 1 | | Odd | | T | | | | 1 | 0 | | T | | Even | | | | 1 | 1 | | T | | T | | Figure 6-3. Data Transfer Table Note: The arrow indicates the direction SD8-SD15 are multiplexed. | Even<br>Odd | Even addressed byte Odd addressed byte | |-------------|-------------------------------------------------------------------------------------------------------------------------------| | T | Tri-state | | X | Don't care | | *1 | The IOCC must multiplex odd byte data for transfers between a 16 bit channel attached device and an 8-bit DMA device. | | *2 | The IOCC will also multiplex odd byte data during transfers between alternate controllers and 8-bit channel-attached devices. | | *3 | DMA devices only | Note: The IOCC handles all multiplexing of data to and from system memory for alternate controllers and DMA device operations. #### -SMEMR; -MEMR The Memory Read Command instructs the selected memory device in the memory address space to send data onto the data bus. -SMEMR is active only when the memory decode is within the low 1 megabyte of the I/O memory space. -MEMR is active on all memory read cycles. The adapter option must hold data on the channel as long as memory read is active. #### -SMEMW; -MEMW The Memory Write Command instructs the selected memory device in the memory address space to store the data present on the data bus. -SMEMW is active only when the memory decode is within the low 1 megabyte of the I/O channel memory space. -MEMW is active on all memory write cycles. **Note:** -MEMW and -MEMR should be used by all 16-bit devices. -SMEMW and SMEMR (along with SA17-SA19) must be driven by any controller which must transfer data with 8-bit memory space devices (such as system board, Coprocessor, and IPL devices). LA17-LA19 must equal SA17-SA19, and LA20-LA23 must be 0. **Note:** -SMEMR, -MEMR, -SMEMW and -MEMW will not be active on the I/O channel when the target memory is translated to system memory. See "Translation Control Words" on page 5-27. #### -IOR The I/O Read Command instructs the selected device in the I/O address space or the "DACK-selected" DMA adapter to send data onto the data bus. The selected device must hold data on the data bus as long as I/O read is active. #### -IOW The I/O Write Command instructs the selected device in the I/O address space or the "DACK-selected" DMA adapter to store the data present on the data bus. **Note:** DMA devices and I/O devices which use default timing cycles must use the trailing edge of -IOW to sample data to guarantee valid data setup time. #### I/O CH RDY I/O Channel Ready (normally high) is pulled low by a selected device to lengthen the current I/O or memory cycle. Any slow device using this line should drive it low as soon as a valid select is decoded and a read or write command is active. Once the device has stored data during a write operation or it has gated valid data onto the data bus during a read operation, it should then drive I/O CH RDY high to indicate that the controller may end the current operation. #### **Notes:** - 1. I/O CH RDY should not be held "not ready" by the selected device longer than 2.1 microseconds. The only exception is the system board in device mode may take longer for certain system memory operations. - 2. For devices which store data on the trailing edge of the write command, I/O CH RDY is used to guarantee the data set-up time. #### -MEMCS16 This signal must be driven active by a 16-bit memory space device after decoding a valid address select using LA17-LA23 only. To meet timing requirements -MEMCS16 must not wait for the latched addresses (such as SA0-SA16 and BALE). A fast default cycle time (see "I/O" Channel Cycle Default Timings" on page 6-18) is used by the DMA controller, unless I/O CH RDY is not ready. #### -I/OCS16 This signal must be driven active by a 16-bit I/O space device after decoding a valid address select from SA0-SA15. A fast default cycle time (see "I/O Channel Cycle Default Timings" on page 6-18) is used by the DMA controller, unless I/O CH RDY is not ready. #### **Notes:** - 1. It is possible that -I/OCS16 will be active during a memory cycle or that -MEMCS16 will be active during an I/O cycle. The DMA controller must know whether an I/O or memory cycle is active and only look at the appropriate signal. - 2. A 16-bit device may use I/O CH RDY to override the fast default cycle time of either -MEMCS16 and -I/OCS16 if it needs to run slower. - 3. The IOCC will use -MEMCS16 and -I/OCS16 to distinguish between 8 and 16-bit devices. See "Multiplexing Rules in Figure 6-3 on page 6-10." A 16-bit DMA controller can use -MEMCS16 AND -I/OCS16 to enable a fast default channel cycle. #### DRO0-DRO3, DRO5-DRO7 The DMA request lines are used by DMA devices or alternate controllers to request control of the I/O channel from the system arbiter. The requests are prioritized with DRO0 having the highest priority and DRQ7 the lowest priority. A request is generated by driving a DRQ line high. A DRO line is held high until the corresponding -DACK line goes active. DRO0-DRO3 are used for 8-bit DMA devices and 16-bit alternate controllers. DRO5-DRO7 are used by 16-bit DMA devices and alternate controllers. All alternate controllers are 16-bit devices, and they may use any of the DRQ lines. For more details on arbitration, see "Arbitration" on page 5-33 and "DMA" on page 5-39. Note: The DRQ lines must be driven with a tri-state driver, which can be enabled or disabled by a software output command. DRQ's must be disabled by system reset (RESET DVR). Since a tri-state level is indeterminate, the system DRO must be disabled whenever an adapter's DMA request line (DRO) is tri-stated. There must be a 60 microsecond wait time from disabling one tri-state driver before turning on the next driver. #### -DACK0-DACK3, -DACK5-DACK7 A DMA Acknowledge (-DACK) is driven active by the System DMA Controller in response to a DMA request (DRQ). For a DMA device the -DACK acts as a DMA device select, and the System DMA Controller drives addresses and control signals on the I/O channel. For alternate controllers the -DACK indicates that the alternate controller has been granted use of the I/O channel following proper activation of the '-master' control line. Note: A DMA device should not honor its DACK, if its DRQ is disabled. #### DRO8: -DACK8 See "I/O Slot Uniqueness" on page 6-48 and "Coprocessor Arbitration" on page 6-50. #### -MASTER This signal is used by an alternate controller to indicate that the system board must tri-state its address and command lines so that the alternate controller may drive the I/O channel after receiving a -DACK from the system DMA controller. After receiving the -DACK, a master pulls the -master line low. After waiting 60 nanoseconds, it may drive the address and data lines, and 125 nanoseconds after addresses are valid it may issue a Read or Write command. When the alternate controller has completed its cycle, it must tri-state all address, data, and data transfer control lines before turning off -master (high). #### T/C(Terminal Count) This line is used to provide a pulse on the I/O channel during a Read or Write command. It indicates that the terminal count of the current DMA operation has been reached. This represents the last byte to be transferred of a pre-programmed DMA block transfer. A DMA adapter must have a valid "DACK" before T/C is valid. #### IRO3-IRO7, IRO9-IRO12, IRO14, IRO15 The interrupt request lines signal the processor that an I/O device requires attention. They occur on priority levels. For more details see "Interrupt Priority" on page 5-57. #### -I/O CH CK -I/O Channel Check generates a nonmaskable interrupt (NMI) to the system processor if an uncorrectable system error is indicated. -I/O CH CK is driven low momentarily, and it must be active for at least 2 I/O channel clock (CLK) periods to be detected. -I/O CH CK is valid on the transition high to low. Every device that uses I/O CH CK must have a programmable status latch, and a programmable enable or disable latch. Note: Channel-attached RAM does not save status, and it holds -I/O CH CK active until it is cleared by the NMI handler software. #### CLK The I/O channel clock may vary from system to system and will be in the range of 4-8MHz. Note: I/O channel timing parameters will be specified independent of the I/O channel clock frequency to allow I/O device compatibility in different systems. The RT PC system board uses 4.77 MHz with a 33% duty cycle. #### -REFRESH This line is driven low on the system board to indicate a refresh cycle to I/O channel-attached RAM. See "Refresh Operation for Channel-Attached RAM" on page 6-24 for details of refresh operations. (See "I/O Slot Uniqueness" on page 6-48 for Coprocessor slot). #### RESET DRV Reset Driver is used to reset all system devices to an initial state. At power-on time RESET DRV will go high and stay active for 100-500 ms after all voltage lines are within operating limits. When RESET DRV is active, I/O adapters must turn off or tri-state all output drivers. **Note:** Software initiated reset commands to specific I/O channel adapters or options may be less than 100 milliseconds, if the adapter has a lower reset requirement. #### OSC The Oscillator is a high speed clock with a 14.31818 Mhz frequency and a 50% duty cycle. #### POWER The following voltages are available on the system board I/O channel: - +5 Vdc ± 5%, located on 5 connector pins - -5 Vdc ± 10%, located on 1 connector pin - +12 Vdc ± 5%, located on 1 connector pin - -12 Vdc ± 10%, located on 1 connector pin GND (Ground), located on 6 connector pins # I/O Channel Data Transfer Data can be transferred on the I/O Channel either directly by the system processor, or by using Direct Memory Access. # **System Processor** The system processor is on the processor board and attaches to the processor channel. The Input/Output channel controller interfaces the processor channel to the I/O channel and to the I/O subsystem. The system processor owns the I/O channel and will transfer control to the system arbiter when a valid request is active. # **Input/Output Channel Controller (IOCC)** The IOCC transfers commands, addresses and data between the processor channel, the I/O channel and the I/O subsystems. It provides a centralized arbiter function for the various I/O subsystem and I/O channel users. It also contains the system arbiter, the system DMA controller and the interrupt controller. # **Direct Memory Access (DMA)** DMA is a method of transferring large blocks of sequential data between two devices with minimal interference to the system processor. One participant in the transfer is usually memory. The other is an adapter or option which supplies or receives the data. DMA capability permits simultaneous use of I/O adapters and the system processor. ### **System DMA Controller** The System DMA Controller supports both DMA devices and alternate controllers. The System DMA Controller resides on the system board and is considered part of the IOCC. Two 8237 DMA controllers are used for this function. See the system board section for more detailed information. The system DMA controller must request use of the I/O channel from the system arbiter. #### DMA Controller A DMA controller is either the system DMA controller or an alternate controller. ### **DMA Types** Two types of DMA are used in this system: **DMA Device** A DMA device is an adapter or option without the ability to handle addressing or I/O controls. It uses the system DMA controller for addressing and for I/O channel control. Alternate Controller An alternate controller is an adapter or option with the ability to handle its own addressing and I/O channel control. All alternate controllers must be 16-bit devices (attached to SD0-SD15) and drive -SBHE. **Note:** A DMA adapter is either a DMA device or an alternate controller. ## **Alternate Controller Operation** When there is a need to transfer data via DMA using an alternate controller adapter, the program (software) for the adapter initiates a preprogrammed block transfer. The software obtains the starting address in memory, the block transfer length and the direction of the transfer. It then loads all of the proper parameters into the adapter's 8237 DMA controller or the adapters DMA controller function and into the proper IOCC registers. Now the software instructs the hardware to take over. The hardware activates its DRQ line enough times to transfer the complete block of data. When the DRQ line is activated, the system DMA controller receives the request, prioritizes it along with any other active requests and acts in turn on the requests. When the alternate controller receives its -DACK, it will activate -Master. The IOCC now tri-states all I/O channel address lines. data lines and proper control signals. Then the alternate controller logic drives the I/O channel address and control signals and drives or receives data as specified. After each byte of data is transferred, the alternate controller tri-states all of its drivers, removes -Master and returns control of the I/O channel to the system DMA controller. The hardware repeats this sequence of events until the complete preprogrammed block of data is transferred. On the last DMA cycle T/C is active to indicate to the IOCC and to the system processor that the DMA block transfer is complete. #### Notes: - 1. See "Arbitration" on page 5-33 for details of the system arbiter function. - 2. Alternate controllers usually have an I/O device mode, therefore they can be controlled by the system processor or another alternate controller. ### **RT PC Coprocessor** Channel-attached processors such as the 286 Coprocessor are generally viewed as alternate controllers which have the additional attributes of executing code, servicing interrupts, and controlling other channel-attached devices. Remember, the system processor is on the processor board. **Note:** Alternate controllers may also have a device mode. When in device mode, the alternate controller acts like any other I/O device. #### Device A device is any channel-attached option or adapter that responds to the address and control of the system processor or a DMA controller. Each device is assigned a unique address range to which it may respond. Once a device recognizes its own unique address on the channel, it is said to be selected, and it is then required to obey the data transfer controls. A device will store data during a Write operation and provide data during a Read operation. Three types of devices are generally referenced: - DMA devices - Memory devices - I/O devices #### **DMA Device** A DMA device is a device that has the ability to request a DMA operation (+DRQ). It requests use of the I/O channel when it needs to transfer a block of data with another device (usually memory). DMA block transfers are achieved in the same manner as alternate controller operations (see "Alternate Controller Operation" on page 6-16) except that the system DMA controller provides addressing and data transfer control signals for the transfer. The DMA device must be ready to provide or receive the data before it requests the use of the I/O channel. It can not drive the 'I/O CH RDY' line not ready for additional setup time. ### **Memory Device** A memory device is a RAM, ROM or EPROM. A memory device can drive the 'I/O CH RDY' line not ready to extend the time to provide or receive data. ### I/O Device An I/O device is an I/O adapter or option which is able to provide or receive data under the control of the system processor, system DMA controller or an alternate controller. ## I/O Channel Cycle Default Timings During a data transfer cycle between the IOCC and a memory or I/O device, if the device does not drive I/O CH RDY not ready, then the IOCC must provide the following default cycle timings: | | | Min | Тур. | Max | |---------|---------------------------------------------|-------|-------|--------| | Case 1. | For 8-bit devices -IOR, -MEMR pulse width | 540ns | 565ns | 1000ns | | Case 2. | For 8-bit devices -IOW, -MEMW pulse width | 540ns | 565ns | 1000ns | | Case 3. | For 16-bit memory devices -MEMR pulse width | 235ns | 250ns | 600ns | | Case 4. | For 16-bit I/O devices -IOR pulse width | 175ns | 190ns | 600ns | | Case 5. | For 16-bit memory devices -MEMW pulse width | 235ns | 250ns | 600ns | | | | Min | Тур. | Max | |---------|------------------------|-------|-------|-------| | Case 6. | For 16-bit I/O devices | 175ns | 190ns | 600ns | | | -IOW pulse width | | | | - Any DMA Controller which transfers data with either type of device (8 or 16-bit) must also provide these default cycles for the case where the device does not drive I/O CH RDY "not ready." - Any DMA Controller which transfers data with a 16-bit I/O space device must receive the signal "-IOCC16" and provide the "short" default cycle timing, Case 4 and Case 6. - Any DMA controller which transfers data with a 16-bit memory space device must receive the signal "-MEMCS16" and provide the "short" default cycle timing, Case 3 and Case 5. - Any Device that cannot store data on a write cycle within the minimum cycle times described above (Case 2, 5, and 6) must use I/O CH RDY "not ready" to stretch the cycle. - 8-bit Memory Devices must provide valid data within 250ns of an active read command or else drive I/O CH RDY "not ready" to stretch the cycle. - 8-bit I/O Devices must provide valid data within 425ns of an active read command or else drive I/O CH RDY "not ready" to stretch the cycle. - 16-bit Memory Devices must provide valid data within 200ns of an active read command or else drive I/O CH RDY "not ready" to stretch the cycle. - 16-bit I/O Device must provide valid data within 135ns of an active read command or else drive I/O CH RDY "not ready" to stretch the cycle. - The System DMA Controller must support memory default timing. - Assume memory READ/WRITE access = max.(250ns) - Assume DMA Controller READ = max. (250ns) data valid - Assume DMA Controller WRITE = max. (200ns) data setup. - Any memory which supports DMA must be able to read or write data within 250ns of an active command or else drive I/O CH RDY "not ready" to stretch the cycle. - Any DMA device must be able to read data within 250ns of an active command and it will have a minimum of 200ns data setup before the end of an -IOW command. Data must be sampled on the trailing edge of -IOW to guarantee valid data setup. ### I/O Channel Protocols This section describes the protocols that channel participants use to perform channel operations. Channel operations included are: - Memory read/write - I/O read/write - Interrupt - Refresh operations - Error detection - Reset. Figure 6-4 on page 6-21 is provided to illustrate the different channel participants, their relationship to the channel structure, important "functional controls" and protocols. Figure 6-4. Protocol Functional Block Diagram ### **Memory Read Operation** For a Memory Read Operation, the DMA controller must drive the address lines and insure they are stable on the channel before the Memory Read command is activated. When the Memory Read command is detected by the memory device, it drives its data onto the I/O channel. If a memory device is unable to drive data onto the I/O channel within the time specified for a normal operation, the signal I/O CH RDY must be driven 'not ready' by the memory device. This will extend the memory read operation and allow additional time before the memory device must drive data onto the I/O channel. The data must be valid on the channel before the memory device releases the I/O CH RDY line to a 'ready' state. The memory device must hold the data lines active until the Memory Read command goes inactive. Figure 6-5. Memory Read Operation Sequence ### **Memory Write Operation** For a Memory Write Operation, the DMA controller must drive both the address and the data lines active. During a memory write operation, the Memory Write command is driven active after the address lines are stable, but before the data lines are valid on the channel. To ensure the data is stored, the DMA controller must provide valid data on the channel no later than 80ns after the Memory Write command is driven active. It is preferable to drive the data active before -MEMW command goes active. Figure 6-6. Memory Write Operation Sequence ### I/O Read Operation For a Read Operation, the DMA controller must drive the address lines and insure they are stable on the channel before the command (I/O or memory) is activated. When the Read Command is detected by the device, it drives its data onto the I/O channel. If a device is unable to drive data onto the I/O channel within the default cycle time, the signal I/O CH RDY must be driven "not ready" by the device. This will extend the I/O read operation and allow additional time before the device must drive data onto the I/O channel. The data must be valid on the channel before the device releases the I/O CH RDY line to a "ready" state. The device must hold the data lines active until the Read Command goes inactive. Figure 6-7. I/O Read Operation Sequence ### I/O Write Operation For a Write Operation, the DMA controller must drive both the address and the data lines active. During a write operation, the Write Command (I/O or memory) is driven active after the address lines are stable, but before the data lines are valid on the channel. A device must sample the data lines at the trailing edge of the Write Command to ensure data will be valid for all circumstances. If a device is unable to store the data within the default cycle time, the signal I/O CH RDY must be driven "not ready" by the device. This will extend the I/O write operation and allow the device additional time to store the data. The DMA controller must maintain both address and data lines active and stable for the duration of the Write Command. Figure 6-8. I/O Write Operation Sequence # Refresh Operation for Channel-Attached RAM Channel refresh operations occur at the minimum rate of 256 refresh cycles every 4ms. The 256 refresh cycles consists of all combinations of row addresses SA0-SA7. This will support refresh for all RAM cards using standard 16K x 1, 64K x 1, and 256K x 1 RAM modules. -REFRESH is driven low by the system board to indicate that channel-attached RAM must start a refresh operation. The -REFRESH line is used to enable a RAS (Row Address Strobe) to all memory banks when -MEMR goes active, and also to disable all CAS (Column Address Strobe) controls. The refresh operations are normally done in distributed bursts of five refresh cycles. However, if the refresh controller is delayed in getting control of the I/O channel, the maximum refresh burst is 17 refresh cycles. See Figure 6-9 on page 6-25 for Refresh timing. Figure 6-9. Refresh Timing Note: Only the system board logic can initiate a refresh timing cycle. ### **Error Detection** The line named I/O Channel Check (I/O CH CK), when active, raises a non-maskable interrupt to the processor. This is the highest priority interrupt and takes precedence over other system operations. #### Reset The RESET DRV control line forces all system devices to an initial state. At power on time, RESET DRV is active high for at least 100 msec after all voltages are within operating limits. The states of the channel signals at the end of a reset are: | Signal | State | | | |-----------------------|-------------------------|--|--| | ADDRESS BUS | Unknown State | | | | DATA BUS | Tri-state | | | | IRQ(n) | Active (High) | | | | DRQ (n) | Inactive (Low) | | | | DACK(n) | Inactive (High) | | | | BALE | Always High | | | | AEN | Inactive (Low) | | | | RD/WR | Inactive (High) | | | | CLK | 4.77 MHz (free running) | | | | I/O CH CK | Inactive (High) | | | | Other Control Signals | Inactive | | | | | | | | # **Timing Diagrams** Figure 6-10. I/O And Memory Default Cycle Timing | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|-------------------------------------------------|------|---------|------| | T1 | -I/OCS16 active from valid address | 0 | | 90 | | T2 | -I/OCS16 inactive from address change | 0 | | 90 | | Т3 | Fast I/O cycle command pulse width (default) | 175 | 350 | 600 | | T4 | Slow I/O cycle command pulse width (default) | 540 | 630 | 1000 | | T5 | -MEMCS16 active from valid address | 0 | energy. | 90 | | Т6 | -MEMCS16 inactive from address change | 0 | _ | 90 | | Т7 | Fast memory cycle command pulse width (default) | 235 | 350 | 600 | | Т8 | Slow memory cycle command pulse width (default) | 540 | 630 | 1000 | Note: All times are specified in nanoseconds. Figure 6-11. I/O Read Operation | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|--------------------------------------------|------|------|------| | T1 | Address valid before -IOR is active | 90 | 140 | ŀ | | T2 | -IOR pulse width default: 8-bit device | 540 | 630 | 1000 | | | 16-bit device | 175 | 350 | 600 | | T3 | Data valid from -IOR default: 8-bit device | 0 | | 425 | | | 16-bit device | 0 | - | 135 | | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|----------------------------------------------|------|------|------| | T4 | I/O CH RDY not ready from -IOR: 8-bit device | 0 | | 150 | | | 16-bit device | 0 | | 60 | | T5 | I/O CH RDY not ready pulse width | 0 | | 2100 | | T6 | Data valid before I/O CH RDY ready | 0 | 50 | | | Т7 | -IOR inactive from I/O CH RDY ready | 0 | 140 | | | Т8 | Data tri-state from -IOR inactive | 0 | - | 45 | | Т9 | Address hold time from -IOR inactive | 40 | 60 | | Figure 6-12. I/O Write Operation | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|----------------------------------------------------|------|------|------| | T1 | Address valid before -IOW is active | 90 | 140 | | | T2 | Data valid before -IOW is active | 0 | 40 | | | Т3 | -IOW pulse width default: 8-bit device | 540 | 630 | 1000 | | | 16-bit device | 175 | 350 | 600 | | T4 | Data setup time before -IOW inactive: 8-bit device | 540 | 670 | | | | 16-bit device | 175 | 390 | | | T5 | I/O CH RDY not ready from -IOW: 8-bit device | 0 | | 150 | | | 16-bit device | 0 | | 60 | | Т6 | I/O CH RDY not ready pulse width | 0 | | 2100 | | T7 | -IOW inactive from I/O CH RDY ready | 0 | 140 | | | Т8 | Data hold time from -IOW inactive | 40 | 60 | | | Т9 | Address hold time from -IOW inactive | 40 | 60 | | Figure 6-13. Memory Read Operation | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|---------------------------------------------|------|------|------| | T1 | Address valid before -MEMR is active | 90 | 140 | | | T2 | -MEMR pulse width default: 8-bit device | 540 | 630 | 1000 | | | 16-bit device | 235 | 350 | 600 | | Т3 | Data valid from -MEMR default: 8-bit device | 0 | | 250 | | | 16-bit device | 0 | | 200 | | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|-----------------------------------------------|------|------|------| | T4 | I/O CH RDY not ready from -MEMR: 8-bit device | 0 | | 150 | | | 16-bit device | 0 | | 60 | | T5 | I/O CH RDY not ready pulse width | 0 | | 2100 | | T6 | Data valid before I/O CH RDY | 0 | 50 | | | T7 | -MEMR inactive from I/O CH RDY ready | 0 | 140 | | | T8 | Data tri-state from -MEMR inactive | 0 | | 45 | | Т9 | Address hold time from -MEMR inactive | 40 | 60 | | Figure 6-14. Memory Write Operation | Symbol | Parameter Description | Min. | Тур. | Max. | |--------|-----------------------------------------------|------|------|------| | T1 | Address valid before -MEMW is active | 90 | 140 | | | T2 | Data valid before -MEMW is active | 0 | 40 | | | Т3 | -MEMW pulse width default: 8-bit device | 540 | 630 | 1000 | | | 16-bit device | 235 | 350 | 600 | | T4 | I/O CH RDY not ready from -MEMW: 8-bit device | 0 | | 150 | | | 16-bit device. | 0 | | 60 | | T5 | I/O CH RDY not ready pulse width | 0 | | 2100 | | Т6 | -MEMW inactive from I/O CH RDY ready | 0 | 140 | | | Т7 | Data hold time from -MEMW inactive | 40 | 60 | | | Т8 | Address hold time from -MEMW inactive | 40 | 60 | | Figure 6-15. Bus Arbitration | Symbol | Parameter Description | Min. | Max. | |--------|--------------------------------------------------------|------|------| | T1 | DMA acknowledge from DRQ active (see note 1) | _ | _ | | T2 | DRQ inactive from -DACK active (see note 6) | 0 | 125 | | Т3 | Bus and commands tri-state from -DACK off (see note 2) | _ | _ | | T4 | -DACK inactive to next DACK active | 0 | _ | | Symbol | Parameter Description | Min. | Max. | |--------|-------------------------------------------------------------------------|------|------| | T5 | DRQ inactive from -DACK active (see notes 3 and 4) | _ | _ | | Т6 | -DACK active to -Master active | 0 | _ | | T7 | -Master active before MasterB drives bus | 60 | - | | Т8 | Address valid before Read/Write command active | 125 | _ | | Т9А,В | -Master and DRQB inactive from Read/Write command inactive (see note 3) | - | _ | | T10 | Bus and commands tri-state before -Master inactive | 0 | _ | | T11 | -Master inactive to IOCC drives bus (see note 4) | 0 | _ | | T12 | DRQ (alt controller) inactive to -DACK inactive (see note 5) | _ | _ | #### Notes: - 1. When multiple requests are active, the DACK response is a function of the IOCC and the system configuration. This means several higher priority devices may get acknowledged first. - 2. If the IOCC is switching from one IOCC cycle to another (system processor or DMA device), it will not need to tri-state the channel. If it is transferring control to an alternate controller it must tri-state the channel before issuing the next DACK. - 3. A alternate controller must hold DRQ and -Master active as long as it needs to control the channel. This includes meeting address and data hold-time requirements. - The IOCC may drive the channel immediately, go idle, or issue another DACK as soon as possible after -Master and DRQ are off, and the IOCC has turned off the original DACK (DACKB in the example). - 5. The IOCC deactivates -DACK as soon as possible after the DRQ has been deactivated. The IOCC rearbitrates as soon as DRO turns off. - 6. This specification is for single cycle DMA transfers. DRQ for multiple cycle DMA transfers may turn off as late as 60ns. after the last command goes active. - 7. SP denotes system processor. Figure 6-16. DMA Read Operations | Symbol | Parameter Description | Min. | Max. | |--------|--------------------------------------------|------|------| | T1 | -DACK active before -MEMR is active | 50 | _ | | T2 | Address -SBHE or AEN valid before commands | 90 | _ | | Symbol | Parameter Description | Min. | Max. | |--------|-------------------------------------------------------|------|-----------| | T3 | -MEMR active before -IOW active | 0 | _ | | T4 | Memory access time (default) | 0 | 250 | | T5 | I/O CH RDY not ready from -MEMR active | 0 | 60 | | T6 | I/O CH RDY ready from data valid | 0 | _ | | T7A | Valid data setup before -IOW inactive (ready case) | 175 | _ | | T7B | Valid data setup before -IOW inactive (default case) | 200 | _ | | T8 | -MEMR inactive after -IOW inactive | 25 | <u>,—</u> | | Т9 | Address -SBHE/AEN/DACK hold time after -MEMR inactive | 40 | | | T10 | -MEMR minimum pulse width (see note 2) | 500 | <u> </u> | | T11 | -IOW minimum pulse width | 260 | _ | | T12 | T/C valid | -50 | 50 | | T13 | T/C minimum pulse width | 250 | | #### **Notes:** - 1. All times are specified in nanoseconds. - 2. For DMA accesses to system memory, -MEMR signal will not go active on the I/O channel. Figure 6-17. DMA Write Operations | Symbol | Parameter Description | Min. | Max. | |--------|--------------------------------------------|------|------| | T1 | -DACK active before -IOR is active | 50 | _ | | T2 | Address -SBHE or AEN valid before commands | 90 | _ | | Symbol | Parameter Description | Min. | Max. | |--------|---------------------------------------------------------|------|------| | Т3 | -IOR active before -MEMW active | 200 | _ | | T4 | Data valid from -IOR | 0 | 200 | | T5 | I/O CH RDY not ready from -MEMW active | 0 | 60 | | Т6 | Time for memory to store data (default) | 0 | 250 | | T7 | I/O CH RDY ready from memory data stored | 0 | _ | | T8 | -IOR inactive after -MEMW inactive | 25 | _ | | Т9 | Address, -SBHE, AEN, DACK hold time after -IOR inactive | 40 | _ | | T10 | -IOR minimum pulse width | 500 | _ | | T11 | -MEMW minimum pulse width (see note 2) | 260 | 1- | | T12 | T/C valid | -50 | 50 | | T13 | T/C minimum pulse width | 250 | | | T14 | Data bus tri-state after -IOR inactive | 0 | 45 | #### **Notes:** - 1. All times are specified in nanoseconds. - 2. For DMA accesses to system memory, -MEMW signal will not go active on the I/O channel. # **Interrupts** This section describes interrupts and their usage in RT PC. There are descriptions of the interrupt sharing architecture and circuit operation. # I/O Channel Interrupt Operations The interrupt request (IRQ) lines signal the system processor or a Coprocessor that an I/O adapter requires service. When an adapter requests service, the interrupt controller interrupts the system processor. Then the system processor acknowledges the interrupt. It is then serviced by the appropriate interrupt routines. All I/O adapters must have a programmable and readable status latch (bit) which shows the interrupt status. The adapter must also have a programmable and readable latch (bit) which can enable or disable the interrupt capability of the adapter. System reset on the 'Reset Dvr' line must reset the status latch, the enable latch and the interrupt line driver on all adapters. RT PC supports two types of interrupts, shared and nonshared interrupts on all its levels. Only one I/O adapter with a nonsharing interrupt can have its interrupt enabled at the same time (per level). I/O adapters with shared IRQ's may have their IRQ's enabled simultaneously and operate concurrently. Mixing types of interrupts on the same level is allowed, as long as one type is disabled, when the other is enabled. RT PC has implemented shared interrupts to solve the problems involved with non-shared interrupts. ## **Nonshared Interrupts** With nonshared interrupts only one adapter can use an IRQ line. The normal state of an enabled nonshared IRQ is low. An interrupt request is generated by raising the IRQ line (from low to high) and holding it high until it is acknowledged by the processor. Then the interrupt service routine must clear the IRO line (from high to low). Note: Disabling a nonshared interrupt forces the IRQ line to go from low to high or tri-state level. The system interrupt controller assumes a valid interrupt has occurred. Therefore, an interrupt level must be masked off before an adapter interrupt is disabled, and the false interrupt condition must be cleared before normal processing can continue on that level. #### **Shared Interrupts** Shared interrupts allow a system to have multiple adapters using a common interrupt request line. To request service, a device sends a negative pulse (125 to 1000 nanoseconds) to the IOCC interrupt controller. The interrupt controller recognizes the interrupt on the low-to-high transition of the pulse. An adapter must set its interrupt status latch bit before initiating an interrupt or use it to initiate the interrupt. The adapter's interrupt status latch is reset and the interrupt level is reenabled by the interrupt service routine. The IRO lines are driven with an open collector driver (or tri-state equivalent) and each I/O adapter must provide a 2.0K or 2.2K ohm +/- 10% pull up resistor on the driver output. Figure 6-18. Block Diagram For IRQ Line Figure 6-18 shows, conceptually, a method of controlling a device's interrupt request output to allow sharing of an interrupt request line. An interrupt originating from the adapter (status bit) is 'ANDed' with the adapter's interrupt enable bit, and the result is used to activate the interrupt request pulse generating circuits unless an interrupt is already active. The adapter requesting service must disable all adapters on the same interrupt level until the requesting adapter is finished. If another adapter has an interrupt pending, it is sent immediately after the trailing edge of the I/O Write which reenables that interrupt level. The I/O Write which is issued by the software interrupt level service routine reenables all devices on that interrupt level. Each interrupt level has a common I/O address that reenables all adapters with one I/O Write instruction. The following is a list of the I/O addresses for the interrupt levels. | Interrupt<br>Level | Hex Address | |--------------------|--------------| | 3 | 2F3 | | 4 | 2F4 | | 5 | 2F5 | | 6 | 2F6 | | 7 | 2F7 | | 9 | 2F2 | | 10 | 6F2 | | 11 | 6F3 | | 12 | 6F4 | | 14 | 6 <b>F</b> 6 | | 15 | 6 <b>F</b> 7 | Bits SA0 through SA10 are the only bits required to be decoded for this address. They must be 'ANDed' with '-IOW' and '+AEN'. When the I/O address is written, it is called Interrupt Level Enable (ILE). The ILE output must be 'ORed' with '+Reset Dvr' as part of the reset circuits. When the ILE is written, no data is required. When a shared interrupt adapter is enabled, the proper ILE must be issued before the device can begin interrupt operations. # I/O Channel Address Maps and Assignments # **Memory Address Map** | Hex Address | Name | Function | | |---------------------|-------------------------------------|------------------------------------------------------------------------------|--| | 000000 to<br>07FFFF | 512Kb | I/O channel memory - IBM Personal Computer AT 512KB Memory Expansion Option | | | 080000 to<br>09FFFF | 128 Kb | Additional I/O channel memory | | | 0A0000 to<br>0BFFFF | 128Kb video RAM | Reserved for graphics display buffer | | | 0C0000 to<br>0DFFF | 128Kb I/O<br>expansion ROM | Reserved for ROM on I/O adapters | | | 0E0000 to<br>0EFFFF | 64Kb Reserved on I/O channel memory | Duplicated code assignment at address FE0000 for Coprocessor option | | | 0F0000 to<br>0FFFFF | 64Kb ROM on the I/O channel memory | Duplicated code assignment at address FF0000 for Coprocessor option | | | 100000 to<br>CFFFFF | Maximum memory up to 12Mb | I/O channel memory reserved for<br>286 Coprocessor using Expansion<br>Option | | | D00000 to<br>D1FFFF | | Advanced Monochrome Graphics<br>Display | | | D40000 to<br>D5FFFF | | 286 Coprocessor video relocation buffer | | Figure 6-19 (Part 1 of 2). Memory Address Map | Hex Address | Name | Function | |---------------------|------|----------------------| | E00000 to<br>E1FFFF | | System expansion ROM | | FC0000 to<br>FFFFFF | | TCW pass through | Figure 6-19 (Part 2 of 2). Memory Address Map Note: All I/O channel memory addresses D00000-FFFFFF are reserved for RT PC system use. # I/O Address Map | Hex Address | Device | | |-------------|-----------------------------------------------------|--| | 0000-003F | Reserved | | | 0040-004F | 286 Coprocessor Access | | | 0440-044F | 286 Coprocessor Access | | | 0840-084F | 286 Coprocessor Access | | | 0C40-0C4F | 286 Coprocessor Access | | | 0050-00FF | Reserved | | | 0160-016F | Advanced Monochrome Graphics Display | | | 0170-0177 | Fixed-disk adapter #2 | | | 01E8-01EF | IBM RT PC Streaming Tape Drive Adapter (QIC-02) | | | 01F0-01F7 | Fixed-disk adapter #1 | | | 0278-027F | Parallel printer port 2 | | | 02D0-02DF | 3278/79 Emulation Adapter | | | 02F0-02F7 | Interrupt sharing | | | 02F8-02FF | Serial port 2 | | | 0300-031F | Prototype card | | | 0360-036F | PC Network | | | 0378-037F | Parallel printer port 1 | | | 03B0-03BF | Monochrome Display and Printer Adapter | | | 03B0-03DF | Enhanced Color Graphics Adapter | | | 03F0-03F7 | Diskette controller | | | 03F8-03FF | Serial port 1 | | | 0550-0557 | 286 Coprocessor communication with system processor | | Figure 6-20 (Part 1 of 2). I/O Address Map | Hex Address | Device | | |-------------|----------------------------------------|--| | 06F0-06F7 | Interrupt sharing | | | 1230-124F | First address range (multiport async) | | | 2230-224F | Second address range (multiport async) | | | 3230-324F | Third address range (multiport async) | | | 4230-424F | Fourth address range (multiport async) | | Figure 6-20 (Part 2 of 2). I/O Address Map Note: The I/O address of the Enhanced Color Graphics Adapter overlaps those of the Monochrome Adapter when it operates in PC monochrome compatibility mode. # **DMA Channels** The following is a list of the DMA channels and the devices associated with those channels. | Channel | Device | | |---------|-------------------------------|--| | 0 | Serial Port A | | | 1 | Serial Port B | | | 2 | Diskette Drive, Serial Port A | | | 3 | PC Network, Serial Port B | | | 5 | Reserved | | | 6 | Reserved | | | 7 | Reserved | | | 8 | 286 Coprocessor | | Figure 6-21. DMA Channels # **Interrupt Levels** The following is a list of the interrupt levels and what devices interrupt on the various levels. | Interrupt<br>Level | Device | | |--------------------|----------------------------------------------------------------------------------------------------|--| | 3 | Serial Port 2, PC Network | | | 4 | Serial Port 1 | | | 5 | Parallel Port 2 | | | 6 | Diskette Drive | | | 7 | Parallel Port 1,<br>Monochrome/Printer | | | 9 | PC Network, (Multiport Async),<br>Enhanced Color Graphics<br>Adapter, 3278/79 Emulation<br>Adapter | | | 10 | (Multiport Async) | | | 11 | (Advanced Monochrome<br>Graphics Display) (Multiport<br>Async) | | | 12 | (IBM RT PC Streaming Tape<br>Drive Adapter) | | | 14 | Fixed Disk | | | 15 | (286 Coprocessor) | | Figure 6-22. Interrupt Levels Note: The parentheses indicate a shared interrupt device. # I/O Slot Uniqueness One slot (Coprocessor) on each system board has some unique assignments that could make it incompatible with some PC cards. The slot has one new DMA channel (8), and it will not support memory board refresh. The board preassignment and unique pin assignment for the I/O slots is given below. | Slot | Unique | Connectors | Assignment | |------|--------|---------------|--------------------------| | 1 | No | 62-Pin/40-Pin | Disk/Diskette<br>Adapter | | 2 | No | 62-Pin/40-Pin | Option | | 3 | No | 62-Pin | Option | | 4 | No | 62-Pin/40-Pin | Option | | 5 | No | 62-Pin/40-Pin | Option | | 6 | No | 62-Pin | Option | | 7 | No | 62-Pin/40-Pin | Option | | 8 | Yes | 62-Pin/40-Pin | Coprocessor/Option | Figure 6-23. Model 20 and Model 25 System Boards | Slot | Unique | Connectors | Assignment | |------|--------|---------------|--------------------------| | 1 | No | 62-Pin | Option | | 2 | No | 62-Pin/40-Pin | Option | | 3 | No | 62-Pin/40-Pin | Option | | 4 | No | 62-Pin/40-Pin | Option | | 5 | Yes | 62-Pin/40-Pin | Coprocessor/Option | | 6 | No | 62-Pin/40-Pin | Disk/Diskette<br>Adapter | Figure 6-24. Model 10 System Board | Pin | I/O Slot<br>Standard | I/O Slot<br>Coprocessor | |-----|----------------------|-------------------------| | B19 | REFRESH | + SPK DRV | | D14 | DACK 7 | - DACK 8 | | D15 | DRQ 7 | + DRQ 8 | Figure 6-25. Unique Pin Assignments ### **Coprocessor Arbitration** The Coprocessor has the lowest DMA request priority on the I/O channel. However, when it is executing out of system memory or I/O channel attached RAM, it can hold on to the channel for multiple cycles to improve performance. When the Coprocessor requires an I/O channel cycle, it drives the DRQ8 signal active. When the channel becomes idle (that is, no other DRQ, PIO request or refresh request is pending) the system arbiter drives the -DACK8 signal active. The Coprocessor drives the -master signal active and then follows the ground rules for alternate controllers when driving the channel. If the channel remains idle, the Coprocessor executes until it is finished using the channel. It will then turn off the DRQ8 signal and end the alternate controller operation normally. If, however, the system arbiter receives a new request while the Coprocessor is active, it turns off the -DACK signal. The Coprocessor may complete any I/O channel operation that is in progress, and then it must tri-state its channel drivers and turn the DRO8 and -master signals off. When the DRQ8 signal turns off, the system arbiter will acknowledge another requestor. If the request was from the system processor, the IOCC may drive the channel immediately. The Coprocessor must wait at least 250 nanoseconds before re-issuing a DMA request. # **Connector/Pin Description and Electrical Characteristics** Refer to the following tables (starting in Figure 6-26) for the list of I/O signals and the associated electrical characteristics. Note: Capacitive load should not exceed 20 picofarads (pf) per signal per adapter. In an 8 adapter configuration channel capacitance will be 200pf maximum allowing 40pf on the system board. | Signal<br>Name | I/O<br>Pin | Driver<br>(Iol MIN ma) | Driver<br>Type | Receiver<br>(Iil MAX ma) | |----------------|------------|------------------------|----------------|--------------------------| | SA0 | A31 | 24 | TS | -0.4 | | SA1 | A30 | 24 | TS | -0.4 | | SA2 | A29 | 24 | TS | -0.4 | | SA3 | A28 | 24 | TS | -0.4 | | SA4 | A27 | 24 | TS | -0.4 | | SA5 | A26 | 24 | TS | -0.4 | | SA6 | A25 | 24 | TS | -0.4 | | SA7 | A24 | 24 | TS | -0.4 | | SA8 | A23 | 24 | TS | -0.4 | | SA9 | A22 | 24 | TS | -0.4 | | SA10 | A21 | 24 | TS | -0.4 | | SA11 | A20 | 24 | TS | -0.4 | | SA12 | A19 | 24 | TS | -0.4 | | SA13 | A18 | 24 | TS | -0.4 | | SA14 | A17 | 24 | TS | -0.4 | | SA15 | A16 | 24 | TS | -0.4 | | SA16 | A15 | 24 | TS | -0.4 | | SA17 | A14 | 24 | TS | -0.4 | | SA18 | A13 | 24 | TS | -0.4 | | SA19 | A12 | 24 | TS | -0.4 | | AEN | A11 | 24 | TS | -0.4 | | I/O CH RDY | A10 | 24 | OC | -2.0 | | SD0 | A09 | 24 | TS | -0.4 | | SD1 | A08 | 24 | TS | -0.4 | | SD2 | A07 | 24 | TS | -0.4 | | SD3 | A06 | 24 | TS | -0.4 | | SD4 | A05 | 24 | TS | -0.4 | | SD5 | A04 | 24 | TS | -0.4 | | SD6 | A03 | 24 | TS | -0.4 | | SD7 | A02 | 24 | TS | -0.4 | | -I/O CH CK | A01 | 24 | OC | -2.0 | | | | | | l | Figure 6-26. 62-Pin Connector Side A TS Tri-state drivers will be used for the class of signals which have multiple sources that are enabled one at a time. TSP Tri-state drivers for command lines will have pullups on the system board. - OCI Open collector drivers used for IRQ sharing require a 2.0K or 2.2K ohm $\pm$ 10% pullup on the I/O adapter. There is a 5K pullup on the system board. - X Optional. - OC Open collector drivers are required for signals that may be dotted together and simultaneously driven by multiple sources. The system board must supply a pull-up resistor for these signals. **Note:** A tri-state driver may be configured to operate properly in an "OC net" by grounding the driver input and using the output enable to control the driver output. | Signal | I/O | Driver | Driver | Receiver | |------------|-------------|--------------|----------------------|----------------| | Name | Pin | (Iol Min ma) | Туре | (Iil MAX ma) | | GND | B31 | | | | | OSC | B30 | X | X | -2.0 | | +5 | B29 | <del></del> | | | | BALE | B28 | 24 | OC | -0.4 | | T/C | B27 | 8 | $\mathbf{X}$ | -0.4 | | -DACK2 | B26 | 8 | X | -0.4 | | IRQ3 | B25 | 24 | OCI | -0.8 | | IRQ4 | B24 | 24 | OCI | -0.8 | | IRQ5 | B23 | 24 | OCI | -0.8 | | IRQ6 | B22 | 24 | OCI | -0.8 | | IRQ7 | B21 | 24 | OCI | -0.8 | | CLK | B20 | 24 | $\mathbf{X}^{\circ}$ | -2.0 | | -REFRESH | B19 | 40 | OC | -2.0 | | DRQ1 | B18 | 24 | TS | -0.2 | | -DACK1 | B17 | 8 | X | -0.4 | | DRQ3 | B16 | 24 | TS | -0.2 | | -DACK3 | B15 | 8 | X | -0.4 | | -IOR | B14 | 24 | TSP | -0.4 | | -IOW | B13 | 24 | TSP | -0.4 | | -SMEMR | B12 | 24 | TSP | -0.4 | | -SMEWM | B11 | 24 | TSP | -0.4 | | GND | B10 | | | · | | +12 | B09 | | <u> </u> | | | (RESERVED) | B08 | <u> </u> | | <del>-</del> | | -12 | B07 | : | _ | · | | DRQ2 | B06 | 24 | TS | -0.2 | | -5 | B05 | <u> </u> | | _ | | IRQ9 | B04 | 24 | OCI | -0.8 | | +5 | B03 | <b>—</b> | | <del> -</del> | | RESET DRV | B02 | 24 | X | -2.0 | | GND | <b>B0</b> 1 | - 1 | | · · | | | | | | | Figure 6-27. 62-Pin Connector Side B | Signal<br>Name | I/O<br>Pin | Driver<br>(Iol MIN ma) | Driver<br>Type | Receiver<br>(Iil MAX ma) | |----------------|------------|------------------------|----------------|--------------------------| | +5 (see note) | C20 | | _ | | | +5(see note) | C19 | | _ | _ | | SD15 | C18 | 24 | TS | -0.4 | | SD14 | C17 | 24 | TS | -0.4 | | SD13 | C16 | 24 | TS | -0.4 | | SD12 | C15 | 24 | TS | -0.4 | | SD11 | C14 | 24 | TS | -0.4 | | SD10 | C13 | 24 | TS | -0.4 | | SD9 | C12 | 24 | TS | -0.4 | | SD8 | C11 | 24 | TS | -0.4 | | -MEMW | C10 | 24 | TSP | -0.4 | | -MEMR | C09 | 24 | TSP | -0.4 | | LA17 | C08 | 24 | TS | -0.4 | | LA18 | C07 | 24 | TS | -0.4 | | LA19 | C06 | 24 | TS | -0.4 | | LA20 | C05 | 24 | TS | -0.4 | | LA21 | C04 | 24 | TS | -0.4 | | LA22 | C03 | 24 | TS | -0.4 | | LA23 | C02 | 24 | TS | -0.4 | | -SBHE | C01 | 24 | TS | -0.4 | Figure 6-28. 40-Pin Connector Side C Note: Pins C19 and C20 are additional +5 volt power pins provided on RT PC. | Signal<br>Name | I/O<br>Pin | Driver<br>(Iol MIN ma) | Driver<br>TYPE | Receiver<br>(Iil MAX ma) | |----------------|------------|------------------------|----------------|--------------------------| | GND (see note) | D20 | | _ | · · | | GND (see note) | D19 | _ | | | | GND | D18 | | | <del></del> | | -MASTER | D17 | 24 | OC | -2.0 | | +5 | D16 | _ | _ | | | DRQ7 | D15 | 24 | TS | -0.2 | | -DACK7 | D14 | 8 | X | -0.4 | | DRQ6 | D13 | 24 | TS | -0.2 | | -DACK6 | D12 | 8 | X | -0.4 | | DRQ5 | D11 | 24 | TS | -0.2 | | -DACK5 | D10 | 8 | X | -0.4 | | DRQ0 | D09 | 24 | TS | -0.2 | | -DACK0 | D08 | 8 | X | -0.4 | | IRQ14 | D07 | 24 | OCI | -0.8 | | IRQ15 | D06 | 24 | OCI | -0.8 | | IRQ12 | D05 | 24 | OCI | -0.8 | | IRQ11 | D04 | 24 | OCI | -0.8 | | IRQ10 | D03 | 24 | OCI | -0.8 | | -I/OCS16 | D02 | 24 | OC | -2.0 | | -MEMCS16 | D01 | 24 | OC | -2.0 | | | | | | | Figure 6-29. 40-Pin Connector Side D Note: Pins C19 and C20 are additional ground pins provided on RT PC. # Section 7. System IPL ROM # **CONTENTS** | About this Section | -3 | |---------------------------------------------------------------|----| | System IPL ROM 7- | | | Post Control Block Fields 7- | | | Slot Byte | -6 | | Interrupt Byte 7- | -6 | | DMA Byte 7- | -7 | | Primary Adapter Address 7- | -7 | | Secondary Adapter Address 7- | -7 | | Adapter Type 7- | -7 | | Error Code Word 7- | | | NVRAM Layout 7- | -8 | | NVRAM Requirements for Diagnostics | -9 | | Indicator Operation and Codes | -9 | | System State 7 | -9 | | Use of ROM Code by Loadable Software | -9 | | ROM Location 7-1 | | | Soft IPL 7-1 | 11 | | Restrictions and Conventions for Externally Callable Routines | 12 | | Register Conventions | 13 | | Display Codes 7-1 | | | Boot Record | 16 | # **About this Section** This section describes the IPL ROM programming necessary to start the RT PC from a powered down condition. It contains the layout for the power on self test (POST) control block and lists the IPL ROM display codes. # **System IPL ROM** The RT PC Initial Program Load (IPL) Read Only Memory (ROM) contains the programming necessary to start the RT PC from a powered down condition. It also provides other functions in support of diagnostics and user convenience re-IPL operations. The functions performed by the IPL ROM and the system requirements it imposes are also discussed. #### **POST Control Block** Internal ROM operation and results are recorded in the POST control block. The POST control block is located in Random Access Memory (RAM) and is created during the execution of ROM power-on self tests. The layout and system memory address assignments of the POST control blocks are shown in Figure 7-1 on page 7-5. At the end of ROM execution, the POST control block contains the following: - A four word entry for each power-on self test, as shown in Figure 7-2 on page 7-6. - 1. An ID that identifies which power-on self test was executed. - 2. An error code which indicates whether or not an error occurred during power-on self tests and, if so, what that error was. - 3. Two configuration words which specify the address, interrupt levels and Direct Memory Access (DMA) levels used on the board. - R/W memory size - List of bad blocks on 128K-byte boundaries - Machine type (Model 10, &clipper1, or Model 25) - Attached keyboard ID number, if available from keyboard - The IPL device number used for IPL - Soft IPL flag byte. The loadable POSTs execution adds an entry in the same format for each loadable POST executed. Figure 7-1. Layout of Post Control Block Figure 7-2. Layout of the Post Control Block Section Dedicated to One Post #### **Post Control Block Fields** The fields defined in Figure 7-2 have the following contents. ## **Slot Byte** The slot byte contains the slot number where the primary and secondary adapters were found. The least significant 4 bits are the primary adapter slot number and the most significant 4 bits are the secondary adapter slot number. A value of X'F' indicates that no adapter was found. ### **Interrupt Byte** The interrupt byte contains the interrupt level used by the primary and secondary adapters. The least significant 4 bits are the interrupt level of the primary adapter and the most significant 4 bits are the interrupt level of the secondary adapter. In the case of two levels used on a single adapter, both levels are indicated but refer to a single adapter. A value of X'8' indicates that no interrupts are used on the adapter or that the adapter is not present. # **DMA Byte** The DMA byte contains the DMA levels used by the primary and secondary adapters. The least significant 4 bits are the DMA level of the primary adapter and the most significant 4 bits are the DMA level of the secondary adapter. A value of hex "F" indicates that no DMA level is used. # **Primary Adapter Address** This 2 byte field contains the I/O address of the primary adapter. Hex 'FFFF' indicates no adapter responds to this address. # **Secondary Adapter Address** This 2 byte field contains the I/O address of the secondary adapter. Hex 'FFFF' indicates no adapter responds to this address. # **Adapter Type** This field contains the adapter type number. The 4 port async adapter overflows these definitions. The configuration data on this adapter conforms to this format for the primary and secondary adapters. Equivalent information on the third and fourth adapters is provided in a second information block in the POST control block as though these were a separate adapter type. #### **Error Code Word** Figure 7-3. Error Code Word The error code word is defined as follows: Bit 0 Bad/Good Bit 1 = Bad 0 = Good Bit 1 Present/Absent Bit 1 = Present 0 = Absent Bits 2-31 Thirty bits of error information #### **NVRAM Layout** The portion of the real time clock Non Volatile Random Access Memory (NVRAM), available for general use, is shown below. Of the 64 bytes of RAM, the last 50 are usable for applications other than the clock. Start of NVRAM is at system address X'F000880E'. F000880E - F000881D Error Log - 16 bytes Usage log F000881E - F0008827 F0008828 - F000882C IPL source table Configuration data F000882D - F0008835 F0008837 **Dialog Status** F0008838 **Shutdown Status** F0008839 - F000883A Reserved F000883B - F000883C **IPL Device IODN** F000883D Reserved F000883E - F000883F **NVRAM CRC Value** #### **NVRAM Requirements for Diagnostics** Diagnostics reserves the right to use portions of NVRAM as described above independent of the user installed operating system or hardware device drivers. Honoring this reservation avoids the destruction of data and allows the hardware to be serviced. #### **Indicator Operation and Codes** The codes displayed on the POST indicators during IPL ROM execution are listed in "Display Codes" on page 7-14 and are further explained in the diagnostics package. All codes not specifically listed are reserved for RAS purposes and future loadable POST releases. Indicators use is reserved for diagnostic and error recovery. The indicators should be blank during normal system software operation. #### **System State** The machine will be left with: - Interrupts disabled - All good memory initialized with good ECC - I/O subsystem I/O devices initialized and quiescent. #### **Use of ROM Code by Loadable Software** Parts of the ROM code may be usable by subsequent software under certain conditions. Since most of the ROM code was written in a high level language, certain restrictions apply to the use of the modules in the ROS entry point table. These restrictions and certain conventions required are detailed in "Restrictions and Conventions for Externally Callable Routines" on page 7-12. The user must provide the proper environment for any ROM modules used. A table of supported entry points (the ROS entry point table) is placed in ROM to support the system software IPL. This table is a list of entry points of modules which may be used. The table location is not guaranteed and must be located by the pointer stored at X'C18' in the POST control block. The order of the entry points in the POST control block is constant. As with all reused code, the ROM code may do a slightly different task than expected, so it should be thoroughly understood before use. For all ROM modules called from loaded code, the following must be observed: - ROM must be mapped into the address space. - Access must be made in real address mode. - Access must be made through the ROS entry point table pointer at X'C18' in the POST control block. - Location X'C28' must either contain 0 or the user must provide appropriate run time routines for the ROM execution. #### Disk and Diskette Sector Read Module Reuse The ROS entry point table contains entry points for modules to read sectors from disk and diskette. These modules accept the following parameters: - The object memory device - The physical address on the memory device as required by the memory adapter - A buffer pointer for the destination of the data obtained. The modules do a read operation to the selected memory device with up to three retries. The module returns an error code to the calling program to indicate resolution. The modules will not do physical block number translation or any write operation. #### **ROM Location** The ROM address is set to real address X '800000' in its initial execution. It is possible to respecify the ROM address to another location. This may cause a system crash, since the code is compiled to run at X '800000'. Some of the code may operate transparently at another address, but this is not guaranteed since some of the code is assembler coded for a specific address. The memory management unit disallows any reference to ROM in translate mode. The ROM entry point table provides for the use of ROM code by loaded code. It contains the following pointers, in the form of 4 byte absolute addresses: - Soft IPL entry point - Hard IPL entry point - Disk sector read module - Diskette sector read module - NVRAM Read/Write module - Power-on self test indicator change module - Speaker beep module. The table entries are offsets from the start of ROM. The ROS entry point table, is accessed by a pointer at location X'C18' in the POST control block. #### Soft IPL ROM code provides support for four IPL functions. These are: 1. Normal POR The normal power-on reset events discussed earlier in this section are performed. 2. Software initiated POR with memory clear The normal sequence of events discussed earlier in this section is performed but initiated by a software jump into ROM code. The single exception to running all power-on tests is that the disk or diskette tests are not rerun due to the timing restrictions. 3. Software initiated soft IPL with no memory clear The system code is reloaded while preserving the existing machine state as much as possible. Memory is not changed from its preexisting values except for those locations filled by the newly loaded code. This action is initiated by a software jump into ROM code. 4. Keystroke sequence initiated soft IPL with no memory clear The system code is reloaded while preserving the existing machine state as nearly as possible. Memory is not changed from its preexisting values, except for those locations filled by the newly loaded code. This action is initiated by the keyboard adapter activating the system processor reset signal. ROM supports these four functions by allowing ROM execution to begin at either of three entry points. These are: - POR entry by means of the system processor POR vector. Operation from this point will test for item four above and jump to the soft IPL entry if the keystroke sequence was the source. - 'Hard' IPL entry from software to mimic the POR action above when the keystroke sequence was not the cause. - 'Soft' IPL entry which will merely reload the system software without going through the power-on self tests or memory tests. The soft entry points cause execution of setup operations to insure that ROM can execute and then transfers control to the IPL controller. The effect is that all ROM power-on self tests are skipped, memory is not reinitialized, and a new IPL load is performed. The only power-on self test run is the NVRAM test. Running this test ensures that the user can redirect the optional IPL table. To cause a soft IPL to use a specific IPL device, the following actions could be used: - 1. Write the specific device number to be used in the IPL to the first position in the NVRAM IPL device order table, insuring good NVRAM CRC. - 2. Cause a soft IPL either to the 'clears memory' or the 'does not clear memory' ROM locations. #### **Re-IPL Entry Point Requirements** The following requirements must be met for execution from the ROM IPL entry points to proceed without error: - ROM must be mapped by the ROM specification register in the memory management unit to real address X'800000', which is the address to which ROM maps itself when power is turned on - RAM must not be mapped over the ROM addresses in real memory. Due to the internal operation of the memory management unit, real memory must be specified to be 8M-bytes or less in size before ROM is accessed or an exception will result from the conflicting specification. If RAM is mapped in an invalid manner, ROM execution causes an appropriate error display and operation halts. - Accesses must be made in real mode since ROM cannot be accessed in translate mode. - The first 2K-bytes of the post control block must be present in memory and contain correct values as determined by the power on execution of ROM. #### Information Left After Soft IPL When the post control block is created by the core sequence controller, the soft IPL byte is set to cold entry value (X'FF'). The soft IPL entry to ROM sets this byte to a warm entry value of X'00' By checking this byte, loaded software can determine whether it has been cold or warm started. If the soft IPL byte is set to the cold entry value (X'FF') by system software then all soft IPL initiations cause a hard IPL with memory clear. # **Restrictions and Conventions for Externally Callable Routines** To use any of the modules in ROM, the proper run time environment must be established. The ROM itself contains an appropriate run time environment. Use this environment if the POST control block is undisturbed and the calling software allocates the proper stack area as expected by the ROM. The stack limit pointer for ROM execution is saved in location X'C20' in the POST control block. The user must guarantee that all memory between the address stored in this pointer and the address contained in location X'804' is free for ROM stack use. This is typically about 32K-bytes. Also, the contents of location X'C28' must be 0 for the ROM to use its own run time environment during external calls. ## **Register Conventions** The following is a list of system processor register conventions for external calls to ROM modules on entry to external routines: | Register | Definition | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Destroyed over the call. | | 1 | Destroyed over the call. | | 2-7 | Contains the parameters in that order. If more than 6 parameters are used, register 7 is the address of a continuation list for more parameters. Registers 6 and 7 are preserved over the call. | | 8-13 | Working registers; values are preserved over the call, but the values are not used in ROM routines. | | 14 | Must point to the stack. | | 15 | Return address to calling routine. | | CS | Destroyed over calls. | | MQ | Destroyed over calls. | | The follows: | mg is a list of register conventions for antennal culture DOM | The following is a list of register conventions for external calls to ROM modules on exit from external routines: | Register | Definition | |----------|--------------------------------------------------------| | 2 | The first, or only, value returned by a function. | | 6-13 | Registers that are preserved by the invoked procedure. | | 14 | Stack address is restored by the invoked routine. | | 15 | Return address to caller. | | CS | Destroyed over calls. | | MQ | Destroyed over calls. | #### **Display Codes** The following is a list of the IPL ROM display codes. - 00 Initializing PC Mono adapter - 01 ROM CRC error - 02 Error testing for soft IPL - 03 Memory test- 1st 128K-bytes - 04 Processor board bad - 05 Processor board or memory bad - 07 IOCC test 1 - 08 Processor board failed in IOCC test - 09 Keyboard adapter - 10 System timer (RTC) - 11 Interrupt controller test - 12 DMA test - 13 Serial ports - 14 Fixed Disk 1 - 15 Fixed Disk 2 - 16 Diskette 1 - 17 Diskette 2 - 18 Reserved - 20 NVRAM CRC - 21 NVRAM order IPL - 22 ROM default order IPL - 23 No IPL device found - 24 D/D slot or address error - 25 Soft IPL check failure condition - 26 Attempting soft IPL - 27 Bootable code won't fit in available RAM - 29 Loadable code has been started - 30 PC Mono LPOST - 31 Enhanced Graphics Adapter LPOST - 32 Advanced Monochrome Graphics Display LPOST - 35 File 0 LPOST - 36 File 1 LPOST - 37 File 2 LPOST - 38 File 3 LPOST - 39 Diskette 0 LPOST - 40 Diskette 1 LPOST - 41 Diskette 2 LPOST - 42 Diskette 3 LPOST - 43 Coprocessor LPOST - 44 FPA LPOST - 45 Printer port (mono) LPOST - 46 PC 3278/79 Emulation Adapter LPOST - 50 PC network LPOST - 51 S/P Serial LPOST - 52 PC SDLC LPOST - 53 Async 232 Multiport 1 - 54 S/P parallel LPOST - 55 Async 232 Multiport 2 - 56 Async 422 Multiport 1 - 57 Async 422 Multiport 2 - 70 Memory board in slot C bad 512K board - 71 Memory board in slot C bad 2M board - 72 Memory board in slot C bad 1M board - 75 Memory board in slot D bad 512K board - 76 Memory board in slot D bad 1M board - 77 Memory board in slot D bad 2M board - 80 Locator LPOST - 81 Keyboard LPOST - 82 Speaker LPOST - 84 PC-AT memory board LPOST - 88 Machine check stop or system processor failure - 89 Unexpected PC or MC - 90 Streaming tape LPOST - 96 Memory board in slot C bad - 97 Memory board in slot D bad - 98 Both memory boards bad - 99 Keylock locked #### **Boot Record** The following diagram shows the IPL boot record for disk and diskette. Figure 7-4. IPL ROM Boot Record Format The following is an explanation of the fields in the boot record. Unique Identifier The characters "IBMA" in EBCDIC **Reserved fields** All reserved fields are set to zero. Number of cylinders The number of cylinders in the disk used; zero for diskette. Number of heads The number of heads in the disk used; zero for diskette. Sectors/Track The number of tracks in the disk used; zero for diskette. Sectors size The size of one sector in bytes. Formatted disk size Cylinder The cylinder containing the start of the loaded code. **Head** The head number to be used to read the loaded code. **Sector** The first sector of the loaded code. **Length in sectors** The length of the loaded code in sectors. Entry Point Offset The offset from the start of the loaded code to the first instruction. VRM cylinder head sector The address of the VRM minidisk in cylinder, head, sector format. # Section 8. System Compatibility ## **CONTENTS** | bout this Section | -3 | |--------------------------------------|----| | O Channel Compatibility 8- | | | System Board 8 | | | I/O Channel Signals 8 | | | Unique Pin Assignments | | | Compatibility With IBM PC Products 8 | | | Keyboard Compatibility 8 | | | Locator Compatibility 8 | | | PC Software Compatibility | -6 | # **About this Section** This section describes the RT PC system compatibility. RT PC is upward compatible only. The information provided in this section is for RT PC only. ## I/O Channel Compatibility #### **System Board** The RT PC system board uses an Input/Output Channel Controller (IOCC) to drive its I/O channel. The IOCC simulates the PC Family I/O channel and allows some PC I/O adapters to operate. However, there are some differences in the signal definitions. Some system board slots on the IBM RT PC have a 40-pin connector in addition to the 62-pin connector. Adapters that use the 40-pin connectors are not compatible with other IBM Personal Computers. Some of the PC-AT adapters and options are compatible. #### I/O Channel Signals - Addresses. All address lines on the RT PC I/O Channel are latched early in the I/O cycle. This is done for performance reasons. - BALE. The 'BALE' signal is held high at all times because the addresses are all latched by the I/O channel. - Oscillator. The 14.31818 MHz. oscillator is not synchronous with the system clock. - Clock. The clock line runs at a frequency of 4.77 MHz. #### **Unique Pin Assignments** The IBM RT PC System Boards each have one unique slot for the optional 286 Coprocessor board. This slot will not support memory refresh or DMA Channel 7. DMA channel 8 arbitration is different than DMA channels 0 through 3 and 5 through 7. The arbitration for DMA channel 8 is discussed in the Coprocessor arbitration section of this manual. The following chart shows the standard and unique pin assignments. | Pin | I/O Slot<br>Standard | I/O Slot<br>Coprocessor | |-----|----------------------|-------------------------| | B19 | REFRESH | + SPK DRV | | D14 | DACK 7 | - DACK 8 | | D15 | DRQ 7 | + DRQ 8 | ### **Compatibility With IBM PC Products** The IBM RT PC supports the following options and adapters: - IBM RT PC Streaming Tape Drive Adapter - PC Network Adapter - 4 Port Asynchronous RS232C Adapter - 4 Port Asynchronous RS422 Adapter - Serial/Parallel Adapter - 12-inch Advanced Monochrome Graphics Display - Monochrome Display and Printer Adapter - **Enhanced Graphics Adapter** - 286 Coprocessor - AT 512 KB Memory Expansion Option - Prototype Adapter - 3278/79 Emulation Adapter - Fixed Disk and Diskette Adapter. The IBM RT PC does not support any other options or adapters. It does not support any other keyboard or locator other than those sold with the product. **Note:** This information is accurate at the time of publication. ## **Keyboard Compatibility** The IBM RT PC keyboard is a 101 key unit. It is not plug or electrically compatible with any of the other IBM PC family keyboards. #### **Locator Compatibility** The IBM RT PC locator is not compatible with any other IBM PC family mouse hardware. ### **PC Software Compatibility** PC software compatibility is addressed in the IBM RT PC 286 Coprocessor Technical Reference manual. # **Section 9. User Input and Output Devices** #### **CONTENTS** | About this Section | <br>. 9-3 | |-----------------------------------------|-----------| | Keyboard | <br>. 9-4 | | Keyboard Command Set | <br>. 9-5 | | Other Keyboard Outputs | <br>. 9-6 | | Keyboard Layout | <br>. 9-7 | | Key Position Layout | <br>. 9-9 | | Connector Specifications | <br>9-10 | | Locator | | | Operational Characteristics | <br>9-11 | | Operation Modes | | | Commands | <br>9-12 | | Data Report | <br>9-14 | | Error Handling | | | Data Frame | <br>9-15 | | Voltage Interchange Information | <br>9-15 | | Connector Specifications | <br>9-16 | | Operator Panel | | | Two-Digit Display | <br>9-18 | | Keylock | | | Model 20 and Model 25 Battery Connector | 9-19 | # **About this Section** This section contains information about the keyboard and locator input devices and operator panel output device used by the IBM RT PC system. ## **Keyboard** The keyboard has a permanently attached cable. The cable's connector has a special overmolding that keys it to a connector at the rear of the keyboard. This shielded six-conductor cable has power (+5 Vdc), ground, two bidirectional signal lines, and two speaker lines. The cable is approximately 2.75 meters long. The keyboard uses a capacitive technology with a microcomputer (Intel 8049) performing the keyboard scan function. The keyboard has two tilt positions for operator comfort (7 and 15 degrees) and a speaker for use by the system for generating tones. The keyboard has 101 keys arranged in four major groups. The central portion of the keyboard is a standard typewriter layout. At the top are 12 user software defined function keys and four predefined function keys. To the immediate right of the central portion are 10 cursor control keys and on the far right is a numeric pad. The keyboard interface allows system software to have maximum flexibility in defining certain keyboard operations. This is accomplished by having the keyboard return a unique scan code for each key. All keys are individually programmable to recognize the following conditions: - Make only - Make/break - Repeat - Repeat make/break - Double rate repeat - Double rate repeat-make/break. Note: Repeat and repeat-make/break keys cannot be mixed on any keyboard. The repeat rate is programmable from 3 to 40 characters per second and repeat delay is programmable from 300 to 600 microseconds. A break code is formed by prefixing the scan code with X'FO'. The microcomputer (Intel 8049) in the keyboard performs several functions, including a self test at power-on or when requested by the system. Additional keyboard functions are: - Keyboard scanning - Buffering up to four key scan codes - Maintaining bidirectional serial communications with the system unit - Executing the hand-shake protocol required by each scan code transfer. # **Keyboard Command Set** | Hex<br>Command | Description | | | | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--| | <b>FF</b> | Reset: Perform power- | Reset: Perform power-on check and report. | | | | FE | Resend: Resend last by | yte. | | | | EE | Echo: Respond with X | 'EE'. | | | | FD | Set make: Set the subse | equent list of keys to make type keys. | | | | FC | Set make/break: Set th | ne subsequent list of keys to make/break. | | | | FB | Set repeat or repeat-ma repeat-make/break. | ke/break: Set the subsequent list of keys to repeat or | | | | F9 | Set all make: Set all the | e keys to make. | | | | F8 | Set all make/break: Se | t all keys to make/break. | | | | F7 | Set all repeat or repeat- | Set all repeat or repeat-make/break: Set all keys to repeat or repeat-make/break. | | | | F6 | Set default: Set all keys to repeat-make/break. | | | | | F5 | Default disable: Set all keys to repeat-make/break and disable scanning. | | | | | F4 | Enable: Start scanning. | | | | | F3 | Set repeat rate/delay: Set the repeat delay to $300 \text{ ms.} + 100 \text{ ms.}$ times the binary value of bits 1 and 2 (bit $0=MSB$ ). Set the repeat rate according to the following: | | | | | | Period = $(8 + A) \times 2^B \times .00313 \text{ s.}$<br>A = Binary value of bits 5, 6, 7<br>B = Binary value of bits 3, 4. | | | | | F2 | Read ID: Respond with | X'BFB0'. | | | | F1 | Toggle keytype menu: Change to the other menu. Alternate is the default. | | | | | | Standard Menu | Alternate Menu | | | | | Make Only<br>Make/Break<br>Repeat<br>Double Rate Repeat | Make Only Make/Break Repeat-Make/Break Double Rate Repeat-Make/Break | | | Set LED indicator: The LED indicators are set according to bits 5, 6, 7 of the ED subsequent byte. > Bit LED Num lock 5 Caps lock Scroll lock 6 # **Other Keyboard Outputs** #### **Hex Outputs Description** | | • | |-------|---------------------------------------------------------------------------------------------------------------------------------| | FE | Resend: Output by keyboard following receipt of a frame with incorrect parity or stop bit. | | FC | Command Reject: Output by keyboard following receipt of an invalid command or parameter. | | FA | ACK: Output by keyboard following receipt of any valid input other than Echo or Resend. | | 00 | Overrun: Placed in last position of the 4 position keystroke queue to indicate overflow of the queue. | | F0 | Break code: Prefixed to the scan code of a make/break key to indicate break of the key. | | AA | BAT completion code: Output following successful completion of the self-tests. Any other output indicates failure of the tests. | | EE | Echo: Output in response to 'Echo' command. | | BF B0 | Keyboard ID: Output in response to 'Read ID' command or following BAT completion code. | The following pages have figures that show the keyboard, the scan codes, and the keyboard interface connector specifications. # **Keyboard Layout** | Key | Scan | Key | Scan | Key<br>Pos | Scan<br>Code | Key<br>Pos | Scan<br>Code | |-----|------|-----|------|------------|--------------|------------|--------------| | Pos | Code | Pos | Code | Pos | Code | Fos | Code | | 1 | 0E | 33 | 23 | | | 97 | 73 | | 2 | 16 | 34 | 2B | | | 98 | 72 | | 3 | 1E | 35 | 34 | | | 99 | 70 | | 4 | 26 | 36 | 33 | | | 100 | 7E | | 5 | 25 | 37 | 3B | | | 101 | 7D | | 6 | 2E | 38 | 42 | | ŀ | 102 | 74 | | 7 | 36 | 39 | 4B | | | 103 | 7A | | 8 | 3D | 40 | 4C | | | 104 | 71 | | 9 | 3E | 41 | 52 | | | 105 | 84 | | 10 | 46 | 42 | 53 | | | 106 | 7C | | 11 | 45 | 43 | 5A | 75 | 67 | | | | 12 | 4E | 44 | 12 | 76 | 64 | 108 | 79 | | 13 | 55 | 45 | 13 | | | | | | | - | 46 | 1A | | | 110 | 08 | | 15 | 66 | 47 | 22 | 79 | 61 | | | | 16 | 0D | 48 | 21 | 80 | 6E | 112 | 07 | | 17 | 15 | 49 | 2A | 81 | 65 | 113 | 0F | | 18 | 1D | 50 | 32 | | | 114 | 17 | | 19 | 24 | 51 | 31 | 83 | 63 | 115 | 1F | | 20 | 2D | 52 | 3A | 84 | 60 | 116 | 27 | | 21 | 2C | 53 | 41 | 85 | 6F | 117 | 2F | | 22 | 35 | 54 | 49 | 86 | 6D | 118 | 37 | | 23 | 3C | 55 | 4A | | | 119 | 3F | | 24 | 43 | | | | | 120 | 47 | | 25 | 44 | 57 | 59 | 89 | 6A | 121 | 4F | | 26 | 4D | 58 | 11 | 90 | 76 | 122 | 56 | | 27 | 54 | | | 91 | 6C | 123 | 5E | | 28 | 5B | 60 | 19 | 92 | 6B | 124 | 57 | | 29 | 5C | 61 | 29 | 93 | 69 | 125 | 5F | | 30 | 14 | 62 | 39 | | | 126 | 62 | | 31 | 1C | | | 95 | 77 | | | | 32 | 1B | 64 | 58 | 96 | 75 | | | Figure 9-1. Scan Codes Table ## **Key Position Layout** Figure 9-2. Key Position Layout # **Connector Specifications** Figure 9-3. Keyboard Cable Connector #### Locator The locator uses a rubber coated ball and two optical encoders to indicate the x and y movement to the system. Two push button switches are located on the locator and their states are transmitted directly to the system. The locator is connected to the system with a thin 2.5 meter long cable whose connector has a special overmolding to key it to a connector on the rear of the system unit. The ball is removable for cleaning. #### **Operational Characteristics** Resolution Programmable to 25, 50, 100, or 200 counts per inch. Default=100. Sampling Rate Programmable to 10, 20, 40, 60, 80, or 100 reports per second. Default=100. Data Modes Stream (default), remote. **Scaling** Linear (default), exponential. $+12 \text{ VDC}, \pm 10\%, < 100 \text{ mA}$ **Power** returned by the locator. $+5 \text{ VDC}, \pm 5\%, < 300 \text{ mA}$ $-12 \text{ VDC}, \pm 10\%, < 100 \text{ mA}$ Protocol RS232C, 9600 baud, asynchronous full duplex, stop bit = 1, odd parity. #### **Operation Modes** | Mode | Description | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reset | At power on or on receipt of a Reset command, the locator performs a self test and transmits a four byte power on error report as follows: X'FF', X'08', X'00', X'00'. The following defaults are set: sampling rate = 100 reports per second, linear scaling, stream mode, 100 counts per inch, and disabled. | | Stream | In this mode the locator transmits a data report to the system, if a switch is pressed or released or if at least one count of movement has been detected. The maximum rate of transfer is the programmed sample rate. No transmissions occur while the locator is motionless unless a switch is operated, in which case the incremental movement report is zero. | | Remote | In this mode the locator transmits data only in response to a read data command. | | Wrap | In this mode any byte of data sent by the system, except X'01' or X'0F', is | # Commands | Hex<br>Command | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | Reset: Causes the locator to enter the reset mode. | | 06 | Read Configuration: Causes the locator to transmit one byte: X'20'. | | 08 | Enable: Allows the locator to begin transmissions if it is in stream mode. | | 09 | Disable: Used in stream mode to stop transmissions from the locator. The locator responds to all other commands while disabled. If the locator is in stream mode, it must be disabled prior to sending it any command that requires a response from the locator. | | 0B | Read X, Y Data: Used in remote mode to cause the locator to transmit one data report. | | <b>0E</b> | Set Wrap Mode: Puts the locator in wrap mode. | | <b>OF</b> | Reset Wrap Mode: Resets wrap mode. | | 78 | Set Exponential Scaling: Exponential scaling modifies the X and Y data reported by the following transform: | | | Transmitted value = Integer $\{2^{[(V \times S)/R.]-3}\}$ | | | Where: | | | V = the current incremental X or Y value S = sampling rate in samples/second R = resolution in counts/inch Integer = integer portion of the expression in brackets | | | Exponential scaling is only performed in stream mode. | | 6C | Reset Exponential Scaling: Restores linear scaling. | 73 Query Status: Causes the locator to send the following 4-byte status report: ``` Byte 1 Bit 0 Always = 1 Always = 1 1 2 Always = 1 3 Always = 0 4 0 = \text{Exponential scaling}; 1 = \text{Linear scaling} 0 = \text{Enabled}; 1 = \text{Disabled} 5 6 0 = Stream mode; 1 = Remote mode 7 Always = 1 Byte 2 Bit 0 1 = Right key depressed Always = 0 1 1 = Left key depressed 2 Bits 3-7 Always = 0 Byte 3 Bits 0-6 Current resolution setting (LSB = 6) 7 Always = 0 Current sampling rate (LSB = 7) Byte 4 Bits 0-7 ``` '8A' 'XX' Set Sampling Rate: Sets the sampling rate to the value indicated by byte 'XX' given below: #### Second ``` Sample Rate Byte 'XX' ``` ``` X'0A' 10/sec. X'14' 20/sec. 40/sec. X'28' X'3C' 60/sec. X'50' 80/sec. X'64' 100/sec. ``` '8D' '00' Set Stream Mode: Sets stream mode. '8D' '03' Set Remote Mode: Sets remote mode. '89' 'XX' Set Resolution: Sets the resolution to the value specified by byte 'XX' given below: | Second<br>Byte 'XX' | Resolution | | | |---------------------|------------|--|--| | X'00' | 200/inch | | | | X'01' | 100/inch | | | | X'02' | 50/inch | | | | X'03' | 25/inch | | | #### **Data Report** The data report format shown below is valid for both stream and remote modes: Negative values of X, and Y data are expressed in twos complement. If greater than 127 counts are counted in a sample interval, 127 is reported at the end of the interval. After a transmission the accumulators are set to zero. ## **Error Handling** If the locator detects an error during a self-test, it transmits, if possible, the power on error report with the error flag bit set (bit 6 of byte 2). If the locator detects an invalid command, parity, or framing error on any transmission from the system, it transmits the power-on error report with the error flag bit set within 25 ms. The locator responds to commands requiring a response within 25 ms. No more than four nonresponse commands may be sent to the locator in succession. In wrap mode, the host transmission will be returned by the locator exactly as received even if it contains a parity error. #### **Data Frame** The data frame is as follows: ## **Voltage Interchange Information** During the transmission of data, the marking condition denotes the binary state 1 and spacing condition denotes the binary state 0. For interface control circuits, the function is on when the voltage is more positive than +3 Vdc with respect to signal ground, and is off when the voltage is more negative than -3 Vdc with respect to signal ground. | Interchange Differential Voltage (A-B) | Binary<br>State | Signal<br>Condition | Interface<br>Control<br>Function | |----------------------------------------|-----------------|---------------------|----------------------------------| | Positive Voltage | Binary 0 | Spacing | = On | | Negative Voltage | Binary 1 | Marking | = Off | Figure 9-4. Locator Signal Levels # **Connector Specifications** Figure 9-5. Locator Cable Connector ## **Operator Panel** The operator panel is located on the front of the system unit. The panel consists of the keylock, power-on light and two-digit display. The keylock has both locked and unlocked positions. If you turn on the power switch while the keylock is in the locked position, the system stops, and the two-digit display indicates 99. You cannot enter keystrokes or perform any other operations until the keylock is turned to the unlock position. When you turn the keylock to the unlocked position, the power-on procedure and program loading continue. The keylock may be locked any time after the program is loaded and operating correctly. The power-on light is green, indicating that the power supply is functioning properly. The two-digit display provides information about the progress of the internal Power On Self Tests (POSTs) and errors encountered in software loading. Figure 9-6. Operator Panel #### **Two-Digit Display** The two-digit display on the front of the system unit indicates the operation of the internal POSTs that are run each time the unit is turned on. The digits indicate 88 (all sections on) when the power is first turned on. During POSTs, a sometimes very rapid sequence of numbers appear, indicating that corresponding numbered tests are being run. Although the numbers may sequence too fast to read, machine operation discontinues when an error requiring repair action is detected, and the number of the test that detected the error is displayed. If the system cannot complete its POST or the loading of its software, the indicators display a number denoting the presence of an error. The indicators will be blank if the program has loaded correctly. ### **Keylock** The keylock deactivates the keyboard and locks the cover on. You can lock the system whether the power is on or off. Turn the key clockwise to lock the system or counterclockwise to unlock it. The key can be removed in either position. When the keylock is in an unlocked position, you can: - Operate the system - Remove the frame cover on a Model 20 or Model 25 - Remove the frame cover on a Model 10 after removing the cover thumbscrews. When the keylock is in the locked position, you cannot: - Operate the keyboard and optional locator - Remove the covers without physical damage to the hardware. ## Model 20 and Model 25 Battery Connector On the Model 20 and Model 25 system unit only the battery plugs onto a connector mounted, on the back, near the center of the operator panel printed circuit board back. Figure 9-7. Model 20 and Model 25 Battery Connector # **Section 10. Power** # **CONTENTS** | About this Section | | |-------------------------|--------| | Input Power | | | | | | | | | | n 10-9 | | Power Supply Signals | | | Power Supply Protection | | # **About this Section** This section contains the system unit power specifications for the RT PC system. Included are the input and output power specifications and power signal definitions. # **Input Power** The following tables lists the input voltages and amperes for the Model 20, Model 25, and Model 10 systems. | Range | Voltage (Vac) | Current (Amperes) | |---------------------|---------------|--------------------------------------| | 115 Vac<br>50/60 Hz | Minimum 100 | Maximum 9 amperes (Includes 1.4 amps | | | Maximum 125 | for ac outlet) | | 220 Vac | Minimum 200 | | | 50/60 Hz | | Maximum 5 amperes | | | Maximum 240 | (Includes 0.8 amps | | | | for ac outlet) | Figure 10-1. Model 10 Input Power **Note:** The maximum in-rush current is 110 amperes. | Range | Voltage (Vac) | <b>Current (Amperes)</b> | |---------------------|---------------|---------------------------------------| | 115 Vac<br>50/60 Hz | Minimum 100 | Maximum 10 amperes (Includes 1.4 amps | | , | Maximum 125 | for ac outlet) | | 220 Vac | Minimum 200 | | | 50/60 Hz | | Maximum 6 amperes | | | Maximum 240 | (Includes 0.8 amps | | | | for ac outlet) | Figure 10-2. Model 20 and Model 25 Input Power Note: The maximum in-rush current is 110 amperes. # **Output Power** The power supply provides +5, -5, +12, and -12Vdc. The following figures show the output connector pin assignments and the regulation tolerance for the voltages. Note: The power supply also supplies 115 Vac or 220 Vac for the displays. | Conn | Pos | Voltage | Conn | Pos | Voltage | |------|-----|---------|------|-----|-----------| | P11 | 1 | +12 Vdc | P1 | 14 | Not used | | P11 | 2 | Ground | P1 | 15 | Not used | | P11 | 3 | Ground | P1 | 16 | Not used | | P11 | 4 | +5 Vdc | P1 | 17 | Ground | | | | | P1 | 18 | Ground | | P12 | 1 | +12 Vdc | P1 | 19 | Ground | | P12 | 2 | Ground | P1 | 20 | Ground | | P12 | 3 | Ground | P1 | 21 | Ground | | P12 | 4 | +5 Vdc | P1 | 22 | Ground | | | | | P1 | 23 | Ground | | P1 | 1 | +5 Vdc | P1 | 24 | Ground | | P1 | 2 | +5 Vdc | | | | | P1 | 3 | +5 Vdc | P4 | 1 | +12 Vdc | | P1 | 4 | +5 Vdc | P4 | 3 | Ground | | P1 | 5 | +5 Vdc | | | | | P1 | 6 | +5 Vdc | P3 | 1 | Sig. Gnd. | | P1 | 7 | +5 Vdc | P3 | 2 | Key plug | | P1 | 8 | +5 Vdc | Р3 | 3 | Not used | | P1 | 9 | +12 Vdc | P3 | 4 | POR | | P1 | 10 | -5 Vdc | Р3 | 5 | EPOW | Figure 10-3 (Part 1 of 2). Model 10 Power Connector Outputs and DC Load Distribution | Conn | Pos | Voltage | Conn | Pos | Voltage | |------|-----|----------|------|-----|----------| | P1 | 11 | Not used | P3 | 6 | +5 Vdc | | P1 | 12 | Not used | P3 | 7 | Not used | | P1 | 13 | -12 Vdc | P3 | 8 | Not used | Figure 10-3 (Part 2 of 2). Model 10 Power Connector Outputs and DC Load Distribution # **Model 10 Power Distribution Diagram** | Nominal<br>Output | Load Current<br>Minimum (A) | Load Current<br>Maximum (A) | Regulation<br>Tolerance | Connector | |-------------------|-----------------------------|-----------------------------|-------------------------|-------------| | +5 Vdc | 12.00 | 37.00 | +5% to -2% | P1, P3 | | +5 | 12.00 | | +5% to -3% | P11,<br>P12 | | -5 | 0.01 | 0.30 | +10% to -8% | P1 | | +12 | 1.50 | 7.20 | +5% to -4% | P1, P4 | | +12 | 1.50 | | +5% to -4% | P11,<br>P12 | | -12 | 0.01 | 0.60 | +10% to -8% | P1 | Figure 10-4. Model 10 Power Output Capability | Conn | Pos | Voltage | Conn | Pos | Voltage | |------|-----|---------|------|-----|----------| | P1 | 1 | +5 Vdc | J10 | 1 | +5 Vdc | | P1 | 2 | +5 Vdc | J10 | 2 | +5 Vdc | | P1 | 3 | +5 Vdc | J10 | 3 | +12 Vdc | | P1 | 4 | +5 Vdc | J10 | 4 | +12 Vdc | | P1 | 5 | Ground | J10 | 5 | Ground | | P1 | 6 | Ground | J10 | 6 | Ground | | P1 | 7 | Ground | J10 | 7 | Ground | | P1 | 8 | Ground | J10 | 8 | Ground | | | | | J10 | 9 | Ground | | P2 | 1 | +5 Vdc | | | | | P2 | 2 | +5 Vdc | P3 | 1 | EPOW | | P2 | 3 | +5 Vdc | P3 | 2 | Key plug | | P2 | 4 | +5 Vdc | P3 | 3 | POR | | P2 | 5 | Ground | P3 | 4 | -12 Vdc | | P2 | 6 | Ground | P3 | 5 | +12 Vdc | | P2 | 7 | Ground | P3 | 6 | -5 Vdc | | P2 | 8 | Ground | P3 | 7 | Ground | | | | | P3 | 8 | Ground | | | | | P3 | 9 | Ground | Figure 10-5. Model 20 and Model 25 Power Connector Outputs and DC Load Distribution # Model 20 and Model 25 Power Distribution Diagram | Nominal<br>Output | Load Current<br>Minimum (A) | Load Current<br>Maximum (A) | Regulation<br>Tolerance | Connector | |-------------------|-----------------------------|-----------------------------|-------------------------|-----------| | +5 Vdc | 12.00 | 45.00 | +5% to -2% | P1, P2 | | +5 | 12.00 | | +5% to -3% | J10 | | -5 Vdc | 0.01 | 0.60 | +10% to -8% | P3 | | +12 | 1.50 | 9.60 * | +5% to -4% | P3, J10 | | -12 | 0.01 | 0.80 | +10% to -8% | P3 | Figure 10-6. Model 20 and Model 25 Power Output Capability Note: \* Start current 16.5A # **Power Supply Signals** **Power On Reset** The power supply will provide an active low 'power supply reset' signal for a minimum of 200 milliseconds and a maximum of 500 milliseconds after the +5V has reached its operational level. Early Power Off Warning The 'early power off warning' (EPOW) signal is activated by the power supply if an input ac fault condition is detected. The EPOW guarantees a minimum of 2.0 milliseconds of in tolerance dc supply voltages. ## **Power Supply Protection** Output protection The power supply provides overvoltage, undervoltage and overcurrent protection monitored at each voltage level in the power supply. An overcurrent condition will not damage the power supply. Protect circuits are electronic devices that are reset by a power-off or power-on cycle. No load operation The power supply will operate with no load applied to the outputs and be within 30% of nominal dc voltages. The system will power off if operational temperature limits are exceeded. #### **Output voltage sequencing** No special sequencing is provided, however, under normal conditions all output voltages will reach regulated levels within 500 milliseconds. The negative voltage levels will equal or lead the positive levels when power is turned on and lag or equal the positive levels when power is turned off. # **Section 11. System Processor and MMU** # **CONTENTS** | About this Section | 11-7 | |------------------------------------|-------| | System Processor | | | System Organization And Control | 11-8 | | System Memory | 11-9 | | Processor Channel | 11-9 | | Programmed I/O | | | Processor | | | Processor States | | | Privileged and Unprivileged States | 11-12 | | General-Purpose Registers (GPR) | | | System Control Registers (SCR) | | | System Timer Facility | 11-17 | | Counter (COU) | | | Timer status | 11-18 | | System Timer Operation | | | Interrupts | | | Processor Priority | 11-20 | | Point of Interrupt | | | Error Handling | 11-21 | | Program Status | 11-21 | | Interrupt Registers | | | Occurrence of Interrupts | | | Interrupt Facility | | | Interrupt Servicing | | | Instruction Set | | | Instruction Formats | | | Memory Access | 11-30 | | Load and Store Instructions | 11-31 | | Load Character Short (LCS) | 11-31 | | Load Character (LC) | 11-31 | | Load Half Algebraic Short (LHAS) | 11-32 | | Load Half Algebraic (LHA) | 11-32 | | Load Half Short (LHS) | | | Load Half (LH) | | | Load Short (LS) | | | Load (L) | | | Load Multiple (LM) | | | Test and Set Half (TSH) | | | Store Character Short (STCS) | 11-34 | | Store Character (STC) | 11-35 | | Store Half Short (STHS) | 11-35 | | Store Half (STH) | | | Store Short (STS) | 11-36 | | | Store (ST) | 11-36 | |----|----------------------------------------------------------------------------------|-------| | | Store Multiple (STM) | 11-36 | | A | Idress Computation | 11-37 | | | Compute Address Lower Half (CAL) | 11-37 | | | Compute Address Lower Half 16-Bit (CAL16) | 11-37 | | | Compute Address Upper Half (CAU) | 11-38 | | | Compute Address Short (CAS) | 11-38 | | | Compute Address 16-Bit (CA16) | 11-38 | | | Increment (INC) | 11-39 | | | Decrement (DEC) | 11-39 | | | Load Immediate Short (LIS) | | | D. | anching | | | ים | Branch and Link Absolute (BALA) | 11-41 | | | Branch and Link Absolute with Execute (BALAX) | | | | Branch and Link Immediate (BALI) | | | | Branch and Link Immediate (BALI) Branch and Link Immediate with Execute (BALIX) | | | | Branch and Link (BALR) | | | | Branch and Link with Execute (BALRX) | | | | Jump on Condition Bit (JB) | | | | Branch on Condition Bit Immediate (BB) | | | | Branch on Condition Bit Immediate (BB) | 11-45 | | | Branch on Condition Bit immediate with Execute (BBA) | 11-45 | | | Branch on Condition Bit (BBR) | | | | Branch on Condition Bit with Execute (BBRA) | | | | Jump on Not Condition Bit (JNB) | 11-40 | | | Branch on Not Condition Bit Immediate (BNB) | 11-47 | | | Branch on Not Condition Bit Immediate with Execute (BNBX) | | | | Branch on Not Condition Bit (BNBR) | 11-48 | | _ | Branch on Not Condition Bit with Execute (BNBRX) | | | Tı | aps | | | | Trap On Condition Immediate (TI) | 11-49 | | | Trap if Register Greater Than or Equal (TGTE) | 11-50 | | | Trap if Register Less Than (TLT) | 11-50 | | M | oves and Inserts | | | | Move Character Zero From Three (MC03) | | | | Move Character One From Three (MC13) | | | | Move Character Two From Three (MC23) | 11-52 | | | Move Character Three From Three (MC33) | 11-52 | | | Move Character Three From Zero (MC30) | | | | Move Character Three From One (MC31) | 11-53 | | | Move Character Three From Two (MC32) | 11-53 | | | Move From Test Bit (MFTB) | | | | Move From Test Bit Immediate Lower Half (MFTBIL) | 11-54 | | | Move From Test Bit Immediate Upper Half (MFTBIU) | 11-54 | | | Move to Test Bit (MTTB) | 11-54 | | | Move to Test Bit Immediate Lower Half (MTTBIL) | 11-55 | | Move To Test Bit Immediate Upper Half (MTTBIU) | 11-55 | |-------------------------------------------------------|-------| | Arithmetic Operations | 11-56 | | Add (A) | 11-57 | | Add Extended (AE) | 11-57 | | Add Extend Immediate (AEI) | 11_57 | | Add Immediate (AI) | 11-58 | | Add Immediate Short (AIS) | 11-50 | | Absolute (ABS) | 11-50 | | Ones Complement (ONEC) | 11-50 | | Twos Complement (TWOC) | 11-59 | | Compare (C) | 11-59 | | Compare Immediate Short (CIS) | 11-39 | | Compare Immediate (CI) | 11-00 | | Compare Logical (CL) | 11-00 | | Compare Logical Immediate (CLI) | 11-01 | | Extend Sign (EXTS) | 11-01 | | Subtract (S) | 11-61 | | Subtract From (SF) | 11-62 | | Subtract Extended (CE) | 11-62 | | Subtract Extended (SE) | 11-62 | | Subtract From Immediate (SFI) | 11-63 | | Subtract Immediate Short (SIS) | 11-63 | | Divide Step (D) Multiply Step (M) | 11-63 | | Multiply Step (M) | 11-65 | | Logical Operations | 11-67 | | Clear Bit Lower Half (CLR2L) | 11-67 | | Clear Bit Upper Half (CLR2U) | 11-67 | | Set Bit Lower Half (SETBL) | 11-68 | | Set Bit Upper Half (SETBU) | 11-68 | | AND (N) | 11-68 | | AND Immediate Lower Half Extended Zeroes (NILZ) | 11-69 | | AND Immediate Lower Half Extended Ones (NILO) | 11-69 | | AND Immediate Upper Half Extended Zeroes (NIUZ) | 11-69 | | AND Immediate Upper Half Extended Ones (NIUO) | 11-70 | | OR (O) | 11-70 | | OR Immediate Lower (OIL) | 11-70 | | OR Immediate Upper (OIU) | 11-71 | | Exclusive OR (X) | 11-71 | | Exclusive OR Immediate Lower Half (XIL) | 11-71 | | Exclusive OR Immediate Upper Half (XIU) | 11-72 | | Count Leading Zeroes (CLZ) | 11-72 | | ShiftsShifts | 11-73 | | Shift Algebraic Right (SAR) | 11-73 | | Shift Algebraic Right Immediate (SARI) | 11-73 | | Shift Algebraic Right Immediate Plus Sixteen (SARI16) | 11-74 | | Shift Right (SR) | 11_74 | | Shift Right Immediate (SRI) | | |-----------------------------------------------------|--------| | Shift Right Immediate Plus Sixteen (SRI16) | 11-75 | | Shift Right Paired (SRP) | 11-75 | | Shift Right Paired Immediate (SRPI) | 11-75 | | Shift Right Paired Immediate Plus Sixteen (SRPI16) | 11-76 | | Shift Left (SL) | | | Shift Left Immediate (SLI) | | | Shift Left Immediate Plus Sixteen (SLI16) | | | Shift Left Paired (SLP) | | | Shift Left Paired Immediate (SLPI) | | | Shift Left Paired Immediate Plus Sixteen (SLPI16) | 11-78 | | System Control | | | Move to SCR (MTS) | | | Move from SCR (MFS) | 11-80 | | Clear SCR Bit (CLRSB) | | | Set SCR Bit (SETSB) | | | Load Program Status (LPS) | 11-81 | | Wait (WAIT) | 11-82 | | Supervisor Call (SVC) | | | Input/Output | | | Input/Output Read (IOR) | | | Input/Output Write (IOW) | | | I/O Capability | | | Programmed I/O | | | I/O Interrupt Requests | | | RAS Facilities | | | Internal Diagnostics | | | | | | Machine-Check Errors | | | Program-Check Errors | 11-8/ | | Simultaneous Program-Check and Machine-Check Errors | | | Multiple Occurrence of Errors | 11-91 | | Memory Management Unit | | | Address Translation Process | | | Address Translation Overview | | | Address Translation Hardware Operation | | | Segment Register Selection | | | Generation of The Virtual Address | | | TLB Operation | 11-98 | | TLB Reload from System Memory Page Tables | 11-101 | | Memory Access Control | | | | 11-108 | | | 11-109 | | Lockbit Processing | | | Reference And Change Bits | | | Control Registers | 11-113 | | I/O Base Address Register | <br>11-113 | |--------------------------------------------------------|------------| | RAM Specification Register | | | ROM Specification Register | <br>11-115 | | Translation Control Register | <br>11-117 | | Memory Exception Register | <br>11-119 | | Memory Exception Address Register | <br>11-124 | | Translated Real Address Register | <br>11-126 | | Transaction Identifier Register | <br>11-126 | | Segment Registers | | | TLB Entries | <br>11-128 | | RAS Mode Diagnostic Register | <br>11-131 | | Translation Assist Functions | <br>11-133 | | Purging TLB Entries | <br>11-133 | | Compute Real Address | | | I/O Address Assignments | | | I/O Base Address Register Initialization | | | Memory Management Unit Control Register Initialization | | | ECC Checking | <br>11-140 | # **About this Section** This section contains information about the system processor and the memory management unit. It also provides information for the system instruction set and the instruction formats. # **System Processor** # **System Organization And Control** A RT PC system consists functionally of a system processor, a memory management unit, system memory, a I/O channel converter, and input/output adapters. This structure is shown below: Figure 11-1. System Processor Block Diagram # **System Memory** The system processor provides direct addressable system memory for data and instructions. The data units in system memory are shown below. Figure 11-2. Data Units in System Memory System memory is organized as a sequence of 32-bit words, each consisting of four 8-bit bytes. Bytes in the system memory are consecutively numbered, left to right, starting with 0. Each number is considered the address of the corresponding byte. All addresses are computed as byte addresses. The address of a word has zeros in the two low-order bits. The address of a halfword has one 0 in the low-order bit. Instructions must be located on halfword boundaries. All memory effective addresses (base address plus displacement) are computed as 32-bit quantities. Wrap around is allowed and occurs on a 32-bit basis, that is, system memory addressing wraps around from the maximum byte address of 4,294,967,295 to address 0. #### **Processor Channel** The processor channel provides a 32-bit plus 4 parity-bits wide synchronous, which cycles at twice the processor cycle rate. The purpose of the channel is to enhance processor performance by having a channel dedicated to processor and memory transfers. All data and addresses transferred on the channel are multiplexed on the 32 address data lines. An optional address extension channel consisting of 8 address lines plus parity is provided for systems using 32-bit addressing. Devices connected to the processor channel are identified by a 5-bit tag identifier that devices send on the processor channel simultaneously with their request. Arbitration is accomplished by using a linear arbitration mechanism with devices connected in a daisy chain. The system processor, memory management unit, and the I/O channel converter (IOCC) interface logic are the only system components attached to this processor channel. # Programmed I/O Programmed I/O is allowed using the Input/Output Read (IOR) and Input/Out Write (IOW) instructions. With these instructions, I/O devices can be read or written synchronously with program execution. #### **Processor** The processor contains the sequencing and processing controls for instruction execution, interrupt action, the system timer, and other control related functions. Instructions are grouped into ten classes: - Memory access - Computation - Branching - Traps - · Moves and inserts - Arithmetic operations - Shifts - System control - Input/output. A separate subsection is devoted to each instruction class (see "Instruction Set" on page 11-27). ## **Processor States** Four states of the processor are defined: - · Execution state - Wait state - · Check stop state - Stopped state. #### **Execution State** The processor is in the execution state when it is executing instructions. In the executing state, instruction fetching and execution proceeds in the specified manner. Interrupts may occur between instructions as specified in "Instruction Set" on page 11-27. #### Wait State After the processor executes the Wait instruction, it is in the wait state. No other instructions are fetched or executed while the processor is in the wait state. The processor leaves the wait state and enters the executing state when an interrupt for which the processor is enabled occurs (see "Interrupts" on page 11-19). The instruction address in the old program status for the priority level associated with the interrupt contains the address of the instruction immediately following the Wait instruction. The I/O pin 'wait' is active when the processor is in the wait state. #### **Check Stop State** When the processor is in the check stop state, instructions are not executed, interrupts do not occur, and system interface operations may be suspended. The processor enters the check stop state when one of the following occurs: - 1. An error is detected during power-on diagnostics. - 2. A machine check error is detected and the check stop mask is 0. - 3. A program check or machine check error is detected and the processor is servicing a machine check error. - 4. A program check error is detected and the processor is servicing a program check error. The check stop condition is cleared during a power-on reset. The processor machine check is described in "Machine-Check Status" on page 11-86 and the program check is described in "Program-Check Status" on page 11-87 #### **Stopped State** The stopped state is entered as a result of operator action from a control panel. Operator-initiated load, display, and stepping functions occur in the stopped state. # **Privileged and Unprivileged States** The selection between privileged and unprivileged state determines whether the full set of instructions is valid. In privileged state, all instructions are valid. In unprivileged state, only instructions that cannot be used to affect system integrity are valid. Privileged instructions include those that inspect or modify any system control registers (except the condition status or multiplier quotient registers), the Load Program Status instruction, and the Wait instruction. A privileged instruction encountered in the unprivileged state constitutes a privileged instruction exception and causes a program check. Refer to "Privileged Instructions" on page A-8 for a list of the privileged instructions. The processor is in unprivileged state when bit 21 of the interrupt control status (ICS) register is a one. The processor is in privileged state when bit 21 of the ICS is a zero. # **General-Purpose Registers (GPR)** The processor provides sixteen 32-bit general-purpose registers (GPRs). All manipulation of data is performed in the GPRs. Each GPR consists of an upper and lower half of 16 bits each. The GPR may be partitioned into four 8-bit characters, C0, C1, C2, and C3. The general-purpose register organization is shown in Figure 11-3. For computation purposes, the content of a GPR is treated as either a signed algebraic quantity, an unsigned positive quantity, or an unstructured logical quantity. In a GPR, an algebraic quantity is represented by 32 bits in twos complement form. | | Re | gister | | |------------|----|--------|-----------| | Upper Half | | L | ower Half | | C0 | C1 | C2 | СЗ | | 0 | 8 | 16 | 24 31 | Figure 11-3. General-Purpose Registers | GPR 0<br>GPR 1 | Register Pair | |------------------|---------------| | GPR 2<br>GPR 3 | Register Pair | | GPR 4<br>GPR 5 | Register Pair | | GPR 6<br>GPR 7 | Register Pair | | GPR 8<br>GPR 9 | Register Pair | | GPR 10<br>GPR 11 | Register Pair | | GPR 12<br>GPR 13 | Register Pair | | GPR 14<br>GPR 15 | Register Pair | Figure 11-4. General Purpose Register Pairs # **System Control Registers (SCR)** Sixteen 32-bit SCRs exist in the processor. An entire SCR or fields within an SCR are assigned to particular facilities in the system such as interrupt, processor, and system timer. The register organization for SCRs is shown below. Some SCRs and SCR fields are reserved and are not assigned to any system facility. The source bits are ignored on an attempt to set the reserved bits of an SCR. When the reserved bits of an SCR are fetched, the resulting values are unpredictable. | Reserved | | SCR 0 | | |----------------|------------|--------|--------| | Res | erved | | SCR 1 | | Res | erved | | SCR 2 | | Reserved | | SCR 3 | | | Reserved | | SCR 4 | | | Reserved | | SCR 5 | | | Counter Source | | SCR 6 | | | Counter | | SCR 7 | | | Reserved | | тѕ | SCR 8 | | Reserved | | SCR 9 | | | Multiplie | r Quotient | | SCR 10 | | Reserved | MCS | PCS | SCR 11 | | Reserved | IR | В | SCR 12 | | IAR | | SCR 13 | | | Reserved | IC | S | SCR 14 | | Reserved CS | | SCR 15 | | Figure 11-5. SCR Organization The system control registers are defined as follows: #### **SCR** Description #### 0 - 5 Reserved - 6 Counter Source: Is a 32-bit value that is automatically loaded into the counter when an alarm occurs. - Counter: Is a 32-bit count-down counter. The counter is decremented from an external source connected to the I/O pin '-Timer Clock'. The counter is updated on an inactive to active transition of '-Timer Clock'. Execution of processor instructions is suspended during the counter update. When the counter is decreased from 1 to 0, the value contained in the counter source is loaded into the counter and the alarm action is initiated. The alarm action sets a bit in the IRB whose priority level corresponds to the timer interrupt priority in SCR 8, if the timer is enabled. The alarm also sets the interrupt status bit to 1, and updates the timer status. The contents of the counter source are not altered. - 8 Timer Status (TS): Bits 24-31 of SCR 8, is defined as follows: - Bit 24 Reserved - Bit 25 Enable: When 0, no interrupts are created. This does not start or stop the counter, but enables or disables the setting of IRB bits. At power-on reset, this bit is 0. - Bit 26 Interrupt status: When 1, an alarm has occurred. This is set only if an alarm has occurred, and the enable bit is set to 1. This bit is reset by software when the counter is serviced. Software can reset this bit by executing a Clear SCR Bit (CLRSB) instruction. - Bit 27 Overflow: When 1, more than one alarm has occurred before the interrupt status bit has been reset. This bit is also reset by software when the counter is serviced. - Bit 28 Reserved - Bits 29-31 Timer interrupt priority: A timer alarm sets an IRB bit, corresponding to the priority level specified by this field, if the timer is enabled. #### 9 Reserved - Multiplier Quotient: The MQ provides a GPR extension to accommodate the product for the Multiply Step instruction and the dividend for the Divide Step instruction. (See hdref refid=instr.). - Machine Check Status and Program Check Status: Bits 16-23 of SCR 11 are referred to as the machine check status (MCS) and bits 24-31 are referred to as the program check status (PCS). These two fields are used for error identification and are described in detail in "Machine-Check Status" on page 11-86 and "Program-Check Status" on page 11-87. - Interrupt Request Buffer: Bits 16-31 of SCR 12 are referred to as the interrupt request buffer (IRB). The interrupt request buffer allows interrupt requests to be generated under program control. For more detailed information refer to "Interrupt Request Buffer" on page 11-24. - Instruction Address Register: The instruction address register is a 32-bit register that contains the address of the next instruction to be executed. Since all instructions lie on halfword boundaries, the low-order bit (bit 31) of the instruction address register is 0. Accesses for instructions may require the fetching of a word, a halfword, or the low-order halfword of a word followed by the high-order halfword of the next consecutive word in system memory. When executing an instruction, the content of the instruction address register is increased by the length of the current instruction. Should this instruction be a successful branch or jump instruction, the content of the instruction address register is changed to the address of the branch or jump target instruction. The IAR contains the address of the next instruction when the IAR is saved as part of the program status and when a system control instruction to read the IAR is executed. - Interrupt Control Status: Bits 16-31 of SCR 14 are referred to as the interrupt control status (ICS). The ICS contains the following: - parity error retry interrupt enable bit Name and Definition - memory protect bit - · unprivileged state bit, - translate mode bit - interrupt mask - · check stop mask - register set number - processor priority. Rit(c) The ICS is described in "Interrupt Control Status" on page 11-24. Condition Status: Bits 16-31 of SCR 15 are referred to as the condition status (CS). The condition status contains information about the results of certain operations and provides a mechanism for decision making. The condition status is defined as follows: | <b>D</b> 10(3) | Name and Definition | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16-23 | Reserved | | 24 | <b>Permanent zero:</b> Set to 0 whenever the condition status is loaded, and cannot be set to 1. Its presence provides for a guaranteed branch or jump by use of a branch on the not-condition bit or jump on the not-condition bit instruction specifying the permanent zero bit. | Less Than (LT): Set to 1 during logical, shift, and certain arithmetic 25 instructions if the result is negative; otherwise, it is set to 1. Less than is also set during compare instructions to indicate the relative algebraic magnitudes of the comparands. Equal (EQ): Set to 1 during logical, shift, and certain arithmetic 26 instructions if all bits of the result are zeros; otherwise, it is set to 0. It is also set during compare instructions if the comparands are equal. Greater Than (GT): Set to 1 during logical, shift, and certain arithmetic 27 instructions if the sign bit of the result is 0 and the result is nonzero; otherwise, it is set to 0. It is also set during compare instructions to indicate the true relative algebraic magnitudes of the comparands. Carry Zero (C0): Set to 1 during certain arithmetic instructions if the 28 operation generates a carry out of bit position zero; otherwise, it is set to 0. 29 Reserved Overflow (OV): Set to 1 during certain arithmetic instructions if the signed 30 result of the operation cannot be represented in 32 bits; otherwise, it is set to 0. **Test Bit (TB)**: Set by the move-to-test bit instructions, where a specified 31 bit of half of a register is moved to the test bit. It is also affected by All bits of the Condition Status, except the Permanent Zero bit, can be set through use of the move to SCR instructions. instructions that load or directly alter the Condition Status register. A 4-bit field in the conditional branch instructions specifies the condition status bit to be tested. A 0 in the 4-bit field of a branch instruction specifies bit 16 of the condition status, a 1 specifies bit 17 of the condition status, and so on. A 3-bit field in the conditional jump instructions specifies the condition status bit to be tested. A 0 in this 3-bit field specifies bit 24, a 1 specifies bit 25, and so on. # **System Timer Facility** Many applications require a knowledge of real time for such functions as system counting, time slicing, time stamping, interval timing, and timing the productivity of operations. The system timer facility provides these functions. For some devices, the device requirements may be such that additional timers are needed in the adapter. A more sophisticated timer can be provided by the I/O device, if needed. The system timer frequency is programmable by system software. The default frequency is approximately 1 KHz. It is referred to as the 1 millisecond timer clock. It is provided by the real time module on the system board. # **Counter (COU)** SCR 7 is referred to as the COU and is a 32-bit count-down counter. The counter is decreased from an external 1 msec signal connected to the I/O pin '-Timer Clock'. The processor instruction execution is suspended during the counter update. When the counter is decreased from 1 to 0, the value contained in the counter source is loaded into the counter and the alarm action is initiated. Normal operations of this action continues by the time the next count pulse arrives. The alarm action sets a bit in the IRB whose priority level corresponds to the timer interrupt priority in SCR 8, if the timer is enabled. The alarm also sets the interrupt status bit to 1, and updates the timer status. The contents of the counter source are not altered. #### Timer status The timer status (TS), bits 24-31 of SCR 8, is defined as follows: | Bit 24 | Reserved | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 25 | Enable: When 0, no interrupts are created. This does not start or stop the counter, but enables or disables the setting of IRB bits. At power-on reset, this bit is 0. | | Bit 26 | Interrupt status: When 1, an alarm has occurred. This is set only if an alarm has occurred, and the enable bit is set to 1. This bit is reset by software when the counter is serviced. Software can reset this bit by executing a Clear SCR Bit (CLRSB) instruction. | | Bit 27 | Overflow: When 1, more than one alarm has occurred before the interrupt status bit has been reset. This bit is also reset by software when the counter is serviced. | | Bit 28 | Reserved | | Bits 29-31 | Timer interrupt priority: A timer alarm causes the setting of an IRB bit corresponding to the priority level specified by this field if the timer is enabled. | # **System Timer Operation** To provide an interval timer, the counter is directly loaded with a value corresponding to the amount of time until the interval is to expire. To provide a fixed interval interrupt, an appropriate value is loaded into the counter source and is not changed. For example, if the counter source was loaded with X'05', and a 1 millisecond timer clock, the processor is interrupted every 5 milliseconds; if it was loaded with 250 (X'FA'), the processor is interrupted every one-fourth of a second. The software then updates internal memory locations and provides time-of-day in whatever format desired. Loading the counter source does not alter the value in the counter. As a result, the interrupt interval corresponding to the value loaded into the counter source begins when the counter is decreased from 1 to 0, and the new counter source is loaded into the counter. To synchronize the counter with a new counter source, both the counter source and the counter must be loaded with the new counter source value. Multiple simultaneous timings can be handled using the system timer as a resource. The counter is loaded from a queue whose entries are calculated to be the time from the completion of the previous entry until the time for the entry in question to be completed. The value loaded into the timer interrupt priority (TS, bits 29-31) must be greater than or equal to zero (000) and less than or equal to six (110). These are the only values for which a corresponding IRB exists. A value of seven (111) in the timer interrupt priority sets no bit in the IRB when a timer interrupt occurs. # **Interrupts** The interrupt facility permits the processor to change its status at the request of some other system component or processor conditions established by the program. Interrupt processing consists of saving the current program status and establishing the program status for servicing the interrupt. Interrupts only occur on instruction boundaries, but some instruction sequences are not interruptible. A Load Program Status (LPS) instruction is provided for software to return from an interrupt. Execution of an LPS instruction restores the IAR, the CS, and the ICS to the values that existed when the interrupt occurred. The processor may also change its status, as a result of error conditions, within the processor or a system component. Error processing consists of saving the current program status and establishing the program status for servicing the error. Errors are grouped into two classes: machine check errors and program check errors. These errors are discussed in detail in "Machine-Check Errors" on page 11-85 and "Program-Check Errors" on page 11-87. The interrupt facility is a priority-based mechanism. This permits the servicing of higher priority functions to take precedence over the servicing of lower functions. Interrupt sources consist of the seven external interrupt inputs (-REQI0-6), software interrupts posted through setting of bits in the IRB, and error conditions (either the '-TRAP' input, or internal errors) detected during system operation. The seven external interrupt inputs and software setting of IRB interrupt request bits are treated in the same manner by the system processor. The interrupt request level is compared to the current processor priority specified by bits in the ICS. If the interrupt request represents a higher priority than the current processor priority, and interrupts are enabled by the interrupt mask in the ICS, then the interrupt is taken. Servicing an interrupt consists of saving the current processor status in the old PSW corresponding to the level of the interrupt request, and loading a new processor status from the new PSW corresponding to the level of the interrupt request. Saving the current processor status requires saving the address of the instruction, the condition status, and the ICS when the interrupt occurred. Loading the new processor status requires loading the new IAR (containing the address of the interrupt service routine) and the new ICS from the new PSW. Saving the current processor status and loading the new processor status is performed automatically by system processor hardware. The GPRs are not automatically saved by hardware. Software is responsible for saving any GPRs modified by the interrupt service routine. Once the interrupt has been serviced, execution of the old program can be resumed by loading the old program status word through an LPS instruction. This will restore the IAR, the CS, and the ICS to the values that existed when the interrupt occurred. In addition to the seven interrupt levels, the detection of error conditions can cause interrupts to the program check and machine check interrupt levels. Interrupts to the program check level consists of errors that are probably due to software errors (that is, detection of an invalid op-code, addressing error, detection of a privileged instruction exception,). Interrupts to the machine check level consists of errors that are probably due to hardware errors (that is, processor channel parity errors, and processor channel timeouts). In addition, an external input '-Trap' can be used by system components to cause a machine check interrupt. See "Machine-Check Status" on page 11-86 and "Program-Check Status" on page 11-87 for description of Machine Check and Program Check interrupts. # **Processor Priority** Under normal system conditions, the processor executes instructions at a level of priority referred to as the processor priority. The processor priority may assume one of eight levels as specified by a 3-bit field in the ICS. Priorities for the eight levels are represented by the following inequality: Priority of Level 0 >Priority of Level 1 > ... >Priority of Level 7 The processor priority may be changed either by an interrupt or by an instruction that modifies the processor priority. There are two sources of interrupts: an interrupt condition signaled through the interrupt request buffer, or an interrupt condition signaled by some system component through the seven interrupt request inputs '-REQ10-6'. The processor may also execute instructions at two levels that are not accessible through the interrupt facility. These levels are provided for the reporting and servicing of machine check and program checking error conditions as discussed in "Machine-Check Errors" on page 11-85 and "Program-Check Errors" on page 11-87. # **Interrupt Request Priority** Interrupt requests occur on one of seven priority levels. Priorities for the seven levels are represented by the following inequality: Priority of level 0 > Priority of Level 1 >...> Priority of Level 6. The processor may execute instructions with a processor priority of 7, but interrupt requests with a priority of 7 cannot occur. #### **Interrupt Priority Assignment** A bit being set to 1 in the interrupt request buffer causes an interrupt request to the level corresponding to that bit. Timer interrupts cause an interrupt request (through the IRB) to the level specified in the timer status. A system component causes an interrupt request at a level determined by the attachment of its interrupt request line '-REQI0-6' to the processor. # **Point of Interrupt** Interrupts only occur on instruction boundaries. Furthermore, interrupts are prevented from occurring within certain instruction sequences. A branch with execute instruction and its subject instruction cannot be interrupted. A branch with execute and its subject instruction is considered to be a unit, and interrupts only occur before or after the unit is executed. See "Instruction Set" on page 11-27. # **Error Handling** If the processor is executing an error routine as a result of a machine check or program check error condition, all interrupt requests from system components and interrupts signaled through the IRB remain pending. # **Program Status** The program status consists of the contents of the following system control registers: - Instruction address register - Condition status - Interrupt control status. Upon interrupt, the current program status is automatically saved in the old program status location. The program status for servicing the interrupt is loaded from the new program status location, with the exception of the condition status. The condition status is not changed by loading the new program status. ## Old and New Program Status Pairs An old and new program status pair consists of eight bytes of old program status and eight bytes of new program status. When an interrupt occurs, the old and new program status pair is specified by the priority level of the interrupt. #### Location of Old and New Program Status Pairs The program status save area in system memory contains the old and new program status pairs. Two old and new program status pairs are for machine check and program check error handling. One old and new program status pair is used for the Supervisor Call (SVC) instruction, and the remaining seven are for interrupt servicing. The SVC old and new program status pair contains a 16-bit SVC interrupt code which is generated by execution of the SVC instruction (See "Supervisor Call (SVC)" on page 11-82). The 16-byte old and new program status pairs are located in consecutive system memory locations. The program status save area is located at addresses X'100' through X'19F'. Address translation is disabled for storing of the old program status and loading of the new program status. The program status save area in system memory is shown below: | Memory<br>Address | Definition | |-------------------|-----------------------------------| | X'100' | Old and New PS Pair 0 | | X'110' | Old and New PS Pair 1 | | X'120' | Old and New PS Pair 2 | | X'130' | Old and New PS Pair 3 | | X'140' | Old and New PS Pair 4 | | X'150' | Old and New PS Pair 5 | | X'160' | Old and New PS Pair 6 | | X'170' | Machine Check Old and New PS Pair | | X'180' | Program Check Old and New PS Pair | | X'190' | SVC Old and New PS Pair | Figure 11-6. Old Program Status Figure 11-7. New Program Status Figure 11-8. SVC New Program Status IAR = Instruction Address Register ICS = Interrupt Control Status CS = Condition Status SVC = Supervisor Call Note: Reserved bits in the old program status are set to unpredictable values. Reserved bits in the new program status are ignored. #### **Interrupt Registers** Two fields are provided within the system control registers to support the interrupt facility. They are the interrupt request buffer and the interrupt control status. #### **Interrupt Request Buffer** The Interrupt Request Buffer (IRB) is a 16-bit field in SCR 12 and has the following format: | Bit(s) | Interrupt Request Level | |--------|-------------------------| | 16 | Level 0 | | 17 | Level 1 | | 18 | Level 2 | | 19 | Level 3 | | 20 | Level 4 | | 21 | Level 5 | | 22 | Level 6 | | 23-31 | Reserved | | | | The IRB can generate interrupt requests under software control. Setting an IRB bit to 1 causes an interrupt request to the level corresponding to that bit. The interrupt request remains active until the bit is cleared by software. If bit 25 of SCR 8 is 1 (enabled), a timer alarm caused by the counter being decreased from 1 to 0 sets a bit in the IRB, which generates an interrupt request. The set bit in the IRB is determined by the timer interrupt priority in the timer status. #### **Interrupt Control Status** The interrupt control status (ICS) is a 16-bit field in SCR 14 with the following format: Note: Bits are on (1) unless stated otherwise. | Bit(s) | Name and Description | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | 16-17 | Reserved | | | 18 | Reserved | | | 19 | Parity Error Retry Interrupt Enable: Enables interrupts when a processor charetry successfully completes a processor-generated transfer that was previous unsuccessful due to detection of a parity error. A successful parity error retrinterrupt will cause a level 0 interrupt by setting the interrupt request level 0 | sly<br>y | | | 16) in the interrupt request buffer. The processor channel check bit (bit 16) in the machine check status indicates the cause of the interrupt. | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20 | Memory Protect: Enables address checking in the memory controller. | | 21 | Unprivileged State: | | | If bit 21 equals 0, the processor is in privileged state. | | | If bit 21 equals 1, the processor is in unprivileged state. | | 22 | Translate Mode: Enables address translation in the memory controller. | | 23 | <b>Interrupt Mask:</b> Inhibits all system component, timer, and software interrupts on all levels. An inhibited interrupt remains pending. | | 24 | <b>Check Stop Mask:</b> Prevents the processor from entering the check stop state on a machine check error. | | 25-27 | <b>Register Set Number:</b> Specifies one of eight register sets as the active register set. The current system processor design implements one of the eight register sets. Bits 25-27 are ignored in this implementation. | | 28 | Reserved | | 29-31 | <b>Processor Priority</b> : Indicates the current processor priority level. Interrupt requests with priorities lower than or equal to the current processor priority are ignored. | #### **Occurrence of Interrupts** An interrupt occurs when: - A bit in the IRB being equal to 1 if the processor priority is lower than the priority corresponding to that bit of the IRB. - The interrupt mask is 0. - No system component is signaling an interrupt request on a higher level than that signaled through the IRB. An interrupt occurs due to: - A system component interrupt request if the processor priority is lower than that of the interrupt request. - The interrupt mask is 0. - The IRB is not signaling an interrupt request on a higher level than that signaled by the system component. #### **Interrupt Facility** The interrupt facility contains features that, if used improperly, may force the processor into an infinite hardware loop. When the processor loads the new program status for servicing an interrupt, it loads the processor priority from the ICS in the new program status location. The value in the processor priority in the new program status is completely under software control. This loaded processor priority must not be lower than the priority of the interrupt request which caused the interrupt. If the interrupt mask in the new program status is zero, the same interrupt request will immediately cause another interrupt. Multiple interrupts would continue to occur until a system component signals an interrupt request on a higher level, or until a power-on reset occurs. #### **Interrupt Servicing** The program should issue an IOW instruction to signal the device that the interrupt request is being serviced, and to reset the interrupt request bit in the device status. - 1. The program should clear the interrupt request of the interrupting device as soon as possible after the point of interrupt. This allows the processor to determine the priority of the next highest interrupt request. - 2. A Load Program Status (LPS) instruction is provided for software to return from an interrupt. The effective address of the LPS instruction points to the program status to which control is being returned. Normally control returns to the previously active program whose status is located in the old program status associated with the interrupt being serviced. #### **Instruction Set** Instructions are grouped into ten classes: - Memory access, - Address computation - **Branching** - Traps - Moves and inserts - Arithmetic operations - Logical operations - **Shifts** - System control - Input/output. A separate section is devoted to each instruction class. Each instruction is specified in terms of mnemonic, operation code (op-code), length, and functional description. Unassigned op-codes are reserved for future use. If these reserved op-codes are encountered by the processor, a program check error occurs. For more detailed information, see "Program-Check Errors" on page 11-87. The system processor does not support dynamic instruction modification (self modifying code). Any attempt by software to modify an instruction may result in unpredictable operation. The system processor provides a privileged state in which all instructions are valid, and an unprivileged state in which only instructions that cannot be used to affect system integrity are valid. The following notation is used to describe each instruction: General-purpose register (The word register is also used to denote a GPR.) **GPR** SCR: System control register **IAR** Instruction address register **IRB** Interrupt request buffer **MCS** Machine check status CS Condition status ICS Interrupt control status | R1,R2 or R3 | These abbreviations denote fields in the instruction which specify one of the sixteen GPRs. | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SRB | This denotes a field in the instruction which specifies an SCR. | | I | This denotes a field of immediate data in the action. | | N | This denotes a condition status bit number | | JI | This denotes an 8-bit relative branch displacement in the JI format instructions. | | BI | This denotes a 20-bit relative branch displacement in the BI format instructions. | | BA | This denotes a 24-bit absolute branch address. | | 0/(R3) | This indicates the value 0 if R3 is specified as 0, else the content of register R3. (That is, if the R3 field is specified as 0, a value of 0 is used for the computation. If the R3 field is not 0, the content of the specified register is used for the computation. Register 0 cannot be used as the R3 register. | | 0[n] | This indicates a field of zeroes, n-bits wide. | | // | Two parallel bars are used to indicate a concatenation of the two fields specified on either side of the bars. | | (R3) | A register specification enclosed in parentheses indicates the content of the specified register. | The seven instruction formats (JI, X, D-Short, R, BI, BA and D) are shown on the following pages. Instructions are either 2 or 4 bytes in length. The first 4-, 5- or 8-bits of an instruction are referred to as the operation code (op-code). The JI format has a 5-bit op-code. The X and D-Short formats both have 4-bit op codes. The R, BI, BA and D formats all have 8-bit op codes. Instructions of formats JI, X, D-Short and R are all 2 bytes long. Instructions of formats BI, BA and D are all 4 bytes long. The R1, R2 and R3 fields specify GPRs. The SRB field specifies an SCR. The I field specifies a displacement of a memory address or an immediate value. The N field specifies a condition status bit. Relative branch displacements JI and BI are both signed binary numbers in twos complement form, while BA designates an absolute branch address. Some R format instructions have an SRB, I, or N field instead of an R2 or R3 field. # **Instruction Formats** The seven instruction formats are shown below. #### J1 Format | Ol | P | N | J1 | | |----|---|---|----|----| | 0 | 5 | | 8 | 15 | #### X Format #### **D-Short Format** #### R Format #### **BI** Format #### **BA** Format | OP | | BA | | |----|---|----|----| | 0 | 8 | | 31 | #### **D** Format | | OP | R2 | R3 | | I | |---|----|----|----|----|----| | 0 | | 8 | 12 | 16 | 31 | #### **Memory Access** System memory is organized as a sequence of 8-bit bytes with a maximum addressing capability of 4,294,967,296 bytes. All memory effective addresses (base address plus displacement) are computed as 32-bit quantities. Wrap around is allowed and occurs on a 32-bit basis, (that is, system memory addressing wraps around from the maximum byte address of 4,294,967,295 to address 0). All memory accesses are for a byte or multiples thereof. Instructions are provided to load or store a single character, a halfword, or a word into a general- purpose register. Memory accesses for halfwords and words ignore the low-order bit or pair of bits, respectively, of the effective address. The address of a halfword or word in system memory is the address of its leftmost byte. The condition status is not changed by any of these instructions. A memory access to an invalid memory location sets the data address exception bit in the program check status and results in a program check. Refer to "Program-Check Status" on page 11-87 for a description of the program check status. All memory access instructions are unprivileged. # **Load and Store Instructions** This group of instructions loads and stores data. #### **Load Character Short (LCS)** Characters C0 through C2 of register R2 are set to 0. Character C3 of register R2 is replaced by the character of memory addressed by 0/(R3) + 0[28]/I. #### Load Character (LC) Characters C0 through C2 of register R2 are set to 0. Character C3 of register R2 is replaced by the character of memory addressed by 0/(R3) plus the sign-extended I-field. #### **Load Half Algebraic Short (LHAS)** The lower half of register R2 is replaced by the halfword of memory addressed by 0/(R3)+0[27]/I/0[1]. The sign bit of the addressed halfwo rd is extended through the upper half of register R2. #### Load Half Algebraic (LHA) The lower half of register R2 is replaced by the halfword of memory addressed by 0/(R3) plus the sign-extended I-field. The sign bit of the addressed halfword is extended through the upper half of register R2. #### **Load Half Short (LHS)** The upper half of register R2 is set to zero. The lower half of register R2 is replaced by the halfword of memory addressed by the content of register R3. #### Load Half (LH) The upper half of register R2 is set to 0. The lower half of register R2 is replaced by the halfword of memory addressed by 0/(R3) plus the sign-extended I-field. #### Load Short (LS) The content of register R2 is replaced by the word in memory addressed by 0/(R3) + 0[26]//I//0[2]. #### Load (L) The content of register R2 is replaced by the word in memory addressed by 0/(R3) plus the sign-extended I-field. #### Load Multiple (LM) The content of registers R2 through 15 is replaced, respectively, by the consecutive words in memory beginning at the address given by 0/(R3) plus the sign-extended I-field. #### **Test and Set Half (TSH)** The upper half of register R2 is set to 0. The lower half of register R2 is replaced by the halfword of memory addressed by 0/(R3) plus the sign-extended I-field. Immediately following the read operation, the memory unit writes all ones in the high-order byte of the selected halfword without permitting any other memory operations between the read and the write. The low-order byte of the selected halfword is left unaltered. ## **Store Character Short (STCS)** The character of memory addressed by 0/(R3) + 0[28]/I is replaced by character C3 of register R2. ## **Store Character (STC)** The character of memory addressed by 0/(R3) plus the sign extended I-field is replaced by character C3 of register R2. #### **Store Half Short (STHS)** The halfword of memory addressed by 0/(R3) + 0[27]//I//0[1] is replaced by the lower half of register R2. #### Store Half (STH) The halfword of memory addressed by 0/(R3) plus the sign-extended I-field is replaced by the lower half of register R2. #### **Store Short (STS)** The word of memory addressed by 0/(R3) + 0[26]/I//0[2] is replaced by the content of register R2. #### Store (ST) The word in memory addressed by 0/(R3) plus the sign-extended I-field is replaced by the content of register R2. ## **Store Multiple (STM)** The consecutive words in memory beginning at the address given by 0/(R3) plus the sign-extended I-field are replaced, respectively, by the content of registers R2 through 15. # **Address Computation** The address computation instructions operate only on the contents of the general-purpose registers. No memory references for operands occur. The resultant values are not inspected for address exceptions. The condition status is not changed by any of these instructions. All address computation instructions are non-privileged. #### **Compute Address Lower Half (CAL)** The address specified by $0/(R_3)$ plus the sign-extended I-field replaces the content of register R2. #### **Compute Address Lower Half 16-Bit (CAL16)** The 16-bit address specified by 0/(R3)[16:31] + I replaces the content of register R2[16:31], and 0/(R3)[0:15] replaces the content of register R2[0:15]. **Note:** This instruction is provided to assist in simulation of 16-bit architectures. #### **Compute Address Upper Half (CAU)** The address specified by 0/(R3) + I/0[16] replaces the content of register R2. #### **Compute Address Short (CAS)** The address specified by (R2) + 0/(R3) replaces the content of register R1. #### **Compute Address 16-Bit (CA16)** The 16-bit address specified by (R2)[16:31] + (R3)[16:31] replaces the content of register R2[16:31], and (R3)[0:15] replaces the content of register R2[0:15]. **Note:** This instruction is provided to assist in simulation of 16-bit architectures. #### **Increment (INC)** The field I, extended on the left with 28 zeroes, is added to the content of register R2, and the result is placed into register R2. #### **Decrement (DEC)** The field I, extended on the left with 28 zeroes, is subtracted from the content of register R2, and the result is placed into the register R2. #### **Load Immediate Short (LIS)** The content of register R2 is replaced by field I and extended on the left with 28 zeroes. # **Branching** The normal sequential execution of instructions may be changed by using the branch instructions. These instructions permit subroutine linkage, decision making, and loop control and provide several different target addressing forms. For every branch instruction, except jumps, there is a corresponding branch with execute instructions. The instruction, immediately following a branch with execute, is called the subject instruction, and is executed regardless of the branch decision, as if it preceded the branch. However, the subject instruction cannot affect the branch decision. Any condition status changes caused by the subject instruction occur after the branch decision has been made. Subroutine linkage is provided by these branch and linkage instructions: BALA, BALA, BALI, BALR, and BALRX. These instructions branch to a new instruction sequence but preserve a return address in an implicitly or explicitly designated general-purpose register. For the nonexecute forms of the instructions, the return address is the updated instruction address, that is the address of the halfword immediately following the branch and link instruction in memory. For the execute forms of the instructions, the return address is the address of the halfword that is 4 bytes beyond the end of the branch and link with execute instruction (it is the updated instruction address plus four). This allows 4 bytes following the branch and link with execute for the subject instruction. If the subject instruction requires only 2 bytes, the 2 remaining bytes are ignored. Decision making and loop control are provided by these conditional branch and conditional jump instructions: BB, BBX, BBR, BBRX, BNB, BNBX, BNBR, BNBRX, JB, and JNB. For the conditional branch instructions, the branch decision is based on any specified state of any bit of the condition status. In these instructions, the value of N specifies the condition status bit with CS bit 16 specified by a value of 0, CS bit 17 by a value of 1, and so forth. For the conditional jump instructions the branch is based on any specified state of the rightmost 8 bits (bits 24-31) of the condition status. In this case, the value of the N-field of the jump instruction specifies the condition status bit with CS bit 24 specified by a value of 0, CS bit 25 by a value of 1, and so forth. For conditional branch instructions, the branch decision is based on any specified state of the rightmost 16 bits (bits 16-31) of the condition status. In this case, the value of the N field specifies which condition status bit is used for the branch decision, with CS bit 16 specified by a value of 0, CS bit 17 specified by a value of 1, and so forth. If a reserved bit in the condition status (bits 16-23) is specified, the branch decision is unpredictable. The branch instructions provide three different branch target addressing forms: absolute, absolute immediate, and relative immediate. The instructions BALR, BALRX, BBR, BBRX, BNBR, and BNBRX are absolute instructions and specify, as an operand, a register that contains the 24-bit branch target address. The instructions BALA and BAL AX are absolute immediate instructions, where the full 24-bit branch target address is contained in the instruction. The instruction BALL. BA LIX, JB, BB, BBX, JNB, BNB, and BNBX are relative immediate instructions; each contains an immediate field that is sign extended, logically shifted left 1 bit, and added to the address of the branch instruction in order to calculate the branch target address. The jump instructions (JB and JNB) contain an 8-bit immediate field that allows a jump range of -127 to +128 halfwords from the jump instruction. The branch (instructions BALI, BALIX, BB and BBX contain a 20-bit immediate field that allows a branch range of -524,286 to +524,289 halfwords from the branch instruction. The branch with execute instruction and its subject instruction are considered to be a single instruction. Thus, interrupts are not honored between the execution of the branch with execute instruction and the execution of its subject instruction. Certain instructions are not allowed to be the subject of a branch with execute instruction. Since the branch with execute instructions change the normal sequential execution of instructions, the subject instruction cannot be an instruction that also changes the instruction sequencing; otherwise the processor may be put in an unpredictable state. Thus, all branches, jumps, traps, Load Program Status, Supervisor Call, and Wait instructions cannot be subject instructions. The system processor provides hardware that detects these illegal instructions and causes a program check interrupt if any of these instructions occur at the subject of a branch with execute instruction. Also, note that, in the case of branch and link with execute instructions, the register containing the return address is available to the subject instruction. Therefore the subject instruction must be constructed so as not to modify the return address unintentionally. Finally, if the subject instruction is a Move From SCR, where the SCR is the IAR, (move from SCR 13) the results of the move are unpredictable. All branch and jump instructions are unprivileged. #### **Branch and Link Absolute (BALA)** | | 8A | | | BA | | | | | |---|----|---|--|----|--|--|---|---| | 0 | | 8 | | | | | 3 | 1 | The content of register 15 is replaced by the updated instruction address, and the updated instruction address is replaced by the field BA, with its rightmost bit forced to 0. #### **Branch and Link Absolute with Execute (BALAX)** The content of register 15 is replaced by the updated instruction address incremented by 4, and the updated instruction address is replaced by the field BA with its rightmost bit forced to 0. The instruction immediately following the branch instruction is executed before the target instruction is executed. #### **Branch and Link Immediate (BALI)** The content of register R2 is replaced by the updated instruction address. The updated instruction address is replaced by the field BI, sign extended, shifted left 1 bit, and added to the branch instruction address. #### **Branch and Link Immediate with Execute (BALIX)** | | 8D | R2 | BI | |---|----|----|-------| | ( | ) | 8 | 12 31 | The content of register R2 is replaced by the updated instruction address incremented by 4. The updated instruction address is replaced by the field BI, sign extended, shifted left 1 bit, and added to the branch instruction address. The instruction immediately following the branch instruction is executed before the target instruction. #### **Branch and Link (BALR)** The content of register R2 is replaced by the updated instruction address. The updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. #### **Branch and Link with Execute (BALRX)** The content of register R2 is replaced by the updated instruction address incremented by 4, and the updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. The instruction immediately following the branch instruction is executed before the target instruction. #### **Jump on Condition Bit (JB)** If the condition status bit specified by N is 1, the updated instruction address is replaced by the field JI, sign extended and shifted left one bit, added to the branch instruction address. If the specified condition status bit is 0, the updated instruction address is unaltered. The field N refers only to the rightmost 8 bits of the condition status (bits 24-31). #### **Branch on Condition Bit Immediate (BB)** If the condition status bit specified by N is 1, the updated instruction address is replaced by the field BI, sign extended and shifted left one bit, added to the branch instruction address. If the specified condition status bit is 0, the updated instruction address is unaltered. #### **Branch on Condition Bit Immediate with Execute (BBX)** If the condition status bit specified by N is 1, the updated instruction address is replaced by the field BI, sign extended and shifted left one bit, added to the branch instruction address. The instruction immediately following the branch instruction is executed before the target instruction. If the specified condition status bit is 0, the updated instruction address is unaltered, and the subject instruction is executed in a normal manner. #### **Branch on Condition Bit (BBR)** If the condition status bit specified by N is 1, the updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. If the specified condition status bit is 0, the updated instruction address is unaltered. #### **Branch on Condition Bit with Execute (BBRX)** If the condition status bit specified by N is 1, the updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. The instruction immediately following the branch instruction is executed before the target instruction. If the specified condition status bit is 0, the updated instruction address is unaltered, and the subject instruction is executed in a normal manner. #### **Jump on Not Condition Bit (JNB)** If the condition status bit specified by N is 0, the updated instruction address is replaced by the field JI, sign extended and shifted left 1 bit, and added to the branch instruction address. If the specified condition status bit is 1, the updated instruction address is unaltered. The field N references only the rightmost 8 bits of the condition status (bits 24-31). #### **Branch on Not Condition Bit Immediate (BNB)** | 88 | N | BI | | |----|---|----|----| | 0 | 8 | 12 | 31 | If the condition status bit specified by N is 0. The updated instruction address is replaced by the field BI, sign-extended and shifted left one bit, and added to the branch instruction address. If the specified condition status bit is 1, the updated instruction address is unaltered. #### **Branch on Not Condition Bit Immediate with Execute (BNBX)** | 89 | N | BI | |----|---|-------| | 0 | 8 | 12 31 | If the condition status bit specified by N is 0, the updated instruction address is replaced by the field BI, sign extended and shifted left one bit, and added to the branch instruction address. The instruction immediately following the branch instruction is executed before the target instruction. If the specified condition status bit is 1, the updated instruction address is unaltered, and the subject instruction is executed in a normal manner. #### **Branch on Not Condition Bit (BNBR)** If the condition status bit specified by N is 0, the updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. If the specified condition status bit is 1, the updated instruction address is unaltered. # **Branch on Not Condition Bit with Execute (BNBRX)** If the condition status bit specified by N is 0, the updated instruction address is replaced by the content of register R3 with the rightmost bit forced to 0. The instruction immediately following the branch instruction is executed before the target instruction. If the specified condition status bit is 1, the updated instruction address is unaltered, and the subject instruction is executed in a normal manner. # **Traps** The trap instructions are provided to test for a specified set of conditions. If the conditions tested by a trap instruction are met, the program trap bit of the program check status is set to 1 and a program check occurs. If the tested conditions are not met, instruction execution continues with the next sequential instruction. The comparisons are performed on operands that are treated as 32-bit unsigned integers (logical quantities). The condition status is not changed by any of these instructions. All trap instructions are unprivileged. #### **Trap On Condition Immediate (TI)** | | CC | LEG | R3 | | I | | |---|----|-----|----|----|---|----| | 0 | | 8 | 12 | 16 | | 31 | If any of the trap conditions specified by bits 9 through 11 are met by comparing the content of register R3 with the value of the sign extended I-field, the trap bit of the PC register is set, and a program check occurs. Trap conditions are selected by bits 9 through 11 as defined below. | Bit | Definition | | |-----|------------------------------------------------------------------------------------------------------------------------------------|--| | 9 | Trap if register R3 is less than the value of the sign extended I-field. The trap is enabled if the bit is 1 and disabled if 0. | | | 10 | Trap if register R3 is equal to the value of the sign extended I-field. The trap is enabled if the bit is 1 and disabled if 0. | | | 11 | Trap if register R3 is greater than the value of the sign extended I-field. The trap is enabled if the bit is 1 and disabled if 0. | | #### Trap if Register Greater Than or Equal (TGTE) If the content of register R2 is greater than or equal to the content of register R3, the trap bit of the PCS is set, and a program check occurs. ### Trap if Register Less Than (TLT) If the content of register R2 is less than the content of register R3, the trap bit of the PCS is set, and a program check occurs. #### **Moves and Inserts** This group of instructions concerns the movement of data between general-purpose registers, and between a general-purpose register and the test bit of the condition status. Except when data is moved into the test bit, none of these instructions alter condition status. All move and insert instructions are unprivileged. #### **Move Character Zero From Three (MC03)** Character C0 of register R2 is replaced by character C3 of register R3. #### **Move Character One From Three (MC13)** Character C1 if register R2 is replaced by character C3 of the register R3. #### **Move Character Two From Three (MC23)** Character C2 of register R2 is replaced by character C3 of register R3. #### **Move Character Three From Three (MC33)** Character C3 of register R2 is replaced by character C3 of register R3. #### **Move Character Three From Zero (MC30)** Character C3 of register R2 is replaced by character C0 of register R3. #### **Move Character Three From One (MC31)** Character C3 of register R2 is replaced by character C1 of register R3. #### **Move Character Three From Two (MC32)** Character C3 of register R2 is replaced by character C2 of register R3. #### **Move From Test Bit (MFTB)** The bit of register R2 specified by the value of bits 27-31 of register R3 is set to the value of the condition status test bit. #### **Move From Test Bit Immediate Lower Half (MFTBIL)** The bit of the lower half of register R2 specified by I is set to the value of the condition status test bit. #### **Move From Test Bit Immediate Upper Half (MFTBIU)** The bit of the upper half of register R2 specified by I is set to the value of the condition status test bit. #### **Move to Test Bit (MTTB)** The condition status test bit is set to the value of the bit of register R2 specified by the value of bits 27-31 of register R3. # Move to Test Bit Immediate Lower Half (MTTBIL) | 9F | R2 | 2 I | | |----|----|-----|----| | 0 | 8 | 12 | 15 | The condition status test bit is set to the value of the bit in the lower half of register R2 specified by I. #### **Move To Test Bit Immediate Upper Half (MTTBIU)** The condition status test bit is set to the value of the bit in the upper half of register R2 specified by # **Arithmetic Operations** The arithmetic operations treat the general-purpose registers as 32-bit quantities in twos complement representation. Each of these instructions affects certain bits in the condition status field. However, the bits that are set and the manner in which they are set may vary according to the instruction that is executed. The less than (LT) bit is set by all instructions except Multiply Step and Divide Step, and compares to indicate the sign of the result. That is, the LT bit is set to 1 if the sign bit of the result is 1. The arithmetic compare instructions set this bit to 1 if the algebraic magnitude of a given comparand is less than the algebraic magnitude of the other. The logical compare instructions set this bit to 1 if the unsigned magnitude of a given comparand is less than the unsigned magnitude of the other. The instructions Multiply Step and Divide Step do not affect this bit. The equal (EO) bit is set by all instructions except Multiply Step and Divide Step if the result is a field of 32 zeroes, or, in the case of the compare instructions, if the two comparands are equal. The Multiply Step and Divide Step instructions do not affect this bit. The greater than (GT) bit is set by all instructions except Multiply Step and Divide Step, and compares to indicate the sign of a non-zero result; it is set to 1 if the sign bit of a non-zero result is 0. The arithmetic compare instructions set this bit if the algebraic magnitude of a given comparand is greater than the algebraic magnitude of the other. The logical compare instructions set this bit to 1 if the unsigned magnitude of a given comparand is greater than the unsigned magnitude of the other. The instructions Multiply Step and Divide Step do not affect this bit. The carry of bit position zero (C0) bit in the condition status is set by all instructions except compares, Extend Sign, Divide Step, and Multiply Step to reflect the carry of bit position zero. The Extend Sign instruction does not affect C0, and the Multiply Step and Divide Step instructions set C0 according to certain multiply and divide conditions. Add operations set C0 to 1 if a carry occurs and to 0 if no carry occurs. Subtract operations set C0 to 0 if a borrow occurs and to 1 if no borrow occurs. The overflow (OV) bit is set by all instructions except Extend Sign, Multiply Step, and Divide Step, and compares to indicate arithmetic overflow (it is set to 1 when the signed result of an operation cannot be represented by 32 bits). The Extend Sign and Multiply Step instructions do not affect this bit, and the Divide Step instruction sets it according to a divide condition. The extended operations incorporate the state of the C0 bit into the result. The extended add instructions, AE and AEI, cause the value of the C0 bit to be added to the sum of the two operands. In the extended subtract instruction, SE, the value of the first operand is added to the ones complement of the second operand, and to this result is added the value of C0 bit. All arithmetic instructions are unprivileged. #### Add (A) The contents of registers R2 and R3 are added, and the result placed into register R2. Condition status bits LT, EQ, GT, C0 and OV are affected. #### Add Extended (AE) The content of register R2, the content of register R3, and the value of condition status bit C0 are summed, and the result placed into register R2. Condition status bits LT, EQ, GT, C0, and OV are affected. Note: This allows multiple precision addition. #### **Add Extend Immediate (AEI)** | D1 | R2 | R3 | | I | | |----|----|----|----|---|---| | ) | 8 | 12 | 16 | 3 | ı | The sign-extended I-field, the content of register R3, and the value of condition status bit C0 are summed and the result placed in register R2. Condition status bits LT, EQ, GT, C0, and OV are affected. Note: This allows multiple precision addition. #### Add Immediate (AI) The sign extended I-field, is added to the content of register R3 and the result placed in register R2. Condition status bits LT, EQ, GT, C0, and OV are affected. #### **Add Immediate Short (AIS)** The I-field, extended on the left with 28 zeroes, is added to the content of register R2, and the result placed in register R2. Condition status bits LT, EQ, GT, C0 and OV are affected. #### **Absolute (ABS)** The content of register R2 is replaced by the absolute value of the content of register R3. Condition status bits LT, EQ, GT, C0 and OV are affected. Normally, only condition status bits EQ or GT are set to 1 according to the result. If register R3 contains the maximum negative number, for which there is no equivalent positive number, then the content of register R2 is set equal to the content of register R3, and the condition status bits LT and OV are set to 1. #### **Ones Complement (ONEC)** | F4 | R2 | R3 | | |----|----|----|----| | 0 | 8 | 12 | 15 | The content of register R2 is replaced by the ones complement of the content of register R3. Condition status bits LT, EQ, and GT are affected. #### **Twos Complement (TWOC)** The content of register R2 is replaced by the two complement of the content of register R3. Condition status bits LT, EO, GT, CO, and OV are affected. ## Compare (C) The contents of registers R2 and R3, both treated as 32-bit signed algebraic quantities, are compared. Condition status bits LT, EQ and GT are affected. Condition status bits LT and GT are set according to the true relative algebraic magnitudes of the contents of registers R2 and R3. LT is set if the content of register R2 is algebraically less than the content of register R3. GT is set if the content of register R2 is algebraically greater than the content of register R3. Condition status bit EO is set if the content of register R2 equals the content of register R3. #### **Compare Immediate Short (CIS)** The content of register R2 is compared to the I-field extended on the left with 28 zeroes. Condition status bits LT, EQ, and GT are affected. Condition status bits LT and GT are set according to the true algebraic magnitudes of register R2 and the I- field. The LT bit is set if the content of register R2 is algebraically less than the I-field extended on the left with 28 zeroes. The GT bit is set if the content of register R2 is greater than the I-field extended on the left with 28 zeroes. The EQ bit is set if the content of register R2 equals the I-field extended on the left with 28 zeroes. #### **Compare Immediate (CI)** The content of register R3 is compared to sign-extended I-field. Condition status bits LT, EQ, and GT are affected. Condition status bits LT and GT are set according to the true relative algebraic magnitudes of register R3 and I-field. The LT bit is set if the content of register R3 is algebraically less than the sign-extended I-field, and the GT bit is set if the content of register R3 is greater than the sign-extended I-field. The EQ bit is set if the content of register R3 equals the sign-extended I-field. ## **Compare Logical (CL)** The contents of registers R2 and R3, both treated as 32-bit unsigned quantities, are compared. Condition status bits LT, EQ and GT are affected. Condition status bits LT and GT are set according to the relative unsigned magnitudes of the contents of registers R2 and R3. LT is set if the content of register R2 is logically less than the content of register R3, and GT is set if the content of register R2 is logically greater than the content of register R3. Condition status bit EQ is set if the content of register R2 equals the content of register R3. ## **Compare Logical Immediate (CLI)** The content of register R3 is compared to the sign extended I-field. Condition status bits LT, EQ and GT are affected. Condition status bits LT and GT are set according to the relative unsigned magnitudes of register R3 and sign extended I-field. The LT bit is set if the content of register R3 is logically less than the sign extended I-field. The GT bit is set if the register R3 is greater than the sign extended I-field. The EQ bit is set if the content of register R3 equals the sign extended I-field. # **Extend Sign (EXTS)** The content of the lower half of register R2 is replaced by the lower half of register R3. Bits 0-15 of register R2 are set equal to bit 16. Condition status bits LT, EQ and GT are affected. #### Subtract (S) The content of register R3 is subtracted from the content of register R2, and the result placed into register R2. Condition status bits LT, EQ, GT, C0 and OV are affected. #### **Subtract From (SF)** The content of register R2 is subtracted from the content of register R3, and the result placed in register R2. Condition status bits LT, EQ, GT, C0 and OV are affected. # **Subtract Extended (SE)** The ones complement of the content of register R3 is added to the content of register R2, and the result is added to the value of Condition status bit C0. The result is placed in register R2. Condition status bits LT, EQ, GT, C0 and OV are affected. Note: This allows multiple precision subtraction. #### **Subtract From Immediate (SFI)** | Γ | D2 | R2 | R3 | I | | |---|----|----|----|----|------| | 0 | | 8 | 12 | 16 | - 31 | The content of register R2 is replaced by the content of register R3 subtracted from the sign extended I-field. The Condition status bits LT, EQ, GT, C0 and OV are affected. #### **Subtract Immediate Short (SIS)** The content of register R2 is replaced by the I-field subtracted from the content of register R2. For the subtraction, the I-field is extended on the left with 28 zeroes. Condition status bits LT, EQ, GT, C0, and OV are affected. ## Divide Step (D) The content of register R3 is added to or subtracted from (R2)// (bit of MQ) depending on whether the signs of registers R2 and R3 disagree or agree. The 32 rightmost bits of the sum replace the content of register R2. The MQ is shifted left one position, and bit 31 of the MQ is set to 1 if and only if the sign of the 33-bit result equals the sign of register R3. Condition status bit C0 is set to 1 if the sign of the 33-bit result equals the sign of the content of register R3. Bit OV is set to 1 if the sign of the 33-bit result equals the sign of the content of register R2. **Note:** The Divide Step instruction can be used to construct algorithms for dividing one number by another. The following example describes an algorithm for dividing a 32-bit dividend by a 32-bit divisor. These operands are in twos complement representation. Example: Divide X by Y giving quotient Q and remainder R where X, Y, Q and R are 32-bit numbers and Y is not equal to zero, plus one, or minus one. Initial Conditions: General-purpose register R2 should be set to the propagated sign of X (zero if X is non-negative, minus one if X is negative). This can be accomplished by loading R2 with X and executing a SARI1 6 R2, 15 instruction. Load Y into general-purpose register R3. IX should then be loaded into MO. Algorithm: The Divide Step instruction should be issued with operands R2 and R3 32 times. If at this point the signs of R2 and R3 differ, add the content of R3 to the content of R2 replacing the content of R2. After this test and possible modification of R2, R2 contains the preliminary remainder. The MO contains the 32 rightmost bits of the preliminary quotient. The final quotient and remainder are either equal to the preliminary quotient and remainder, or are found by adding one to the preliminary quotient and subtracting the divisor, R3, from the preliminary remainder. Proof: The Divide Step instruction supports a nonrestoring division algorithm. Division is accomplished by repetitive subtraction. The first time, only the sign of the dividend extended to an appropriate width participates in the subtraction. On each subsequent repetition, an additional dividend bit is included to the right of the result of the previous repetition; this has the effect of halving the divisor. Because the division involves binary numbers, the divisor can be subtracted from the current minuend either 1 or 0 times. If it is 1, the appropriate quotient bit is 1. If it is 0, the quotient bit is 0; however, the subtraction has already been performed. Instead of adding the divisor back at this point, half the divisor is added at the next repetition, since the result of subtracting the divisor and adding half the divisor is the same as subtracting half the divisor. When all dividend bits have been used, and the signs of the divisor and remainder differ, restoration must be done for the last step, and so the divisor is added back into the remainder without changing the quotient. This produces the preliminary quotient and remainder. The actual algorithm depends on the signs of the divisor and the dividend at each step. These signs also determine whether the initial step is addition or subtraction. The above algorithm can be modified for dividing a 64-bit dividend contained in R2//MQ. If the initial value of (R2)//(bit 0 of MQ) exceeds the divisor in magnitude, then divide overflow will occur. This condition can be determined by testing for OV=1 after execution of the first Divide Step instruction. #### Multiply Step (M) | E6 | R | 2 R: | 3 | |----|---|------|----| | 0 | 8 | 12 | 15 | The incomplete product of the content of register R3 and bits 30 and 31 of the MO register is formed in (R2)//MO. A 34-bit sum is formed in accordance with the table below. The MQ is algebraically shifted right two positions, with the two rightmost bits of the sum replacing bits 0 and 1 of the MQ. The content of register R2 is replaced by the 32 leftmost bits of the sum. Condition status bit C0 is set to the complement of bit 30 of the MO before the shift. | Condition<br>Status<br>Bit C0 | MQ<br>Bit 30 | MQ<br>Bit 31 | Algebraic Sum | |-------------------------------|--------------|--------------|---------------| | 0 , , | 0 | 0 | (R2) + (R3) | | 0 | 0 | 1 | (R2) + 2*(R3) | | 0 | 1 | 0 | (R2) - (R3) | | 0 | 1 | 1 | (R2) + 0 | | 1 | 0 | 0 | (R2) + 0 | | 1 | 0 | 1 | (R2) + (R3) | | 1 | 1 | 0 | (R2) + 2*(R3) | | 1 | 1 | 1 | (R2) - (R3) | #### **Multiply Step Operations** The Multiply Step instructions can be used to construct algorithms for multiplying two numbers together. The following example describes an algorithm for multiplying a 32-bit multiplicand by a 16-bit multiplier. The operands are in two complement representation. Example: Multiply X by Y giving Z where X is a 32-bit number and Y is a 16-bit number. Initial Conditions: Load X into general-purpose register R3; load Y into the MO; set the content of general-purpose register R2 to 0; set condition status bit C0 to 1. R2 and C0 can be initialized simultaneously by executing an S R2, R2 instruction. Algorithm: Issue the Multiply Step instruction with operands R2 and R3 eight times. Result: The 16 rightmost bits of the product Z are in the MQ; the 32 leftmost bits are in register R2. Proof: The 16-bit multiplier Y can be expressed as the sum of 16 terms of the form: or eight terms of the form: $$(y + 2*y ) *4$$ $2i 2i+1$ where $$y$$ and $y$ equal 0 or 1 and $i = 0,1...,7$ . The Multiply Step instruction accumulates a partial sum in register R2 and the leftmost bits of the MQ; a condition status bit C0 equal to 0 indicates a carry. The instruction provides four cases for the parenthesized factor when there is no carry into the term and four cases when there is a carry. | $y + 2*y$ $2i \qquad 2i+1$ | Carry | Value | |----------------------------|-------|------------------------| | 0 | No | (R2) | | 1 | No | (R2) + (R3) | | 2 | No | (R2) + 4*(R3) - 2*(R3) | | 3 | No | (R2) + 4*(R3) - (R3) | | 0 | Yes | (R2) + (R3) | | 1 | Yes | (R2) + 2*(R3) | | 2 | Yes | (R2) + 4*(R3) - (R3) | | 3 | Yes | (R2) + 4*(R3) | In the parenthesized factor, $y_{2i}$ is the value of MQ bit 31, and $y_{2i+1}$ is the value of MQ bit 30. Whenever MQ bit 30 is 1, the term 4\*(R3) appears. This is a carry into the next partial sum. The Multiply Step instruction places the rightmost two bits of the partial sum in vacated MQ bits (bits 0 and 1). This provides the 4<sup>i</sup> factor since it has the effect of multiplying the remaining bits of the multiplier by four. # **Logical Operations** The logical operations treat the contents of the general-purpose register as 32-bit unsigned integers except for the instruction Count Leading Zeroes (CLZ), which is applied to the lower half of a register. All logical operations except CLZ set condition status bits LT, EQ and GT according to the algebraic value expressed in two complement representation. If the result is a negative value, LT is set to 1; if it is 0, EQ is set to 1; if it is positive and not 0, GT is set to 1. The condition status is unaffected by the Count Leading Zeroes instruction. All logical instructions are unprivileged. #### **Clear Bit Lower Half (CLRBL)** A bit in the lower half of register R2 is set to 0, where the bit is specified by the immediate I-field. Condition status bits LT, EQ, and GT are affected. #### **Clear Bit Upper Half (CLRBU)** A bit in the upper half of register R2 is set to 0, where the bit is specified by the immediate I-field. Condition status bits LT, EQ, and GT are affected. # **Set Bit Lower Half (SETBL)** | 9B | R2 | I | | |----|----|----|----| | 0 | 8 | 12 | 15 | A bit in the lower half of register R2 is set to 1, where the bit is specified by the immediate I-field. Condition status bits LT, EQ and GT are affected. #### Set Bit Upper Half (SETBU) A bit in the upper half of register R2 is set to 1, where the bit is specified by the immediate I-field. Condition status bits LT, EQ and G T are affected. #### AND (N) The AND of the contents of registers R2 and R3 replaces the content of the register specified by R2. Condition status bits LT, EQ and GT are affected. ## **AND Immediate Lower Half Extended Zeroes (NILZ)** The AND of the I-field extended on the left with 16 zeroes and the content of register R3 replace the content of register R2. Condition status bits LT, EO and GT are affected. #### **AND Immediate Lower Half Extended Ones (NILO)** The AND of the I-field extended on the left with 16 ones and the content of register R3 replace the content of register R2. Condition status bits LT, EO and GT are affected. #### **AND Immediate Upper Half Extended Zeroes (NIUZ)** The AND of the I-field extended on the right with 16 zeroes and the content of register R3 replace the content of register. Condition status bits LT, EQ and GT are affected. ## **AND Immediate Upper Half Extended Ones (NIUO)** The AND of the I-field extended on the right with 16 ones and the content of register R3 replace the content of register R2. Condition status bits LT, EQ and GT are affected. ## OR (O) The OR of the contents of registers R2 and R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. ## **OR Immediate Lower (OIL)** The OR of the I-field extended on the left with 16 zeroes and the content of register R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. #### **OR Immediate Upper (OIU)** The OR of the I-field extended on the right with 16 zeroes and the content of register R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. #### **Exclusive OR (X)** The EXCLUSIVE OR of the contents of registers R2 and R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. ## **Exclusive OR Immediate Lower Half (XIL)** The EXCLUSIVE OR of the I-field extended on the left with 16 zeroes and the content of register R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. # **Exclusive OR Immediate Upper Half (XIU)** | D7 | R2 | R3 | I | | |----|----|----|----|----| | 0 | 8 | 12 | 16 | 31 | The EXCLUSIVE OR of the I-field extended on the right with 16 zeroes and the content of register R3 replaces the content of register R2. Condition status bits LT, EQ and GT are affected. #### **Count Leading Zeroes (CLZ)** The content of register R2 is replaced by the binary representation of the number of leading zeroes in the lower half of register R3 (that is, the number of zeroes to the left of the leftmost 1 bit in the lower half of register R3). **Note:** If the lower half of register R3 is equal to 0, the content of register R2 is replaced by the binary representation of 16. #### **Shifts** Shift instructions operate on either the content of a register or a register half. Immediate form shifts specify a shift amount of 0 to 31 bits to the left or right based on the value of the immediate field. Indirect shifts specify a shift amount of 0 to 63 bits to the left or right based on the low-order six bits of register R3. A shift amount greater than 31 bits results in a 32-bit shift. All shifts set the condition status bits LT, EQ and GT according to the resultant algebraic value returned to the register. All instructions except the shift algebraic right instructions supply zeroes to the vacated bit positions. All shift instructions are unprivileged. #### Shift Algebraic Right (SAR) | В0 | R2 | R | .3 | |----|----|----|----| | 0 | 8 | 12 | 15 | The content of register R2 is shifted right the number of bit positions specified by bits 26-31 of register R3. Bits equal to the original sign bit (bit 0) are supplied to the vacated high-order positions. Condition status bits LT, EQ and GT are affected. #### Shift Algebraic Right Immediate (SARI) The content of register R2 is shifted right the number of bit positions specified by the I-field. Bits equal to the original sign bit (bit 0) are supplied to the vacated high-order positions. Condition status bits LT, EQ and GT are affected. # Shift Algebraic Right Immediate Plus Sixteen (SARI16) The content of the register R2 is shifted right the number of bit positions specified by the I-field plus 16. Bits equal to the original sign bit (bit 0) are supplied to the vacated high-order positions. Condition status bits LT, EQ and GT are affected. ## Shift Right (SR) The content of register R2 is shifted right the number of bit positions specified by bits 26-31 of register R3. Zeroes are supplied to the vacated high-order positions. Condition status bits LT, EQ and GT are affected. #### **Shift Right Immediate (SRI)** The content of register R2 is shifted right the number of bit positions specified by the I-field. Zeroes are supplied to the vacated high-order positions. Condition Status bits LT, EQ and GT are affected. #### Shift Right Immediate Plus Sixteen (SRI16) | A9 | R2 | I | | |----|----|----|----| | 0 | 8 | 12 | 15 | The content of register R2 is shifted right the number of bit positions specified by the I-field plus 16. Zeroes are supplied to the vacated high-order positions. Condition status bits LT, EQ and GT are affected. #### **Shift Right Paired (SRP)** The content of the register R2, shifted right the number of bit positions specified by bits 26-31 of register R3 with zeroes supplied to the vacated high-order positions, is placed in the twin register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. #### **Shift Right Paired Immediate (SRPI)** The content of register R2, shifted right the number of bit positions specified by the I-field with zeroes supplied to the vacated high-order positions, is placed in the twin register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. #### Shift Right Paired Immediate Plus Sixteen (SRPI16) The content of register R2, shifted right the number of bit positions specified by the I-field plus 16 with zeroes supplied to the vacated high-order positions is placed, in the twin of register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. ## Shift Left (SL) The content of register R2 is shifted left the number of bit positions specified by bits 26-31 of register R3. Zeroes are supplied to the vacated low-order positions. Condition status bits LT, EQ and GT are affected. #### **Shift Left Immediate (SLI)** The content of the register R2 is shifted left the number of bit positions specified by the I-field. Zeroes are supplied to the vacated low-order positions. Condition status bits LT, EQ and GT are affected. #### Shift Left Immediate Plus Sixteen (SLI16) | AB | R2 | 2 I | | |----|----|-----|----| | 0 | 8 | 12 | 15 | The content of register R2 is shifted left the number of bit positions specified by the I-field plus 16. Zeroes are supplied to the vacated low-order positions. Condition Status bits LT, EQ and GT are affected. #### **Shift Left Paired (SLP)** The content of register R2 shifted is left the number of bit positions specified by bits 26-31 of register R3 with zeroes supplied to the vacated low-order positions is placed in the twin of register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. ## Shift Left Paired Immediate (SLPI) The content of register R2 is shifted left the number of bit positions specified by the I-field with zeroes supplied to the vacated low-order positions is placed in the twin of register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. # Shift Left Paired Immediate Plus Sixteen (SLPI16) | AF | R2 | I | | |----|----|----|----| | 0 | 8 | 12 | 15 | The content of the register R2 is shifted left the number of bit positions specified by the I-field plus 16 with zeroes supplied to the vacated low order positions is placed in the twin of register R2. The content of register R2 is not affected. Condition status bits LT, EQ and GT are affected. # **System Control** The system control instructions provide a means of examining and manipulating the state of certain processor facilities. This is done through two subclasses of instructions. The first subclass operates on the contents of the system control registers. These instructions allow the reading or writing of any SCR or the setting or clearing of any of the low-order 16 bits of the SCR. A second subclass of instructions within this class provides the necessary software interface to the interrupt facility described in "Interrupts" on page 11-19. The instructions that deal with the SCRs provide a general capability of operating on any of the SCRs. However, because of the definition of certain SCRs, not every operation on an SCR gives a predictable result. Moreover, bits in any SCR that have been specified as reserved bits cannot be used in a predictable manner. These exceptional cases are specified along with the instruction definitions. Finally, all SCRs except the ICS (SCR 14) are dynamically changed by the processor, often asynchronously to instruction sequencing. Therefore, a read of an SCR following a write does not necessarily get the same data that was written. Only certain system control instructions are unprivileged. The unprivileged instructions are MTS, MFS, SETSB, and CLRSB when the SCR referred to by these instructions is the MQ or CS, and the SVC instruction. An attempt to execute any other system control instruction in unprivileged state causes the privileged instruction exception bit in the program check status to be set and a program check to occur. Refer to "Program-Check Status" on page 11-87 for a description of the program check status. #### Move to SCR (MTS) The content of system control register SRB is replaced by the content of register R3. Any reserved bits in the specified SCR are not set to predictable values. If the specified SCR is the IAR (SCR 13), the results of this instruction are unpredictable. ## Move from SCR (MFS) The content of register R3 is replaced by the content of system control register SRB. The bits of register R3 corresponding to reserved bits of the specified SCR are set to unpredictable values. If the specified SCR is the IAR (SCR 13), the value that is loaded into register R3 is the address of the instruction immediately following the MFS instruction in system memory. #### **Clear SCR Bit (CLRSB)** A bit in the lower half of system control register SRB is set to 0, where the bit is selected by the immediate I-field. If the selected bit of the SCR is a reserved bit, it is not set to a predictable value. If the specified SCR is the IAR (SCR 13), the results of this instruction are unpredictable. #### **Set SCR Bit (SETSB)** A bit in the lower half of system control register SRB is set to 1, where the bit is selected by the immediate I-field. If the selected bit of the SCR is a reserved bit, it is not set to a predictable value. If the specified SCR is the IAR (SCR 13), the results of this instruction are unpredictable. #### **Load Program Status (LPS)** | D0 | Т000 | R3 | ] | | |----|------|----|----|----| | 0 | 8 | 12 | 16 | 31 | The content of the IAR (SCR 13) is replaced by the word in system memory addressed by 0/(R3)plus the sign extended I-field. The content of the ICS (SCR 14) is replaced by the content of the system memory halfword addressed by 0/(R3) plus the sign extended I-field plus four. The content of the CS (SCR 15) is replaced by the content of the system memory halfword addressed by 0/(R3) plus the sign extended I-field plus six. Any reserved bits in the SCRs are set to unpredictable values. If the processor is on the machine check level (see "Machine-Check Status" on page 11-86) when the LPS is executed, the content of the MCS is set to 0. If the processor is on the program check level (see "Program-Check Status" on page 11-87) when the LPS is executed, the content of the PCS is set to 0. If bit 11 of this instruction is a 1, interrupts remain pending until the target instruction of the LPS instruction has been executed. If bit 11 is 0, interrupts may occur after the LPS instruction is executed. #### **Programming Note:** The LPS instructions may be used to return from an interrupt. The LPS instruction may also be used to trace instruction execution. This is accomplished by setting a bit in the IRB to generate an interrupt request before executing the LPS instruction. The bit that is set should have a corresponding interrupt request priority greater than the processor priority that is loaded by the LPS instruction. If the interrupt mask that is loaded by the LPS is 0, and if bit 11 of the LPS instruction is a 1, an interrupt occurs after the target instruction of the LPS has been executed. #### Wait (WAIT) The processor enters the wait state. When the processor is in the wait state, it does not execute any instructions nor make any memory accesses. The processor exits the wait state on a interrupt, error, or power-on reset. ## **Supervisor Call (SVC)** The content of the IAR (SCR 13) is stored into the word in system memory beginning at address X'190'. The content of the ICS (SCR 14) is stored into the halfword in system memory beginning at address X'194'. The content of the CS (SCR 15) is stored into the halfword in system memory beginning at address X'196'. The low-order 16-bits of the 32-bit sum 0/(R3) + 0[16]/I is stored into the halfword in system memory beginning at address X'19E'. The content of the IAR (SCR 13) is replaced by the word in system memory beginning at address X'198'. The content of the ICS (SCR 14) is replaced by the content of the halfword in system memory beginning at address X'1 9C'. Any reserved bits in the IAR and the ICS are set to unpredictable values. # Input/Output Programmed I/O (PIO) instructions are used to transfer data between the general-purpose registers and registers in the memory management unit. All I/O addresses are considered to be device addresses. The upper byte of the I/O address is checked to be 0. A nonzero high-order byte in the I/O address causes a program check. All PIO instructions are unprivileged. Each I/O device determines whether it is a privileged or unprivileged device. Privileged I/O devices accept I/O commands from the processor only when the processor is in privileged state. An attempt to access a privileged I/O device from unprivileged state causes the data address exception bit in the program check status to be set and a program check to occur. See "Privileged and Unprivileged States" on page 11-12 for a description of privileged I/O device connection, and "Program-Check Status" on page 11-87 for a description of the program check status. # Input/Output Read (IOR) The content of register R2 is replaced by data transferred from the I/O device selected by the effective address 0/(R3) + 0[16]//I. Bits 8-31 of the 32-bit effective address are interpreted as the I/O device address. Bits 0-7 of the effective address must be 0. #### Input/Output Write (IOW) The content of register R2 is transferred to the I/O device selected by the effective address 0/(R3) + 0[16]//I. Bits 8-31 of the 32-bit effective address are interpreted as the I/O device address. Bits 0-7 of the effective address must be 0. #### I/O Capability The system processor provides two capabilities for controlling I/O operations: programmed I/O (PIO), and I/O interrupts. ## Programmed I/O Two programmed I/O (PIO) instructions (IOR and IOW) provide I/O operations that are synchronous to the program. For each PIO instruction executed, a 24-bit I/O address field is sent to an I/O device, and data is transferred between the I/O device and a general-purpose register. These I/O instructions are used to access memory management unit registers. #### I/O Interrupt Requests I/O interrupt requests report asynchronous events. Each of these interrupt requests is assigned one of seven priority levels. Processor logic allows I/O interrupts (unless masked) on a priority basis. The interrupt facility is described in "Interrupts" on page 11-19. #### **RAS Facilities** RAS Facilities provide for: - Detection of processor errors - Detection and isolation of program-related errors - Decreased exposure to data loss and error situations. #### **Internal Diagnostics** The processor executes an internal microcode routine to perform register initialization when a processor reset occurs. Successful completion of the register initialization routine normally indicates that the processor is functional for instruction execution. The internal microcode diagnostic does not verify any internal bus functions, or other system components. No other system components are verified by the internal diagnostic. #### **Machine-Check Errors** Machine-check errors are those errors that are most often caused by hardware malfunctions. #### **Machine-Check Error Handling** Upon the detection of a machine-check error condition, other than an I/O trap, all current processor activity is halted, regardless of that activity. If the detected error is an I/O trap, the processor completes its current activity before servicing the error. I/O traps are reported by activating the '-TRAP' input. The processor then takes one of two courses of action, depending on the value contained in the check stop mask. If the check stop mask has a value of 0, the processor enters the check stop state when any machine check error is detected (including an error reported by -TRAP). This preserves the state of internal processor latches for inspection by a support processor. The I/O pin '-FAIL' goes active to indicate a failure. If the check stop mask has a value of 1, and a machine-check error is detected other than one caused by the '-TRAP' interrupt input, a reset packet is sent on the processor channel to clear any pending processor channel operations. If the machine-check interrupt is caused by the '-TRAP' interrupt input, the reset packet is not sent on the processor channel. If the check stop mask has a value of 1, the processor saves the current program status in the old program status location in the Machine Check Old and New PS Pairs (beginning at location X'170'). The program status for servicing the error is then loaded from the new program status location except for the condition status, and the processor attempts to continue execution. The machine-check routine must execute a Load Program Status (LPS) instruction to return from the machine check error. #### **Machine-Check Status** The machine-check status (MCS) provides a means for reporting hardware malfunctions. Information is provided to assist an error-servicing routine in determining the type and source of the error. The MCS is an 8-bit field in system control register 11. Upon the detection of a machine-check error, appropriate bits of the MCS are set to ones (except for the parity check bit (bit 18) which is set whenever the processor receives a reply with invalid data parity). The MCS is defined as follows: - Bit 16 Processor Channel Check. Set to 1 when a device on the processor channel detects invalid parity on a processor-generated transfer over an abnormally large number of retries. This bit is also set when the processor generates an interrupt to report an processor channel retry that successfully corrected a parity error (See "Interrupt Control Status" on page 11-24). - Bit 17 Reserved. - Bit 18 Parity Check. Set to 1 whenever the processor receives a reply on the processor channel with invalid data parity. This bit is set whether or not a machine check occurs. - Bit 19 Instruction Timeout. Set to 1 when the processor fails to receive an expected reply to an instruction fetch. - Bit 20 Data Timeout. Set to 1 when the processor fails to receive an expected reply to a data fetch. - Bit 21 Processor Channel Timeout. Set to 1 whenever the processor has been unable to transfer a request on the processor channel over an abnormally large number of cycles, and no parity errors have been signalled. The request may be unsuccessful due to busy responses or unsuccessful arbitration. - Bit 22 I/O Trap. Set to 1 when an I/O device signals a trap condition. - Bit 23 Reserved. The MCS is cleared when a Load Program Status (LPS) instruction is executed to return from the machine check level. The MCS provides a summary of processor conditions that are present when a machine-check error is detected. Thus, multiple bits of the MCS can be set upon detection of an error. For example, if bits 16, 19, and 20 of the MCS are set, the processor failed to receive a reply to both an instruction and a data fetch. In addition, a device on the processor channel has detected invalid parity on a processor-generated request. In this case, invalid parity on the request has prevented the processor from successfully transferring both instruction and data requests. #### **Program-Check Errors** Program-check errors are those errors that are usually caused by software errors. #### **Program-Check Error Handling** Upon the detection of a program-check error condition, the processor completes its current activity (such as, instruction, timer) unless that activity caused the program-check condition. The processor then saves the current program status in the old program status location in the Program Check Old and New PS Pair (beginning at location X'180'). The program status for servicing the error is loaded from the new program status location, except for the condition status. The program-check routine must execute a Load Program Status (LPS) instruction to return from the program-check error. #### **Program-Check Status** The Program-Check Status (PCS) provides a means for reporting certain programming errors. Reported program-check errors include: - Attempted execution of an unassigned or unimplemented operation code - Attempted execution of a privileged instruction with the unprivileged state bit (bit 21 of SCR 14) being set at 1 - An improper data condition which is detected by the execution of a trap instruction - Attempted access of an invalid memory location. The PCS is an 8-bit field in system control register 11. Upon the the detection of a program-check error, all bits of the PCS are set to zeros. The appropriate bits of the PCS are then set to ones. The PCS is defined as follows: | Bit 24 | Program check with known origin. Set to 1 when a program check occurs and the | |--------|-------------------------------------------------------------------------------------------| | | location of the failing instruction is determined from the IAR in the old program status. | | | | - Bit 25 Program check with unknown origin. Set to 1 when a program check occurs and the location of the failing instruction cannot be determined from the IAR in the old program status. - Bit 26 Program Trap. Set to 1 when a trap exception condition is generated by a trap instruction. - Bit 27 Privileged Instruction Exception. Set to 1 when the processor attempts to execute a privileged instruction and the unprivileged state bit (bit 21 of SCR 14) is set to 1. - Bit 28 Illegal Operation Code. Set to 1 when the attempted execution of an unassigned or unimplemented operation code is detected. - Bit 29 Instruction Address Exception. Set to 1 when no device on the processor channel responds to a processor instruction fetch request, or when a reply to an instruction fetch is accompanied by an invalid address indication. - Bit 30 Data Address Exception. Set to 1 when no device on the processor channel responds to a processor data request, or when a device on the processor channel responds to a data request with an invalid address indication. This bit is also set when an access to a privileged I/O device is attempted from unprivileged state or when an unaligned memory address is detected, and an interrupt on unaligned memory address is enabled. #### Bit 31 Reserved. The PCS is cleared by the Load Program Status (LPS) instruction. The detection of a program trap condition sets bits 24 and 26 to ones. The IAR in the old program status contains the address of the trap instruction. The detection of an illegal branch with execute subject instruction sets both bits 24 and 28 to ones. The IAR in the old program status contains the address of the branch with execute instruction. If a data address exception occurs, bit 30 of the PCS is set to 1, and either bit 24 or 25 is set to 1 to indicate the meaning of the IAR in the old program status. If bit 24 is set to 1, the IAR in the old program status contains the address of the instruction that attempted to access the invalid memory location. If the subject instruction of a branch with execute attempts to access an invalid memory location, the IAR in the old program status contains the address of the branch with execute instruction. If bit 25 of the PCS is set to 1, the IAR in the old program status contains the address of the instruction that was executing when the data address exception was detected. If this instruction required the data which was accessed at the invalid address, it did not complete successfully. Figure 11-9 provides a summary of program-check errors when address translation and memory protect are disabled. Figure 11-10 provides a summary of program-check errors when address translation or memory protect is enabled. | | PCS Bits | | | | | | | | | |----------------------------------|----------|----|----|----|----|----|----|----|--| | Program Check Error | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | Invalid instruction address | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | | Invalid data address | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | | Successful trap instruction | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | Privileged instruction exception | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | Illegal op-code | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | Figure 11-9. Program Check Errors (Memory Protect and Address Translation Disabled) | | PCS Bits | | | | | | | | | |----------------------------------|----------|----|----|----|----|----|----|----|--| | Program Check Error | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | | Invalid instruction address | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | | Invalid data address | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | Successful trap instruction | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | Privileged instruction exception | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | Illegal op-code | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | Figure 11-10. Program Check Errors (Memory Protect and Address Translation Enabled) #### Simultaneous Program-Check and Machine-Check Errors Certain hardware error conditions can result in both a program-check and a machine-check error, as the result of a single request. For example, a memory controller may generate both an exception reply and activate the '-TRAP' input to report an uncorrectable memory error (uncorrectable ECC error or parity error). The exception reply causes a program check, and the -TRAP causes a machine check. The exception reply is necessary to prevent the processor from using bad data from the request, and requires '-TRAP' to report hardware errors at the machine-check interrupt level. If a machine-check and program-check error occur simultaneously, the processor performs both a program-check PSW swap, and then a machine-check PSW swap. In order to guarantee that both the program-check and machine-check interrupts are properly handled, system devices using both an exception reply and '-TRAP' must report both errors simultaneously. Devices should activate '-TRAP' when the error is detected, and send an exception indication with the reply. Once the program-check and machine-check PSW swaps are completed by the processor, the machine-check interrupt handler is executed. The machine-check and program-check interrupt handlers must be properly designed to handle this multiple error condition. The machine-check interrupt handler can determine the reason for the interrupt by examining status bits in the MCS and status register in each system component. Once the source of the error has been isolated and logged, the machine-check interrupt handler can complete and should execute an LPS instruction to return from the machine-check interrupt. Executing an LPS on the machine-check level clears all bits in the MCS and returns to the next highest priority level. In this case, a program-check interrupt is pending so the machine-check interrupt handler returns to the program-check interrupt handler. System software must be constructed so that sufficient information is available to the program-check interrupt handler. This determines that the program-check interrupt was due to the machine check error that was previously handled. If the machine-check interrupt handler performed all of the steps necessary to service the error, then the program-check interrupt handler executes an LPS instruction to return from the program-check level. Executing the LPS on the program-check level clears all bits in the PCS, and returns to the routine that was executing when the error was detected. A single error causes both a machine-check and a program-check interrupt, and that both interrupts must be processed. The machine-check interrupt handler is always executed first, and returns to the program-check interrupt handler by executing an LPS instruction. Once the program-check interrupt handler completes, it returns to the routine in which the error was detected by executing an LPS. Executing an LPS from the machine-check level terminates processing on the machine-check level, clears all bits in the MCS, and returns to the next highest priority interrupt. # **Multiple Occurrence of Errors** The processor will enter the check-stop state, regardless of the value in the check-stop mask, under the following conditions: - The processor is servicing a machine-check error, and another machine-check error is detected. - The processor is servicing a machine-check error, and a program-check error is detected. - The processor is servicing a program-check error, and another program-check error is detected. If the processor is servicing a program-check error and a machine-check error is detected, the machine-check error is handled as outlined in "Machine-Check Errors" on page 11-85. # **Memory Management Unit** The memory management unit attaches to the processor channel and contains the logic required to interface with up to 16M-bytes of memory. The memory management unit is functionally divided into the three sections shown in Figure 11-11 on page 11-93. The function of each of these sections is described below: - 1. Processor Channel Interface. This logic consists of the common front end (CFE) macro that provides the proper protocol from the processor channel to the address translation logic and memory control logic. All communication to and from the processor channel is handled by this logic. - 2. Address Translation Logic. This logic provides the translation from a virtual address received from the processor channel to a real address used to access memory. This logic contains a translation look-aside buffer (TLB) organized as 2-way set associate with 16 congruence classes. This logic automatically reloads TLB entries from page tables in system memory as required. Operation and use of the address translation logic is described in "Address Translation Process" on page 11-93 through "I/O Address Assignments" on page 11-135. - 3. Memory Control. This logic provides the address, data, and memory control signals that link the memory management unit to external RAM and ROS. This logic also provides ECC logic and dynamic memory refresh control. In addition to the memory control logic provided in the memory management unit, external interface logic is contained on the processor board to adapt the memory management unit memory interface to that required for ROM and RAM. Figure 11-11. Memory Management Unit Functional Partition #### **Address Translation Process** Whether an address is treated as virtual (translated) or treated as real is controlled by the value of the translate mode bit on the processor channel. Each device that places a request on the processor channel controls the value of the translate mode bit for each request. If the translate mode bit is active, the address is treated as a virtual address and is translated. When the translate mode bit is inactive, the address is not translated. A virtual equal-to-real addressing mode that allows selected virtual addresses to bypass the normal address translation, memory protection, and lockbit processing is provided. Virtual equal to real mode is enabled by a bit in the translation control register (see "Translation Control Register" on page 11-117). #### **Address Translation Overview** The memory management unit address translation mechanism provides support for the following: - · Multiple independent virtual address spaces - Address space size of 4 gigabytes - Demand paging - Page size of 2048 or 4096 bytes - Memory protection - · Shared segments for instructions and data - Special segment support with high resolution protection - Real memory addressability of up to 16 megabytes - Reference and change bits for each real page - Hardware assist for load real address, invalidated TLB entries, and memory exception address. Memory is treated as if it were mapped onto a single 40-bit virtual address space consisting of 4096 segments of 256 megabytes each. The 32-bit address received from the processor channel is converted to a 40-bit ("long form virtual") address by using the four high-order bits to select one of 16 segment registers, and the 12-bit contents which concatenated with the remaining 28 bits of the effective address. The translation mechanism then converts the 40-bit virtual address to a real address for memory access. At any given instant, only 4 gigabytes of memory is addressable, namely the sixteen 256 megabyte segments specified by the 16 segment registers. This fact allows the operating system to create multiple independent virtual address spaces by loading appropriate values into the segment registers. As a limiting case, 256 completely independent 4 gigabyte address spaces can be created in this manner, although some segments (such as nucleus code) can be shared across multiple address spaces. Memory protection similar to that of System 370 is provided on a 2K or 4K-byte page basis. Memory protect and fetch protect are supported, with the protect key (equivalent to the key in the S/370 PSW) specified independently for each 256 megabyte segment. Support for special segments is provided by a set of lock bits associated with each virtual page. The lock bits effectively extend the memory protection granularity to lines of memory (128 bytes for 2K pages, or 256 bytes for 4K pages) and allow the operating system to detect and automatically journal changes to persistent variables. Each of the 16 segments can be marked as present or not present. The memory management unit accepts a virtual address only if the selected segment register entry indicates that the segment is present. This facility allows the virtual address space to be partitioned among multiple memory management units (or other devices) on the processor channel. Isolation of system processor and I/O device access is provided on a segment basis which allows each segment to be accessible by system processor requests only, I/O device requests only, both requests, or neither. This function can be used to protect against unauthorized access of memory by either the system processor or an I/O device (hard file). # **Address Translation Hardware Operation** The incoming 32-bit effective address is first expanded to a 40-bit virtual address by concatenating a segment identifier to the effective address. The virtual address is then presented to the translation hardware for conversion to the equivalent real address. Virtual addresses are translated to a real memory address by the process described in "Segment Register Selection" on page 11-96 through "TLB Reload from System Memory Page Tables" on page 11-101. # **Segment Register Selection** The high-order 4 bits of the incoming effective address index into the segment table to select one of 16 segments. A segment present bit, a system processor access protect bit, an I/O access protect bit, a 12-bit segment identifier, a special segment bit, and a key bit are obtained from the selected segment register. The segment present bit indicates the corresponding segment is assigned to the memory management unit as described in "Segment Registers" on page 11-127. The system processor access protect bit, the I/O protect bit, the special segment bit, and the key bit are used for access validation as described in "Memory Access Control" on page 11-108. The 12-bit segment identifier is used for formation of the virtual address. Figure 11-12 shows the segment table format. Figure 11-12. Segment Register Format ## **Generation of The Virtual Address** The 12-bit segment identifier is concatenated with bits 4 through 31 of the incoming effective address to form a 40-bit virtual address. The low-order 11 bits for 2K pages, or 12 bits for 4K pages, of the effective address are used as the byte address for the selected real page. These bits are not altered by the translation process. The remaining bits of the virtual address are then presented to the translation hardware. Figure 11-13 shows the generation of the virtual address using the segment identifier and the memory effective address. Figure 11-13. Generation of Virtual Address ## **TLB Operation** The memory management unit utilizes a translation look-aside buffer (TLB) to contain translations of the most recently used virtual addresses. Hardware is used to automatically update TLB entries from system memory page tables as new virtual addresses are presented to the TLBs for translation. A simplified data-flow of the translation hardware is shown in Figure 11-14 on page 11-100 and the format of each TLB is shown Figure 11-15 on page 11-101. The memory management unit utilizes two TLBs with 16 entries per TLB (2-way set associative with 16 congruence classes). The low-order 4 bits of the virtual page index are used to address both TLBs in parallel. The address tag entry in each TLB is compared with the segment identifier concatenated with the remaining bits of the virtual page index (25 bits for 2K pages, or 24 bits for 4K pages). If either of the two compares are equal and the TLB entry is valid (as indicated by the valid bit), the associated TLB contains the translation information for the given virtual address. The real page number field in the selected TLB entry contains the real page number in system memory that is mapped to the given virtual address. If this is not a special segment, the access is checked for memory protect violations using the key bits from the TLB entry and the key bit from the segment register before the access is allowed. If this is a special segment, as indicated by the special bit in the segment register, lockbit processing is performed before the access is allowed. The memory protect facility is described in "Memory Protection Processing" on page 11-109; and special segment processing is described "Lockbit Processing" on page 11-110. If the access is permitted, system memory is then accessed, and the reference and change bits associated with the page are updated. "Reference And Change Bits" on page 11-111 describes the setting of the reference and change bits. Figure 11-14. Address Translation Mechanism Figure 11-15. TLB Contents. One of two TLBs shown. #### **TLB Reload from System Memory Page Tables** If a match is not obtained from the two TLB compares, the address translation logic attempts to reload the faulting TLB entry from the page table entries in system memory. The system memory page table is resident in real memory and logically consists of two parts, a hash anchor table (HAT) and an inverted page table (IPT). The HAT maps any virtual address to any real page through a hashing function. The IPT defines which virtual address is currently assigned to each real page. There is one HAT and one IPT entry for each page of real memory. Translation of a virtual address to a real address is accomplished by first exclusive 'ORing' selected low-order bits of the effective address with bits from the segment identifier. This hashed address is then used to index into the HAT. The selected HAT entry points to the beginning of a list of IPT entries to be searched for the given virtual address. Entries in the list of IPT entries to be searched are linked together by a pointer in each entry that points to the next IPT entry to be searched. A flag bit in the IPT entry indicates the end of the search chain. Since the hashing function can produce the same HAT address for several different effective addresses, several virtual address entries in the IPT chain must be searched. #### **HAT and IPT Format** For hardware efficiency reasons, the HAT and IPT are combined into one structure that can be addressed by one indexing structure. There is one entry in the combined HAT and IPT for each page of real memory. For example, 1 megabyte of memory organized as 2K-byte pages requires 512 entries and 512K-bytes organized as 4K-pages requires 128 entries. The format of the combined HAT and IPT entries is shown in Figure 11-16. The HAT/IPT contains 16 bytes for each entry and starts on an address that is a multiple of the table size. Figure 11-16. System Memory Inverted Page Table Entry Format The first word in each entry contains the address tag which is composed of the segment identifier | | virtual page index. Note that for 2K pages the address tag is 29 bits, and for 4K pages it is 28 bits. If a page size of 4K is used, the 28-bit address tag is stored in bits 3 through 30. Bit 2 is reserved. The first word also contains a 2-bit key that is used for memory protection as described in "Memory Protection Processing" on page 11-109. The second word contains the HAT pointer, IPT pointer, and valid bits for each pointer. Use of the pointers is described in "HAT Address Generation" on page 11-104 and "IPT Search" on page 11-105. The third word contains the write protect, lock bits, and TID for special segments. Use of these fields are described in "Memory Protection Processing" on page 11-109. The fourth word is not used for TLB reloading, and is reserved for future use. #### **HAT/IPT Base Address** The HAT/IPT base address is the starting address for the system memory inverted page table (combined HAT/IPT), and is computed based on a field in the translation control register (TCR), the memory size defined by the RAM configuration register, and the page size defined in the translation control register. The value contained in the HAT/IPT base address field in the TCR is multiplied by value shown in Figure 11-17 to obtain the starting address of the HAT/IPT. Also shown in Figure 11-17 is the size of the HAT/IPT for each memory size and page size. | Memory Size<br>Bytes | Page Size<br>Bytes | HAT/IPT Size<br>(Entries/Bytes | HAT/IPT Base Address<br>Multiplier | |----------------------|--------------------|--------------------------------|------------------------------------| | 64K | 2K | 32/512 | 512 | | 64K | 4K | 16/256 | 256 | | 128K | 2K | 64/51K | 1024 | | 128K | 4K | 32/512 | 512 | | 256K | 2K | 120/2K | 2048 | | 256K | 4K | 64/1K | 1024 | | 512K | 2K | 256/4K | 4096 | | 512K | 4K | 128/2K | 2048 | | 1 <b>M</b> | 2K | 512/8K | 8192 | | 1M | 4K | 256/4K | 4096 | | 2M | 2K | 1024/16K | 16284 | | 2M | 4K | 512/8K | 8192 | | 4M | 2K | 1048/32K | 32768 | | 4M | 4K | 1024/16K | 16284 | | 8M | 2K | 4096/64K | 65536 | | 8M | 4K | 2048/32K | 32768 | | 16M | 2K | 8192/128K | 131072 | | 16M | 4K | 4096/64K | 65536 | Figure 11-17. HAT/IPT Base Address Multiplier #### **HAT Address Generation** The HAT index is computed by exclusive 'ORing' selected bits from the segment identifier with bits from the effective address. The number of bits used is chosen so that the resulting index selects one of the entries in the HAT/IPT. The bits used for generation of the HAT Index are listed in Figure 11-18. The memory address of the selected HAT entry is computed as: HAT/IPT Base Address + HAT Index | | 0100. The selected HAT entry is accessed and the empty bit is checked to determine if the IPT search chain is empty. If the empty bit is 1, there is no page mapped to the given virtual address and a page fault is reported as described in "Memory Exception Register" on page 11-119. If the empty bit is 0, entries in the IPT search chain exist, and they are searched. The HAT pointer field of the selected HAT entry is then used as a pointer to the start of the IPT search chain. | Memory<br>Size<br>(Bytes) | Page<br>Size<br>(Bytes) | Number<br>of<br>Pages | Segment<br>ID<br>Bits | Effective<br>Address<br>Bits | Index<br>(Number<br>of Bits) | |---------------------------|-------------------------|-----------------------|-----------------------|------------------------------|------------------------------| | 64K | 2K | 32 | 7 - 11 | 16 - 20 | 5 | | 64K | 4K | 16 | 8 - 11 | 16 - 19 | 4 | | 128K | 2K | 64 | 6 - 11 | 15 - 20 | 6 | | 128K | 4K | 32 | 7 - 11 | 15 - 19 | 5 | | 256K | 2K | 128 | 5 - 11 | 14 - 20 | 7 | | 256K | 4K | 64 | 6 - 11 | 14 - 19 | 6 | | 512K | 2K | 256 | 4 - 11 | 13 - 20 | 8 | | 512K | 4K | 128 | 5 - 11 | 13 - 19 | 7 | | 1M | 2K | 512 | 3 - 11 | 12 - 20 | 9 | | 1M | 4K | 256 | 4 - 11 | 12 - 19 | 8 | | 2M | 2K | 1024 | 2 - 11 | 11 - 20 | 10 | | 2M | 4K | 512 | 3 - 11 | 11 - 19 | 9 | | 4M | 2K | 2048 | 1 - 11 | 10 - 20 | 11 | | 4M | 4K | 1024 | 2 - 11 | 10 - 19 | 10 | | 8M | 2K | 4096 | 0 - 11 | 9 - 20 | 12 | Figure 11-18 (Part 1 of 2). HAT/IPT Index Generation Source Fields | Memory<br>Size<br>(Bytes) | Page<br>Size<br>(Bytes) | Number<br>of<br>Pages | Segment<br>ID<br>Bits | Effective<br>Address<br>Bits | Index<br>(Number<br>of Bits) | |---------------------------|-------------------------|-----------------------|-----------------------|------------------------------|------------------------------| | 8M | 4K | 2048 | 1 - 11 | 9 - 19 | 11 | | 16M | 2K | 8192 | 0 - 11 | 8 - 20 | 13 | | 16M | 4K | 4096 | 0 - 11 | 8 - 19 | 12 | Figure 11-18 (Part 2 of 2). HAT/IPT Index Generation Source Fields #### **IPT Search** The HAT pointer previously accessed is used as the starting index into the IPT. The memory address of the first IPT entry is computed as: HAT/IPT Base Address + HAT Pointer | 0000. The first entry in the IPT is accessed and the address tag is compared to the given virtual address. If the two are equal, the real page assigned to the virtual address has been located, and the faulting TLB entry can be reloaded. Reloading of the TLB entry is described in "TLB Reload from System Memory Page Tables" on page 11-101. If the two are not equal, the IPT search continues by accessing the IPT pointer. The IPT pointer address is computed as: HAT/IPT base address + HAT pointer | 0100. The IPT pointer is then accessed, and the last bit is checked to determine if additional entries in the IPT search chain exist. If the last bit is a 0, there are additional entries and the search process continues. If the last bit is a 1, there are no additional IPT entries to be searched, and a page fault is reported as described in "Memory Exception Register" on page 11-119. If there are additional IPT entries to be searched, the address of the next IPT entry for searching is computed as: HAT/IPT Base Address + IPT Pointer | 0000. This address accesses the next entry in the IPT search chain; the address tag contained in the selected entry is compared to the given virtual address. If the two are equal, the real page assigned to the virtual address has been located and the faulting TLB entry can be reloaded. Reloading of the TLB entry is described in "TLB Reload from System Memory Page Tables" on page 11-101. If the two are not equal, the search process continues by accessing the pointer to the next entry to be searched. The address of the pointer to the next entry is computed as: HAT/IPT base address + IPT pointer | 0100. This word is then accessed, and the last bit is checked to determine if there are additional entries in the IPT search chain. If the last bit is a 1, there are no additional IPT entries to be searched, and a page fault is reported as described in "Memory Exception Register" on page 11-119. If the last bit is a 0, there are additional entries and the search process continues. The current IPT pointer is used to access subsequent entries using the previously described process, until either the address tag in the IPT entry is equal to the given virtual address, or no match is found and the last bit indicates no further entries exist in the search chain. #### **TLB Reload** If an IPT entry is found with an address tag field equal to the given virtual address, the faulting TLB entry is reloaded. Reloading consists of selecting the least recently used TLB entry for the congruence class of the faulting virtual address and then loading the selected entry with the given virtual address tag field, the corresponding real page number and the key bits. If this is a special segment as indicated by the special bit in the segment register, then the write bit, TID, and lock bits are also reloaded. Hardware is used to determine the least recently used TLB entry in each congruence class. Since the low-order bits of the virtual address determine the congruence class, the only decision to be made is which TLB should have the selected entry replaced. One of the two TLBs is then selected according to which TLB contained the entry in the given congruence class that was referenced the furthest in the past. Once the least recently used TLB entry for the given congruence class is determined, the selected TLB entry can be reloaded. The address tag field and key bits are reloaded from the IPT entry contained in system memory. The address of this entry was previously computed in the IPT search process. Since the IPT index computed in the search process is equal to the real page number, this value is used to reload the real page number field in the TLB. If this is a special segment, as indicated by the special bit in the segment register, the write bit, TID, and lock bits are also reloaded. The write bit, TID, and lock bits are reloaded by accessing the third word in the selected IPT entry. #### **TLB Reload Performance** The time required to reload a TLB entry is a function of the IPT search chain length, and whether the TLB entry is for a special or nonspecial segment. The TLB reload time can be computed from the sum of the following components. - Base time - IPT search time - Special segment time - Page fault time - Correctable ECC error time. The base time is approximately equal to 850 nanoseconds. IPT search time is a function of the IPT search chain length. If the empty bit in the HAT pointer indicates there are no entries in the IPT, the IPT search time is 0. If the empty bit in the HAT pointer indicates there are valid entries in the IPT, the IPT search time can be computed as 510 nanoseconds times the number of entries searched in the IPT. Special segment time is added only for special segments, and is equal to 340 nanoseconds. Page fault time is added only if a page fault condition is detected during the IPT search. The page fault time is equal to 170 nanoseconds. Correctable ECC error time is added for each correctable ECC error, which occurs during the TLB reload. Each correctable ECC error requires 170 nanoseconds for correction. For example, consider the calculation of the TLB reload time for special segment which is successful (that is, no page fault), and a search of two IPT entries. Also, assume no correctable ECC errors occur during the reload. This results in a total TLB reload time of 850 nsec. + (510 nsec. times 2) + 340 nsec., or 2.2 microseconds. # **Memory Access Control** The memory management unit provides three access control facilities. The first facility determines if an access is allowed, based on the source of the request (either system processor or an I/O device) and the system processor access protect and I/O access protect bits in the selected segment register. After an access has been validated on a segment basis, there is a second facility that applies to nonspecial segments which provides read/write protection for each page of real memory. A third facility applies only to special segments and is used to support the PL.8 Persistent data type. These access control facilities apply only to translated requests. Memory protection and lockbit processing are disabled for virtual equal to real mode. Virtual equal to real mode is enabled by the segment register zero virtual equal to real bit (bit 16) in the translation control register. When this bit is set to 1, translated accesses to segment register zero are treated as virtual equal to real. If a violation is detected by any of these facilities, the memory access is terminated and an exception reported to the system processor as described in "Memory Exception Register" on page 11-119. ## **Segment Protection Processing** Segment protection processing applies to all translated requests, including requests made in virtual equal real mode. The high-order 4 bits of the incoming effective address are used to index into the segment table to select one of 16 segment registers. A system processor access protection bit and an I/O access protection bit are obtained from the selected segment register. These bits, in conjunction with the source of the request (either system processor or an I/O device), determine whether the requested access is permitted for the selected segment. The source determination of the request is made by the tag field on the processor channel associated with each request. If the tag indicates the request is from the system processor, the system processor access protect bit determines if the access is valid. If the tag is from any device other than the system processor, (such as the I/O channel controller) the I/O access protect bit determines if the access is valid. Access is controlled as shown in Figure 11-19. | Access<br>Type | System Processor<br>Access Protect Bit | I/O Access<br>Protect Bit | Access<br>Permitted | |------------------|----------------------------------------|---------------------------|---------------------| | system processor | 0 | _ | Yes | | system processor | 1 | _ | No | | I/O | _ | 0 | Yes | | I/O | _ | 1 | No | Figure 11-19. Segment Protection Processing If the access is not allowed, then the translation is terminated, and a segment protection exception is reported to the system processor as described in "Memory Exception Register" on page 11-119. ### **Memory Protection Processing** Memory protection processing applies only to virtual requests to nonspecial segments. Memory protection processing is disabled for virtual equal real accesses. Once a correspondence between a virtual and a real address is determined by the TLB, the requested access is verified to insure proper access authority. This facility allows each page to be marked as no access, read only, or read/write. Access control is a function of the 1-bit protection key in the selected segment register, the 2-bit key in the TLB entry, and whether the access is a load or store operation. For memory protection processing, a test-and-set (TSH) operation is treated as a store. Access is controlled as shown in Figure 11-20 on page 11-110. | Key In | | Protect<br>Key In | Access Permitted | | |--------|-----------------------|-------------------|------------------|------------| | TLB | Type of Page | Seg Reg | Load | Store | | 00 | Key 0 fetch-protected | 0 | Yes<br>No | Yes<br>No | | 01 | Key 0 read/write | 0 | Yes<br>Yes | Yes<br>No | | 10 | Public read/write | 0 | Yes<br>Yes | Yes<br>Yes | | 11 | Public read-only | 0 | Yes<br>Yes | No<br>No | Figure 11-20. Protection Key Processing If the access is not allowed, then the translation is terminated, and a protection exception is reported to the system processor as described in "Memory Exception Register" on page 11-119. ## **Lockbit Processing** Lockbit processing applies only to virtual requests to special segments as indicated by the special bit in the selected segment register. Lockbit processing is disabled for virtual equal real accesses. Lockbit processing allows the operating system to automatically monitor changes to persistent variables and to journal changes, create shadow pages, and perform other processing required for data base consistency. Lockbits also extend the protection from the page size resolution (either 2K or 4K-bytes) provided by the memory protect facility to lines of either 128 or 256 bytes. A resolution of 128 bytes is provided for 2K pages, and 256 bytes for 4K pages. The individual line lockbit is selected by bits (21-24) of the effective address for 2K pages, and bits (20-23) for 4K pages. The proper lockbit is selected by these four bits with a value of 0000 selecting lockbit zero (bit 16 in the lockbit field in the HAT/IPT entry), and a value of 0001 selecting lockbit one (bit 17 in the lockbit field in the HAT/IPT entry). The selection of the proper lockbit continues in this manner with a value of 1111 selecting lockbit fifteen (bit 31 in the lockbit field in the HAT/IPT entry). Access control is a function of the 1-bit write key in the selected TLB entry, the lockbit value of the selected line, the TID compare, and whether the access is a load or store operation. For lockbit processing, a test-and-set (TSH) operation is treated as a store. Access is controlled as shown in Figure 11-21. | Current TID Compared to | Write<br>Bit | Lockbit Value For | Access Pe | rmitted<br>Store | |-------------------------|--------------|-------------------|-----------|------------------| | TID In TLB | In TLB | Selected Line | Loau | Sitte | | Equal | 1 | 1 | Yes | Yes | | | _ | 0 | Yes | No | | Equal | 0 | 1 | Yes | No | | | | 0 | No | No | | Not Equal | | | No | No | Figure 11-21. Lockbit Processing The data memory exception reports a lockbit violation. This violation may not represent an error; it may be simply an indication that a newly modified line must be processed by the operating system. ## **Reference And Change Bits** Reference and change bits are provided for each page of real memory. These bits are in arrays external to the memory management unit and are updated, as required, for each memory access. The reference bit is set to 1 if the corresponding real page is accessed for either a read or write operation. The change bit is set if the corresponding page is written. Reference and change bits are accessible via I/O read and write instructions (IOR and IOW) from the system processor. Reference and change bits for each page of real memory start at the I/O address specified by the I/O Base Address Register plus X'1000'. The I/O address of the reference and change bits for a given page when 2K pages are used (TCR bit 23 set to zero) is given by the following equation. I/O Address = Address Specified by I/O Base Address Register X'1000' Page Number The I/O address of the reference and change bits for a given page when 4K pages are used (TCR bit 23 set to 1) is given by the following equation. I/O Address = Address Specified by I/O Base Address Register X'1000'Page Number \* 2 Each I/O address contains the reference and change bits for one page of real memory. The format of the reference and change bits is shown in Figure 11-22. Figure 11-22. Reference and Change Bit Format Data transferred by accesses to reference and change bits is defined as follows: | Bits 0-29 | Reserved. | |-----------|-----------------------------------------------------------------------------------------------------| | Bit 30 | Reference Bit. Set to 1 when the corresponding real page is accessed for a read or write operation. | | Bit 31 | Change Bit. Set to 1 when the corresponding real page is accessed for a write operation. | Reference and change bits are not initialized by hardware. They are initialized and cleared by system software via IOW instructions. Since reference and change bits can be set or cleared by program execution, a write to clear or set reference and change bits followed by a read, will not necessarily read the same data that was written. Translated accesses which do not have a corresponding TLB entry causes a superfluous memory access to the last page of the 16M-byte real memory address space. This superfluous access causes the reference bit for this page (page 8191 for 2K page size systems, and page 4095 for 4K page size systems) to be set. There are no other side effects from this superfluous access, other than setting of the reference bit for the last page. # **Control Registers** There are 4 control registers used for defining the I/O base address, the RAM and ROM memory configuration, and the translation control information. There are 2 registers used to report errors detected by memory management unit, one register for use with the Compute Real Address function, one for the transaction identifier, and 16 segment registers. These registers are accessed by system software via I/O read and I/O write (IOR and IOW) instructions from the system processor. These registers are accessible only from privileged state. All control registers are initialized to 0 by the power-on-reset (POR) sequence. # I/O Base Address Register The I/O base address register specifies which 64K block of I/O addresses are assigned to memory management unit. The I/O base address is equal to the value contained in the I/O base address register multiplied by 65536 (X'10000'). The format of the I/O base address register is shown in Figure 11-23. Figure 11-23. I/O Base Address Register The I/O base address register is defined as follows: Bits 0-23 Reserved. Bits 24-31 I/O Base Address. This 8-bit value defines which 64K-byte block of I/O addresses are assigned to the memory management unit (these 8 bits are the most significant 8 bits in the I/O address recognized by memory management unit). #### **RAM Specification Register** The RAM specification register defines the RAM size and RAM starting address. The format for the RAM specification register is shown in Figure 11-24 on page 11-114. Figure 11-24. RAM Specification Register The RAM specification register is defined as follows: Bits 0-19 Reserved. Bits 20-27 RAM Starting Address. This 8-bit field defines the starting address of RAM for non translated accesses. Translated accesses are unconditionally directed to RAM. For nontranslated accesses, the RAM starting address is used in conjunction with RAM Size to determine if an address is within the address range specified for memory management unit. The starting address of RAM is defined as a binary multiple of the RAM size, and is computed by multiplying the bits indicated below by the value specified by RAM Size. | RAM | Bits | Bits | | |------------|-----------------------|-----------------------------------------------|------------| | Size | 20 21 22 23 | 24 25 26 27 | Multiplier | | 64K | $x \times x \times x$ | $\mathbf{x} \mathbf{x} \mathbf{x} \mathbf{x}$ | 64K | | 128K | X X X X | X X X - | 128K | | 256K | X X X X | X X | 256K | | 512K | X X X X | X | 512K | | 1 <b>M</b> | X X X X | ' | 1 <b>M</b> | | 2M | X X X - | | 2M | | 4M | X X | | 4M | | 8M | X | | 8 <b>M</b> | | 16M | | | 16M | X = bit used in address calculation - = bit not used in address calculation For example, if a memory size of 256K is specified, bits 20-25 specify which one of sixty four 256K-byte boundaries is the RAM starting address. If bits 20-25 are 011101, the RAM starting address is X'00740000'. If a RAM size of 1M-byte is specified, bits 20-23 specify which one of 16 1M-byte boundaries is the RAM starting address. If bits 20-23 are 1001, the RAM starting address is X'00900000'. **Note:** To provide memory for the system processor PSWs, the RAM starting address must be set to zero. Bits 28-31 RAM Size. This 4-bit field defines the size of RAM attached to memory management unit. RAM size is selectable from 64K-bytes to 16M-bytes as defined below. | Bits 28-31 | RAM Size | |--------------|------------| | 0000 | No RAM | | 0001<br>thru | | | 0111 | 64K | | 1000 | 128K | | 1001 | 128K | | 1001 | 256K | | 1010 | 512K | | 1011 | 1 <b>M</b> | | 1100 | 2M | | 1101 | 4 <b>M</b> | | 1110 | 8M | | 1111 | 16M | # **ROM Specification Register** The ROM specification register defines the ROM starting address, ROM size, and whether parity is provided by ROM. ROM can be accessed only in non translated mode. The format of the ROM specification register is shown in Figure 11-25. Figure 11-25. ROM Specification Register The ROM specification register is defined as follows: Bits 0-18 Reserved. Bit 19 [P] ROM Parity Enable. This bit is used to enable internal memory management unit parity checking for ROM accesses. When this bit is set to 1, parity is checked by the memory management unit for ROM accesses (the ROM has parity bits). When set to 0, parity is not checked by the memory management unit for ROM accesses. In both cases, the memory management unit generates parity for processor channel replies to ROM requests. Parity is not implemented on the processor board ROM, which requires that this bit always be set to 0. Bits 20-27 ROM Starting Address. This eight-bit field defines the starting address of ROM for nontranslated accesses. For nontranslated accesses, the ROM starting address is used in conjunction with ROM size to determine if an address is within the address range specified for this memory controller. The starting address of ROM is defined as a binary multiple of the ROM size, and is computed by multiplying the bits indicated below by the value specified by ROM size. Note: The processor board provides only a 64K-byte ROM. | ROM | Bits | Bits | | |------|-----------------------------------------------|-------------|------------| | Size | 20 21 22 23 | 24 25 26 27 | Multiplier | | 64K | $\mathbf{x} \mathbf{x} \mathbf{x} \mathbf{x}$ | X X X X | 64K | | 128K | X X X X | X X X - | 128K | | 256K | X X X X | X X | 256K | | 512K | X X X X | X | 512K | | 1M | X X X X | | 1 <b>M</b> | | 2M | X X X - | | 2M | | 4M | X X | | 4M | | 8M | X | | 8 <b>M</b> | | 16M | | | 16M | X = bit used in address calculation - = bit not used in address calculation For example, if a ROM size of 64K is specified, bits 20-27 specify which one of 256 64K-byte boundaries is the ROM starting address. If bits 20-27 are 11001000, the ROM starting address is X'00C80000'. Bits 28-31 ROM Size. This 4 bit field defines the size of ROM attached to the memory management unit. The processor board provides a 64K-byte ROM. ROM sizes of 128K thru 16M are not supported. The ROM size bits must be set to either no ROM or 64K only. | Bits 28-31 | ROM Size | |--------------|------------| | 0000 | No ROM | | 0001<br>thru | | | 0111 | 64K | | 1000 | 128K | | 1001 | 256K | | 1010 | 512K | | 1011 | 1 <b>M</b> | | 1100 | 2M | | 1101 | 4M | | 1110 | 8M | | 1111 | 16M | | | | Note: If the ROM address space, as defined by the ROM starting address and the ROM size, overlaps any of the RAM address space, as defined by the RAM starting address and the RAM size. the results are unpredictable. This means that if any ROM is used (bits 28 - 31 not zero), the maximum RAM size is 8M. ### **Translation Control Register** The translation control register (TCR) specifies: - If segment register zero accesses are treated as virtual equal to real - If interrupts are generated on a successful processor channel parity error retry - If RAS diagnostic mode is enabled - If unusually long IPT searches are terminated - If interrupts are generated on correctable ECC errors - If interrupts are generated on successful hardware TLB reload, - The size of each page (either 2K or 4K-bytes) - The starting address of the system memory page table (combined HAT and IPT). The translation control register format is shown in Figure 11-26 on page 11-118. Figure 11-26. Translation Control Register The translation control register is defined as follows: Bits 0-15 Reserved. - Bit 16 (V) Segment Register Zero Virtual Equal To Real. When set to 1, all accesses to segment register zero are treated as a real (untranslated) address. In this mode, memory protection checking and lockbit processing are disabled, and the low-order 24 bits of the 32-bit virtual address are used as the memory address. Contents of the TLBs are not altered by virtual equal to real accesses. When segment register zero virtual equal to real is set to 0, normal protection processing and address translation applies to virtual accesses to segment register zero. - Bit 17 (E) Interrupt On Successful Parity Error Retry. When set to 1, this bit enables a machine check interrupt, unless RAS diagnostic mode is enabled, when a processor channel retry successfully completes a memory management unit reply that was previously unsuccessful due to detection of a parity error by the receiving device. A successful parity error retry sets the ACKD and NAKD bits in the MER (bits 15 and 16) to 1. When interrupt on successful parity error retry is set to 0 or RAS diagnostic mode is enabled (TCR bit 18 set to 1), no interrupt results from a successful retry. - Bit 18 (D) Enable RAS Diagnostic Mode. When set to 1, this bit enables ECC diagnostic checking. When set to 0, diagnostic mode is disabled. When RAS diagnostic mode is enabled, all machine check interrupts and exception replies (except addressing errors) from the memory management unit are disabled. Also, all store operations use the alternate check bits stored in the RMDR instead of the memory management unit generated ECC check bits for the stored data. See "RAS Mode Diagnostic Register" on page 11-131 for a complete description of RAS diagnostic mode. - Bit 19 (I) Terminate Long IPT Search. When set to 1, this bit terminates hardware searching of the IPT after 127 entries have been compared in a given search chain, and a matching entry is not found. When the IPT search is terminated, an exception reply is generated and the IPT specification error bit (bit 25) in the MER is set to 1. When terminate long IPT search is set to 0, the IPT search continues until a matching entry is found, or until the end of the search chain is detected. Since each IPT search chain should contain only a few entries, use of this facility will normally report only software errors in constructing the search chains. Unusually long search chains, or search chains which contain an infinite loop are detected and reported by enabling this facility. - Bit 20 (C) Enable Interrupt On Correctable ECC Error. When set to 1, this bit enables reporting of correctable ECC errors via the machine check interrupt line to the system processor, unless RAS diagnostic mode is enabled. A correctable ECC error sets the correctable ECC error bit (bit 21) in the MER to one, and the MEAR is loaded with the memory address of the correctable error, if it is not locked. The MEAR is then locked to all subsequent real errors and no further ECC error machine check interrupts are reported until the RMDR is read. When enable interrupt on correctable ECC error is set to 0 or RAS diagnostic mode is enabled (TCR bit 18 set to 1), correctable ECC errors are not reported. - Bit 21 (R) Enable Interrupt On Successful TLB Reload. This bit enables reporting of successful hardware TLB reloading. When set to 1, a successful hardware TLB reload generates a exception reply, and sets the TLB reload bit (bit 22) in the MER to 1. When enable interrupt on successful TLB reload is set to 0, successful hardware reloading of TLB entries is not reported. This facility is used for software performance measurement of the TLBs. - Bit 22 Reserved. - Bit 23 (S) Page Size. A value of 0 is used for 2K-byte pages, and a value of 1 is used for 4K-byte pages. - Bits 24-31 HAT/IPT Base Address. This 8-bit field specifies the starting address of HAT/IPT entries in system memory. The value contained in this field is multiplied by a constant determined by the size of real memory and the page size, to determine the starting address of the HAT/IPT entries. For a page size of 2K-bytes, the base address is specified by bits 25-31, and for 4K-pages by bits 24-31. The constant for each memory size and page size configuration is listed in Figure 11-17 on page 11-103. #### **Memory Exception Register** The memory exception register (MER) reports errors in the translation process, system errors, and ECC errors for a memory access. Individual bits are provided to report each error condition detected by the memory management unit. In the case of multiple errors, each error is reported by setting of the appropriate bit. Bits which were set by previous errors are not reset by subsequent errors. The MER is initialized to 0 by the POR sequence. Once an exception is reported, system software is responsible for clearing the MER (via an IOW instruction) after the exception is processed. The memory management unit provides a -PGM Check output to report suspected software errors. The - PGM Check output is activated when software related errors are detected. Reading the MER by an IOR instruction resets the -PGM CHECK output. The memory exception register format is shown in Figure 11-27 on page 11-120. Figure 11-27. Memory Exception Register The memory exception register is defined as follows: - Bits 0-13 Reserved. - Bit 14 (V) Segment Protection Violation. This bit is set to 1 when translation is terminated because segment protection processing determines that a memory access is not allowed. This bit is set only for protection errors detected during the processing of system processor generated requests. Detection of a segment protection violation for any processor channel request generates a exception reply, unless RAS diagnostic mode is enabled. If the segment protection violation is caused by a system processor generated load or store, and the MEAR is not locked, the MEAR is loaded with the effective address causing the segment protection violation, and is set to the locked state. Bit 15 (A) Processor channel ACKD. This bit is set to the value of the processor channel data cycle ACK signal when a reply from the memory management unit to another device on the processor channel is rejected. This bit, combined with the processor channel NAKD bit, allows software to determine the reason a reply was rejected. The four combinations of ACKD and NAKD are defined below: | ACKD | NAKD | Meaning | | |------|------|---------------------|--| | 0 | 0 | No Device Responded | | | 0 | 1 | Device Busy | | | 1 | 0 | Transfer Successful | | | 1 | 1 | Parity Error | | Whenever a memory management unit reply is rejected, the memory management unit will retry the reply two times. Programming Note: Setting Of ACKD And NAKD Bits The processor channel ACKD and NAKD bits are loaded with the proper values whenever an processor channel retry occurs. This can occur during system operation, or when a support processor is used for system testing. In normal system operation, the ACKD and NAKD bits are loaded if there is no response to a memory management unit reply (ACKD=0, NAKD=0), a device responds busy to a memory management unit reply (ACKD=0, NAKD=1), or a device indicates a parity error to a memory management unit reply (ACKD=1, NAKD=1). System software reads the value of the ACKD and NAKD bits to determine the reason a reply was rejected. Software is responsible for resetting these bits once they have been read. - Bit 16 (N) Processor channel NAKD. This bit is set to the value of the processor channel data cycle NAK signal when a reply from the memory management unit to another device on the processor channel is rejected. This bit, combined with the processor channel ACKD bit, allows software to determine the reason a reply was rejected. The four combinations of ACKD and NAKD are defined above. - Bit 17 (B) Invalid Memory Address. This bit is set to 1 when an address is within the address range specified for ROM or RAM by the ROM specification register and RAM specification register, but is not within the address range defined on the ROM and RAM memory boards attached to the memory management unit. For example, if the RAM specification register defines 4M-bytes of RAM starting at address 0, and only 3M-bytes of memory are actually attached to the memory management unit, an address from 0 to 4M will be accepted by the memory management unit, but addresses greater than 3M set this bit (invalid memory address). This bit is set for invalid memory addresses generated by any processor channel device. Detection of an invalid memory address generates an exception reply for read accesses or translated write accesses, and activates the program check interrupt line for nontranslated write accesses. The MEAR is loaded with the invalid memory address, if it is not locked. Bit 18 (O) Invalid I/O Address. This bit is set to 1 when an I/O operation to a reserved address within the 64K address range recognized by the memory management unit is detected, or when an I/O read to a write only address (such as a read to the address for purge TLB, purge TLB segment, purge TLB entry, or load real address) is detected. Detection of an invalid I/O address generates an exception reply for I/O reads, unless RAS diagnostic mode is enabled, and activates the program check interrupt line for I/O writes. The MEAR is loaded with the invalid I/O address, if it is not locked. - Bit 19 (L) Access Type. This bit is set to 1 when an exception is caused by a load, and set to 0 when the exception is caused by a store or test-and-set. This bit is valid only for segment protection violation, IPT specification error, TLB specification error, page fault, protection, and data exceptions caused by a system processor load or store. - Bit 20 (U) Uncorrectable Memory Error. This bit is set to 1 when there is an uncorrectable ECC error. Detection of an uncorrectable memory error generates an exception reply for read accesses or translated write accesses, and activates the machine check interrupt line, unless RAS diagnostic mode is enabled. The MEAR is loaded with the address of the uncorrectable memory error, if it is not locked. The MEAR is then locked to all subsequent real errors and ECC error machine checks are not generated until the RAS mode diagnostic register is read. The RMDR is loaded with ECC bits of the failing memory operation and locked until read. Bit 21 (C) Correctable ECC Error. This bit is set to 1, unless the uncorrectable memory error bit is already set, when a correctable ECC error is detected during a memory operation for any processor channel device, If interrupt on correctable ECC error is enabled (TCR bit 20 set to 1), and a correctable ECC error is detected, the machine check interrupt line is activated, unless RAS diagnostic mode is enabled. The MEAR is loaded with the memory address of the correctable ECC error, if it is not locked. The MEAR is then locked to all subsequent real errors and ECC error machine checks are not generated until the RAS mode diagnostic register is read. The RMDR is loaded with ECC bits of the failing memory operation and locked until read. Bit 22 (T) Successful TLB Reload. This bit is set to 1 when interrupt on successful TLB reload is enabled (TCR bit 21 set to 1), and a TLB entry is successfully reloaded for any processor channel device. If a successful TLB reload occurs and interrupt on successful TLB reload is enabled, an exception reply is generated, unless RAS diagnostic mode is enabled (such as successful TLB reload interrupts are disabled whenever RAS diagnostic mode, bit 18 in the TCR, is set to a 1). Bit 23 Reserved. Bit 24 (W) Write To ROM Attempted. This bit is set to 1 when an attempt to write to an address contained in the ROM address space is made by any processor channel device. Detection of a write to ROM activates the program check interrupt line. The MEAR is loaded with the memory address causing the error, if it is not locked. - Bit 25 (I) IPT Specification Error. This bit is set to 1 when: - Terminate long IPT search is enabled (TCR bit 19 set to 1) - TLB miss causes an IPT search which fails to find a matching IPT entry - The end of the IPT search chain after 127 IPT entries. This bit is set only for IPT specification errors detected during the processing of system processor generated requests. Detection of an IPT specification error for any processor channel request generates an exception reply, unless RAS diagnostic mode is enabled. If the IPT specification error is caused by a system processor generated load or store, and the MEAR is not locked, the MEAR is loaded with the effective address causing the IPT specification error, and is set to the locked state. - Bit 26 (E) External Device Exception. This bit is set to 1 when an exception (segment protect, IPT specification error, page fault, protection, or data) is caused by the IOCC. - Bit 27 (M) Multiple Exception. This bit is set to 1 when more than one exception (segment protect, IPT specification error, page fault, protection, or data) has occurred before the exception indication has been cleared in the memory exception register and the MEAR is currently locked with a virtual error. This bit is set only if the multiple exception is caused by system processor loads or stores. This bit normally indicates that system software has failed to process an exception. However, if an exception is caused by a Load Multiple (LM) or Store Multiple (STM) instruction, this bit can be set since the LM or STM instruction attempts to load or store all of the registers specified in the instruction before the instruction is terminated due to an exception. If two virtual error bits are set, and the multiple exception bit is not set, one of the errors was caused by an unexecuted instruction prefetch. - Bit 28 (F) Page Fault. This bit is set to 1 when: - Translation is terminated because no TLB entry or system memory page table entry contains the translation for a virtual address - A TLB reload operation is in progress when a reset packet is received - A TLB reload operation is terminated because an invalid address or an uncorrectable memory error is detected during a TLB reload operation. This bit is set only for page faults detected during the processing of system processor generated requests. Detection of a page fault for a IOCC request generates a exception reply, unless RAS diagnostic mode is enabled. If the page fault is caused by a system processor load or store, and the MEAR is not locked, the MEAR is loaded with the effective address causing the page fault, and is set to the locked state. Bit 29 (S) TLB Specification. This bit is set to 1 when translation is terminated because two TLB entries were found for the same virtual address for any processor channel request. Detection of a TLB specification error generates a exception reply and activates the machine check interrupt line, unless RAS diagnostic mode is enabled. The MEAR is loaded with the effective address causing the TLB specification error, if it is not locked, and is set to the locked state. If a TLB Specification error occurs during a store operation, the store occurs to an address that is the logical OR of the real page number value in the two matching TLB entries. Bit 30 (P) Protection. This bit is set to 1 when translation is terminated because memory protection processing for a non-special segment determines that a memory access is not allowed. This bit is set only for protection errors detected during the processing of system processor generated requests. Detection of a protection error for any processor channel request generates a exception reply, unless RAS diagnostic mode is enabled. If the protection error is caused by a system processor generated load or store, and the MEAR is not locked, the MEAR is loaded with the effective address causing the protection error, and is set to the locked state. Bit 31 (D) Data. This bit is set to 1 when translation is terminated because transaction ID/lockbit processing for a special segment determines that a memory access is not allowed. This bit is set only for data errors detected during the processing of system processor generated requests. Detection of a data error for any processor channel request generates a exception reply, unless RAS diagnostic mode is enabled. If the data error is caused by a system processor generated load or store, and the MEAR is not locked, the MEAR is loaded with the effective address causing the data error, and is set to the locked state. #### Reading of the MER by Diagnostic Routines Diagnostic routines must be aware that a cycle of delay exists between the occurrence of a memory error and the reporting of that error in the MER. If a load or store instruction which is expected to cause an error is followed immediately by an IOR of the MER, the value returned by the IOR may not have the corresponding error bits set. A load to register RX should be followed by a CAS RX, RX, R0 and then the IOR to guarantee that the correct MER value is read. If the faulting instruction is a store, insert an intervening load instruction before the IOR to assure that the correct MER value is returned. #### **Memory Exception Address Register** The memory exception address register (MEAR) contains the 32-bit effective address causing an exception reported by the memory exception register (MER) for an IPT specification error, page fault, TLB specification, segment protection violation, protection, or data exception, if the exception was caused by a system processor generated load or store operation. The MEAR is not loaded for exceptions caused by system processor instruction fetches, or by IOCC requests for the exceptions previously listed. System processor generated load and store operations cause the MEAR to be loaded with the 32-bit effective address causing the exception, if the MEAR is not locked. Detection of a TLB specification error for any virtual request causes the MEAR to be loaded with the 32-bit effective address causing the specification exception, if the MEAR is not locked. Once the MEAR is loaded with an effective address, it is set to the locked state. In addition, the MEAR contains the 24-bit memory address causing an error reported by the MER for an invalid memory address, invalid I/O address, uncorrectable ECC error, correctable ECC error, or write to ROM attempted error. The MEAR is loaded when the system processor or any other processor channel devices causes one of these errors, and the MEAR is not locked. Loading of the MEAR with a memory address does not set the MEAR to the locked state. However, loading of the MEAR for all uncorrectable ECC errors and correctable ECC errors when interrupt on correctable ECC error or RAS diagnostic mode are enabled (bits 18 or 20 in the TCR set to one), prevents the MEAR from being loaded by other memory related errors until the RMDR is read by an IOR instruction. All virtual exceptions will still be loaded into the MEAR for system processor loads and stores, and the MEAR is then placed in the locked state. The MEAR is initialized to the not locked state as part of the POR sequence. Writing of the MEAR as a result of an IPT specification error, page fault, TLB specification, segment protection violation, protection, or data exception causes the MEAR to be set to the locked state. Locking the MEAR prevents further exceptions from writing the MEAR. Reading or writing of the MEAR by software (via an IOR or IOW instruction) sets the MEAR to the not locked state. In the case of multiple errors (bit 27 of the MER set to one) the MEAR contains the address of the oldest exception. The memory exception address register format is shown in Figure 11-28. Figure 11-28. Memory Exception Address Register The memory exception address register is defined as follows: Bits 0-31 Memory Exception Address. The 32-bit effective memory address causing the exception reported by the MER for virtual accesses, or the 24-bit real memory address reported by the MER for real accesses. The 24-bit real memory address is contained in bits 8-31, and bits 0-7 are set to 0. In the case of multiple errors (bit 27 of the MER set to 1), the address contained in the MEAR is the address of the oldest exception. #### Reading of the MEAR by Diagnostic Routines Diagnostic routines must be aware that a cycle of delay exists between the occurrence of a memory error and the loading of the address of that error in the MEAR. If a load or store instruction which is expected to cause an error is followed immediately by an IOR of the MEAR, the value returned by the IOR may not have the corresponding error address. A load to register RX should be followed by a CAS RX,RX,R0 and then the IOR to guarantee that the correct MEAR value is read. If the faulting instruction is a store, insert an intervening load instruction before the IOR to assure that the correct MEAR value is returned. ### **Translated Real Address Register** The translated real address register (TRAR) contains the real memory address determined by the Compute Real Address operation. The Compute Real Address function is used to determine if a virtual address is currently mapped in real memory, and the corresponding real address if the virtual address is mapped. The Compute Real Address function is described in "Compute Real Address" on page 11-134. The translated real address register format is shown in Figure 11-29. Figure 11-29. Translated Real Address Register The translated real address register is defined as follows: - Bit 0 (I) Invalid Bit. This bit is set to 1 if the translation failed, and is set to 0 if the translation is successful. Segment protection, memory protect, and lockbit checking are not included in determination of the invalid bit. - Bits 1-7 Zeros. This 7-bit field is always 0. - Bits 8-31 Real Memory Address. This 24-bit field contains the real memory address mapped to the given virtual address if translation was successful. This field is unpredictable if translation fails. # **Transaction Identifier Register** The transaction identifier register (TID) contains the eight-bit identifier of the task currently defined as the owner of special segments. If a segment is defined as a special segment by the special bit in the selected segment register, then lockbit processing as described in "Lockbit Processing" on page 11-110 applies to the memory access. Lockbit processing uses the value contained in the TID and compares it against the TID entry in the TLB to determine if the memory access is permitted. The format of the transaction identifier register is shown in Figure 11-30. Figure 11-30. Transaction Identifier Register The transaction identifier register is defined as follows: Bits 0-23 Reserved. Bits 24-31 Transaction Identifier. This 8-bit value specifies the owner of special segments. ## **Segment Registers** The sixteen segment registers contain the segment present bit, the system processor access protection bit, the I/O access protection bit, the segment identifier, special bit, and key bit. The segment present bit indicates whether the corresponding segment is assigned to the memory management unit. The system processor and I/O access protect bits indicate whether system processor or I/O accesses are permitted to the corresponding segment. The 12-bit Segment Identifier specifies one of 4096 256M-byte virtual memory segments. The special bit indicates this is a special segment and lockbit processing applies. The key bit indicates the level of access authority associated with the currently executing task with respect to memory accesses within the given segment. The format of each segment register is shown in Figure 11-31. | 0 | 15 | | 18 | 3 | 29 | 31 | | |----------|----|---|----|------------|----|----|--| | Reserved | Р | R | 1 | Segment ID | s | K | | Figure 11-31. Segment Register (One Of Sixteen) The content of each segment register is defined as follows: - Bits 0-14 Reserved. - Bit 15 (P) Segment Present. This bit is set to 1 if the corresponding segment is assigned to the memory management unit. A virtual request will only be accepted by the memory management unit if the selected segment is assigned to the memory management unit. Virtual requests which select a segment that is not assigned to the memory management unit (segment present bit set to 0) are not accepted. This facility allows multiple memory management units (or other processor channel devices) to accept only selected virtual addresses. - Bit 16 (R) System Processor Access Protect. This bit is set to 0 if system processor accesses are allowed for the given segment, and set to 1 if system processor accesses are not allowed for the given segment. Use of this bit for segment protection is described in "Segment Protection Processing" on page 11-108. - Bit 17 (I) I/O Access Protect. This bit is set to 0 if I/O (non system processor) accesses are allowed for the given segment, and set to 1 if I/O (non system processor) accesses are not allowed for the given segment. Use of this bit for segment protection is described in "Segment Protection Processing" on page 11-108. | Bits 18-29 | Segment Identifier. This 12-bit quantity specifies one of 4096 256M-byte virtual memory segments. | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 30 (S) | Special Bit. This bit is set to 1 for special segments, and set to 0 for non special segments. | | Bit 31 (K) | Key Bit. This bit determines the level of access authority of the currently executing task for accesses within the given segment. Use of this bit for memory access control is described in "Memory Protection Processing" on page 11-109. | #### **TLB Entries** Each of the two TLBs contain sixteen entries, which provide the necessary translation and control information for the conversion of a virtual address to a real address. In addition, each TLB entry contains information used for memory access control. Since the TLB contents are automatically updated from the system memory page table by hardware, writing of a TLB entry followed by a read will not necessarily read the same data which was written. Also, altering TLB entries can cause unpredictable results since the correspondence between virtual and real addresses will be destroyed. Access to the TLB contents is provided for diagnostic purposes only, and should only be made in non-translated mode. A write to a TLB entry in non-translated mode with all other translated accesses disabled, followed by a read, will read the same data that was written. Each TLB entry is logically a 66-bit quantity composed of: - A 25-bit address tag - A 13-bit real page number - A valid bit - A 2-bit key - A write bit - A 8-bit transaction ID - And 16 lockbits. Each TLB entry is partitioned into three fields which are individually addressable. The format for each of the TLB fields are described in "TLB Address Tag" on page 11-129 through "TLB Write Bit, Transaction ID, and Lockbits" on page 11-130. #### **TLB Address Tag** The TLB Address Tag field contains the high-order 25 bits of the segment identifier | | virtual page index for 2K pages, and the high-order 24 bits for 4K pages. The format of the address tag field for each TLB entry is shown in Figure 11-32. Figure 11-32. TLB Address Tag Field (One Of Sixteen Per TLB) The content of each TLB address tag field is defined as follows: Bits 0-2 Reserved. Address Tag. This field contains the high-order 25 bits of the segment identifier | | virtual page index for 2K pages, and the high-order 24 bits for 4K pages. For 4K pages, the address tag is contained in bits (3-26). Bits 28-31 Reserved. ### TLB Real Page Number, Valid Bit, and Key Bits This field contains the real page number assigned to the virtual address contained in the address tag field of the TLB entry. This field also includes a valid bit to indicate the given TLB entry contains valid information, and key bits for the access authority required for a given page. The format of this field for each TLB entry is shown in Figure 11-33. Figure 11-33. TLB Real Page Number, Valid, and Key Bits (One of Sixteen Per TLB) The content of the real page number, valid, and key Bits field is defined as follows: Bits 0-15 Reserved. Bits 16-28 Real Page Number (RPN). This 13-bit field specifies one of 8192 real pages. If less than 8192 pages are implemented, only those low-order bits required to address the number of implemented pages are used. The RPN is contained in bits (16-27) for 4K pages, and in bits (16-28) for 2K pages. Bit 28 is 0 for 4k pages. - Bit 29 (V) Valid Bit. This bit is 1 when the selected TLB entry contains valid information. This bit is 0 if the TLB entry contains invalid information. - Bits 30-31 Key Bits. This 2-bit field defines the access authority for each page. Use of the key bits are described in "Memory Protection Processing" on page 11-109. #### TLB Write Bit, Transaction ID, and Lockbits This field contains the write bit, transaction ID, and lockbits assigned to the virtual address contained in the address tag field of the TLB entry, if the TLB entry is for a special segment. The format of this field for each TLB entry is shown in Figure 11-34. Figure 11-34. Write Bit, Transaction ID, and Lockbits (One of Sixteen Per TLB) The content of each TLB write bit, transaction ID, and lockbit field is defined as follows: - Bits 0-6 Reserved. Bit 7 (W) Write Bit. This bit defines the access authority associated with each page for special accessing is described in "Memory Protection". - segments. Use of this bit in lockbit processing is described in "Memory Protection Processing" on page 11-109. Transaction Identifier. This 8 bit field defines the task which currently owns the - Bits 8-15 Transaction Identifier. This 8-bit field defines the task which currently owns the selected page within a special segment. Use of these bits in lockbit processing are described in "Memory Protection Processing" on page 11-109. - Bits 16-31 Lockbits. This 16-bit field defines the access authority for each line within a 2K or 4K page for special segments. A line is 128 bytes for 2K pages, and 256 bytes for 4K pages. Use of these bits in lockbit processing are described in "Memory Protection Processing" on page 11-109. ### **RAS Mode Diagnostic Register** The RAS mode diagnostic register (RMDR) is used to verify operation of the ECC logic, and to identify failing bits in memory. The RMDR allows systems software to determine which memory bits are failing by examining the check bits read from the location causing the ECC error. Alternate ECC check bits can be supplied from a field in the RMDR to verify proper operation of the ECC logic in the memory management unit. The format of the RMDR is shown in Figure 11-35. Figure 11-35. RAS Mode Diagnostic Register The RAS mode diagnostic register is defined as follows: Bits 0-15 Reserved. Bits 16-23 Array Check Bits. This 8-bit field is loaded with the eight ECC check bits read from RAM for the first load or read-modify-write store (such as store character, store half, or test-and-set) when a correctable or uncorrectable ECC error is detected and RAS diagnostic mode or interrupt on correctable ECC error are enabled (bits 18 or 20 of the TCR set to 1). If RAS diagnostic mode and interrupt on correctable ECC error are disabled (bits 18 and 20 of the TCR set to 0), this field will be loaded only by uncorrectable ECC errors. Once this field is loaded, the value in the RMDR is locked, and is not altered until the RMDR is read by system software via an IOR instruction. The MEAR remains locked to all memory related errors until the RMDR is read. The eight array check bits are read only, an I/O write to these bits will not alter their value. The correspondence of the eight array check bits to the eight ECC check bits described in "ECC Checking" on page 11-140 is defined below: #### RMDR Bit ECC Check Bit | Bit 16 | ECC0 | |--------|------| | Bit 17 | ECC1 | | Bit 18 | ECC2 | | Bit 19 | ECC3 | | Bit 20 | ECC4 | | Bit 21 | ECC5 | | Bit 22 | ECC6 | | Bit 23 | ECC7 | Alternate Check Bits. This 8-bit field contains alternate ECC check bits that are written to RAM for store accesses when RAS diagnostic mode is enabled (bit 18 of the TCR set to 1). This field allows software to supply a source of ECC check bits for diagnostic or error recovery procedures. When RAS diagnostic mode is enabled, the alternate check bits are supplied to the RAM as ECC check bits in place of the ECC check bits which are normally generated by internal memory management unit hardware. When RAS diagnostic mode is disabled (bit 18 of the TCR set to 0), check bits generated by the internal memory management unit ECC logic are supplied to RAM. The correspondence of bits in this field to ECC check bits are defined below: | RMDR Bit | ECC Check Bit | |----------|---------------| | Bit 24 | ECC0 | | Bit 25 | ECC1 | | Bit 26 | ECC2 | | Bit 27 | ECC3 | | Bit 28 | ECC4 | | Bit 29 | ECC5 | | Bit 30 | ECC6 | | Bit 31 | ECC7 | | | | ### **Translation Assist Functions** The memory management unit provides hardware support for frequently required translation functions. This hardware provides the ability to selectively invalidate TLB entries, and to perform a "compute real address" function. ### **Purging TLB Entries** As changes to the virtual-to-real address mapping are made, it is necessary for system software to synchronize the contents of the TLBs with the contents of the page table in system memory. Entries must be purged (invalidated) to ensure that obsolete mapping information is not used for a subsequent translation. The memory management unit provides three functions to assist in the synchronization of TLB entries with the contents of the page table in system memory. These functions can be used to invalidate the entire TLB contents, or to invalidate only selected TLB entries. These functions are invoked by I/O write instructions (IOW) directed to specific I/O addresses within the 64K-byte block of I/O addresses recognized by the memory management unit. The address assignment for each of these functions is given in "I/O Address Assignments" on page 11-135. #### Invalidate Entire TLB This function causes all TLB entries to be invalidated. This will force the TLB contents to be updated from page tables in system memory for subsequent translations. An I/O write to the address associated with this function causes all TLB entries to be invalidated. The data transferred by the I/O write instruction is not used. ### **Invalidate TLB Entries In Specified Segment** This function causes all TLB entries with the specified segment identifier to be invalidated. Subsequent translations using this segment identifier causes the TLB contents to be updated from page tables in system memory. An I/O write to the address associated with this function causes TLB entries with the specified segment identifier to be invalidated. Bits (0-3) of the data transferred by the I/O write instruction are used to select the segment identifier. All TLB entries containing this segment identifier are invalidated. Subsequent translations with an effective address within the invalidated segment causes the TLB contents to be updated from the page table in system memory. ### **Invalidate TLB Entry For Specified Effective Address** This function causes the TLB entry with the specified effective address to be invalidated. Subsequent translations with an effective address within the page containing the specified effective address causes the TLB contents to be updated from the page table in system memory. An I/O write to the address associated with this function causes the TLB entry with the specified effective address to be invalidated. Bits (0-31) of the data transferred by the I/O write instruction are used as the effective address. The normal translation process is applied using the segment register contents contained in the memory management unit. ### **Compute Real Address** The compute real address function is used by system software to determine if a given virtual address is currently mapped in real memory, and what real address is assigned to the virtual address if it is mapped. The compute real address function is invoked by an I/O write to the address associated with this function. Bits (0-31) of the data transferred by the I/O write instruction are used as the effective address. This effective address is then used for the normal translation process, except the results of translation are loaded into the translated real address register (TRAR), rather than being used to access memory. The TRAR contains a bit indicating whether the translation was successful, and the corresponding real memory address if the translation was successful. The indication of successful translation ignores the segment protection and present bits, as well as normal memory protection processing and lockbit processing. Results of the compute real address function are obtained by an I/O read of the TRAR. ### I/O Address Assignments A 64K-byte block of I/O addresses are assigned to the memory management unit. This 64K-byte block begins at an I/O address specified by the I/O base address register (see "I/O Base Address Register"). The I/O base address is defined to be on 64K boundaries. The I/O address assignments listed below are displacements in the specified 64K-byte block. The absolute I/O address is equal to the I/O base address plus the hex displacement as shown below. | Hex<br>Displacement | Assignment | |---------------------|------------------------------------------------------------------------------| | 0000-000F | Segment Registers 0 through 15 | | 0010 | I/O Base Address Register | | 0011 | Memory Exception Register | | 0012 | Memory Exception Address Register | | 0013 | Translated Real Address Register | | 0014 | Transaction ID Register | | 0015 | Translation Control Register | | 0016 | RAM Specification Register | | 0017 | ROM Specification Register | | 0018 | RAS Mode Diagnostic Register | | 0019-001F | Reserved | | 0020-002F | TLB0 Address Tag Field for TLB0 entries 0 through 15 | | 0030-003F | TLB1 Address Tag Field for TLB0 entries 0 through 15 | | 0040-004F | TLB0 Real Page Number, Valid Bit, and Key Bits for TLB0 entries 0 through 15 | | 0050-005F | TLB1 Real Page Number, Valid Bit, and Key Bits for TLB0 entries 0 through 15 | | 0060-006F | TLB0 Write Bit, Transaction ID, and Lockbits for TLB0 entries 0 through 15 | | 0070-007F | TLB1 Write Bit, Transaction ID, and Lockbits for TLB0 entries 0 through 15 | | 0080 | Invalidate Entire TLB | | 0081 | Invalidate TLB Entries In Specified Segment | | 0082 | Invalidate TLB Entry For Specified Effective Address | | 0083 | Load Real Address | | 0084-0FFF | Reserved | 1000-2FFF Reference and Change bits for pages 0 through 8191 3000-FFFF Reserved. ## I/O Base Address Register Initialization Before any control registers in the memory management unit can be accessed, the I/O base address register must be initialized to define which I/O addresses are assigned to the memory management unit. Initializing the I/O base address register gives addressability to the other control registers in the memory management unit. The address of the various control registers are defined in "I/O Address Assignments" on page 11-135. I/O address X'808000' is reserved for initialization purposes, and provides access to the I/O base address register. System software must first execute an I/O write instruction to this address to define which I/O addresses are assigned to the memory management unit. Since the memory management unit I/O base address register is loaded with all zeros at POR, the memory management unit recognizes all valid I/O addresses in the first 64K of the I/O address space until a different value is written into the I/O base address register using an IOW instruction. Once the I/O base address register contents are defined, the other I/O registers in the memory management unit can be initialized by I/O write instructions to the individual registers. Once the contents of the I/O base address register are defined, the I/O base address register is addressable at two separate I/O addresses; at address X'808000' and at the address within the specified I/O address range of the memory management unit. ### **Memory Management Unit Control Register Initialization** Once the I/O base address register has been initialized, system software can then initialize other memory management unit control registers using I/O write instructions to the address of the individual control registers. System software will normally first define the actual size and beginning address of RAM and ROM. The memory management unit will initially accept any memory request, and direct it to RAM or ROM. The determination of whether the request is to RAM or ROM is based on whether the first access after POR was a read or write. If the first access was a read, all memory requests are directed to ROM. If the first access was a write, all memory requests are directed to RAM. Master mode is disabled by initializing either the RAM specification register or the ROM specification register. System software must insure that the address defined in the ROM specification register or the RAM specification register provides access to the instructions being used for initialization purposes. Once an I/O write is executed to define the ROM specification register or the RAM specification register, master mode is disabled, and only memory addresses within the range specified by the initialized specification register is be accepted. Incorrect specification of the ROM specification register or RAM specification register can result in system lock-up, since the memory management unit will no longer recognize addresses generated by the system processor. An example of the proper initialization sequence of the ROM specification register and RAM specification register is given below. Assuming that the memory management unit is initialized to master mode, and ROM is used to contain the initialization code, the address map recognized by the memory management unit before the ROM specification register or the RAM specification register is initialized is shown in Figure 11-36 part A. The ROM image is repeated at all addresses in the memory map. For example, with a 64K-byte ROM, the 64K-byte ROM image repeats every 64K-bytes. This means that the first word in the ROM can be accessed at address X'000000', X'010000', X'020000', ... X'FF0000', and the second word at X'000004', X'010004', X'020004', ... X'FF90004', with the last word at addresses X'00FFFC', X'01FFFC', X'02FFFC', ... X'FFFFFC'. Since the ROM is 32 bits wide, the byte address of consecutive words differ by four. Figure 11-36. Address Space Recognized by Memory Management Unit During Initialization The initialization code in ROM must first define the actual ROM address space by writing the appropriate size and base address information to the ROM specification register. Assuming that the ROM size is 64K- bytes, and it is desired to start the ROM address space at X'FD0000', writing the ROM specification register with this information would change the address map recognized by the memory management unit to that shown in Figure 11-36 part B. Be aware that addresses which were previously recognized by nature of master mode, are no longer recognized. The initialization code contained in ROM must be written assuming it is at the address range specified by the value it writes to the ROM specification register. If the IAR used by the system processor for fetching subsequent instructions after the I/O write of the ROM specification register is not within the range defined by the ROM specification register, the memory management unit will fail to accept any instruction fetches and the system processor will time-out and machine check. The initial IAR contained in ROM location 000000 should contain the address of instructions within the ROM address range written to the ROM specification register by these instructions. After initializing the ROM specification register, the RAM specification register can be initialized to define the RAM address range recognized by the memory management unit. Once the ROM specification register and RAM specification register have been initialized, the memory management unit accepts memory requests for addresses within each range, and will appropriately direct that request to either ROM or RAM. Assuming that 1M-byte of RAM is defined starting at address X'000000', the memory address map recognized by the memory management unit after initialization of the RAM specification register is shown in Figure 11-36 part C. RAM should be defined starting at address X'000000', since the system processor PSW vectors require RAM at addresses X'000100' through X'000190'. For example, after POR, loading ROM location 0 with X'E80004' causes the system processor to begin execution with the instruction contained in the second word of the ROM. If that first instruction is a branch absolute to location X'E80008', the system processor continues execution with the instruction located in the third ROM word. The ROM starting address in the ROM specification register can then be loaded with X'E8' while still allowing the memory management unit to accept ROM instruction fetches. Once the ROM specification register is loaded, the RAM specification register can be safely loaded with the proper values for the system configuration. At that point, RAM accesses are accepted by the memory management unit. **Note:** Because of the POR sequence just described, ROM must be able to recognize two address ranges, X'00XXXX' and X'E8XXXX'. This means that if address checking is performed for ROM addresses, only those bits actually used to access the ROM are checked for their proper value. The high order address bits are checked by the memory management unit ROM specification register. # **ECC Checking** The memory management unit implements 32/40 ECC which detects and corrects all single bit failures, and detects all double bit failures. In addition, the 32/40 code detects several multiple bit failures not detected by a 32/39 code. ECC check bits are computed as an exclusive OR of the data bits shown in Figure 11-37. | | Data | | | | | | | | |-----------------|--------------------|--------------------|-----------------|---------------------|--|--|--|--| | Byte 0 Bits 0-7 | Byte 1<br>Bits 0-7 | Byte 2<br>Bits 0-7 | Byte 3 Bits 0-7 | ECC<br>Check<br>Bit | | | | | | 10101010 | 10101010 | 11000000 | 11000000 | ECC0 | | | | | | 01010101 | 01010101 | 00110000 | 00110000 | ECC1 | | | | | | 11111111 | 00000000 | 00001100 | 00001100 | ECC2 | | | | | | 00000000 | 11111111 | 00000011 | 00000011 | ECC3 | | | | | | 11000000 | 11000000 | 11111111 | 00000000 | ECC4 | | | | | | 00110000 | 00110000 | 00000000 | 11111111 | ECC5 | | | | | | 00001100 | 00001100 | 10101010 | 10101010 | ECC6 | | | | | | 00000011 | 00000011 | 01010101 | 01010101 | ECC7 | | | | | Figure 11-37. Check Bit Matrix For 32/40 ECC - 1 = bit used in check bit generation - 0 = bit not used in check bit generation # **Appendix A. Instruction Mnemonics** # **Instruction Set By Mnemonic** The following table lists the instruction set by mnemonic and provides information for instruction execution time. These are typical execution times, and do not include potential degredation due to concurrent DMA operations. | Mnemonic | Op-Code | Format | Instruction | Cycles | Note | |----------|------------|----------------|----------------------------------------|--------|------| | A | <b>E</b> 1 | (R) | Add | | | | | | | | 1 | | | ABS | E0 | (R) | Absolute | 2 | | | AE | F1 | (R) | Add Extended | 1 | | | AEI | D1 | $(\mathbf{D})$ | Add Extended Immediate | 1 | | | AI | C1 | (D) | Add Immediate | 1 | | | AIS | 90 | (R) | Add Immediate Short | 1 | | | BALA | 8 <b>A</b> | (BA) | Branch And Link Absolute | 5-7 | 1 | | BALAX | 8B | (BA) | Branch and Link Absolute With Execute | 5-7 | 1 | | BALI | 8C | (BI) | Branch And Link Immediate | 5-7 | 1 | | BALIX | 8D | (BI) | Branch And Link Immediate With Execute | 5-7 | 1 | | BALR | EC | (R) | Branch And Link | 5-7 | 1 | | BALRX | ED | (R) | Branch And Link With Execute | 5-7 | 1 | | BB | 8E | (BI) | Branch On Condition Bit Immediate | | • | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BBR | EE | (R) | Branch On Condition Bit | 5 / | • | | | | ` ′ | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BBRX | EF | (R) | Branch On Condition Bit With Execute | 3-1 | 1 | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | Mnemonic | Op-Code | Format | Instruction | Cycles | Note | |----------|------------|--------|----------------------------------------------------|--------|------| | BBX | 8F | (BI) | Branch On Condition Bit Immediate With Execute | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BNB | 88 | (BI) | Branch On Not Condition Bit Immediate With Execute | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BNBR | E8 | (R) | Branch On Not Condition Bit | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BNBRX | E9 | (R) | Branch On Not Condition Bit With Execute | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | BNBX | 89 | (BI) | Branch On Not Condition Bit Immediate With Execute | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | C | <b>B4</b> | (R) | Compare | 1 | | | CAL | C8 | (D) | Compute Address Lower Half | 1 | | | CAL16 | C2 | (D) | Compute Address Lower Half 16-Bit | 1 | | | CAS | 6 | (X) | Compute Address Short | 1 | | | CAU | D8 | (D) | Compute Address Upper Half | 1 | | | CA16 | F3 | (R) | Compute Address 16-Bit | 1 | | | CI | D4 | (D) | Compare Immediate | 1 | | | CIS | 94 | (R) | Compare Immediate Short | 1 | | | CL | <b>B3</b> | (R) | Compare Logical | 1 | | | CLI | D3 | (D) | Compare Logical Immediate | 1 | | | CLRBL | 99 | (R) | Clear Bit Lower Half | 1 | | | CLRBU | 98 | (R) | Clear Bit Upper Half | 1 | | | CLRSB | 95 | (R) | Clear SCR Bit | 4 | | | CLZ | F5 | (R) | Count Leading Zeros | 1 | | | D | <b>B</b> 6 | (R) | Divide Step | 3 | | | DEC | 93 | (R) | Decrement | . 1 | | | EXTS | <b>B</b> 1 | (R) | Extend Sign | 1 | | | INC | 91 | (R) | Increment | 1 | | | IOR | CB | (D) | Input/Output Read | 1 | | | IOW | DB | (D) | Input/Output Write | 2 | | | Mnemonic | Op-Code | Format | Instruction | Cycles | Note | |----------|--------------------|--------|-----------------------------------------|--------|------| | JB | 08-0F | (JI) | Jump On Condition Bit | | | | | | ` ' | Unsuccessful | 1 | | | - | | | Successful | 5-7 | 1 | | JNB | 00-07 | (JI) | Jump On Not Condition Bit | | | | | | | Unsuccessful | 1 | | | | | | Successful | 5-7 | 1 | | L | $\mathbf{CD}^{-1}$ | (D) | Load | 1-6 | 2 | | LC | CE | (D) | Load Character | 1-6 | 2 | | LCS | 4 | (DS) | Load Character Short | 1-6 | 2 | | LH | DA | (D) | Load Half | 1-6 | 2 | | LHA | CA | (D) | Load Half Algebraic | 1-6 | 2 | | LHAS | 5 | (DS) | Load Half Algebraic Short | 1-6 | 2 | | LHS | EB | (R) | Load Half Short | 1-6 | 2 | | LIS | A4 | (R) | Load Immediate Short | 1-6 | 2 | | LM | C9 | (D) | Load Multiple | | 3 | | LPS | D0 | (D) | Load Program Status | 12-16 | 6 | | LS | 7 | (DS) | Load Short | 1-6 | 2 | | M | E6 | (R) | Multiply Step | 4 | | | MC03 | F9 | (R) | Move Character Zero From Three | 1 | | | MC13 | FA | (R) | Move Character One From Three | 1 | | | MC23 | FB | (R) | Move Character Two From Three | 1 | | | MC33 | FC | (R) | Move Character Three From Three | 1 | | | MC30 | FD | (R) | Move Character Three From Zero | 1 | | | MC31 | FE | (R) | Move Character Three From One | 1 | | | MC32 | FF | (R) | Move Character Three From Two | 1 | | | MFS | 96 | (R) | Move From SCR | 2 | | | MFTB | BC | (R) | Move From Test Bit | 1 | | | MFTBIL | 9D | (R) | Move From Test Bit Immediate Lower Half | . 1 | | | MFTBIU | 9C | (R) | Move From Test Bit Immediate Upper Half | 1 | | | MTS | B5 | (R) | Move To SCR | 3 | | | MTTB | BF | (R) | Move To Test Bit | 1 | | | MTTBIL | 9F | (R) | Move To Test Bit Immediate Lower Half | 1 | | | MTTBIU | 9E | (R) | Move To Test Bit Immediate Upper Half | 1 | | | N | E5 | (R) | And | 1 | | | NILO | C6 | (D) | And Immediate Lower Half Extended Ones | 1 | | | Mnemonic | Op-Code | Format | Instruction | Cycles | Note | |----------|------------------------|--------|----------------------------------------------|--------|------| | NILZ | C5 | (D) | And Immediate Lower Half Extended Zeroes | 1 | | | NIUO | <b>D</b> 6 | (D) | And Immediate Upper Half Extended Ones | 1 | | | NIUZ | D5 | (D) | And Immediate Upper Half Extended Zeroes | 1 | | | О | E3 | (R) | OR | 1 . | | | OIL | C4 | (D) | OR Immediate Lower Half | 1 | | | OIU | C3 | (D) | OR Immediate Upper Half | 1 | | | ONEC | F4 | (R) | Ones Complement | 1 | | | S | <b>E2</b> | (R) | Subtract | 1 | | | SAR | <b>B</b> 0 | (R) | Shift Algebraic Right | 1 | | | SARI | <b>A</b> 0 | (R) | Shift Algebraic Right Immediate | 1 | | | SARI16 | <b>A</b> 1 | (R) | Shift Algebraic Right Immediate Plus Sixteen | 1 | | | SE | F2 | (R) | Subtract Extended | 1 | | | SETBL | 9B | (R) | Set Bit Lower Half | 1 | | | SETBU | 9A | (R) | Set Bit Upper Half | 1 | | | SETSB | 97 | (R) | Set SCR Bit | 4 | | | SF | <b>B2</b> | (R) | Subtract From | 1 | | | SFI | D2 | (D) | Subtract From Immediate | 1 | | | SIS | 92 | (R) | Subtract Immediate Short | 1 | | | SL | BA | (R) | Shift Left | 1 | | | SLI | $\mathbf{A}\mathbf{A}$ | (R) | Shift Left Immediate | 1 | | | SLI16 | AB | (R) | Shift Left Immediate Plus sixteen | 1 | | | SLP | BB | (R) | Shift Left Paired | 1 | | | SLPI | ΑE | (R) | Shift Left Paired Immediate | 1 | | | SLPI16 | AF | (R) | Shift Left Paired Immediate Plus Sixteen | 1 | | | SR | <b>B8</b> | (R) | Shift Right | 1 | | | SRI | <b>A</b> 8 | (R) | Shift Right Immediate | 1 | | | SRI16 | <b>A</b> 9 | (R) | Shift Right Immediate Plus Sixteen | 1 | | | SRP | <b>B</b> 9 | (R) | Shift Right Paired | 1 | | | SRPI | $\mathbf{AC}$ | (R) | Shift Right Paired Immediate | 1 | | | SRPI16 | AD | (R) | Shift Right Paired Immediatd Plus Sixteen | 1 | | | ST | DD | (D) | Store | 2-6 | 4 | | STC | DE | (D) | Store Character | 2-6 | 4 | | STCS | 1 | (DS) | Store Chatacter Short | 2-6 | 4 | | STH | DC | (D) | Store Half | 2-6 | 4 | | STHS | 2 | (DS) | Store Half Short | 2-6 | 4 | | Mnemonic | Op-Code | Format | Instruction | Cycles | Note | |----------|------------|--------|----------------------------------------|--------|------| | STM | D9 | (D) | Store Multiple | | 5 | | STS | 3 | (DS) | Store Short | 2-6 | | | SVC | C0 | (D) | Supervisor Call | 16-20 | 6 | | TGTE | BD | (R) | Trap If Register Greater Than Or Equal | | | | | | | Unsuccessful | 2 | | | | | | Successful | 16 | | | TI | CC | (D) | Trap On Condition Immediate | | | | | | | Unsuccessful | 2 | | | | | | Successful | 16 | | | TLT | BE | (R) | Trap If Register Less Than | | | | | | | Unsuccessful | 2 | | | | | | Successful | 16 | | | TSH | CF | (D) | Test And Set Half | 1-6 | 2 | | TWOC | E4 | (R) | Twos Conplement | 1 | | | WAIT | F0 | (R) | Wait | 1 | | | X | E7 | (R) | Exclusive OR | 1 | | | XIL | <b>C</b> 7 | (D) | Exclusive OR Immediate Lower Half | 1 | | | XIU | <b>D</b> 7 | (D) | Exclusive OR Immediate Upper Half | 1 | | - 1. Execution cycles for successful branch instructions and jumps instructions depend on system memory conditions, and the alignment of the branch or jump target instruction. Execution cycles do not include any TLB reload times if there is a TLB miss. Actual execution cycles are determined by the following conditions: - Execution time is 5 cycles if the target instruction is in a nonbusy memory bank, and is either a 2-byte instruction, or is a 4-byte instruction aligned on a full-word boundary. - Execution time is 6 cycles if the target instruction is in a busy memory bank, and is either a 2-byte instruction, or is a 4-byte instruction aligned on a full-word boundary. Execution time is also 6 cycles if the target instruction is in a nonbusy memory bank and is a 4-byte instruction not aligned on a full-word boundary. - Execution time is 7 cycles if the target instruction is in a busy memory bank, and is a 4-byte instruction not aligned on a full-word boundary. - 2. Execution cycles for load instructions and Test and Set Half (TSH) depends on whether address translation is enabled, and which subsequent instruction uses the load (or TSH) data if address translation is disabled. Execution cycles also depend on whether the load instruction accesses data in system memory or on the I/O channel. Actual execution cycles are determined by the following conditions: - If address translation is enabled, the system processor unconditionally waits for a response from the memory management unit before executing the next instruction. This is necessary to guarantee that the load instruction can be restarted if there is a memory management exception. In this case, the load instruction executes in 5 cycles if the load operand is in a nonbusy memory bank, and 6 cycles if the bank is busy. These times do not include any TLB reload times, if there is a TLB miss. - If address translation is disabled, the system processor continues to execute subsequent instructions while the load is being processed by the memory management unit, if the subsequent instructions do not require data from the load instruction. If the load data is required, the system processor waits until the data is returned by the memory management unit before the next instruction is executed. The load data is available after 5 cycles if the load operand is in a nonbusy bank, and 6 cycles if the bank was busy. This results in a minimum load execution time of 1 cycle if no subsequent instructions use the load data before the 5 (or 6) cycles have elapsed. For example, assume there is a load to a nonbusy memory bank, and there are three single-cycle instructions after the load which do not use the load data, and the fourth instruction does use the load data. In this case, the load executes in one cycle, and the next three instructions execute in one cycle each. However, the fourth instruction that requires the load data must wait for 2 cycles for the load to complete. In this case, the load appears to execute in 3 cycles (1 for the load plus 2 waits). - If the load instruction references data in an adapter on the I/O channel, execution time is dependent on the speed of the adapter. For typical adapters, the load instruction executes in 9 to 11 cycles. - 3. Execution cycles for Load Multiple (LM) depend on whether address translation is enabled, and the number of registers loaded by the LM instruction. The number of registers loaded by the LM instruction is represented by R in the following equations. - If address translation is enabled, the number of execution cycles is: - -3 + 2\*R When R is even. - -4 + 2\*R When R is odd These times do not include any TLB reload times, if there is a TLB miss. - If address translation is disabled, the number of execution cycles is: - -1+2\*R+K When R is even. - -2 + 2\*R + K When R is odd. K is equal to one if r14 is used by the next instruction after the LM, and is equal to two is r15 is used by the next instruction after the LM. 4. Execution cycles for store instructions depend on whether address translation is enabled or disabled. If address translation is disabled, execution time for store instructions is 2 cycles. If address translation is enabled, execution time for store instructions is 5 cycles if the store is to a nonbusy memory bank, and 6 cycles if it is to a busy bank. Store exectuion times with address translation enabled do not include any TLB reload times, if there is a TLB miss. - 5. Execution cycles for Store Multiple (STM) depend on whether address translation is enabled. and the number of registers stored by the STM instruction. The number of registers stored by the STM instruction is represented by R in the following equations. Actual execution cycles are: - 3 + 3\*RIf address translation is enabled. - 2 + 2\*RIf address translation is disabled. These times do not include any TLB reload times, if there is a TLB miss when address translation is enabled. 6. Execution cycles for Load Program Status (LPS) and Supervisor Call (SVC) varies based on previous instruction. Minimum and maximum execution cycles are shown for both LPS and SVC. ### **Privileged Instructions** | Mnemoni | c Op-Coce | Format | Instruction | |---------|-----------|--------|---------------------| | CLRSB | 95 | (R) | CLEAR SCR BIT | | LPS | D0 | (D) | LOAD PROGRAM STATUS | | MFS | 96 | (R) | MOVE FROM SCR | | MTS | <b>B5</b> | (R) | MOVE TO SCR | | SETSB | 97 | (R) | SET SCR BIT | | WAIT | F0 | (R) | WAIT | Note: Clear SCR Bit (CLRSB), Move From SCR (MFS), Move To SCR (MTS), and Set SCR Bit (SETSB) are privileged if the referenced SCR is the Counter Source (SCR 6), Counter (SCR7), Timer Status (SCR8), Machine Check Status (SCR 11), Program Check Status (SCR 11), Interrupt Request Buffer (SCR 12), Instruction Address Register (SCR 13), or the Interrupt Control Status (SCR 14). Clear SCR Bit (CLRSB), Move From SCR (MFS), Move To SCR (MTS), and Set SCR Bit (SETSB) are unprivileged if the referenced SCR is the Multiplier Quotient (SCR 10), or the Condition Status (SCR 15). # **Figures** | 1-14<br>1-15 | |--------------| | 1-15 | | | | 1-15 | | 1-15 | | 1-16 | | | | | | 1-21 | | 1-22 | | 1-22 | | 1-25 | | 1-30 | | 1-33 | | 1-34 | | 1-34 | | 1-35 | | 1-37 | | 2-6 | | 2-7 | | 2-9 | | 2-10 | | 2-12 | | 2-16 | | 2-17 | | 2-19 | | 2-21 | | 2-22 | | 2-24 | | 3-7 | | 3-15 | | 3-16 | | 3-17 | | 3-18 | | 3-19 | | 3-21 | | 4-5 | | 4-6 | | 4-6 | | | | | | 17 | |--------------|----------------------------------------------------------------------|------------| | 4-4. | Floating Point Registers | 4-/<br>1-8 | | 4-5.<br>4-6. | Floating Point Status Registers | 4-0 | | 4-0.<br>4-7. | 100 Pin FPA Board Slot | 4-41 | | 4-7.<br>4-8. | Floating-Point Accelerator Slot (R-Side) | 4-42 | | 4-8.<br>4-9. | Floating-Point Accelerator Slot (K-Side) | 4-44 | | 5-1. | Model 20 and Model 25 Connector Locations | 5-8 | | 5-1.<br>5-2. | Model 10 Connector Locations | 5-10 | | 5-2.<br>5-3. | RT PC Address/Data Flow Diagram | 5-11 | | 5-4. | System Board I/O Address Map | 5-12 | | 5-5. | Channel Control Register (Address X'008C20') | 5-15 | | 5-6. | DMA Addressing Mode Combinations | 5-16 | | 5-7. | Address Translation (Page Mode) Real Address Format | 5-18 | | 5-8. | Address Translation (Region Mode) Real Address Format | 5-19 | | 5-9. | Address Translation (Region Mode) Virtual Address Format | 5-20 | | 5-10. | DMA Mode Register (System Address X'F00088E0') | 5-21 | | 5-11. | System DMA - Page Mode (8-Bit Channel) Translated Address Formation | 5-23 | | 5-12. | System DMA - Page Mode (16-Bit Channel) Translated Address Formation | 5-24 | | 5-13. | Alternate Controller - Page Mode Translated Address Formation | 5-25 | | 5-14. | Alternate Controller-Region Mode Translated Address Formation | 5-26 | | 5-15. | Translation Control Word (TCW) Port Addresses | 5-27 | | 5-16. | Translation Control Word (TCW) Binary Port Address | 5-28 | | 5-17. | TCW Format | 5-29 | | 5-18. | Virtual Access and I/O Channel Destination Bits | 5-30 | | 5-19. | Channel Control Register (Address X'008C20') | 5-31 | | 5-20. | DMA Access Bits | 5-32 | | 5-21. | Processor Board to System Board Data Interface | 5-37 | | 5-22. | Single Cycle Operation Data Placement | 5-38 | | 5-23. | Multicycle Operation to 16-Bit Device | 5-38 | | 5-24. | Multicycle Operation to 8-Bit Device | 5-39 | | 5-25. | Component Reset Register B (Address X'F0008C60') | 5-40 | | 5-26. | 8237 DMA Controller #1 Control Register Addresses | 5-41 | | 5-27. | 8237 DMA Controller 1 Write Mode Register (Address X'00884B') | 5-42 | | 5-28. | 8237 DMA Controller 1 Request Register(Address X'008849') | 5-43 | | 5-29. | 8237 DMA Controller 1 Mask Register 1 (Address X'00884A') | 5-43 | | 5-30. | 8237 DMA Controller 1 Mask Register 2 (Address X'00884F') | 5-44 | | 5-31. | 8237 DMA Controller 1 Status Register (Address X'008848') | 5-45 | | 5-32. | 8237 DMA Controller 1 Command Register (Address X'008848') | 5-46 | | 5-33. | 8237 DMA Controller 2 Control Register Addresses | 5-47 | | 5-34. | 8237 DMA Controller 2 Mode Register (Address X'008876') | 5-48 | | 5-35. | 8237 DMA Controller 2 Request Register (Address X'008872') | 5-49 | | 5-36. | 8237 DMA Controller 2 Mask Register 1 (Address X'008874') | 5-49 | | 5-37. | 8237 DMA Controller 2 Mask Register 2 (Address X'00887E') | 3-3U | | 5-38. | 8237 DMA Controller 2 Status Register (Address X'008870') | 3-31 | | 5-39. | 8237 DMA Controller 2 Command Register (Address X'008870') | 3-32 | | 5-40. | Channel 8 Enable Register(Address X'008C00') | 5-53 | |--------------|-----------------------------------------------------------------------------------------------|------------------------| | 5-41. | Channel Control Register (Address X'008C20') | 5-54 | | 5-42. | Buffer Register (Address X'0088C0') | 5-55 | | 5-43. | 8259 #1 | 5-5 | | 5-44. | 8259 #2 | 5-5 | | 5-45. | Diagnostic Interrupt Activate Register (Address X'008CA0') | 5-58 | | 5-46. | Component Reset Register A (Address X'008C40') | 5-60 | | 5-47. | Component Reset Register A (Address X'008C40') Component Reset Register B (Address X'008C60') | 5-62 | | 5-48. | CSR - Channel Status Register Address (X'010800') | 5-63 | | 5-49. | Memory Configuration Register | 5-73 | | 5-50. | Real Time Clock Address Map | 5-76 | | 5-51. | Serial Port Address Map | 5-78 | | 5-52. | Write Register 11 | 5-78 | | 5-53. | External Register A | 5-83 | | 5-54. | External Register B | 5-84 | | 5-55. | Serial Port Connectors | 5-84 | | 5-56. | Adapter Logic and System Interface | 5-134 | | 5-57. | Adapter-to-Keyboard Connector Interface | 5-135 | | 5-58. | Adapter-to-Locator Connector Interface | 5_136 | | 5-59. | Keyboard Connector | 5.145 | | 5-60. | Locator Connector | | | 5-61. | Model 20 and Model 25 Power Supply Connector (J1) | 5-140<br>5-147 | | 5-62. | Model 20 and Model 25 Power Supply Connector (J2) | 5 1/19 | | 5-63. | Model 20 and Model 25 Power Supply Signal Connector (J3) | 5 1/10 | | 5-64. | Model 20 and Model 25 Operator Panel Connector | 3-143<br>5-150 | | 5-65. | Model 20 and Model 25 Serial Port Connectors | J-1J(<br>5 151 | | 5-66. | Model 10 Power Supply Connector (J1) | 3-131<br>5 150 | | 5-67. | Model 10 Power Supply Signal Connector (J3) | 3-132<br>5-152 | | 5-68. | Model 10 Operator Panel Connector | J-1JJ<br>5 1 <i>51</i> | | 5-69. | Model 10 Battery Connector | 3-134<br>5-156 | | 6-1. | 62 Din DC Adoptors | 3-133 | | 6-1.<br>6-2. | 62-Pin PC Adapters | . 6-7 | | 6-3. | 98 and 102 Pin PC-AT or RT PC Adapters | . 6-8 | | 6-4. | Data Transfer Table | 6-10 | | 6-5. | Protocol Functional Block Diagram | 6-21 | | | Memory Read Operation Sequence | 6-22 | | 6-6. | Memory Write Operation Sequence | 6-23 | | 6-7. | I/O Read Operation Sequence | 6-23 | | 6-8. | I/O Write Operation Sequence | 6-24 | | 6-9. | Refresh Timing | 6-25 | | 6-10. | I/O And Memory Default Cycle Timing | 6-26 | | 6-11. | I/O Read Operation | 6-28 | | 6-12. | I/O Write Operation | 6-29 | | 6-13. | Memory Read Operation | 6-31 | | 6-14. | Memory Write Operation | 6-32 | | 6-15. | Bus Arbitration | 6-34 | | 6-16. | DMA Read Operations | | |------------------------------|------------------------------------------------------------------------|-------| | 6-17. | DMA Write Operations | | | 6-18. | Block Diagram For IRQ Line | | | 6-19. | Memory Address Map | 6-43 | | 6-20. | I/O Address Map | 6-45 | | 6-21. | DMA Channels | | | 6-22. | Interrupt Levels | | | 6-23. | Model 20 and Model 25 System Boards | 6-48 | | 6-24. | Model 10 System Board | 6-49 | | 6-25. | Unique Pin Assignments | 6-49 | | 6-26. | 62-Pin Connector Side A | 6-52 | | 6-27. | 62-Pin Connector Side B | | | 6-28. | 40-Pin Connector Side C | 6-55 | | 6-29. | 40-Pin Connector Side D | 6-56 | | 7-1. | Layout of Post Control Block | . 7-5 | | 7-2. | Layout of the Post Control Block Section Dedicated to One Post | . 7-6 | | 7-3. | Error Code Word | . 7-8 | | 7-4. | IPL ROM Boot Record Format | 7-16 | | 9-1. | Scan Codes Table | | | 9-2. | Key Position Layout | . 9-9 | | 9-3. | Keyboard Cable Connector | 9-10 | | 9-4. | Locator Signal Levels | 9-16 | | 9-5. | Locator Cable Connector | 9-16 | | 9-6. | Operator Panel | | | 9-7. | Model 20 and Model 25 Battery Connector | 9-19 | | 10-1. | Model 10 Input Power | 10-4 | | 10-2. | Model 20 and Model 25 Input Power | 10-4 | | 10-3. | Model 10 Power Connector Outputs and DC Load Distribution | | | 10-4. | Model 10 Power Output Capability | | | 10-5. | Model 20 and Model 25 Power Connector Outputs and DC Load Distribution | 10-8 | | 10-6. | Model 20 and Model 25 Power Output Capability | 10-10 | | 11-1. | System Processor Block Diagram | 11-8 | | 11-2. | Data Units in System Memory | 11-9 | | 11-3. | General-Purpose Registers | 11-12 | | 11-4. | General Purpose Register Pairs | 11-13 | | 11-5. | SCR Organization | 11-14 | | 11-6. | Old Program Status | 11-23 | | 11-7. | New Program Status | 11-23 | | 11-8. | SVC New Program Status | 11-23 | | 11-9. | Program Check Errors (Memory Protect and Address Translation Disabled) | 11-89 | | 11-10. | Program Check Errors (Memory Protect and Address Translation Enabled) | 11-89 | | 11-11. | Memory Management Unit Functional Partition | 11-93 | | 11-12. | Segment Register Format | 11-97 | | 11-13. | Generation of Virtual Address | 11-98 | | 11-13.<br>11 <sub>-</sub> 14 | Address Translation Mechanism | | | 11-15. | TLB Contents. One of two TLBs shown. | 11-101 | |--------|--------------------------------------------------------------------------|--------| | 11-16. | System Memory Inverted Page Table Entry Format | 11-102 | | 11-17. | HAT/IPT Base Address Multiplier | 11-103 | | 11-18. | HAT/IPT Index Generation Source Fields | 11-104 | | 11-19. | Segment Protection Processing | 11-109 | | 11-20. | Protection Key Processing | 11-110 | | 11-21. | Lockbit Processing | 11-111 | | 11-22. | Reference and Change Bit Format | 11-112 | | 11-23. | I/O Base Address Register | 11-113 | | 11-24. | RAM Specification Register | 11-114 | | 11-25. | ROM Specification Register | 11-115 | | 11-26. | Translation Control Register | 11-118 | | 11-27. | Memory Exception Register | 11-120 | | 11-28. | Memory Exception Address Register | 11-125 | | 11-29. | Translated Real Address Register | 11-126 | | 11-30. | Transaction Identifier Register | 11-126 | | 11-31. | Segment Register (One Of Sixteen) | 11-127 | | 11-32. | TLB Address Tag Field (One Of Sixteen Per TLB) | 11-129 | | 11-33. | TLB Real Page Number, Valid, and Key Bits (One of Sixteen Per TLB) | 11-129 | | 11-34. | Write Bit, Transaction ID, and Lockbits (One of Sixteen Per TLB) | 11-130 | | 11-35. | RAS Mode Diagnostic Register | 11-131 | | 11-36. | Address Space Recognized by Memory Management Unit During Initialization | 11-138 | | 11-37 | Check Bit Matrix For 32/40 FCC | 11-140 | # Glossary - A. Ampere. - ac. Alternating current. **accumulator.** A register in which the result of an operation is formed. **ACK0.** A transmission control character for even positive acknowledgement. **ACK1.** A transmission control character for odd positive acknowledgement. active high. Designates a signal that has to go high to produce an effect. Synonymous with positive true. active low. Designates a signal that has to go low to produce an effect. Synonymous with negative true. **adapter.** An electronic part used to connect two unlike parts or machines. address. (1) A name, label, or number identifying a location in storage, a device in a network, or any other data source. (2) A number that identifies the location of data in memory. address bus. One or more conductors used to carry the binary-coded address from the processor throughout the rest of the system. addressing. (1) In data communications, the way that the sending or control station selects the station to which it is sending data. (2) A means of identifying storage locations. algorithm. A finite set of well-defined rules for the solution of a problem in a finite number of steps. All Points Addressable (APA) display. A display that allows each pel to be individually addressed. An APA display allows for images to be displayed that are not made up of images predefined in character boxes. **alphameric.** Consisting of letters, numbers and often other symbols, such as punctuation marks and mathematical symbols. **alphanumeric (A/N).** Pertaining to a character set that contains letters, digits, and usually other characters, such as punctuation marks. Synonymous with alphameric. alternating current (ac). A current that periodically reverses its direction of flow. American National Standard Code for Information Exchange (ASCII). The code developed by ANSI for information interchange among data processing systems, data communications systems, and associated equipment. The ASCII character set consists of 7-bit control characters and symbolic characters. ampere (A). The basic unit of electric current. A/N. Alphanumeric. analog. (1) Pertaining to data in the form of continuously variable physical quantities.(2) Contrast with digital. array. An arrangement of elements in one or more dimensions. asynchronous transmission. In data communications, a method of transmission in which the bits included in a character or block of characters occur during a specific time interval. However, the start of each character or block of characters can occur at any time during this interval. Contrast with synchronous transmission. bandwidth. The difference, expressed in hertz, between the two limiting frequencies of a band. base address. The beginning address for resolving symbolic references to locations in storage. **base register.** A general purpose register that the programmer chooses to contain a base address. basic assurance test (BAT). An internal diagnostic program activated each time the system is turned on. baud. (1) A unit of signaling speed equal to the number of discrete conditions or signal events per second. For example, one baud equals one bit per second in a train of binary signals, one-half dot cycle per second in Morse code, and one 3-bit value per second in a train of signals each of which can assume one of eight different states. (2) In asynchronous transmission, the unit of modulation rate corresponding to one unit of interval per second; that is, if the duration of the unit interval is 20 milliseconds, the modulation rate is 50 baud. binary. (1) Pertaining to a system of numbers to the base two; the binary digits are 0 and 1. (2) Involving a choice of two conditions, such as on-off or yes-no. binary digit. (1) In binary notation, either of the characters 0 or 1. (2) Synonymous with bit. binary notation. Any notation that uses two different characters, usually the binary digits 0 and 1. binary synchronous communications (BSC). A form of communications line control using transmission control characters to control the transfer of data over a communications line. bit. Either of the binary digits 0 or 1 used in computers to store information. See also byte. bits per second (bps). A unit of measurement representing the number of discrete binary digits transmitted by a device in one second. **block.** (1) A group of records that is recorded or processed as a unit. Same as *physical record*. (2) In data communications, a group of records that is recorded, processed, or sent as a unit. (3) A block is 1024 bytes long. block check character. The character used in BSC to check that all bits transmitted were received. bps. Bits per second. **branch.** In a computer program an instruction that selects one of two or more alternative sets of instructions. A conditional branch occurs only when a specified condition is met. buffer. (1) A temporary memory unit, especially one that accepts information at one rate and delivers it at another rate. (2) An area of memory, temporarily reserved for performing input or output, into which data is read, or from which data is written. **bus.** One or more conductors used for transmitting signals or power. **byte.** The amount of storage required to represent one character; a byte is 8 bits. C. Celsius. cathode ray tube (CRT). A vacuum tube in which a stream of electrons is projected onto a fluorescent screen producing a luminous spot. The location of the spot can be controlled. **CCITT.** International Telegraph and Telephone Consultative Committee. Celsius (C). A temperature scale. Contrast with Fahrenheit (F). central processing unit (CPU). Term for processing unit. **channel.** A path along which data passes. Also a device connecting the processor to I/O. character. A letter, digit, or other symbol. character generator. (1) In computer graphics, a functional unit that converts the coded representation of a graphic character into the shape of the character for display. (2) In word processing, the means within equipment for generating visual characters or symbols from coded data. **character key.** A keyboard key that allows the user to enter the character shown on the key. Compare with *function keys*. character set. A group of characters used for a specific reason; for example, the set of characters a printer can print or a keyboard can support. characters per second (cps). A standard unit of measurement for the speed at which a printer prints. check. (1) An error condition. (2) To look for a condition. clocking. In data communications, a method of controlling the number of data bits sent on a communications line in a given time. **CMOS.** Complementary metal oxide semiconductor. code. (1) Instructions for the computer. (2) To write instructions for the computer; to program.(3) A representation of a condition, such as an error code. coding scheme. Synonym for code. command. A request to perform an operation or execute a program. When parameters, arguments, flags, or other operands are associated with a command, the resulting character string is a single command. communications adapter. A hardware feature enabling a computer or device to become a part of a data communications network. complementary metal oxide semiconductor (CMOS). A logic circuit family that uses very little power. It works with a wide range of power supply voltages. **complement of a number.** The value that can be added to the number to equal a given value. concatenate. (1) To link together. (2) To join two character strings. **configuration.** The group of machines, devices, and programs that make up a computer system. conjunction. Synonym for AND operation. **connector.** A part of the system unit or remote controller to which cables for display stations and printer are attached. **counter.** A register or storage location used to accumulate the number of occurrences of an event. **coupler.** A device connecting a modem to a telephone network. cps. Characters per second. CPU. Central processing unit. CRC. Cyclic redundancy check. **CRT.** Cathode ray tube. CRT display. Cathode ray tube display. CTS. Clear to send. Associated with modem control. cursor. (1) A movable symbol (such as an underline) on a display, used to indicate to the operator where the next typed character will be placed or where the next action will be directed. (2) A marker that indicates the current data access location within a file. cyclic redundancy check (CRC). (1) A redundancy check in which the check key is generated by a cyclic algorithm. (2) A system of error checking performed at both the sending and receiving station after a block-check character has been accumulated. **cylinder.** All fixed disk or diskette tracks that can be read or written without moving the disk drive or diskette drive read/write mechanism. data. (1) A representation of facts, concepts, or instructions in a formalized manner suitable for communication, interpretation, or processing by human or automatic means. (2) Any representations, such as characters or analog quantities, to which meaning is, or might be assigned. data transmission. Synonym for transmission. dc. Direct current. Deutsche Industrie Norm (DIN). (1) German Industrial Norm. (2) The committee that sets German dimension standards. digit. (1) A graphic character that represents an integer; for example, one of the characters 0 to 9. (2) A symbol that represents one of the non-negative integers smaller than the radix. For example, in decimal notation, a digit is one of the characters 0 to 9. **digital.** (1) Pertaining to data in the form of digits. (2) Contrast with analog. DIN. Deutsche Industrie Norm. **DIN connector.** One of the connectors specified by the DIN committee. **DIP.** Dual in-line package. **DIP** switch. One of a set of small switches mounted in a dual in-line package. **direct current (dc).** A current that always flows in one direction. direct memory access (DMA) device. A component that can read or write to system storage directly, without processor intervention. Two device types are identified: 1) a first party DMA device resides on a hardware adapter and 2) a third party DMA device resides on the system planar. DMA capability permits simultaneous use of input/output devices and the processor. **disable.** A processing unit is disabled when it prevents the occurrence of certain types of interrupts. disabled. Pertaining to a state of a processing unit that prevents the occurrence of certain types of interruptions. Synonymous with masked. disk. Loosely, a magnetic disk unit. disk drive. A mechanism for moving a disk pack and controlling its movements. diskette. A thin, flexible magnetic plate that is permanently sealed in a protective cover. It can be used to store information copies from the disk. **diskette drive.** The mechanism used to read and write information on diskettes. display. (1) A visual presentation of data. (2) A device for visual presentation of information on any temporary character imaging device. (3) To present data visually. (4) See cathode ray tube display. display attribute. In computer graphics, a particular property that is assigned to all or part of a display; for example, low intensity, green color, blinking status. **DMA.** Direct memory access. **double precision.** Pertaining to the use of two computer words to represent a number in accordance with the required precision. **DSR.** Data set ready. Associated with modem control. **DTR.** Data terminal ready. Associated with modem control. dual in-line package (DIP). A widely used container for an integrated circuit. DIPs have pins in two parallel rows. The pins are spaced 1/10 inch apart. See also DIP switch. duplex. Pertains to communications data that can be sent and received at the same time. Same as full duplex. Contrast with half duplex. duty cycle. In the operation of a device, the ratio of on time to idle time. Duty cycle is expressed as a decimal or percentage. dynamic memory. RAM memory using transistors and capacitors as the memory elements. This memory requires a refresh (recharge) cycle every few milliseconds. Contrast with static memory. **EBCDIC.** See extended binary-coded decimal interchange code. ECC. Error checking and correction. edge connector. A terminal block with a number of contacts attached to the edge of a printed-circuit board to facilitate plugging into a foundation circuit. EIA. Electronic Industries Association. **enable.** A processing unit is enabled when it allows certain types of interrupts. F. Fahrenheit. **Fahrenheit (F).** A temperature scale. Contrast with Celsius (C). falling edge. Synonym for negative-going edge. FCC. Federal Communications Commission. feature. A programming or hardware option, usually available at an extra cost. **fetch.** To locate and load a quantity of data from storage. **field.** An area in a record or panel used to contain a particular catagory of data. The smallest component of a record that can be referred to by name. **fixed disk.** A flat circular plate with a magnetizable surface layer on which data can be stored by magnetic recording. **fixed-disk drive.** The mechanism used to read and write information on fixed disk. flag. (1) Any of various types of indicators used for identification. (2) A character that signals the occurrence of some condition, such as the end of a word. flexible disk. Synonym for diskette. format. (1) A defined arrangement of such things as characters, fields, and lines, usually used for displays, printouts, or files. (2) The pattern which determines how data is recorded. **function keys.** Keys that request actions but do not display or print characters. Included are the keys that normally produce a printed character, but when used with the code key produce a function instead. Compare with *character key*. **G.** (1) Prefix giga; 1 000 000 000. (2) When referring to computer storage capacity, 1 073 741 824. (1 073 741 824 = 2 to the 30th power.) gate. (1) A combinational logic circuit having one output channel and one or more input channels, such that the output channel state is completely determined by the input channel states. (2) A signal that enables the passage of other signals through a circuit. **G-byte.** 1 073 741 824 bytes. general-purpose register (GPR). An explicitly addressable register that can be used for a variety of purposes (for example, as an accumulator or an index register. accumulator, as an index register, or as a special handler of data. giga (G). Prefix 1 000 000 000. gram (g). A unit of weight (equivalent to 0.035 ounces). graphics. A type of data created from fundamental drawing units such as lines, splines, curves, polygons, and so forth. **graphic character.** A character that can be displayed or printed. half-duplex. Pertains to communications in which data can be sent in only one direction at a time. Contrast with *duplex*. hardware. The equipment, as opposed to the programming, of a computer system. head. A device that reads, writes, or erases data on a storage medium; for example, a small electromagnet used to read, write, or erase data on a magnetic disk. hertz (Hz). A unit of frequency equal to one cycle per second. hex. Common abbreviation for hexadecimal. hexadecimal. Pertaining to a system of numbers to the base sixteen; hexadecimal digits range from 0 (zero) through 9 (nine) and A (ten) through F (fifteen). **high-order position.** Most significant; leftmost. For example, bit 0 in a register. Hz. Hertz. immediate data. Data appearing in an instruction itself (as opposed to the symbolic name of the byte of data). The data is immediately available from the instruction and therefore does not have to be read from memory. immediate instruction. An instruction that contains within itself an operand for the operation specified, rather than an address of the operand. index. (1) A table containing the key value and location of each record in an indexed file. (2) A computer storage position or register, whose contents identify a particular element in a set of elements. index register. A register whose contents may be used to modify an operand address during the execution of computer instructions. indicator. An internal switch that communicates a condition between parts of a program or procedure. infinity. A name for the upper boundary of the set of numbers. inhibited. (1) Pertaining to a state of a processing unit in which certain types of interruptions are not allowed to occur. (2) Pertaining to the state in which a transmission control unit or an audio response unit cannot accept incoming calls on a line. initialize. To set counters, switches, addresses, or contents of storage to 0 or other starting values at the beginning of, or at prescribed points in, the operation of a computer routine. input/output (I/O). Pertaining to either input, output, or both between a computer and a device. **input-output channel controller (IOCC).** A hardware component that supervises communication between the input/output channel and the processor. instruction. A statement that specifies an operation to be performed by the computer, along with the values or locations of operands, if any exist. This statement represents the programmer's request to the processor to perform a specific operation. **instruction set.** The set of instructions of a computer, of a programming language, or of the programming languages in a programming system. interface. A shared boundary between two or more entities. An interface might be a hardware component to link two devices together or it might be a portion of memory or registers accessed by two or more computer programs. interrupt. (1) To temporarily stop a process. (2) In data communications, to take an action at a receiving station that causes the sending station to end a transmission. (3) A signal sent by an I/O device to the processor when an error has occurred or when assistance is needed to complete I/O. An interrupt usually suspends execution of the currently executing program. I/O. See input/output. I/O area. Synonym for buffer. **IOCC.** I/O Channel Controller. A hardware component that supervises communication between the input/output channel and the system processor. irrecoverable error. An error that makes recovery impossible without the use of recovery techniques external to the computer program or run. k. Prefix kilo; 1000. **K.** When referring to memory capacity, 1024. (1024 = 2 to the 10th power.) K byte. 1024 bytes. kg. Kilogram; 1000 grams. kHz. Kilohertz; 1000 hertz. kilo (k). Prefix 1000 kilogram (kg). 1000 grams. kilohertz (kHz). 1000 hertz latch. (1) A simple logic-circuit memory element. (2) A feedback loop in sequential digital circuits used to maintain a state. **least-significant digit.** The rightmost digit. See also low-order position. LED. Light-emitting diode. **light-emitting diode (LED).** A semiconductor device that gives off visible or infrared light when activated. load. (1) To move data or programs into memory. (2) To place a diskette into a diskette drive, or a magazine into a diskette magazine drive. (3) To insert paper into a printer. **logarithm.** A mathematical operation related to the base of a numbering system. **low-order position.** The rightmost position in a string of characters. See also least-significant digit. m. (1) Prefix milli; 0.001. (2) Meter. M. (1) Prefix mega; 1 000 000. (2) When referring to computer memory capacity, 1 048 576. (1 048 576 = 2 to the 20th power.) mA. Milliampere; 0.001 ampere. machine language. A language that can be used directly by a computer without intermediate processing. mark. A symbol or symbols that indicate the beginning or the end of a field, of a word, of an item of data, or of a set of data such as a file, a record, or a block. mask. A pattern of characters that controls the keeping, deleting, or testing of portions of another pattern of characters. masked. Synonym for disabled. matrix. An array arranged in rows and columns. **M byte.** 1 048 576 bytes. mega (M). Prefix 1 000 000. megabyte. One million bytes. megahertz (MHz). 1 000 000 hertz. **memory.** Storage on electronic memory such as random access memory, read only memory, or registers. Memory Management Unit (MMU). Hardware on the system board that manages virtual memory by providing translation from a virtual address to a real address. meter (m). A unit of length (equivalent to 39.37 inches). MFM. Modified frequency modulation. MHz. Megahertz; 1 000 000 hertz. **micro** ( $\mu$ ). Prefix 0.000 001. microcode. (1) One or more microinstructions. (2) A code, representing the instructions of an instruction set, implemented in a part of memory that is not program-addressable. microinstruction. (1) An instruction of microcode. (2) A basic or elementary machine instruction. microprocessor. An integrated circuit that accepts coded instructions for execution; the instructions may be entered, integrated, or stored internally. **milli (m).** Prefix 0.001. milliampere (mA). 0.001 ampere. millisecond (ms). 0.001 second. MMU. See memory management unit mnemonic. The field of an assembler instruction that contains the acronym or abbreviation for a machine instruction. Using mnemonics frees the programmer from having to remember the machine's numeric operator codes. mode. (1) A method of operation; for example, the binary mode, the interpretive mode, the alphanumeric mode. (2) The most frequent value in the statistical sense. modem (modulator-demodulator). A device that converts data from the computer to a signal that can be transmitted on a communications line, and converts the signal received to data for the computer. modified frequency modulation (MFM). The process of varying the amplitude and frequency of the 'write' signal. MFM pertains to the number of bytes of storage that can be stored on the recording media. The number of bytes is twice the number contained in the same unit area of recording media at single density. modulation. Changing the frequency or size of one signal by using the frequency or size of another signal. modulation rate. The reciprocal of the measure of the shortest nominal time interval between successive significant instants of the modulated signal. If this measure is expressed in seconds, the modulation rate is expressed in baud. monitor. (1) A device that observes and verifies the operation of a data processing system and indicates any significant departure from the norm. (2) Software or hardware that observes, supervises, controls, or verifies the operations of a system. most-significant digit. The leftmost (non-zero) digit. See also high-order position. ms. Millisecond; 0.001 second. multiplexer. A device capable of interleaving the events of two or more activities, or capable of distributing the events of an interleaved sequence to the respective activities. multipoint. In data communications, pertains to a network that allows two or more stations to communicate with a single system on one line. multiprogramming. The processing of two or more programs at the same time. n. Prefix nano; 0.000 000 001. nano (n). Prefix 0.000 000 001. nanosecond (ns). 0.000 000 001 second. negative true. Synonym for active low. **negative-going edge.** The edge of a pulse or signal changing in a negative direction. Synonymous with falling edge. non-return-to-zero (inverted) recording (NRZI). Deprecated term for non-return-to-zero change-on-ones recording. nonvolatile random access memory. A portion of random access memory that retains its contents after electrical power to the machine is shut off. **NRZI.** Non-return-to-zero change-on-ones recording. ns. Nanosecond; 0.000 000 001 second. **NUL.** The null character. **null character (NUL).** The character hex 00, used to represent the absence of a printed or displayed character. **NVRAM.** See nonvolatile random access memory. odd-even check. Synonym for parity check. offline. Pertaining to the operation of a functional unit without the continual control of a computer. **one-shot.** A circuit that delivers one output pulse of desired duration for each input (trigger) pulse. op code. See operation code. operand. An instruction field that represents data (or the location of data) to be manipulated or operated upon. Not all instructions require an operand field. operating system. Software that controls the running of programs; in addition, an operating system may provide services such as resource allocation, scheduling, input/output control, and data management. **operation code.** A numeric code indicating to the processor which operation should be performed. **OR.** A logic operator having the property that if P is a statement, Q is a statement, R is a statement,..., then the OR of P, Q, R,...is true if at least one statement is true, false if all statements are false. **OR gate.** A gate in which the output is 1 only if at least one input is 1. output. The result of processing data. output process. (1) The process that consists of the delivery of data from a data processing system, or from any part of it. (2) The return of information from a data processing system to an end user, including the translation of data from a machine language to a language that the end user can understand. **overcurrent.** A current of higher than specified strength. overflow indicator. (1) An indicator that signifies when the last line on a page has been printed or passed. (2) An indicator that is set on if the result of an arithmetic operation exceeds the capacity of the accumulator. **overrun.** Loss of data because a receiving device is unable to accept data at the rate it is transmitted. overvoltage. A voltage of higher than specified value. page. A block of instructions, data, or both. page fault. A program interruption that occurs when a page of memory not in real memory is referred to by an active page. parallel. (1) Pertaining to the concurrent or simultaneous operation of two or more devices, or to the concurrent performance of two or more activities. (2) Pertaining to the concurrent or simultaneous occurrence of two or more related activities in multiple devices or channels. (3) Pertaining to the simultaneity of two or more processes. (4) Pertaining to the simultaneous processing of the individual parts of a whole, such as the bits of a character and the characters of a word, using separate facilities for the various parts. (5) Contrast with serial. parameter. Information that the user supplies to a panel, command, or function. picture element (pel). In computer graphics, the smallest element of a display space that can be independently assigned color and intensity. **phototransistor.** A transistor whose switching action is controlled by light shining on it. **picture element (PEL).** The smallest displayable unit on a display. **polling.** A method for determining whether any of the stations sharing a communications line has data to send. **port.** An access point for data input to or data output from a computer system. positive true. Synonym for active high. **positive-going edge.** The edge of a pulse or signal changing in a positive direction. Synonymous with rising edge. **power supply.** A device that produces the power needed to operate electronic equipment. **precision.** A measure of the ability to distinquish between nearly equal values. See *single precision* and *double precision*. **printed-circuit board.** A usually copper-clad plastic board used to make a printed circuit. **priority.** The relative ranking of items. For example, a job with high priority in the job queue will be run before one with medium or low priority. privileged instructions. System control instructions that can only run in the processor's privileged state. Privileged instructions generally manipulate virtual machines or the memory manager; they typically are not used by application programmers. See *privileged state*. **privileged state.** A hardware protection state in which the processor can run privileged instructions. The processor's privileged state supports the virtual machine's VRM state. **processing program.** A program that performs such functions as compiling, assembling, or translating for a particular programming language. **processing unit.** A functional unit that consists of one or more processors and all or part of internal memory. processor. (1) In a computer, a functional unit that interprets and executes instructions. (2) A functional unit, a part of another unit such as a terminal or a processing unit, that interprets and executes instructions. (3) Deprecated term for processing program. (4) See microprocessor. **processor channel.** The interface used directly by the system processor and the memory management unit. **program.** A file containing a set of instructions conforming to a particular programming language syntax. **propagation time.** The time necessary for a signal to travel from one point on a communications line to another. **protocol.** (1) A specification for the format and relative timing of information exchanged between communicating parties. (2) The set of rules governing the operation of functional units of a communication system that must be followed if communication is to be achieved. **pulse.** A variation in the value of a quantity, short in relation to the time schedule of interest, the final value being the same as the initial value. **RAM.** Random access memory. Read/write memory. random access memory (RAM). Read/write memory. raster array. In computer graphics, a predetermined pattern of lines that provides uniform coverage of a display space. **read.** To acquire or interpret data from a storage device, from a data medium, or from another source. **read-only memory (ROM).** A memory device whose contents cannot be modified. The memory is retained when power is removed. read/write memory. A memory device whose contents can be modified. Also called RAM. **Real Address.** A 24 bit address on the processor channel which will be applied to memory by the memory management unit without modification by the translation mechanism of MMU. **real number.** A number, containing a decimal point, stored in fixed-point or floating-point format. **Real Resolved Address.** A real processor channel address in which the 8 high order bits as received from a DMA adapter have been replaced by the IOCC. **recoverable error.** An error condition that allows continued execution of a program. **red-green-blue-intensity (RGBI).** The description of a direct-drive color monitor that accepts input signals of red, green, blue, and intensity. **redundancy check.** A check that depends on extra characters attached to data for the detection of errors. See cyclic redundancy check. Region. The term region is used within the IOCC document to reference to a 128K byte block of memory on a 128 KB boundary. The MMAT and TCW table map each entry onto a region for purpose of control. register. (1) A memory area, in a computer, capable of storing a specified amount of data such as a bit or an address. (2) See general purpose register and system control register. register pair. See register twin. register twin. The twin of a general purpose register is the binary value of the register with the low-order bit inverted. For example, the twin of register 5 with a binary value of 0101 is register 4 with a binary value of 0100. retry. To resend the current block of data (from the last EOB or ETB) a prescribed number of times, or until it is entered correctly or accepted. reverse video. A form of highlighting a character, field, or cursor by reversing the the color of the character, field, or cursor with its background; for example, changing a red character on a black background to a black character on a red background. RGBI. Red-green-blue-intensity. rising edge. Synonym for positive-going edge. **ROM.** Read-only memory. **ROM/BIOS.** The ROM resident basic input/output system, which provides the level control of the major I/O devices in the computer system. **RS232C.** A standard by the EIA for communication between computers and external equipment. RTS. Request to send. Associated with modem control. schematic. The representation, usually in a drawing or diagram form, of a logical or physical structure. second level interrupt handler (SLIH). A routine that handles the processing of an interrupt from a specific adapter. An SLIH is called by the first level interrupt handler associated with that interrupt level. sector. (1) An area on a disk track or a diskette track reserved to record information. (2) The smallest amount of information that can be written to or read from a disk or diskette during a single read or write operation. signal. A variation of a physical quantity, used to convey data. sink. A device or circuit into which current drains. **Soft Reset.** A system processor reset issued by the locator adapter upon detection of a unique 3-keystroke sequence. **software.** (1) Computer programs, procedures, and rules concerned with the operation of a data processing system. (2) Contrast with hardware. source. The origin of a signal or electrical energy. SS. Start-stop. start bit. (1) A signal to a receiving mechanism to get ready to receive data or perform a function. (2) In a start-stop system, a signal preceding a character or block that prepares the receiving device for the reception of the code elements. **start-stop system.** A data transmission system in which each character is preceded by a start bit and is followed by a stop bit. start-stop (SS) transmission. (1) Asynchronous transmission such that a group of signals representing a character is preceded by a start bit and followed by a stop bit. (2) Asynchronous transmission in which a group of bits is preceded by a start bit that prepares the receiving mechanism for the reception and registration of a character and is followed by at least one stop bit that enables the receiving mechanism to come to an idle condition pending the reception of the next character. static memory. RAM memory using flip-flops as the memory elements. Data is retained as long as power is applied to the flip-flops. Contrast with dynamic memory. stop bit. (1) A signal to a receiving mechanism to wait for the next signal. (2) In a start-stop system, a signal following a character or block that prepares the receiving device for the reception of a subsequent character or block. memory. (1) A memory device. (2) A device, or part of a device, that can retain data. (3) The retention of data in a memory device. (4) The placement of data into a memory device. STX. Start-of-text. supervisor call (SVC). An instruction that interrupts the program being executed and passes control to the supervisor so it can perform a specific service indicated by the instruction. symbol. (1) A conventional representation of a concept or a representation of some thing by reason of relationship, association, or convention. (2) A representation of something by reason of relationship, association, or convention. synchronization. The process of adjusting the corresponding significant instants of two signals to obtain the desired phase relationship between these instants. synchronous transmission. (1) Data transmission in which the time of occurrence of each signal representing a bit is related to a fixed time frame. (2) Data transmission in which the sending and receiving devices are operating continuously at substantially the same frequency and are maintained, by means of correction, in a desired phase relationship. syntax. The rules for the construction of a command or program. system memory. Program-addressable memory from which instructions and other data can be loaded directly into registers for subsequent execution or processing. system unit. The part of the system that contains the processing unit, the disk drive and the disk, and the diskette drive and diskettes. TCW. Translation Control Word used within the IOCC to translate and/or reformat the incoming DMA address. time-out. (1) A parameter related to an enforced event designed to occur at the conclusion of a predetermined elapsed time. A time-out condition can be cancelled by the receipt of an appropriate time-out cancellation signal. (2) A time interval allotted for certain operations to occur; for example, response to polling or addressing before system operation is interrupted and must be restarted. **track.** A circular path on the surface of a disk or diskette on which information is magnetically recorded and from which recorded information is read. **transistor-transistor logic (TTL).** A popular logic circuit family that uses multiple-emitter transistors. translate. To transform data from one language to another. transmission. (1) The sending of data from one place for reception elsewhere. (2) In ASCII and data communication, a series of characters including headings and text. (3) The dispatching of a signal, message, or other form of intelligence by wire, radio, telephone, or other means. (4) One or more blocks or messages. For BSC and start-stop devices, a transmission is terminated by an EOT character. (5) Synonymous with data transmission. **trap.** An unprogrammed, hardware-initiated jump to a specific address. Occurs as a result of an error or certain other conditions. TTL. Transistor-transistor logic. **two's complement.** Representation of negative binary numbers. Formed by subtracting each digit of the number from zero, then adding one to the result. typamatic key. A key that repeats its function multiple times when held down. unprivileged state. A hardware protection state in which the processor can only run unprivileged instructions. The processor's unprivileged state supports the virtual machine's operating system state and problem state. #### V. Volt. video. Computer data or graphics displayed on a cathode ray tube, monitor, or display. Virtual Address. A 32 bit address on the internal bus intended to be translated by Memory Management. **volt.** The basic practical unit of electric pressure. The potential that causes electrons to flow through a circuit. #### W. Watt. watt. The practical unit of electric power. word. A contiguous series of 32 bits (four bytes) in storage, write. To make a permanent or transient recording of data in a storage device or on a data medium. write precompensation. The varying of the timing of the head current from the outer tracks to the inner tracks of the diskette to keep a constant 'write' signal. # Index | A | | D | | |-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | address maps I/O channel 6-43 address translation segment register selection TLB operation 11-98 TLB reload 11-101 virtual address generation | | description Floating-Point Accelerator Board 1 I/O subsystem 1-11 memory channel 1-10 processor board 1-9 processor channel 1-10 system board 1-9 system memory boards 1-10 DMA 5-39 DMA addressing modes 5-15 | -10 | | block diagram Floating-Point Accelerator system unit 1-8 | 4-4 | ECC checking 11-140 | | | C | | $oldsymbol{\mathbb{F}}$ | | | cable connector | | | | | keyboard 9-10 | | Floating-Point Accelerator 4-4 | | | Locator 9-16 connector | | block diagram 4-4<br>command encoding 4-13 | | | keyboard 5-145 | | programming considerations 4-40 | | | locator 5-146 | | register sets 4-6 | | | Model 10 Battery 5-155 | | slot pin assignments 4-41 | | | Model 10 Operator Panel | | | | | Model 10 Power Supply | | | | | Model 20 and Model 25 O<br>Model 20 and Model 25 Po | | $ \mathbf{G} $ | | | Model 20 and Model 25 Fe | | | | | Widden 20 and Widden 25 be | J. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. | general-purpose registers | | | | | system processor 11-12 | | | I | commands 9-12 | |----------------------------------------|-------------------------------------------------| | <u> </u> | data frame 9-15 | | | operation modes 9-11 | | I/O channel 6-1 | operational characteristics 9-11 | | address maps 6-43 | voltage interchange information 9-15 | | connector/pin description 6-51 | | | data transfer 6-15 | | | interrupts 6-40 | [10] | | signal definitions 6-8 | M | | I/O channel compatibility 8-4 | | | I/O channel operations 5-37 | machine check errors 11-85 | | I/O subsystem adapters 5-75 | memory 3-4 | | instruction formats | board slots 3-5 | | memory access 11-30 | configurations 3-8 | | system processor 11-29 | signal definitions 3-6 | | instruction set | slot pin assignments 3-18 | | system processor 11-27 | timing waveforms 3-14 | | interrupts 1-36 | memory exception address register 11-124 | | I/O channel 6-40 | memory exception register 11-119 | | IPL ROM | Memory Management Unit 11-92 | | boot record 7-16 | address translation 11-93 | | display codes 7-14 | address translation hardware operation 11-96 | | location 7-10 | address translation overview 11-94 | | NVRAM layout 7-8 | control register initialization 11-137 | | register conventions 7-13 | control registers 11-113 | | register conventions 7 15 | ECC checking 11-140 | | | I/O address assignments 11-135 | | | I/O base address register initialization 11-133 | | <b>K</b> | lockbit processing 11-110 | | | memory access control 11-108 | | keyboard 9-4 | memory protection processing 11-109 | | cable connector 9-10 | reference and change bits 11-111 | | command set 9-5 | segment protection processing 11-108 | | layout 9-7 | segment registers 11-127 | | outputs 9-6 | TBL entries 11-128 | | Catpath 7 0 | translation assist functions 11-133 | | | translation control register 11-117 | | | Model 10 system 1-6 | | L | | | | Model 20 and Model 25 systems 1-5 | | locations | | | Model 10 system board 5-10 | | | Model 20 and Model 25 system board 5-8 | | | Locator 9-11 | | | cable connector 9-16 | | | 0 | $\lfloor \mathbf{s} \rfloor$ | |-------------------------------------|--------------------------------------------------------------------| | operator panel 9-17 | segment registers 11-127 | | keylock 9-18 | slot pin assignments | | Model 20 and Model 25 Battery | Floating-Point Accelerator 4-41 | | Connector 9-19 | memory 3-18 | | two-digit display 9-18 | processor board 2-16 | | | system addressing model 1-26 | | | system arbitration 5-33 | | | system board | | P | addressing modes 5-14 | | | I/O address assignments 5-12 | | power 10-1 | I/O subsystem adapters 5-75 | | input 10-4 | interrupt controllers 5-56 | | Model 10 Distribution Diagram 10-6 | keyboard adapter 5-86 | | Model 20 and Model 25 Distribution | keyboard connector 5-145 | | Diagram 10-9 | locator adapter 5-86 | | output 10-5 | locator connector 5-146 | | signals 10-10 | Model 10 Battery Connector 5-155 | | processor board 2-1 | Model 10 locations 5-10 | | dataflow 2-6 | Model 10 Operator Panel Connector 5-15 | | description 2-4 | Model 10 Power Supply Connectors 5-152 | | function overview 2-6 | Model 20 and Model 25 locations 5-8 | | memory channel interface 2-11 | Model 20 and Model 25 Operator Panel | | processor channel interface 2-8 | Connector 5-150 | | signal definitions 2-11 | Model 20 and Model 25 Power Supply | | slot pin assignments 2-16 | Connectors 5-147 | | program check errors 11-87 | RS232C interface 5-84 | | programming considerations | serial port connectors 5-151 | | Floating-Point Accelerator 4-40 | speaker adapter 5-86 | | | system boards 5-1 | | | system compatibility 8-1 | | | system PL ROM 7-4 | | R | | | | system memory addressing conventions 1-19 system memory boards 3-1 | | RAS mode diagnostic register 11-131 | system memory boards 3-1 system nomenclature 1-13 | | | system overview 1-7 | | | system overview 1-7 system performance 1-12 | | | | | | system processor 11-8 | | | address map 1-34 | | | general-purpose registers 11-12 instruction formats 11-29 | | | | | | instruction set 11-27 | | | interrupt registers 11-24 | interrupt servicing 11-26 interrupts 11-19 machine check errors 11-85 privileged and unprivileged states 11-12 processor channel 11-9 processor priority 11-20 processor states 11-10 program check errors 11-87 program status 11-21 RAS facilities 11-85 system control registers 11-14 system memory 11-9 system timer facility 11-17 system processor instructions address computation 11-37 arithmetic operations 11-56 branching 11-40 input/output 11-83 load and store 11-31 logical operations 11-67 moves and inserts 11-51 shifts 11-73 system control 11-79 traps 11-49 system unit block diagram 1-8 TLB reload HAT address generation 11-104 HAT and IPT format 11-102 HAT/IPT base address 11-103 IPT search 11-105 transaction identifier register 11-126 translated real address register 11-126 user input/output devices 9-1 ©IBM Corp. 1985 All rights reserved. International Business Machines Corporation Department 997, Building 998 11400 Burnet Rd. Austin, Texas 78758 Printed in the United States of America 6489893