# 21MX E-Series Computer Operating and Reference Manual #### **ADDITIONAL 21MX COMPUTER REFERENCE MANUALS** 21MX E-Series Computer Operating and Reference Manual 12979A 2109A/2113A Firmware 12979A I/O Extender 21MX E-Series Computer 21MX E-Series Computer Installation and Service Manual 12979-90006 Installation and Service Manual Microprogramming Reference Manual 02109-90004 02109-90002 12903B Slide Mounting Kit 12979A LO Extender 21MX E-Series Computer Installation Instructions (for HP 2109/12979/12990) Operating and Reference Manual Microprogramming Pocket Guide 02109-90008 12979-90007 12903-90002 12903B Slide Mounting Kit 12903C Slide Mounting Kit Installation Instructions (for HP 2109 12979/12990) 13304A Firmware Accessory Board Installation Instructions (for HP 2113) 12903-90003 Installation and Service Manual 12903-90002 13304-90001 12898A Dual-Channel Port Controller 12897B Dual-Channel Port Controller 13047A User Control Store Kit Installation Manual Installation Manual Installation and Service Manual 12898-90001 12897-90005 13047-90001 21MX 21MX E-Series Computer 12892B Memory Protect 13197A Writable Control Store I O Interfacing Guide Installation Manual Reference Manual 13197-90005 02109-90006 12892-90007 2102B Memory Controller 13306A Fast FORTRAN Processor 12990A Installation Manual Installation Manual 02102-90005 13306-90001 12990A Memory Extende Installation and Service Manual 12990-90003 13187A 16K Memory Module Installation Manual 13187-90002 12903B Slide Mounting Kit Installation Instructions Accessories (for HP 2109 12979 12990) 12903-90002 12991A Power Fail Recovery System 12998A 8K Memory Module Installation Manual Installation Manual (for HP 2113 12990) 12998-90001 13187A 16K Memory Module 12991-90001 Installation Manual 13187-90002 2102E High Performance Memory Controller 21MX 21MX E-Series Computer Installation Manual 10 Interfacing Guide 02109-90006 02102-90007 12998A 8K Memory Module Installation Manual 12998-90001 12741A 16K High Performance 21MX E-Series Computer Memory Module Engineering Supplement Package Installation Manual 02109-90007 12741A 16K High Performance 12741-90001 Memory Module Installation Manual 12741-90001 12944A Power Fail Recovery System 2000 Systems Diagnostic Configurator Reference Manual 02100-90157 Installation Manual (for HP 2109) 12944-90001 12944A Power Fail Recovery System Installation Manual (for HP 2109) 12944-90001 13305A Dynamic Mapping System Installation Manual 13305-90001 12992 Loader ROM's Installation Manual 12992-90001 Copyright © 1977 by Hewlett-Packard Company # HP Computer Museum www.hpmuseum.net For research and education purposes only. # 21MX E-SERIES COMPUTER operating and reference manual HEWLETT-PACKARD COMPANY 11000 WOLFE ROAD, CUPERTINO, CALIFORNIA, 95014 > Printed: JULY 1977 Printed in U.S.A. # CONTENTS | Section I | Page | Reserved Memory Locations | | |--------------------------------------------|---------------|--------------------------------------------------------------|-------| | SYSTEM FEATURES | | Nonexistent Memory | | | Architecture | 1-1 | Base Set Instruction Formats | | | User Microprogramming | 1-1 | Memory Reference Instructions | | | Self-Test Diagnostics | | Register Reference Instructions | | | Local and Remote Bootstrap Loaders | | Input/Output Instructions | 3-4 | | Power System | | Extended Arithmetic Memory | | | Memory System | | Reference Instructions | 3-5 | | Input/Output | | Extended Arithmetic Register | | | Software | | Reference Instructions | | | Specifications | | Extended Instructions | | | System Expansion and Enhancement | 1-3 | Floating Point Instructions | | | Section II | Page | Base Set Instruction Coding | | | OPERATING PROCEDURES | 1 age | Memory Reference Instructions | | | Hardware Registers | 2-1 | Register Reference Instructions | | | A-Register | | Shift/Rotate Group | | | B-Register | | Alter/Skip Group | | | M-Register | | Input/Output Instructions | 3-12 | | T-Register | | Extended Arithmetic Memory | 0.10 | | P-Register | | Reference Instructions | 3-13 | | S-Register | | Extended Arithmetic Register | 0.14 | | Extend Register | | Reference Instructions | | | Overflow Register | | Extended Instruction Group | | | Display Register | | Index Register Instructions | | | X- and Y-Registers | | Jump Instructions | | | Operator Panel | | Byte Manipulation Instructions | | | Rear Panel | | Bit Manipulation Instructions | | | Internal Switches | | Word Manipulation Instructions | | | Operating Procedures | | Floating Point Instructions | | | Cold Power-Up | | Instruction Execution Times | 3-24 | | Loading Programs Manually | | | | | Loading Programs from Paper Tape Reader | | Section IV | Page | | Loading Programs from Disc Drive | | DYNAMIC MAPPING SYSTEM | | | Loading Programs from Other Loading Device | | Memory Addressing | | | Verifying Programs | | Map Register Loading | | | Running Programs | | Status and Violation Registers | | | Special Register Display Mode | | Map Segmentation | | | X- and Y- (x and y) Registers | | Power Fail Characteristics | | | DMS Map (m, t, and f) Registers | | DMS Instruction Coding | | | Status (s) Register | | Instruction Execution Times | | | Shutdown Procedures | | Sample Map Load/Enable Routine | | | Shutdown (Memory Sustained) | 2-11 | Additional DMS Definitions | | | Shutdown (Memory Not Sustained) | | Alternate Map | 4-11 | | Remote Program Loading | | Protected Mode | | | Self-Test Firmware Diagnostics | | MEM Violations | | | Test Descriptions | $\dots 2-12$ | DCPC Operation in a DMS Environment | 4-1] | | Test 1 | $\dots 2-12$ | Section V | Page | | Test 2 | 2-12 | MICROPROGRAMMING | 1 age | | Test 3 | 2-12 | | 5 1 | | Text Execution | 2-12 | The Microprogrammed Computer The Microprogrammable Computer | | | Exchanging I/O Interfaces | $\dots 2$ -12 | Customized Instructions | | | Halt Codes | $\dots 2-14$ | System Speed | | | Abnormal Indications | $\dots 2-14$ | Memory Space and Security | | | Section III | Page | Developing Microprograms | 5 4 | | PROGRAMMING INFORMATION | rage | Support for the Microprogrammer | 5.6 | | Data Formats | ସ 1 | Optional Instruction Sets | | | Marson Addressing | 0-1 | | | | Memory Addressing | | Imamic Manning System | | | Do win a | | Dynamic Mapping System | | | Paging Direct and Indirect Addressing | $\dots 3$ -1 | Fast FORTRAN Processor Conclusion | 5- | # **CONTENTS** (continued) | Parity Error Interrupt 6-3 Memory Protect/DMS Interrupt 6-4 Dual-Channel Port Controller Interrupt 6-6 Input/Output Interrupt 6-6 Central Interrupt Register 6-6 | Dual-Channel Port Controller 7-6 DCPC Operation 7-6 DCPC Initialization 7-7 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | Interrupt System Control 6-6 | Appendix Page | | | Computer Physical Layout | | Section VII Page | Character Codes | | INPUT/OUTPUT SYSTEM | Octal Arithmetic A-4 | | Input/Output Addressing | Octal/Decimal Conversions | | Input/Output Priority | Mathematical Equivalents | | Control Bit | Instruction Codes in Octal | | Flag Bit7-3 | Base Set Instruction Codes in Binary A-10 | | Buffer 7-4 | Dynamic Mapping System Instruction | | Input/Output Data Transfer | Codes in Binary A-12 | | Input Data Transfer (Interrupt Method)7-4 | Extend and Overflow Examples A-13 | | Output Data Transfer (Interrupt Method) 7-5 | Interrupt and I/O Control Summary A-14 | | | ILLUSTRATIONS | | Title Page | Title Page | | HP 21MX E-Series Microprogrammable Computers . 1-0 | Basic Word Format Vs Map Register Format 4-1 | | Operator Panel Controls and Indicators2-2 | Map Segmentation | | HP 2109A Rear Panel and I/O PCA Cage2-6 | Microprogram Development Cycle | | HP 2113A Rear Panel and I/O PCA Cage2-7 | Input/Output System | | Remote Program Load Routine | I/O Address Assignments | | Data Formats and Octal Notation3-2 | Priority Linkage | | Base Set Instruction Formats | Interrupt Sequences | | Shift and Rotate Functions | Input Data Transfer (Interrupt Method) | | Examples of Double-Word Shifts and Rotates 3-15 Basic Memory Addressing Scheme 4-1 | Output Data Transfer (Interrupt Method) | | Expanded Memory Addressing Scheme | DCPC Control Word Formats | | | TABLES | | Title Page | Title Page | | Specifications | Alter/Skip Group Combing Guide | | Options and Accessories | Typical Base Set Instruction Execution Times 3-25 | | Operator Panel Control and Indicator | MEM Status Register Format | | Functions | MEM Violation Register Format | | HP 2109A Rear Panel Features | Typical DMS Instruction Execution Times 4-13 | | HP 2113A Rear Panel Features | Sample DMS Load/Enable Routine 4-15 | | Starting Address Vs Memory Size2-9 | HP 2109A Interrupt Assignments | | Optional Loader Selection | HP 2113A Interrupt Assignments | | Halt Codes | Sample Power Fail Subroutine | | Memory Paging | and DMS Subroutine | | Reserved Memory Locations | Noninterrupt Transfer Routines | | Shift/Rotate Group Combing Guide | DCPC Initialization Program | | | iii | Page Section VI INTERRUPT SYSTEM Power Fail Interrupt ...... 6-1 #### ALPHABETICAL INDEX OF STANDARD INSTRUCTIONS | Instruc | stion . | Page | Instruc | tion | Page | |------------|---------------------------------------------------------|------------------------|------------|----------------------------------------------------------|---------------| | ADA | Add to A | 3-5 | JLY | Jump and Load Y | 3-19 | | ADB | Add to B | 3-5 | JMP | Jump | . 3-6 | | ADX | Add Memory to X | 3-16 | JPY | Jump | . 3-20 | | ADY | Add Memory to Y | 3-16 | JSB | Jump to Subroutine | . 3-6 | | ALF | Rotate A Left Four | 3-8 | LAX | Load A Indexed by X | . 3-17 | | ALR | A Left Shift, Clear Sign | 3.8 | LAY | Load A Indexed by Y | | | ALS | A Left Shift | | LBT | Load Byte | | | AND | "And" to A | | LBX | Load B Indexed by X | . 3-18 | | ARS | A Right Shift | | LBY<br>LDA | Load B Indexed by Y | | | ASL | Arithmetic Shift Left (32) | | LDA | Load A | . 3-6 | | ASR | Arithmetic Shift Right (32) | | LDX | Load X from Memory | . 0-0<br>9 10 | | BLF | Rotate B Left Four | | LDY | Load Y from Memory | 3.19 | | BLR | B Left Shift, Clear Sign | | LIA | Load Input to A | | | BLS | B Left Shift | | LIB | Load Input to B | 3-12 | | BRS | B Right Shift | 3-9 | LSL | Logical Shift Left (32) | . 3-16 | | CAX | Copy A to X | 3-16 | LSR | Logical Shift Right (32) | . 3-16 | | CAY | Copy A to Y | 3-16 | MBT | Move Bytes | . 3-21 | | CBS | Clear Rite | 3.21 | MIA | Merge Into A | . 3-12 | | CBT | Compare Bytes | 3-20 | MIB | Merge Into B | . 3-12 | | CBX | Copy B to A | 3-16 | MPY | Multiply | . 3-14 | | CBY | Copy B to Y | 3-17 | MVW | Move Words | . 3-28 | | CCA | Clear and Complement A | | NOP | No Operation | . 3-9 | | CCB | Clear and Complement B | . 8-10 | OTA | Output A | . 3-18 | | CCE | Clear and Complement E | 3-10 | ОТВ | Output B | | | CLA | Clear A | | RAL | Rotate A Left | | | CLB | Clear B | | RAR<br>RBL | Rotate A Right | | | CLC | Clear Control | 20210 | RBR | Rotate B Right | | | CLE | Clear B | 219 | RRL | Rotate Left (32) | 3-16 | | CLO | Clear Overflow | 3-12 | RRR | Rotate Right (32) | 3.16 | | CMA | Complement A | 3-10 | RSS | Reverse Skip Sense | | | CMB | Complement B | 3-11 | SAX | Store A Indexed by X | | | CME | Complement E | 3 11 | SAY | Store A Indexed by Y | | | CMW | Compare Words | | SBS | Set Bits | | | CPA | Compare to A | 3-6 | SBT | Store Byte | . 3-21 | | CPB | Compare to B | 3-6 | SBX | Store B Indexed by X | . 3-19 | | CXA | Copy X to A | 3-17 | SBY | Store B Indexed by Y | . 3-19 | | CXB | Copy X to B | 3-17 | SEZ | Skip if E is Zero | . 3-1 | | CYA | Copy Y to A | 3.17 | SFB | Scan For Byte | . 3-2. | | CYB | Copy Y to B | 3-17 | SFC | Skip if Flag Clear | | | DIV | Divide | 3-14 | SFS | Skip if Flag Set | 10 2 1 | | DLD | Double Load | | SLA<br>SLB | Skip if LSB of A is Zero 3<br>Skip if LSB of B is Zero 3 | | | DST | Double Store | 9 17 | SOC | Skip if Overflow Clear | 3_1 | | DSX<br>DSY | Decrement Y and Skip if Zero | | SOS | Skip if Overflow Set | | | ELA | Rotate E Left with A | | SSA | Skip if Sign of A is Zero | 3-1 | | ELB | Rotate E Left with B | | SSB | Skip if Sign of B is Zero | . 3-1 | | ERA | Rotate E Right with A | | STA | Store A | . 3-7 | | ERB | Rotate E Right with B | 3-9 | STB | Store B | . 3-7 | | FAD | Floating Point Add | | STC | Set Control | 3-1 | | FDV | Floating Point Divide | | STF | Set Flag | 3-1 | | FIX | Floating Point to Integer | | STO | Set Overflow | 3-1 | | FLT | Integer to Floating Point | 3-24 | STX | Store X to Memory | | | FMP | Floating Point Multiply | 3-24 | STY | Store Y to Memory | | | FSB | Floating Point Subtract | 3-24 | SZA | Skip if A is Zero | 3-1 | | HLT | Halt | 3-12 | SZB | Skip if B is Zero | 3-1 | | INA | Increment A | 3-11 | TBS | Test Bits | 3-2 | | INB | Increment B | 3-11 | XAX | Exchange A and X | 3-1 | | IOR | "Inclusive Or" to A | 3-6 | XAY | Exchange A and Y | . 3-1 | | ISX | Increment X and Skip if Zero | 3-17 | XBX | Exchange B and X | 5-1 | | ISY<br>ISZ | Increment Y and Skip if Zero Increment and Skip if Zero | | XBY<br>XOR | Exchange B and Y | ə-1 | | | Ingramont and Skin if Zara | 06.5.3.20 to 3.018.666 | XUK | Exclusive Of to A | | #### ALPHABETICAL INDEX OF DYNAMIC MAPPING SYSTEM INSTRUCTIONS | Instruc | tion Page | Instruc | | Page | |---------|-------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DJP | Disable MEM and JMP | SJP | Enable System Map and JMP | . 4-7 | | DJS | Disable MEM and JSB | SJS | Enable System Map and JSB | . 4-7 | | JRS | Jump and Restore Status | SSM | Store Status Register Into Memory | . 4-7 | | LFA | Load Fence From A 4-4 | SYA | Load/Store System Map per A | . 4-7 | | LFB | Load Fence From B 4-4 | SYB | Load/Store System Map per B | . 4-8 | | MBF | Move Bytes From Alternate Map 4-4 | UJP | Enable User Map and JMP | | | MBI | Move Bytes Into Alternate Map 4-4 | UJS | Enable User Map and JSB | | | MBW | Move Bytes Within Alternate Map 4-5 | USA | Load/Store User Map per A | . 4-8 | | MWF | Move Words From Alternate Map 4-5 | USB | Load/Store User Map per B | | | MWI | Move Words Into Alternate Map 4-5 | XCA | Cross Compare A | | | MWW | Move Words Within Alternate Map 4-5 | XCB | Cross Compare B | | | PAA | Load/Store Port A Map per A 4-6 | XLA | Cross Load A | | | PAB | Load/Store Port A Map per B 4-6 | XLB | Cross Load B | | | PBA | Load/Store Port B Map per A 4-6 | XMA | Transfer Maps Internally per A | . 4-9 | | PBB | Load/Store Port B Map per B 4-6 | XMB | Transfer Maps Internally per B | | | RSA | Read Status Register Into A 4-6 | XMM | Transfer Maps or Memory | THE WAR STREET | | RSB | Read Status Register Into B 4-6 | XMS | Transfer Maps Sequentially | | | RVA | Read Violation Register Into A 4-7 | XSA | Cross Store A | | | RVR | Read Violation Register Into R 4.7 | YCB | Cross Store B | THE RESERVE THE PARTY OF PA | Figure 1-1. HP 21MX E-Series Microprogrammable Computers ### SYSTEM FEATURES The HP 21MX E-Series computers shown in figure 1-1 are high-performance machines designed to satisfy a wide range of computing needs. Because of a unique design philosophy, many features have been incorporated as standard in the E-Series; this same philosophy allows optional features to be added at low cost. E-Series computers have traditional HP quality and reliability built in from the ground up and compatibility with previous Hewlett-Packard computers is maintained. HP 21MX E-Series computers (hereafter referred to as E-Series computers), provide very cost-effective solutions to a variety of systems applications. #### 1-1. ARCHITECTURE E-Series computers have a proven architecture that features a fully microprogrammed processor, including all arithmetic functions, input/output, and operator panel control. Four general purpose registers are available, two of which may be used as index registers. There are 128 standard instructions including index instructions, integer and floating point arithmetic instructions, input/output instructions, and a full complement of instructions for logical operations as well as bit and byte manipulation. The E-Series computers have been optimized for performance. At the heart of the computer is a microprogrammed control section that directs the operations of the other functional units of the computer. In the E-Series, the control section has been speeded up for certain operations due to a sophisticated technique of varying the microinstruction cycle time. In addition, the efficiency of the microprogrammed routines that determine the machine language operation has been increased. The result is a highperformance computer that retains compatibility with earlier Hewlett-Packard computers and the flexibility of user microprogramming. All instructions will execute faster in an HP 21MX E-Series computer than in an HP 21MX M-Series Computer. The central processor unit (CPU) to memory interface is asynchronous in the E-Series computers, thus assuring that faster memory speeds can be used to good advantage. For those applications where even the HP standard set of instructions is not enough, E-Series computer users may expand their instruction repertoire by using HP-supplied instruction sets. Off-the-shelf enhancements include the Dynamic Mapping System (DMS) for expanded memory management and the Fast FORTRAN Processor for fast handling of compiler and extended precision routines. #### 1-2. USER MICROPROGRAMMING The power and flexibility of microprogramming is made readily available to the E-Series computer user through the microinstruction set of 211 micro-orders. Microprogrammers have access to 12 special scratch pad registers in addition to the other internal registers of the E-Series, and may address up to 16K, 24-bit words of control store. E-Series computers also support up to three levels of nested subroutines in microprograms. Closely resembling assembly language programming in simplicity, microprogramming offers the advantages of speed and security as well as the ability to expand the instruction set to meet any computing need. Microprogramming is supported by Hewlett-Packard through software assembly and debug packages and customer training courses. User-developed microprograms may be permanently fused in programmable Read-Only Memory (pROM) chips for mounting on the Firmware Accessory Board, or may be loaded into Writable Control Store (WCS) modules where they can be dynamically altered. #### 1-3. SELF-TEST DIAGNOSTICS A comprehensive set of diagnostic routines permanently stored in Read-Only Memory (ROM) are standard in E-Series computers. Two of these routines, executed each time the IBL/TEST function is performed, test the CPU and the enabled memory (up to 32K) for quick verification of operating condition. A third routine, executed every time the machine is powered up, tests the CPU and all installed memory. #### 1-4. LOCAL AND REMOTE BOOT-STRAP LOADERS The initial binary loading (IBL) function is easily performed on E-Series computers. For local bootstrap loading, a 64-word ROM-resident IBL program is called by a pushbutton switch on the operator panel. A paper tape loader ROM and a disc loader ROM are standard. One or two additional loader ROM's may be included; these programs may be purchased as accessories or may be usergenerated. Computers at remote sites can be force-loaded from a central location through the use of the Remote Program Load (RPL) capability. All of the information normally keyed into the operator panel is set in a special set of switches on the CPU board so that the bootstrapping sequence may be initiated from a remote site. #### 1-5. POWER SYSTEM E-Series computers are equipped with power systems designed to continue normal operations in environments where power may fluctuate widely. Input line voltages and frequencies may vary widely without affecting the operation of the computer. The optional Power Fail Recovery System provides automatic restart capability and, depending on the memory size, also provides between 1.75 and 4.25 hours of memory sustaining power in the event of complete power failure. (See Power Fail Recovery System specifications in table 1-1.) #### 1-6. MEMORY SYSTEMS E-Series computers are available with either of two semiconductor memory systems. Both systems are based on 4k-bit MOS/RAM semiconductor chips that offer fieldproven reliability and economy. The HP 2102B Standard Performance Memory System has a system cycle time of 560 nanoseconds. The HP 2102E High-Performance Memory System has a system cycle time of 350 nanoseconds. For data integrity, memory parity checking is provided as a standard feature in both systems. Memory is easily expanded by plug-in 8k- and 16k- word modules for the HP 2102B and 16k-word modules for the HP 2102E systems. The HP 2109A Computer has space in the mainframe for five modules and the HP 2113A Computer can contain up to ten modules. Up to nine additional modules can be added in the HP 12990A Memory Extender to increase the HP 2109A Computer memory size to 224k words or the HP 2113A Computer memory size to 304k words. Addressing physical memory configurations larger than 32k words is possible only through the use of the HP 13305A Dynamic Mapping System. The Dynamic Mapping System (DMS), which is a combination of hardware and firmware, is a powerful memory management scheme that allows E-Series computer users to address up to one million words of memory and provides read and/or write protection of each individual 1024 word page. Four independent memory maps are provided, one for the system, one for the user, and two Port Controller maps for direct memory access operations. Control of the DMS is implemented through the use of 38 instructions. #### 1-7. INPUT/OUTPUT SYSTEM The input/output system for E-Series computers features a multilevel vectored priority interrupt structure. There are 60 distinct interrupt levels, each of which has a unique priority assignment. Any I/O device can be selectively enabled or disabled, or the entire interrupt system (except power fail and parity error interrupts) can be enabled or disabled under program control. Data transfer between the computer and I/O devices may take place under program control, Dual Channel Port Controller (DCPC) control, or under microprogram control. The DCPC provides two direct links between memory and I/O devices and is program assignable to any two devices. DCPC transfers occur on an I/O cycle-stealing basis not subject to the I/O priority interrupt structure. The total bandwidth through both DCPC channels is 1.0 million words per second (input); see Direct Memory Access specifications in table 1-1 for the output transfer rates and the DCPC latency times. For applications where higher transfer rates are desirable, E-Series computers have a special microprogrammed I/O capability that will allow transfer rates of up to 1.59 million words per second. This capability can be attained by making simple modifications to the interface hardware and by writing a block I/O control microprogram. The HP 2109A Computer has nine I/O channels in the mainframe; the HP 2113A Computer has fourteen. The number of available channels may be increased by adding one or two HP 12979A I/O Extenders, providing sixteen channels each. All I/O channels are fully powered, buffered, and bidirectional. Because of the modular design of the E-Series computers, mainframe memory capacity is completely independent of I/O capacity so that either memory or I/O modules may be added without taking valuable mainframe space from the other. A full line of I/O interface controllers is available with E-Series computers for interfacing to any of the broad line of HP manufactured peripherals or to specialized devices. #### 1-8. SOFTWARE The E-Series computers are fully program compatible with earlier Hewlett-Packard computers so that the user may take advantage of *many* man-years of software development. A wide range of operating system software is available. The Real-Time Executive (RTE) systems are multiprogramming systems that permit priority scheduling of several real-time programs while concurrent background processing takes place. RTE software contains all the tools needed for dynamic control of real-time events and has an efficient file management capability for data processing applications. The most powerful version, RTE-III, supports up to 304K words of memory managed by the Dynamic Mapping System. Languages supported by Hewlett-Packard operating systems include four high-level compilers: HP FORTRAN; HP FORTRAN IV; HP ALGOL; and HP BASIC; plus an extended, efficient assembler that is callable by FORTRAN and ALGOL. Utility software includes a debugging routine, an editor, and an extensive library of commonly used computational routines. E-Series computer users may also take advantage of a wide variety of thoroughly tested and documented programs that have been contributed to the Hewlett-Packard User Library. 21MXE System Features #### 1-9. SPECIFICATIONS Table 1-1 lists the specifications for the HP 2109A and HP 2113A Computers and the HP 2102B and HP 2102E Memory Systems. Both computers have been product accepted by the Underwriters' Laboratories (UL) and the Canadian Standards Association (CSA). #### 1-10. SYSTEM EXPANSION AND EN-HANCEMENT Table 1-2 lists the options and accessories available to expand or enhance the computer system. Table 1-1. Specifications | CENTRAL PROCESSOR | | |-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address Space: | 2,048 words (direct addressing) | | | 32,768 words (indirect addressing) | | | 1,048,576 words with Dynamic Mapping System (optional) | | Word Size: | 16 bits | | Instruction Set: | 128 standard instructions | | Memory Reference: | 14 | | Register Reference | 39 | | Input/Output: | 7 | | Extended Arithmetic: | 10 | | Index | 32 | | Bit, Byte, Word Manipulation: | 10 | | Floating Point: | Capara Anna Capara Capa | | Registers: | 10 | | Accumulators: | Two (A and B), 16 bits each. Explicitly addressable, also addressable | | Accumulators, | as memory locations. | | Index: | Two (X and Y), 16 bits each | | Memory Control: | Two (T and P), 16 bits each; one (M), 15 bits. | | Supplementary: | Two (Overflow and Extend), one bit each | | Display: | One, 16 bits | | CONTROL PROCESSOR | | | Address Space: | 16,384 words (64 modules of 256 words each) | | Word Size: | 24 bits | | Word Formats: | Four | | Word Fields: | <b>Eive</b> | | Instruction Execution Time: | Variable: 175 nS or 280 nS | | Micro-Orders (microinstructions): | 211 | | Operations | 15 | | Special: | 나는 그는 그리트 그림을 들는 하고 있는 경험을 모임한 경험을 모으면 하면서 들어가 한 아무리에서 되어 하는 그는 아이들이 아니는 아이들이 그는 것이 하는 그는 아이들로 함께 살고 없었습니다. 그런 | | ALU and Conditional: | 68 | | Store | 32 | | S-Bus: | 32 | | Reverse Skip Sense | 32 | | NITIAL BINARY LOADERS | ROM resident; capacity of four 64-word programs callable from operator panel. Computer can be configured for forced cold loading from a remote site. | Table 1-1. Specifications (Continued) #### **CONTROL PROCESSOR (Continued)** SELF-TEST Automatic tests of CPU and memory operating condition. Executed on cold power-up and whenever operator panel IBL/TEST switch is pressed. #### INPUT/OUTPUT Interrupt Structure: Multilevel vectored priority interrupt; priority determined by interrupt location. | 1/0 | SYSTEM SIZE | HP 2109A | HP 2113A | |------|-------------------|----------|----------| | Stan | dard I/O Channels | 9 | 14 | | With | One Extender | 25 | 30 | | With | Two Extenders | 41 | 46 | Compatibility: Instruction set and program compatible with HP 21MX M-Series computers (time loop programs excepted). Current Available for Memory, Accessories, and I/O: | SUPPLY<br>VOLTAGE | HP 2109A | HP 2113A | |-------------------|----------|----------| | +5V | 24.8A | 38.8A | | -2V | 5.0A | 10.0A | | +12V | 1.5A | 3.0A | | – 12V | 1.5A | 3.0A | | DC Required: | Model | +5V | -2V | |--------------|------------------------------------|--------------------|-------| | | 12892B Memory protect <sup>3</sup> | 1.25A | .05A | | | 12987B DCPC | 2.4A | .05A | | | 12731A MEM <sup>3</sup> | 3.9A | - | | | 13307A DMS <sup>3</sup> | .78A | _ | | | 13306A FFP | 1.8A | _ | | | 13197A 1k WCS | 2.2A | .01A | | | 12990A Memory extender | 0 | - | | | 12992 Loader ROMS (each) | .15A | _ | | | 12979A I/O extender | 2.0A | 1.35A | | | 2102B Memory controller | 1.2A | - | | | 2102E Memory controller | 2.56A | _ | | | 12741A HP 16k memory | .6A | ~ | | | 12998Å 8k memory | .5A | _ | | | 13187A 16k memory module | .6A | - | | | 13047A 2k UCS | 7.39A <sup>1</sup> | _ | | | 13304A FAB | 1.8A <sup>2</sup> | _ | <sup>&</sup>lt;sup>1</sup> Fully loaded; refer to individual data sheets for partially loaded boards. <sup>&</sup>lt;sup>2</sup> Due to power saver circuit, this is the maximum current regardless of amount of microcode loaded on the board. <sup>3</sup> Part of HP 13305A DMS. Table 1-1. Specifications (Continued) **DIRECT MEMORY ACCESS** Available only with DCPC accessory. **Number of Channels:** Two Word Size: 16 bits Maximum Transfer Block Size: 32,768 words I/O Assignable: Assignable to any two I/O channels; all logic necessary to facilitate bidirectional direct memory transfer to and from I/O is contained on DCPC (controller). Transfer Rate: | | HP 2102B | HP 2102E | |--------|-------------------------------------------------------------|---------------------------------------------------------------| | Input | 1.0 Mwords/sec | 1.14 Mwords/sec | | Output | 919 kwords/sec<br>without DMS<br>836 kwords/sec<br>with DMS | 1.14 Mwords/sec<br>without DMS<br>1.05 Mwords/sec<br>with DMS | DCPC Latency (Channel 1): Latency is defined as the time interval between the generation of a Service Request (SRQ) signal by an I/O device through the initiation of a DCPC channel 1 cycle to the completion of the I/O data transfer to or from the I/O interface PCA. | | HP 2102B | HP 2102E | | |-------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|--| | Input Latency Time<br>(worst case) | 3.15 usec without DMS 3.26 usec with DMS 4.01 usec User Written Microcode | 2.35 usec without DMS 2.28 usec with DMS 3.05 usec User Written Microcode | | | Output Latency Time<br>(worst case) | 3.95 usec without DMS 4.10 usec with DMS 4.94 usec User Written Microcode | 2.84 usec without DMS 2.98 usec with DMS 3.68 usec User Written Microcode | | #### PHYSICAL CHARACTERISTICS Width: 16-3/4 inches (42.55 cm) behind rack mount; 19 inches (48.26 cm) front panel width on sides. Depth: 23-1/2 inches (59.69 cm); 23 inches (58.42 cm) behind rackmounting ears. | | HP 2109A | HP 2113A | |--------|-------------------------|--------------------------| | Height | 8-3/4 in.<br>(22.23 cm) | 12-1/2 in.<br>(31.69 cm) | | Weight | 45 pounds<br>(20.41 kg) | 65 pounds<br>(29.48 kg) | #### **ELECTRICAL CHARACTERISTICS** Line Voltage: 110/220V ac (±20%) Line Frequency: 47.5 to 66 Hz | | HP 2109A | HP 2113A | |--------------|----------|----------| | Power (max.) | 525W | 800W | Table 1-1. Specifications (Continued) #### **ELECTRICAL CHARACTERISTICS (Continued)** Power Supply: Sustains computer over a line loss of 40 mS when operating at normal 110/220V ac Input Line Overvoltage Protection: Input crowbar in series with line fuse for line voltages >40% above normal. Output Protection: All voltages protected from overvoltage and overcurrent conditions. Output Voltage Regulation: $\pm 5\%$ (except -2V is $\pm 10\%$ and $\pm 28V$ is unregulated). Thermal Sensing: Monitors internal temperature and automatically shuts down when computer temperature exceeds specified level. **ENVIRONMENTAL LIMITATIONS** Operating Temperature: 32° to 131°F (0° to 55°C) Storage Temperature: -40° to 167°F (-40° to 75°C) Relative Humidity: 20% to 95% at 104°F (40°C), no condensation. Ventilation: Intake, left-hand side; exhaust, right-hand side. Heat Dissipation (Btu/hour (max.)) HP 2109A HP 2113A 2730 Altitude: Transportable to 40,000 feet (12.17 km) for nonoperating condition and to 15,000 feet (4.57 km) for operating condition. Vibration and Shock: Type tested to qualify for normal shipping and handling shock and vibration. Vibration: 0.012 inch (0.3 mm) p-p, 10-55 Hz, 3-axis. Shock: 30g, 11 mS, 1/2 sine wave, 3-axis. Contact factory for review of any application regarding operation under continuous vibration. **MEMORY SYSTEMS** Type: 4K N-channel MOS semiconductor RAM Word Size: 16 bits plus parity bit Advisor WA Configuration: Controller plus multiple plug-in memory modules. Available in 8,192 word and 16,384 word modules. Page Size: 1,024 words Address Space: 32,768 words; 1,048,576 words with DMS accessory. System Cycle Time: Standard Memory: 560 ±35 nsec without DMS; 630 ±35 nsec with DMS. High Performance Memory: 350 ±35 nsec without DMS; 420 ±35 nsec with DMS. Table 1-1. Specifications (Continued) **MEMORY SYSTEM (Continued)** Volatility Protection: Line standby mode and sustaining power for line loss of 160 mS are standard. Power fail recovery system is optional. Parity Error Detection: Monitors all words read from memory. Switch selectable for either halt or ignore interrupt error when detected. With memory protect or DMS accessory, interrupt on parity error occurs. **POWER FAIL** Interrupt Priority: Highest priority interrupt. Power Failure: Detects power failure and generates an interrupt to user-written power- failure routine. A minimum of 500 $\mu$ S is available for the routine. Power Fail Recovery System: Available as an accessory. Power Restart: Detects resumption of power and generates an interrupt to user-written automatic restart program which has been protected in memory by the sustaining battery. Power Control and Charge Unit: Monitors battery charge status and provides trickle charge. Sustaining Battery: Type: 12V nickel cadmium Charging rate: 300 mA Capacity: 3.5 ampere-hours; will sustain four memory modules 2 hours (HP 2109A) or eight memory modules 2 hours (HP 2113A). See graph below for other memory configurations. Table 1-2. Options and Accessories | DESCRIPTION | OPTION NO. | ACCESSORY NO. | |---------------------------------------------------------------|-----------------------------------------|---------------| | HP 2109A and 2113A Computers | | | | 230V Operation | -015 | | | Power Fail Recovery System (HP 2105A, HP 2108A, HP 2109A) | _ | 12944A | | Power Fail Recovery System (HP 2112A, HP 2113A, HP 12990A) | _ | 12991A | | Memory Protect | _ | 12892B | | Dual Channel Port Controller (DCPC) | | 12897B | | E-Series Firmware Accessory Board | | 13304A | | E-Series Dynamic Mapping System <sup>1,2</sup> | | 13305A | | E-Series Fast FORTRAN Processor | | 13306A | | 1K Writable Control Store | _ | 13197A | | Slide Mounting Kit (HP 2108A, HP 2109A, HP 12979A, HP 12990A) | | 12903B | | Slide Mounting Kit (HP 2112A, HP 2113A) | _ | | | Dynamic Mapping Instructions | | 12903C | | Memory Expansion Module | | 13307A | | Loader ROM for 2644A and 2645A | | 12731A | | Loader ROM for 7970B/E | - · · · · · · · · · · · · · · · · · · · | 12992C | | 2K User Control Store | | 12992D | | ZN OSEI COMO Store | | 13047A | | HP 2102 MOS MEMORY Systems | | | | HP 2102B Standard Performance Memory | _ | 2102B | | 8K Memory Module | _ | 12998A | | 16K Memory Module | | 13187A | | HP 2102E High Performance Memory | _ | 2102E | | 16K Memory Module | <u> </u> | 12741A | | Input/Output Extender | | 12979A | | 230V Operation | - 015 | | | DCPC for I/O Extender | -013 | 12898A | | DOLO OF TO EXCUDE | | 12090A | | <u> </u> | | 120004 | | Memory Extender | | 12990A | | 230V Operation | 015 | • | | 230 Y Operation | - 015 | . — | <sup>&</sup>lt;sup>1</sup>Includes Memory Protect. <sup>&</sup>lt;sup>2</sup>Requires E-Series Firmware Accessory Board. # **OPERATING PROCEDURES** omputer Museum This section describes the hardware registers accessible to the programmer and the functions of the various operating controls and indicators. Also included are basic operating examples such as a cold start procedure to load a program via a punched-tape reader, manually loading a short program via the operator panel, and running a program after it has been loaded into memory. #### 2-1. HARDWARE REGISTERS The computer has eight 16-bit working registers which can be selected for display and modification by operator panel controls; two 1-bit registers; and one 16-bit display register. The functions of these registers are described in following paragraphs. #### 2-2. A-REGISTER The A-register is a 16-bit accumulator that holds the results of arithmetic and logical operations performed by programmed instructions. This register can be addressed directly by any memory reference instruction as location 000000 (octal), thus permitting interrelated operations with the B-register (e.g., "add B to A," "compare B with A," etc.) using a single-word instruction. #### 2-3. B-REGISTER The B-register is a second 16-bit accumulator, which can hold the results of arithmetic and logic operations completely independent of the A-register. The B-register can be addressed directly by any memory reference instruction as location 000001 (octal) for interrelated operations with the A-register. #### 2-4. M-REGISTER The M-register holds the address of the memory cell currently being read from or written into by the CPU. #### 2-5. T-REGISTER All data transferred into or out of memory is routed through the T-register. When displayed, the T-register indicates the contents of the memory location currently pointed to by the M-register. The A- or B-register contents are displayed if the M-register contents are 000000 or 000001, respectively. #### 2-6. P-REGISTER The P-register holds the address of the next instruction to be fetched from memory. #### 2-7. S-REGISTER The S-register is a 16-bit utility register. The S-register can be addressed as an input/output device (select code 01) and, in the run mode, it is displayed in the operator panel display register. Thus, the S-register may serve as a communication link between the computer and operator. #### 2-8. EXTEND REGISTER The one-bit extend register is used by rotate instructions to link the A- and B-registers or to indicate a carry from the most-significant bit (bit 15) of the A- or B-register by an add instruction or an increment instruction. This is of significance primarily for multiple-precision arithmetic operations. If already set (logic 1), the extend bit cannot be cleared by a carry. However, the extend bit can be selectively set, cleared, complemented, or tested by programmed instructions. When the operator panel EXTEND indicator is lighted, the extend bit is set. This register can also be accessed from the operator panel by entering the special register display mode described under paragraph 2-23. #### 2-9. OVERFLOW REGISTER The one-bit overflow register is used to indicate that an add instruction, divide instruction, or an increment instruction referencing the A- or B-register has caused (or will cause) the accumulators to exceed the maximum positive or negative number that can be contained in these registers. The overflow bit can be selectively set, cleared, or tested by programmed instructions. The operator panel OVERFLOW indicator will remain lighted until the overflow is cleared. This register can also be accessed from the operator panel by entering the special register display mode described under paragraph 2-23. #### 2-10. DISPLAY REGISTER The display register, which is included on the operator panel, provides a means of displaying and/or modifying the contents of the eight 16-bit working registers and the special registers when the computer is in the halt mode. An illuminating indicator is located directly above each of the 16-bit switches; a lighted indicator denotes a logic 1 and an unlighted indicator denotes a logic 0. When the computer is in the run mode, the contents of the S-register are displayed automatically. #### 2-11. X- AND Y-REGISTERS These two 16-bit registers, designated X and Y, are accessed through the use of 30 index register instructions and 2 jump instructions described under paragraphs 3-24 and 3-25, respectively. These registers can also be accessed from the operator panel by entering the special register display mode described under paragraph 2-23. #### 2-12. OPERATOR PANEL The location and function of the various controls and indicators mounted on the operator panel are illustrated in figure 2-1 and described in table 2-1. All operator panel controls (except the key-operated switch) are two-position, momentary-contact rocker switches; the status of the computer is displayed by light-emitting diodes. #### 2-13. REAR PANEL The rear panel and the I/O PCA cage for the HP 2109A and HP 2113A Computers are shown in figures 2-2 and 2-3 and described in tables 2-2 and 2-3, respectively. Figure 2-1. Operator Panel Controls and Indicators **Operating Procedures** Table 2-1. Operator Panel Control and Indicator Functions | | STANDBY/OPERATE/<br>LOCK/R | Four-position, | | | AND DESCRIPTIONS OF THE PARTY O | |---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | abor - The transfer of the same sam | of ac power to<br>controls the a<br>ventilating fan | the mainfact power i | ed switch; does <i>not</i> control the application ame. (The ~LINE switch on the rear property to the computer power supply | oanel | | | | charge. CPU | and I/O po | ents are sustained and the battery in<br>wer are off; I/O interfaces may be instage. Key is removable. | | | | | OPERATE. Po removable. | wer is sup | plied to the entire mainframe. Key is | s not | | | | | enabled (w | HALT switches are disabled; all cithin the constraints of the run/halt mo | | | | | failure, the aut<br>running withou<br>POWER FAIL i | omatic rest<br>ut operator<br>ndicator to | becomes invalid due to a prolonged poration of power will preclude the CPU intervention. (This condition will cause be lighted. Rotating this switch momen ration. Key is not removable. | from<br>e the | | 2 | RUN/HALT | RUN. Starts CPU and lights the RUN indicator. All operator panel functions are disabled except Display Register, CLEAR DISPLAY, and HALT. Pressing RUN automatically causes the S-register contents to be displayed, and no other register can be selected during the run mode; thus, the Display Register effectively becomes the S-register, which may be addressed as select code 01 by the program. | | | | | | | HALT. Halts the computer at the end of the current instructi turns off the RUN indicator. All other operator panel c become enabled. The T-register is selected automatically for computer at the end of the current instruction. | | | | | 3 | PRESET-IBL/TEST | PRESET. Disables the interrupt system and clears the parity indicator and overflow bit (if set). From I/O channel 06 up, clears control flip-flops and sets flags. Pressing and holding PRESET upon the restoration of power will force a ARS condition (see paragraph 6-1). | | | | | | | paper tape lo<br>loader ROM's<br>and the autom | ader ROM,<br>to be writte<br>atic execut<br>graph 2-31 | TEST. Causes the contents of the stan standard disc loader ROM, or the opten into the uppermost 64 memory location of self-test firmware diagnostics 1 at .) Bits 15 and 14 of the S-register selectfollows: | tional<br>ations<br>and 2. | | | | | BITS | | | | | | 15 | 14 | LOADER SELECTED | | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | on the state of th | 0 | Standard paper tape loader ROM | | | | | The state of s | 0 | Standard disc loader ROM | | | | | 0 | 1 | Option loader ROM 0 | | | | | 1 | 1 | Option loader ROM 1 | | Table 2-1. Operator Panel Control and Indicator Functions (Continued) | FIG. 2-1,<br>INDEX NO. | NAME | FUNCTION | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | INTERRUPT SYSTEM | Indicates the status of the interrupt system. When lighted, the interrupt system is enabled (Flag set); when turned off, the interrupt system is disabled (Flag clear). | | 5 | PARITY | Lights when a parity error occurs as a result of reading from memory. In the halt mode, the light can be turned off by pressing the PRESET switch. With the memory protect or DMS option installed and the parity error interrupt enabled, the indicator is turned off automatically by a parity error interrupt and is therefore not ordinarily lighted long enough to be visible. | | <b>6</b><br>State and Earth | POWER FAIL | If the power fail/automatic restart feature is enabled (i.e., internal ARS/ARS switch is set to ARS position as described in Section V) the indicator will light when power is restored. This light can be turned off by pressing the PRESET switch in the halt mode. | | | Register Select ▶ | In the halt mode, this switch allows any one of the working registers or special registers (A, B, M, T, P, S, x, y, m, t, f, or s) to be selected for display and/or modification. Pressing the left half (◄) of the switch moves the "dot" indicator left; pressing the right half (▶) of the switch moves the "dot" indicator right. The register currently selected is indicated by the appropriate indicator light. | | | | Note: During standard register display mode, the "dot" indicator is the lighted indicator; i.e., the selected register (A, B, M, T, P, or S) is indicated by the lighted indicator and the remaining indicators are not lighted. During special register display mode, the "dot" indicator is the unlighted indicator; i.e., the selected register (x, y, m, t, f, or s) is indicated by the indicator not lighted and the remaining indicators are lighted. | | | | After a programmed or manual halt, the T-register is selected automatically for display. In this case, the T-register holds the contents of the last accessed memory cell. In the case of a programmed halt, the halt instruction will be displayed. | | 8 | INSTR STEP/CLEAR<br>DISPLAY | INSTR STEP. Pressing and releasing this switch while in the halt mode advances the program to the next instruction. If the T-register indicator lights when the switch is released, infinite indirect addressing is indicated. Actuating this switch does not actually place the computer in the run mode. (See note for additional information.) | | | | CLEAR DISPLAY. In the run or halt mode, clears the Display Register; i.e., contents become 000000. | | 9<br>9 | INC M/m-DEC M/m | INC M. In the halt mode, increments the M-register contents during standard display mode and the m-register contents during special display mode. (Refer to paragraph 2-25.) | | in the control of | Server of the end of the control of the end | DEC M. In the halt mode, decrements the M-register contents during standard display mode and the m-register contents during the special display mode. (Refer to paragraph 2-25.) | | | | Note: Incrementing and decrementing occur even when the Moor m-register is not displayed. | | | | | Table 2-1. Operator Panel Control and Indicator Functions (Continued) | FIG. 2-1,<br>INDEX NO. | NAME | FUNCTION FUNCTION | |-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10 | STORE/MODE | STORE. In the halt and standard display modes, stores the contents of the Display Register into the selected working register (A, B, M, T, P, or S). If the Register Select "dot" is pointing to T and STORE is pressed, the contents of the Display Register will be loaded into memory cell m, the M-register will be incremented automatically to m + 1, and the Display Register will not be updated. This latter feature allows the same data to be stored in consecutive memory locations (e.g., halts in the trap cells, same word into a buffer, etc.). If the Register Select "dot" is pointing to any register other than T, only that one register will be updated when STORE is pressed. (Refer to paragraph 2-23 STORE functions during special register display mode.) | | e de 1884 e 1911 — en personales son de sucreta | | MODE. Selects either standard or special register display mode. If pressed when operating in standard register display mode, switches operator panel to special register display mode. If pressed when operating in special register display mode, switches operator panel back to standard register display mode. | | | Display Register SCIAN CONTROL OF THE PROPERTY PROPER | In the halt mode, displays the contents of the register currently pointed to by the Register Select "dot;" only the S-register is displayed during the run mode. A logic 1 is signified when the displayed bit indicator is lighted; a logic 0 is signified when the displayed bit indicator is not lighted. Pressing the upper half of the switch sets that bit to a logic 1; pressing the lower half of the switch sets that bit to a logic 0. The Display Register is cleared to all zeros when the CLEAR DISPLAY switch is pressed. | | 12 | EXTEND | In both the run and halt modes, continuously displays the content of the extend register. When lighted, the extend bit is set (logic 1). | | 13 | OVERFLOW | In both the run and halt modes, continuously displays the content of overflow register. When lighted, the overflow bit is set (logic 1). | #### NOTE When pressing the INSTR STEP switch and performing a jump instruction while monitoring the T-, P-, or M-register, the following will be noted: - a. The P-register will go to the operand target address. - b. The M-register will go to the operand target minus one (M=P-1). - c. The T-register will display the memory location prior to the current instruction to be executed. Pressing the INSTR STEP switch will not cause an instruction step if there is a pending interrupt and the interrupt system is on; pressing PRESET or turning the interrupt system off will re-enable the INSTR STEP function. Operating Procedures 21MXE Figure 2-2. HP 2109A Rear Panel and I/O PCA Cage Table 2-2. HP 2109A Rear Panel Features | FIG. 2-2,<br>INDEX NO. | NAME | FUNCTION | | |------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | ~LINE connector | Three-input power connector; provides means of connecting ac line power to computer. | | | 2 | ~LINE ON/OFF | Two-position toggle switch; controls application of ac line power to computer power supply and ventilating fans. | | | 3 | Fuse F1 | Provides protection against ac line power overload. Current and voltage rating are as follows: | | | | | LINE VOLTAGE REQUIRED FUSE RATING | | | | | 110V 6A, 250V, normal blow<br>220V 4A, 250V, normal blow | | | A | PWR CONT | Nine-pin connector; provides means of connecting an external memory extender, I/O extender, or satellite computer to main computer. When connected, these units are controlled by the key-operated switch (1, figure 2-1) on main computer. A power failure or error condition in any one of the interconnected units will cause all units to cease operation until cause of power failure or error condition has been corrected. | | | 5 | BAT. INPUT | Two pin connector; provides means of connecting optional battery to memory sustaining circuits. | | | 6 | BATTERY ON/OFF | Two-position slide switch; controls application of current from optional battery to memory sustaining circuits. | | | 7 | Fuse F2 | A 5A, 250V, normal-blow fuse; protects memory sustaining circuits. Also protects optional battery while being charged. | | Figure 2-3. HP 2113A Rear Panel and I/O PCA Cage Table 2-3. HP 2113A Rear Panel Features | FIG. 2-3,<br>INDEX NO. | NAME | FUNCTION | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>Liver to the section | ~LINE connector | Three-input power connector; provides means of connecting ac line power to computer. | | esmil i na <b>2</b> ng na san<br>Managan na ang managa | ~LINE ON/OFF | Two-position circuit breaker. Controls application of ac line power to computer power supply and ventilating fans; provides protection against ac line power overload. | | | F1 and F2 | F1 is a 1A, 250V normal-blow fuse; protects part of memory sustaining circuits. F2 is a 3A, 250V, normal-blow fuse; protects part of memory sustaining circuits. Also protects optional battery while being charged. | | 4 | BATTERY ON/OFF | Two-position slide switch; controls application of current from optional battery to memory sustaining circuits. | | e districting of the second | PWR CONT IN and PWR<br>CONT OUT | Two nine-pin connectors; provides means of connecting an external memory extender, I/O extender, or satellite computer (in any combination of two units) to main computer. When connected, these units are controlled by the key-operated switch (1, figure 2-1) on main computer. A power failure or error condition in any one of the interconnected units will cause all units to cease operation until the cause of power failure or error condition has been corrected. | | 6 | BAT. INPUT | Two two-pin connectors; provides means of connecting optional batteries to memory sustaining circuits. | #### 2-14. INTERNAL SWITCHES Two toggle switches are mounted on the rear of the central processor unit (CPU) printed-circuit assembly (PCA). The setting of the ARS/ARS switch determines the action that the computer will take in the event of a primary power failure and the setting of the HLT /INT-IGNORE switch determines the action to be taken in the event of a parity error or memory protect violation. Programming considerations concerning these switches are given in Section VI. Also mounted on the central processor unit PCA are the RPL configuration switches. These switches as used as follows: - a. To enable RPL operation. - b. Select one of four loader ROM's. - c. Patch in the select code of loading device. Details concerning the configuration of these switches are given in the HP 21MX E-Series Computer Installation and Service Manual, part no. 02109-90002. #### 2-15. OPERATING PROCEDURES The following procedures describe a cold power-up; how to load programs manually; how to load programs using punched tape, disc, magnetic tape, or other such media; how to verify and run programs; and how to enter the special register display mode. #### 2-16. COLD POWER-UP Perform the cold power-up as follows: - a. Set key-operated switch to STANDBY. If computer is equipped with an optional power fail recovery system, set BATTERY switch to OFF. - b. Set ~LINE switch to OFF. Wait approximately one second for HP 2109A or six seconds for HP 2113A and set ~LINE switch to ON. - c. Set BATTERY switch to ON. Rotate key-operated switch first to R (reset), then to STANDBY, and finally to OPERATE. - d. The diagnostic will begin execution and the Display Register can be observed incrementing as each 32K block of memory is tested. When a cold power-up is performed, the computer automatically executes a firmware diagnostic that checks most of the computer registers and functions and all physical memory. (Refer to paragraphs 2-31 through 2-36 for additional firmware self-test diagnostic information.) This diagnostic executes in approximately 10 seconds or less depending on memory size and clears memory upon completion. Upon successful completion, the T-register will automatically be selected for display. If a computer or memory failure is detected, the display register and all six working register indicators are lighted. In this case, refer to the HP 21MX E-Series Computer Installation and Service Manual, part no. 02109-90002 for further analysis. #### 2-17. LOADING PROGRAMS MANUALLY Short programs can be loaded manually from the operator panel as follows: - a. Press MODE switch if required to obtain standard register display mode and press left half (◄) or right half (▶) of Register Select switch to select M-register. - Press CLEAR DISPLAY and set Display Register to starting address of program. - c. Press STORE. Select T-register and change contents of Display Register to binary code of first instruction to be loaded; press STORE. - d. Enter next instruction in Display Register and press STORE. (Pressing STORE with T-register selected automatically increments M-register.) - e. Repeat step d until entire program has been loaded. ## 2-18. LOADING PROGRAMS FROM PAPER TAPE READER Use the following steps to first load the contents of the standard paper tape loader ROM into memory and then load your program by means of a tape reader. Proceed as follows: - a. Press MODE switch if required to obtain standard register display mode and press left half (◄) or right half (▶) of Register Select switch to select S-register. - Press CLEAR DISPLAY and set bits 6 through 11 to display octal select code of tape reader. - c. Press STORE, PRESET, and then press IBL/TEST. The paper tape loader is now loaded into the uppermost 64 locations of memory and the select code of the tape reader is patched according to the contents of the S-register. The P-register contains the address of the first instruction of the loader. (Starting addresses versus memory size are listed in table 2-4.) - d. A successful load is indicated if the OVERFLOW light remains off. An unsuccessful load is indicated if the OVERFLOW light is on; this will occur if the select code programmed in step b was less than 10 (octal) or if a memory hardware fault is detected. 21MXE Operating Procedures e. Turn on tape reader and prepare it for reading. Press PRESET and then press RUN. The program will now be read into memory and the computer will halt with the T-register selected automatically. A successful load is indicated if the Display Register contents are 102077 (octal). If the halt code displayed is not 102077 (octal), one of two possible error condition halt codes will be displayed. If the halt code displayed is 102055 (octal), an address error is indicated; check to ensure that the proper tape was used or that the tape was not installed backwards. If the halt code displayed is 102011 (octal), a checksum error is indicated; check for a possible defective or dirty tape or tape reader. Table 2-4. Starting Address Vs Memory Size | MEMORY<br>SIZE | STARTING ADDRESS (in octal) OF THE PAPER TAPE LOADER | | |----------------|------------------------------------------------------|--| | <b>BK</b> | 017700 | | | 16K | 037700 | | | 24K | 057700 | | | 32K | 077700 | | #### 2-19. LOADING PROGRAMS FROM DISC DRIVE Use the following steps to first load the contents of the standard disc loader ROM into memory and then load your program by means of an HP 7900A, HP 7901A, or HP 7905A Disc Drive. Proceed as follows: - a. Press MODE switch if required to obtain standard register display mode and press left half (◀) or right half (▶) of Register Select switch to select S-register. - b. Press CLEAR DISPLAY and set bit 15 to logic 1 to select standard disc loader ROM. - Set bits 13 and 12 as shown below to select appropriate disc drive. | Addition ABITS | er a selective i Silvania amerikanili separat | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | 13 12 | DISC SELECTED | | | | | The state of s | HP 7900A or HP 7901A | | 0 1 | HP 7905A | - d. Set bits 11 through 6 to octal select code of disc drive interface PCA. - e. Set bits 2 through 0 as shown below to select corresponding disc subchannel. | BITS<br>2 1 0 | DISC LOADING DEVICE | |---------------|---------------------------------------| | 0.0.0 | HP 7900A (fixed disc) | | 0 0 1 | HP 7900A (removable disc) or HP 7901A | | 0 0 0 | HP 7905A (top of removable disc) | | 0 0 1 | HP 7905A (bottom of removable disc) | | 0.1.0 | HP 7905A (fixed disc) | - f. Press STORE, PRESET, and then IBL/TEST. The disc loader is now loaded into the uppermost 64 locations of memory and the select code of the disc drive is patched according to the contents of the S-register. The P-register contains the address of the first instruction of the loader. (Starting addresses versus memory size are listed in table 2-4.) - g. A successful load is indicated if the OVERFLOW light remains off. An unsuccessful load is indicated if the OVERFLOW light is on; this will occur if the select code programmed in step d was less than 10 (octal) or if a memory hardware fault is detected. - h. Turn on and prepare disc drive for operation and then press RUN. The program will now be read into memory and the computer will halt with the T-register selected automatically. A successful load is indicated if the Display Register contents are 102077 (octal). ### 2-20. LOADING PROGRAMS FROM OTHER LOADING DEVICES The following procedure is used when loading programs from a disc, magnetic tape, or other such media. The contents of the optional loader ROM, associated with the loading device, must be loaded before the program can be loaded. Locations have been provided within the computer to accommodate two optional loaders; i.e., optional loader ROM 0 and 1. Each of these loaders is used to control the loading of programs from a particular type of loading device. It is assumed that the optional loader ROM, associated with the loading device to be used, is installed in the computer and that its location is known. Use the following steps to first load the contents of one of the optional loader ROM's into memory and then load your program by means of a disc, magnetic tape, or other such media. The program must be in binary form and must contain absolute addresses. Assuming that the loading device has been prepared for reading, proceed as follows: - a. Press MODE switch if required to obtain standard register display mode and press left half (◄) or right half (▶) of Register Select switch to select S-register. - b. Press CLEAR DISPLAY and set bit 6 through 11 to display octal select code of loading device. - c. Set bits 15 and 14 as listed in table 2-5 to select the optional loader corresponding to your loading device. - d. Set bits 0 through 5, 12, and 13 as outlined in the instructions provided with optional loader. - e. Press STORE and then press IBL/TEST. The optional loader is now loaded into the uppermost 64 locations of memory and the select code of the loading device is patched according to the contents of the S-register. The P-register is now pointing to the address of the first instruction of the optional loader. (Starting addresses versus memory size are listed in table 2-4.) - f. A successful load is indicated if the OVERFLOW light remains off. An unsuccessful load is indicated if the OVERFLOW light is on; this will occur if the select code programmed in step b was less than 10 (octal) or if a memory hardware fault is detected. - g. Verify that loading device is prepared for reading. Press PRESET and then press RUN. The program will now be read into memory and the computer will halt with the T-register selected automatically. A successful program load is typically indicated if the contents of the Display Register are 102077 (octal). Refer to the instructions included with each optional loader for the specific halt code used. Table 2-5. Optional Loader Selection | 15 14 | LOADER<br>SELECTED | |-----------------------|-----------------------| | | Optional Loader ROM 0 | | ira tallatratar parti | Optional Loader ROM 1 | #### 2-21. VERIFYING PROGRAMS If desired, programs may be verified after loading by the following procedure: a. Press MODE switch if required to obtain standard register display mode and press left half (◄) or right half (►) of Register Select switch to select M-register. - b. Press CLEAR DISPLAY and set Display Register to the binary starting address of the program. - c. Press STORE. Select T-register and verify that the binary instruction code is displayed as desired for the first program instruction. - d. Press INC M to increment the contents of the M-register by one and verify that the binary instruction code displayed is as desired for next programmed instruction. - Repeat step d until all programmed instructions have been verified. Pressing DEC M permits the previous programmed instruction to be verified. #### 2-22. RUNNING PROGRAMS To run a program after it has been loaded, proceed as follows: - a. Press MODE switch if required to obtain standard register display mode and press left half (◀) or right half (◀) of Register Select switch to select P-register. - Press CLEAR DISPLAY and set Display Register to starting address of program. - c. Press STORE, PRESET, and RUN. The RUN indicator will remain lighted as long as the program is running. If the key-operated switch is set to OPERATE, all operator panel controls except the Display Register, CLEAR DISPLAY, and HALT switches are disabled. During the run mode, the contents of the S-register are automatically selected for display in the Display Register and none of the other registers can be selected. Therefore, the Display Register effectively becomes the S-register and it can be directly addressed as I/O select code 01 (octal) by the program. If the key-operated switch is set to LOCK, the functions of the RUN/HALT switch are disabled. All other operator panel controls are enabled within the constraints of the run or halt mode of operation. ### 2-23. SPECIAL REGISTER DISPLAY MODE The special register display mode provides the capability of displaying and/or modifying the contents of the X- and Y-registers (paragraph 2-11), the optional Dynamic Mapping System (DMS) registers, the extend and overflow registers (paragraphs 2-8 and 2-9), the central interrupt register (CIR), and the interrupt system. To enter the special register display mode, use the MODE switch as discussed in table 2-1 and press the left half ( $\blacktriangleleft$ ) or right half ( $\blacktriangleright$ ) of the Register Select switch as required to move the unlighted "dot" indicator above the register (x, y, m, t, f, or s) to be displayed. It should be noted that the operator panel is switched back to the standard register display mode whenever the RUN switch is pressed. Each of the special register displays is discussed in the following paragraphs. 2-24. X- AND Y- (x and y) REGISTERS. When either of these registers is selected, the current contents of the register is indicated by the Display Register as discussed in paragraph 2-10 and table 2-1. If the STORE switch is pressed while either x or y is selected, the contents of the display are loaded into the selected register. The display is not altered. 2-25. DMS MAP (m, t, and f) REGISTERS. The m-register is a 7-bit register that holds the current memory map number (0 - 1778) being read from or written into by the CPU. When selected for display, bits 6 - 0 indicate the memory map number on the Display Register. The memory map number can be incremented or decremented with the INC M/m - DEC M/m switch as discussed in table 2-1. Any memory map can be quickly accessed when the m-register is selected for display by entering the memory map number on the Display Register and pressing the STORE switch. To read the contents of the selected map number, select the t-register for display. The t-register is a 16-bit register that holds the selected map number contents and the read/write protect bits. When selected for display, bits 9 - 0 on the Display Register indicate the contents of the memory map addressed by the m-register. If bit 15 is set (logic 1), the memory page is read-protected; if bit 14 is set, the memory page is write-protected. Bits 13 - 10 are always zero. If DMS is not installed and this register is selected for display, the display will be all 1's. To change the contents of the addressed memory map, enter the new contents on the Display Register with bit switches 9 - 0 and press the STORE switch. To read- or write-protect the memory map, set the Display Register bit switches 15 or 14 to 1, respectively and press the STORE switch. If the INC M/m - DEC M/m switch is pressed when this register is selected for display, the contents of the next or previous memory map address will be displayed. The f-register is the 16-bit Memory Expansion Module status register and, when selected for display, indicates the address of the base page fence and DMS status as discussed in paragraph 4-2. If DMS is not installed and this register is selected for display, the display will be all 1's. To alter the address of the base page fence, enter the new address on the Display Register bit switches 10 - 0 and press the STORE switch. Status bits 15 - 11 cannot be altered. If Display Register bit switches 15 - 11 are changed from the original display and the STORE switch is pressed, no action takes place and the original contents of the f-register is again displayed. 2-26. STATUS (s) REGISTER. The s-register is a 16-bit status register. When selected for display, bit 15 indicates the status of the overflow register. (Refer to paragraph 2-9.) Bit 14 indicates the status of the extend register. (Refer to paragraph 2-8.) Bit 13 indicates the status of the interrupt system; a logic 1 indicates that the system is enabled. Bits 12 - 6 are always zero. Bits 5 - 0 indicate the current contents of the Central Interrupt Register (CIR) which is the octal select code of the device that last interrupted the computer. When the s-register is displayed, the overflow register bit, extend register bit, and interrupt system can be set as desired with Display Register bit switches 15, 14, and 13 respectively, and then pressing the STORE switch. The contents of CIR cannot be altered. Bit 13 of the s-register will not display the status of the interrupt system correctly and cannot be changed if memory protect is enabled. #### 2-27. SHUTDOWN PROCEDURES One of the following procedures should be used when the computer is shut down during periods of nonoperation. The first procedure should be used when it is necessary to sustain memory contents. The second procedure should be used when it is not necessary to sustain memory contents. - 2-28. SHUTDOWN (MEMORY SUSTAINED). Use the following procedure to shut down the computer when it is necessary to sustain memory during periods of nonoperation: - a. Ensure that ac power is available and that computer ~LINE switch is ON. If computer is housed in a system cabinet, ensure that system power switch is set to provide ac power to rack-mounted units. - b. Set computer key-operated switch to STANDBY. In the standby mode, memory contents are sustained by the internal power supply, a trickle charge is applied to the optional battery, and CPU and I/O power are off. In the event of a power failure, the contents of memory will be lost unless the optional power fail recovery system is installed. In this case, the battery will sustain the contents of memory for a minimum of 2 hours. - 2-29. SHUTDOWN (MEMORY NOT SUSTAINED). Use the following procedure to shut down the computer when it is not necessary to sustain memory during periods of nonoperation: - a. Set key-operated switch to STANDBY. If computer is equipped with optional power fail recovery system, set BATTERY switch to OFF to prevent the battery from discharging. - b. Set computer ~ LINE switch to OFF or, if the computer is housed in a system cabinet, set the system power switch to remove ac power. All contents of memory and internal registers will be lost. When operation is to be resumed, the cold power-up procedure and program loading must be repeated. Operating Procedures 21MXE #### 2-30. REMOTE PROGRAM LOADING The Remote Program Load (RPL) capability is a combination of hardware and firmware that allows loading and initiating execution of program to be controlled from a remote site. The hardware consists of a set of eight switches called the configuration switches mounted on the CPU board and typically, an appropriate communications interface board. (The HP 12966A or HP 12968A must be used if an HP standard interface is utilized.) The configuration switches are used to program the information normally entered into the S-register from the operator panel for Initial Binary Loader (IBL) operations. (Refer to the HP 21MX E-Series Computer Installation and Service manual, part no. 02109-90002 for switch programming details.) The communications interface board provides the link through which remote devices initiate RPL operations. The firmware is a micro-routine that automatically reads the information from the configuration switches, calls the IBL routine specified by the configuration switches, and issues the RUN command to the computer. The routine can be called by a command from a remote computer site, a console device, or automatically whenever line power is applied to the computer. By programming the configuration switches, the computer is informed whether or not the RPL capability is to be used, which of the four non-volatile loader ROM programs is to be used, and the I/O select code for the channel through which the loading is to occur. The RPL routine is initiated by any computer HALT condition. This can be any programmed halt instruction or power-up condition. In addition, forced halts can be initiated via the I/O system. This permits system consoles via their interfaces or remote systems via data communication links to initiate the RPL sequence. The RPL capability can be enabled or disabled by programming the configuration switches on the CPU board or by the key-operated switch on the operator panel. A flowchart of the complete RPL sequence is shown in figure 2-4. # 2-31. SELF-TEST FIRMWARE DIAGNOSTICS The standard microprogrammed base set includes three tests that are designed to conveniently and quickly test the computer and memory without supplementary diagnostics. These firmware diagnostics are not designed as a substitute for more complex software diagnostics and it may frequently be the case that you require a more thorough and detailed testing than provided by these standard self-test routines. #### 2-32. TEST DESCRIPTIONS 2-33. TEST 1. Test 1 tests most of the computer registers and functions. This test will not alter or destroy the contents of any working register or memory. An error condition will set all display registers, indicator bits, and the overflow register. The execution time is negligible. 2-34. TEST 2. Test 2 is a fast microprogrammed memory test that checks the presently enabled memory space (up to 32K words). The microprogram reads each memory location, complements the data and writes it back, reads it, compares it to expected data, then complements it and writes it back into memory. The execution time is negligible and is non-destructive to memory data. An error condition is usually accompanied by a parity error indication and will set all display registers and indicator bits and clear the overflow register. The A-register will contain the expected (good) data, the B-register will contain the actual (bad) data, and the M-register will contain the logical memory location of the failure. 2-35. TEST 3. Test 3 is a significantly more sophisticated microprogrammed memory test. All memory installed in the computer will be tested. Execution time is dependent on the amount of memory installed; approximately one second per 32K words. The display register will increment as memory in each 32K word space is tested. Error reporting is the same as in Test 2 except the S-register will contain the number of the 32K word space where the memory failure occurred. (Refer to the 21MX E-Series Computer Installation and Service Manual, part no. 02109-90002 for additional information. #### 2-36. TEST EXECUTION On a cold power-up (paragraph 2-16), Tests 1 and 3 will each be executed once. Pressing the IBL-TEST switch on the operator panel will not only perform the loader function as described in paragraphs 2-18 and 2-19, it will also cause the execution of Tests 1 and 2. Executing the octal instruction 100000 via the INST STEP switch on the operator panel with the key-operated switch in the OPERATE position will execute Tests 1 and 3 once. If the key-operated switch is set to the LOCK position, the microprogram diagnostic will continuously loop until the key-operated switch is returned to the OPERATE position. A CPU or a memory failure, of course, will terminate the test and report the error. #### 2-37. EXCHANGING I/O INTERFACES Figures 2-2 and 2-3 show the HP 2109A and the HP 2113A I/O PCA cages and the select codes associated with each slot. Select code 10 (octal) has the highest priority in the interrupt structure and the highest numbered select code has the lowest priority. When it becomes necessary to install a new I/O interface PCA or change the location of an existing one, proceed as follows: 21MXE Operating Procedures Figure 2-4. Remote Program Load Routine Note: Do not set the ~LINE switch on the computer rear panel to OFF or otherwise remove ac line power because doing so would remove power from memory and its contents would be lost. - Set key-operated switch to STANDBY to remove CPU and I/O power. - b. If computer is equipped with an optional power fail recovery system, set BATTERY switch to OFF and disconnect battery cable(s) from BAT. INPUT connector(s). - c. Remove rear cover from I/O PCA cage and loosen the two screws securing PCA retainer. Slide PCA retainer to the right to permit installation or exchange of I/O PCA's. Note: The internal RPL configuration switches must be reconfigured if you intend to use the RPL capability and you decide to relocate the PCA associated with your loading device (tape reader, disc, magnetic tape, etc.) Details on how to configure these switches are given in the HP 21MX E-Series Computer Installation and Service Manual. - d. Install new I/O interface PCA or exchange I/O interface PCA's as required. If an HP 12979A I/O Extender is to be used, install its interface PCA in the first available lowest priority I/O slot. - Slide PCA retainer to the left and tighten the two screws. Replace I/O PCA cage cover. - f. If computer is equipped with an optional power fail recovery system, reconnect battery cable(s) to BAT. INPUT connector(s) and set BATTERY switch to ON. #### 2-38. HALT CODES Table 2-6 provides a quick reference to those halt codes associated with the input device loader. These halt codes are displayed in the Display Register, when the computer is in the halt mode. #### 2-39. ABNORMAL INDICATIONS Table 2-7 provides a quick reference to the operator panel indications that occur when an abnormal condition exists during operation in the normal register display mode. Abnormal indications encountered during the execution of the firmware diagnostics are discussed in paragraphs 2-31 through 2-36. 21MXE Operating Procedures Table 2-6. Halt Codes | HALT CODE<br>(in octal) | COMMENTS | |-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 102077 | Indicates a successful program load from paper tape and typically indicates a successful program load from disc, magnetic tape, or other such media. | | 102055 | Indicates that an address error occurred while loading from input device. | | 102011 | Indicates that a checksum error occurred while loading from input device. | Table 2-7. Abnormal Indications | INDICATION | ABNORMAL CONDITION | REMEDY | |-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------| | POWER FAIL light remains on. | Indicates that power has been restored after a power failure and that the power fail/automatic restart feature is enabled. | Press HALT: then PRESET or execute an STC 04 or CLC 04 instruction. | | PARITY light is on. | Indicates that a parity error occurred while reading from memory. | Refer to HP 21MX E-Series Installation and Service Manual, part no. 02109-90002. | | OVERFLOW light is on after IBL/<br>TEST is pressed. | Indicates that: a. The presence of memory was not detected. b. The programmed select code | a. Check that memory modules are installed and programmed correctly. b. Check that the programmed | | | was less than 10 (octal). c. The memory was defective. | c. Refer to HP 21MX E-Series Installation and Service Manual, part no. 02109-90002. | | | | , | |--|--|---| | | | | | | | | | | | | | | | | | | | | SECTION ## PROGRAMMING INFORMATION Ш This section describes the software data formats and the base set machine-language instruction coding required to operate the computer and its associated input/output system. Machine-language instruction coding for the optional Dynamic Mapping System is presented in Section IV. #### 3-1. DATA FORMATS As shown in figure 3-1, the basic data format is a 16-bit word in which bit positions are numbered from 0 through 15 in order of increasing significance. Bit position 15 of the data format is used for the sign bit; a logic 0 in this position indicates a positive number and a logic 1 in this position indicates a negative number. The data is assumed to be a whole number and the binary point is therefore assumed to be to the right of the number. The basic word can also be divided into two 8-bit bytes or combined to form a 32-bit double word. The byte format is used for character-oriented input/output devices; packing two bytes of data into one 16-bit word is accomplished by software drivers. In I/O operations, the higher-order byte (byte 1) is the first to be transferred. The integer double-word format is used for extended arithmetic in conjunction with the extended arithmetic instructions described under paragraphs 3-19 and 3-20. Bit position 15 of the most-significant word is the sign bit and the binary point is assumed to be to the right of the least-significant word. The integer value is expressed by the remaining 31 bits. When loaded into the accumulators, the B-register contains the most-significant word and the A-register contains the least-significant word. The floating-point double-word format is used with floating-point software. Bit position 15 of the most-significant word is the mantissa sign and bit position 0 of the least-significant word is the exponent sign. Bits 1 through 7 of the least-significant word express the exponent and the remaining bits (bits 8 through 15 of the least-significant word and bits 0 through 14 of the most-significant word) express the mantissa. Since the mantissa is assumed to be a fractional value, the binary point appears to the left of the mantissa. Software drivers convert decimal numbers to this binary form and normalize the quantity expressed (sign and leading mantissa differ). If either the mantissa or the exponent is negative, that part is stored in two's complement form. The number must be in the appriximate range of $10^{-38}$ to $10^{+38}$ . When loaded into the accumulators, the A-register contains the most-significant word and the B-register contains the least-significant word. Figure 3-1 also illustrates the octal notation for both single-length (16-bit) and double-length (32-bit) words. Each group of three bits, beginning at the right, is combined to form an octal digit. A single-length (16-bit) word can therefore be fully expressed by six octal digits and a double-length (32-bit) word can be fully expressed by 11 octal digits. Octal notation is not shown for byte or floating-point formats, since bytes normally represent characters and floating-point numbers are given in decimal form. The range of representable numbers for single-word data is +32,767 to -32,768 (decimal) or +77,777 to -100,000 (octal). The range of representable numbers for double-word integer data is +2,147,483,647 to -2,147,483,648 (decimal) or +17,777,777,777 to -20,000,000,000 (octal). #### 3-2. ADDRESSING #### 3-3. PAGING The computer memory is logically divided into pages of 1,024 words each. A page is defined as the largest block of memory that can be directly addressed by the address bits of a single-length memory reference instruction. (Refer to paragraph 3-8.) These memory reference instructions use 10 bits (bits 0 through 9) to specify a memory address; thus, the page size is 1,024 locations (2000 octal). Octal addresses for each page, up to a maximum memory size of 32K, are listed in table 3-1. Provision is made to directly address one of two pages: page zero (the base page consisting of locations 00000 through 01777) and the current page (the page in which the instruction itself is located). Memory reference instructions reserve bit 10 to specify one or the other of these two pages. To address locations on any other page, indirect addressing is used as described in following paragraphs. Page references are specified by bit 10 as follows: - a. Logic 0 = Page Zero (Z). - b. Logic 1 = Current Page (C). Figure 3-1. Data Formats and Octal Notation Table 3-1. Memory Paging | MEMORY<br>SIZE | PAGE | OCTAL<br>ADDRESSES | | | |--------------------|-------------|--------------------|--|--| | | | 00000 to 01777 | | | | | | 02000 to 03777 | | | | | 2 | 04000 to 05777 | | | | 4κ ↓ | 3 | 06000 to 07777 | | | | | 4 | 10000 to 11777 | | | | as ical accellus s | 5 | 12000 to 13777 | | | | | 6 | 14000 to 15777 | | | | 8K ∳ | | 16000 to 17777 | | | | | 8 4 | 20000 to 21777 | | | | debiloi debe in | 9 | 22000 to 23777 | | | | | 10 | 24000 to 25777 | | | | 12K <b>♦</b> | <b>, 11</b> | 26000 to 27777 | | | | | 12 | 30000 to 31777 | | | | e destar area. | 13 | 32000 to 33777 | | | | | 14 | 34000 to 35777 | | | | 16K <b>→</b> | 45 | 36000 to 37777 | | | | | 16 | 40000 to 41777 | | | | | 17 | 42000 to 43777 | | | | ATMANER BULL | 18 | 44000 to 45777 | | | | | 19 | 46000 to 47777 | | | | | 20 | 50000 to 51777 | | | | | 21 | 52000 to 53777 | | | | | 22 | 54000 to 55777 | | | | 24K <b>↓</b> | 23 | 56000 to 57777 | | | | | 24 | 60000 to 61777 | | | | | 25 | 62000 to 63777 | | | | | 26 | 64000 to 65777 | | | | | 27 | 66000 to 67777 | | | | | 28 | 70000 to 71777 | | | | | 29 | 72000 to 73777 | | | | | 30 | 74000 to 75777 | | | | 32K <b>↓</b> | 31 | 76000 to 77777 | | | ### 3-4. DIRECT AND INDIRECT ADDRESSING All memory reference instructions reserve bit 15 to specify either direct or indirect addressing. For single-length memory reference instructions, bit 15 of the instruction word is used; for extended arithmetic memory reference instructions, bit 15 of the address word is used. Indirect addressing uses the address part of the instruction to access another word in memory, which is taken as the new memory reference for the same instruction. This new address word is a full 16 bits long: 15 address bits plus another direct/indirect bit. The 15-bit length of the address permits access to any location in memory. If bit 15 again specifies indirect addressing, still another address is obtained; thus, multistep indirect addressing may be done to any number of levels. The first address obtained that does not specify another indirect level becomes the effective address for the instruction. Direct or indirect addressing is specified by bit 15 as follows: - a. Logic 0 = Direct (D). - b. Logic 1 = Indirect (I). #### 3-5. RESERVED MEMORY LOCATIONS The first 64 memory locations of the base page (octal addresses 00000 through 00077) are reserved as listed in table 3-2. The first two locations are reserved as addresses for the two 16-bit accumulators (the A- and B-registers). If options or input/output devices corresponding to locations 00005 through 00077 are not included in the system configuration, these locations can be used for programming purposes. The uppermost 64 locations of memory for any given configuration are reserved for the initial binary loader. The initial binary loader is permanently resident in a read-only memory (ROM) and loaded into the uppermost 64 memory locations by a pushbutton switch on the operator panel. These 64 locations are not protected and can therefore be used for temporary storage of data, trap cells, buffers, etc. Table 3-2. Reserved Memory Locations | MEMORY<br>LOCATION | PURPOSE | | | | |--------------------|----------------------------------------------------------------------------------------------------|--|--|--| | 00000 | A-register address. | | | | | 00001 | B-register address. | | | | | 00002-00003 | Exit sequence if contents of A-<br>register and B-register are used as<br>executable words. | | | | | 00004 | Power-fail interrupt (highest priority). | | | | | 00005 | Memory parity, memory protect, and DMS interrupt. | | | | | 00006 | Reserved for dual-channel port controller (DCPC) channel 1. | | | | | 00007 | Reserved for dual-channel port controller (DCPC) channel 2. | | | | | 00010-00077 | Interrupt locations in decreasing order of priority; e.g., location 00010 has priority over 00011. | | | | #### 3-6. NONEXISTENT MEMORY Nonexistent memory is defined as those locations not physically implemented in the machine. Any attempt to write into a nonexistent memory location will be ignored (no operation). Any attempt to read from a nonexistent memory location will return an all-zeros word (000000 octal); no parity error occurs. # 3-7. BASE SET INSTRUCTION FORMATS The base set of instructions are classified according to format. The five formats used are illustrated in figure 3-2 and described in following paragraphs. In all cases where a single bit is used to select one of two cases (e.g., D/I), the choice is made by coding a logic 0 or logic 1, respectively. Figure 3-2. Base Set Instruction Formats # 3-8. MEMORY REFERENCE INSTRUCTIONS This class of instructions, which combines an instruction code and a memory address into one 16-bit word, is used to execute some function involving data in a specific memory location. Examples are storing, retrieving, and combining memory data to and from the accumulators (A- and B-registers) or causing the program to jump to a specified location in memory. The memory cell referenced (i.e., the absolute address) is determined by a combination of 10 memory address bits (0) through 9) in the instruction word and 5 bits (10 through 14) assumed from the current contents of the M-register. This means that memory reference instructions can directly address any word in the current page; additionally, if the instruction is given in some location other than the base page (page zero), bit 10 (Z/C) of the instruction doubles the addressing range to 2.048 locations by allowing the selection of either page zero or the current page. (This causes bits 10 through 14 of the address contained in the M-register to be set to zero instead of assuming the current contents of the M-register.) This feature provides a convenient linkage between all pages of memory, since page zero can be reached directly from any other page. As discussed under paragraph 3-4, bit 15 is used to specify direct or indirect memory addressing. Note also that since the A- and B-registers are addressable, any single-word memory reference instruction can apply to either of these registers as well as to memory cells. For example, an ADA 0001 instruction adds the contents of the B-register (address 0001) to the contents currently held in the A-register; specify page zero for these operations since the addresses of the A- and B-registers are on page zero. # 3-9. REGISTER REFERENCE INSTRUCTIONS In general, the register reference instructions manipulate bits in the A-register, B-register, and E-register; there is no reference to memory. This group includes 39 basic instructions which may be combined to form a one-word multiple instruction that can operate in various ways on the contents of the A-, B-, and E-registers. These 39 instructions are divided into two subgroups: the shift/rotate group (SRG) and the alter/skip group (ASG). The appropriate subgroup is specified by bit 10 (S/A). Typical operations are clear and/or complement a register, conditional skips, and register increment. #### 3-10. INPUT/OUTPUT INSTRUCTIONS The input/output instructions use bits 6 through 11 for a variety of I/O instructions and bits 0 through 5 to apply the instructions to a specific I/O channel. This provides the means of controlling all peripherals connected to the I/O channels and for transferring data to and from these peripherals. Included also in this group are instructions to control the interrupt system, overflow bit, and computer halt. 21MXE Programming Information # 3-11. EXTENDED ARITHMETIC MEMORY REFERENCE INSTRUCTIONS As the single-word memory reference instruction described previously, the extended arithmetic memory reference instructions include an instruction code and a memory address. In this case, however, two words are required. The first word specifies the extended arithmetic class (bits 12 through 15 and 10) and the instruction code (bits 4 through 9 and 11); bits 0 through 3 are not needed and are coded with zeros. The second word specifies the memory address of the operand. Since the full 15 bits are used for the address, this type of instruction may directly address any location in memory. As with all memory reference instructions, bit 15 is used to specify direct or indirect addressing. Operations performed by this class of instructions are integer multiply and divide (using double-length product and dividend) and double load and double store. ## 3-12. EXTENDED ARITHMETIC REGISTER REFERENCE INSTRUCTIONS This class of instructions provides long shifts and rotates on the combined contents of the A- and B-registers. Bits 12 through 15 and 10 identify the instruction class; bits 4 through 9 and 11 specify the direction and type of shift; and bits 0 through 3 control the number of shifts, which can range from 1 to 16 places. #### 3-13. EXTENDED INSTRUCTIONS The extended instructions include index register instructions, bit and byte manipulation instructions, and move and compare instructions. Instructions comprising the extended instruction group are one, two, or three words in length. The first word is always the instruction code; operand addresses are given in the words following the instruction code or in the A- and B-registers. The operand addresses are 15 bits long, with bit 15 (most-significant bit) generally indicating direct or indirect addressing. #### 3-14. FLOATING POINT INSTRUCTIONS The floating point instructions allow addition, subtraction, multiplication, and division of 32-bit floating point quantities. Two conversion routines are provided for transforming numerical integer representations to/from floating point representations. #### 3-15. BASE SET INSTRUCTION CODING Machine language coding for the base set of instructions are provided in following paragraphs. Definitions for these instructions are grouped according to the instruction type: memory reference, register reference, input/output, extended arithmetic memory reference, and extended arithmetic register reference. Directly above each definition is a diagram showing the machine language coding for that instruction. The gray shaded bits code the instruction type and the gold shaded bits code the specific instruction. Unshaded bits are further defined in the introduction to each instruction type. The mnemonic code and instruction name are included above each diagram. In all cases where an additional bit is used to specify a secondary function (D/I, Z/C, or H/C), the choice is made by coding a logic 0 or logic 1, respectively. In other words, a logic 0 codes D (direct addressing), Z (zero page), or H (hold flag); a logic 1 codes I (indirect addressing), C (current page), or C (clear flag). ## 3-16. MEMORY REFERENCE INSTRUCTIONS The following 14 memory reference instructions execute a function involving data in memory. Bits 0 through 9 specify the affected memory location on a given memory page or, if indirect addressing is specified, the next address to be referenced. Indirect addressing may be continued to any number of levels; when bit 15 (D/I) is a logic 0 (specifying direct addressing), that location will be taken as the effective address. The A- and B-registers may be addressed as locations 00000 and 00001 (octal), respectively. If bit 10 (Z/C) is a logic 0, the memory address is on page zero; if bit 10 is a logic 1, the memory address is on the current page. If the A- or B-register is addressed, bit 10 must be a logic 0 to specify page zero, unless the current page is page zero. Adds the contents of the addressed memory location to the contents of the A-register. The sum remains in the A-register and the contents of the memory cell are unaltered. The result of this addition may set the extend bit or the overflow bit. (Extend and overflow examples are illustrated on page A-13.) Adds the contents of the addressed memory location to the contents of the B-register. The sum remains in the B-register and the contents of the memory cell are unaltered. The result of this addition may set the extend bit or the overflow bit. (Extend and overflow examples are illustrated on page A-13.) Combines the contents of the addressed memory location and the contents of the A-register by performing a logical "and" operation. The contents of the memory cell are unaltered. Compares the contents of the addressed memory location with the contents of the A-register. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances two counts instead of one count. If the two words are identical, the next sequential instruction is executed. Neither the A-register contents nor memory cell contents are altered. Compares the contents of the addressed memory location with the contents of the B-register. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances two counts instead of one count. If the two words are identical, the next sequential instruction is executed. Neither the B-register contents nor memory cell contents are altered. Combines the contents of the addressed memory location and the contents of the A-register by performing a logical "inclusive or" operation. The contents of the memory cell are unaltered. Adds one to the contents of the addressed memory location. If the result of this operation is zero (memory contents incremented from 177777 to 000000), the next instruction is skipped; i.e., the P-register is advanced two counts instead of one count. If the result of this operation is not zero, the next sequential instruction is executed. In either case, the incremented value is written back into the memory cell. Transfers control to the addressed memory location. That is, a JMP causes the P-register count to set according to the memory address portion of the JMP instruction so that the next instruction will be read from that location. This instruction, executed in location P (P-register count), causes the computer control to jump unconditionally to the memory location (m) specified by the memory address portion of the JSB instruction. The contents of the P-register plus one (return address) is stored in memory location m, and the next instruction to be executed will be that contained in the next sequential memory location (m+1). A return to the main program sequence at P+1 will be effected by a JMP indirect through location m. Loads the contents of the addressed memory location into the A-register. The contents of the memory cell are unaltered. Loads the contents of the addressed memory location into the B-register. The contents of the memory cell are unaltered. Stores the contents of the A-register in the addressed memory location. The previous contents of the memory cell are lost; the A-register contents are unaltered. Stores the contents of the B-register in the addressed memory location. The previous contents of the memory cell are lost; the B-register contents are unaltered. Combines the contents of the addressed memory location and the contents of the A-register by performing a logical "exclusive or" operation. The contents of the memory cell are unaltered. ## 3-17. REGISTER REFERENCE INSTRUCTIONS The 39 register reference instructions execute functions on data contained in the A-register, B-register, and E-register. These instructions are divided into two groups: the shift/rotate group (SRG) and the alter/skip group (ASG). In each group, several instructions may be combined into one word. Since the two groups perform separate and distinct functions, instructions from the two groups cannot be mixed. Unshaded bits in the coding diagrams are available for combining other instructions. - **3-18. SHIFT/ROTATE GROUP.** The 20 instructions in the shift/rotate group (SRG) are defined first; this group is specified by setting bit 10 to a logic 0. A comparison of the various shift/rotate functions are illustrated in figure 3-3. Rules for combining instructions in this group are as follows (refer to table 3-3): - a. Only one instruction can be chosen from each of the two multiple-choice columns. - References can be made to either the A-register or B-register, but not both. - c. Sequence of execution is from left to right. - In machine code, use zeros to exclude unwanted microinstructions. - e. Code a logic 1 in bit position 9 to enable shifts or rotates in the first position; code a logic 1 in bit position 4 to enable shifts or rotates in the second position. - f. The extend bit is not affected unless specifically stated. However, if a "rotate-with-E" instruction (ELA, ELB, ERA, or ERB) is coded but disabled by a logic 0 in bit position 9 and/or position 4, the E-register will be updated even though the A- or B-register contents are not affected; to avoid this situation, code a "no operation" (three zeros) in the first and/or second positions. Figure 3-3. Shift and Rotate Functions Table 3-3. Shift/Rotate Group Combining Guide Rotates the A-register contents (all 16 bits) left four places. Bits 15, 14, 13, and 12 rotate around to bit positions 3, 2, 1, and 0, respectively. Equivalent to four successive RAL instructions. Shifts the A-register contents left one place and clears sign bit 15. Arithmetically shifts the A-register contents left one place, 15 magnitude bits only; bit 15 (sign) is not affected. The bit shifted out of bit position 14 is lost; a logic 0 replaces vacated bit position 0. Arithmetically shifts the A-register contents right one place, 15 magnitude bits only; bit 15 (sign) is not affected. A copy of the sign bit is shifted into bit position 14; the bit shifted out of bit position 0 is lost. Rotates the B-register contents (all 16 bits) left four places. Bits 15, 14, 13, and 12 rotate around to bit positions 3, 2, 1, and 0, respectively. Equivalent to four successive RBL instructions. Shifts the B-register contents left one place and clears sign bit 15. Arithmetically shifts the B-register contents left one place, 15 magnitude bits only; bit 15 (sign) is not affected. The bit shifted out of bit position 14 is lost; a logic 0 replaces vacated bit position 0. Arithmetically shifts the B-register contents right one place, 15 magnitude bits only; bit 15 (sign) is not affected. A copy of the sign bit is shifted into bit position 14; the bit shifted out of bit position 0 is lost. Clears the E-register; i.e., the extend bit becomes a logic 0. Rotates the E-register content left with the A-register contents (one place). The E-register content rotates into bit position 0; bit 15 rotates into the E-register. Rotates the E-register content left with the B-register contents (one place). The E-register content rotates into bit position 0; bit 15 rotates into the E-register. Rotates the E-register content right with the A-register contents (one place). The E-register content rotates into bit position 15; bit 0 rotates into the E-register. Rotates the E-register content right with the B-register contents (one place). The E-register content rotates into bit position 15; bit 0 rotates into the E-register. This all-zeros instruction causes a no-operation cycle. Rotates the A-register contents left one place (all 16 bits). Bit 15 rotates into bit position 0. Rotates the A-register contents right one place (all 16 bits). Bit 0 rotates into bit position 15. Rotates the B-register contents left one place (all 16 bits). Bit 15 rotates into bit position 0. Rotates the B-register contents right one place (all 16 bits). Bit 0 rotates into bit position 15. | SLA | | | | | | SKI | РΙ | FL | SB | OF | A | IS | ZE | RO | |-------|----|----|----|----|---|-----|----|----|----|----|---|----|----|----| | 15 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0 | | | | | | | | 1 | | | | Skips the next instruction if the least-significant bit (bit 0) of the A-register is a logic 0. | SLB | | | | | 3 | SKI | РΙ | FL | SB | OF | B | IS | ZE | RO | |-------|----|----|----|----|---|-----|----|----|----|----|---|----|----|----| | 15 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 1 | | | | | | | | 1 | | | | Skips the next instruction if the least-significant bit (bit 0) of the B-register is a logic 0. 3-19. ALTER/SKIP GROUP. The 19 instructions comprising the alter/skip group (ASG) are defined next. This group is specified by setting bit 10 to a logic 1. Rules for combining instructions are as follows (refer to table 3-4): - a. Only one instruction can be chosen from each of the two multiple-choice columns. - b. References can be made to either the A-register or B-register, but not both. - c. Sequence of execution is from left to right. - d. If two or more skip functions are combined, the skip function will occur if either or both conditions are met. One exception exists: refer to the RSS instruction. - In machine code, use zeros to exclude unwanted instructions. Table 3-4. Alter/Skip Group Combining Guide | CCA | CLEAR AND COMPLEMENT A | |-----|------------------------| |-----|------------------------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | | | 0 | | 1 | 1 | | | | | | | | | Clears and complements the A-register contents; i.e., the contents of the A-register become 177777 (octal). This is the two's complement form of -1. | CCE | } | | | | ( | CLE | AF | R A | ND | C | OM | PLE | M | ΕN | ΤВ | |-----|----|----|----|----|----|-----|----|-----|----|---|----|-----|---|----|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0 | 1 | | 1 | 1 | | | | | | | | | Clears and complements the B-register contents; i.e., the contents of the B-register become 177777 (octal). This is the two's complement form of -1. | CCE | CLE | AR A | ND | CC | M | PLE | M | ENT | ΓΕ | |-------------|---------|------|----|----|---|-----|---|-----|----| | 15 14 13 12 | 11 10 9 | 8 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | enion | | 1 | 1 | | | | | | | Clears and complements the E-register content (extend bit); i.e., the extend bit becomes a logic 1. | CLA | 1 | | | | | | | | | | | ( | CLE | AF | R A | |------|----|----|----|----|-----|---|---|---|---|---|---|---|-----|----|-----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1005 | | | | 0 | 3,0 | 0 | | | | | | | | | | Clears the A-register; i.e., the contents of the A-register become 000000 (octal). | CLE | } | | | | | | | | | | | ( | CLI | ΕAI | R B | |-----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|-----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0 | 1 | | 0 | 1 | | | | | | | | | Clears the B-register; i.e., the contents of the B-register become 000000 (octal). | CLE | | | | | | | | | | | | ( | CLE | ΞAΙ | R E | |-----|-----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|-----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 111 | | | | | | | 0 | | | | | | | | Clears the E-register; i.e., the extend bit becomes a logic 0. | CM/ | 1 | | | | | | | | | CC | MI | PLE | ME | N | ГΑ | |-----|----|----|----|----|----|---|---|---|---|----|----|-----|----|---|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0 | | 1 | 0 | | | | | | | | | Complements the A-register contents (one's complement). # CMB COMPLEMENT B 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0 0 0 0 1 1 1 0 0 Complements the B-register contents (one's complement). #### CME COMPLEMENT E | 15 14 13 12 | 11 10 9 | 8 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---------|-----|---|---|---|---|---|---|---| | | | | 0 | | | | | | | Complements the E-register content (extend bit). #### INA INCREMENT A | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | | | 0 | | | | | | | | | 1 | | | Increments the A-register by one. The overflow bit will be set if an increment of the largest positive number (077777 octal) is made. The extend bit will be set if an all-ones word (177777 octal) is incremented. #### INB **INCREMENT B** | 15 14 13 12 | 11 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------|---|---|---|---|---|---|---|---|---|---| | | | | | | | | | | 1 | | | Increments the B-register by one. The overflow bit will be set if an increment of the largest positive number (077777 octal) is made. The extend bit will be set if an all-ones word (177777 octal) is incremented. #### **RSS** REVERSE SKIP SENSE | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | 0 | | | | | | | | | | | | | 1 | Skip occurs for any of the following skip instructions, if present, when the non-zero condition is met. An RSS without a skip instruction in the word causes an unconditional skip. If a word with RSS also includes both SSA and SLA (or SSB and SLB), bits 15 and 0 must both be logic 1's for a skip to occur; in all other cases, a skip occurs if one or more skip conditions are met. #### SEZ SKIP IF E IS ZERO | 15 14 13 12 | 11 10 9 | 8 7 | 6 | 5 4 | 3 | 2 | 1 | 0 | |-------------|---------|-----|---|-----|---|---|---|---| | | 1 | | | 1 | | | | | Skips the next instruction if the E-register content (extend bit) is a logic 0. #### SLA SKIP IF LSB OF A IS ZERO | 15 14 13 12 | 11 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------|---|---|---|---|---|---|---|---|---|---| | TALL | 0 1 | | | | | | | 1 | | | | Skips the next instruction if the least-significant bit (bit 0) of the A-register is a logic 0; i.e., skips if an even number is in the A-register. #### SLB SKIP IF LSB OF B IS ZERO | 15 14 13 12 | 11 10 9 | 8 | 7 6 | 5 | 4 3 | 2 | 1 | 0 | |-------------|---------|---|-----|---|-----|---|---|---| | 0.00 | 1 1 | | | | 1 | | | | Skips the next instruction if the least-significant bit (bit 0) of the B-register is a logic 0; i.e., skips if an extraumber is in the B-register. #### **SSA** SKIP IF SIGN OF A IS ZERO | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | 1 | | 0 | | | | | | | 1 | | | | | Skips the next instruction if the sign bit (bit 15) of the A-register is a logic 0; i.e., skips if a positive number is in the A-register. #### SSB SKIP IF SIGN OF B IS ZERO | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---| | | Ţ. | 0 | 1 | 1 | | | | | | | | | | | | Skips the next instruction if the sign bit (bit 15) of the B-register is a logic 0; i.e., skips if a positive number is in the B-register. #### SZA SKIP IF A IS ZERO | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|------------|----|-----|----|----|---|---|---|---|---|---|---|---|---|---| | | <b>300</b> | 0 | le. | 0 | 1 | | | | | | | | | 1 | | Skips the next instruction if the A-register contents are zero (16 zeros). SZB SKIP IF B IS ZERO Skips the next instruction if the B-register contents are zero (16 zeros). #### 3-20. INPUT/OUTPUT INSTRUCTIONS The following input/output instructions provide the capability of setting or clearing the I/O flag and control bits, testing the state of the overflow and the I/O flag bits, and transferring data between specific I/O devices and the A- and B-registers. In addition, specific instructions in this group control the vectored priority interrupt system and can cause a programmed halt. Bit 11, where relevant, specifies the A- or B-register or distinguishes between set control and clear control; otherwise, bit 11 may be a logic 0 or a logic 1 without affecting the instruction (although the assembler will assign zeros in this case). In those instructions where bit position 9 includes the letters H/C, the programmer has the choice of holding (logic 0) or clearing (logic 1) the device flag after executing the instruction. (Exception: the H/C bit associated with instructions SOC and SOS holds or clears the overflow bit instead of the device flag.) Bits 8, 7, and 6 specify the appropriate I/O instruction and bits 5 through 0 form a two-digit octal select code (address) to apply the instruction to one of up to 64 input/output devices or functions. Clears the control bit of the selected I/O channel or function. This furns off the specific device channel and prevents it from interrupting. A CLC 00 instruction clears all control bits from select code 06 upward, effectively turning off all I/O devices. Clears the flag of the selected I/O channel or function. A CLF 00 instruction disables the interrupt system for all select codes except power fail (select code 04) and parity error (select code 05), which are always enabled; this does not affect the status of the individual channel flags. Clears the overflow bit. Halts the computer and holds or clears the flag of the selected I/O channel. The HLT instruction has the same effect as pressing the operator panel HALT pushbutton. The HLT instruction will be contained in the T-register, which is selected and displayed automatically when the computer halts. The P-register will contain the HLT location plus one. Loads the contents of the I/O buffer associated with the selected device into the A-register. Loads the contents of the I/O buffer associated with the selected device into the B-register. By executing a logical "inclusive or" function, merges the contents of the I/O buffer associated with the selected device into the A-register. By executing a logical "inclusive or" function, merges the contents of the I/O buffer associated with the selected device into the B-register. Outputs the contents of the A-register to the I/O buffer associated with the selected device. If the I/O buffer is less than 16 bits in length, the least-significant bits of the A-register are normally loaded. (Some exceptions to this exist, depending on the type of output device.) The contents of the A-register are not altered. Outputs the contents of the B-register to the I/O buffer associated with the selected device. If the I/O buffer is less than 16 bits in length, the least-significant bits of the B-register are normally loaded. (Some exceptions to this exist, depending on the type of output device.) The contents of the B-register are not altered. Skips the next programmed instruction if the flag of the selected channel is clear (device busy). Skips the next programmed instruction if the flag of the selected channel is set (device ready). | SOC | ; | | | | | Sk | ΊP | ۱F | ٥٧ | ER | FL | .OV | V C | LE, | AR | |-----|----|----|----|----|----|-----|----|----|----|----|----|-----|-----|-----|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0 | 0 | 0 | 0 | | H/C | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Skips the next programmed instruction if the overflow bit is clear. Use the H/C bit (bit 9) to either hold or clear the overflow bit following the completion of this instruction (whether the skip is taken or not). Skips the next programmed instruction if the overflow bit is set. Use the H/C bit (bit 9) to either hold or clear the overflow bit following the completion of this instruction (whether the skip is taken or not). Sets the control bit of the selected I/O channel or function. Sets the flag of the selected I/O channel or function. An STF 00 instruction enables the interrupt system for all select codes except power fail (select code 04), which is always enabled and parity error (select code 05), which is selectively controllable. Sets the overflow bit. # 3-21. EXTENDED ARITHMETIC MEMORY REFERENCE INSTRUCTIONS The four extended arithmetic memory reference instructions provide for integer multiply and divide and for loading and storing double-length words to and from the A- and B-registers. The complete instruction requires two words: one for the instruction code and one for the address. When stored in memory, the instruction word is the first to be fetched; the address word is in the next sequential location. Since 15 bits are available for the address, these instructions can directly address any location in memory. As for all memory reference instructions, indirect addressing to any number of levels may also be used. A logic 0 in bit position 15 specifies direct addressing; a logic 1 specifies indirect addressing. Divides a double-word integer in the combined B- and A-registers by a 16-bit integer in the addressed memory location. The result is a 16-bit integer quotient in the A-register and a 16-bit integer remainder in the B-register. Overflow can result from an attempt to divide by zero, or from an attempt to divide by a number too small for the dividend. In the former case (divide by zero), the division will not be attempted and the B- and A-register contents will be unchanged except that a negative quantity will be made positive. In the latter case (divisor too small), the execution will be attempted with unpredictable results left in the B- and A-registers. If there is no divide error, the overflow bit is cleared. Loads the contents of addressed memory location m (and m + 1) into the A- and B-registers, respectively. Stores the double-word quantity in the A- and B-registers into addressed memory locations m (and m+1), respectively. Multiplies a 16-bit integer in the A-register by a 16-bit integer in the addressed memory location. The resulting double-length integer product resides in the B- and A-registers, with the B-register containing the sign bit and the most-significant 15 bits of the quantity. The A-register may be used as an operand (i.e., memory address 0), resulting in an arithmetic square. The instruction clears the overflow bit. # 3-22. EXTENDED ARITHMETIC REGISTER REFERENCE INSTRUCTIONS The six extended arithmetic register reference instructions provide various types of shifting operations on the combined contents of the B- and A-registers. The B-register is considered to be to the left (most-significant word) and the A-register is considered to be to the right (least-significant word). An example of each type of shift operation is illustrated in figure 3-4. The complete instruction is given in one word and includes four bits (unshaded) to specify the number of shifts (1 to 16). By viewing these four bits as a binary-coded number, the number of shifts is easily expressed; i.e., binary-coded 1 = 1 shift, binary-coded 2 = 2 shifts . . . binary-coded 15 = 15 shifts. The maximum number of 16 shifts is coded with four zeros, which essentially exchanges the contents of the B- and A-registers. The extend bit is not affected by any of the following instructions. Except for the arithmetic shifts, overflow also is not affected. Arithmetically shifts the combined contents of the B- and A-registers left n places. The value of n may be any number from 1 through 16. Zeros are filled into vacated low-order positions of the A-register. The sign bit is not affected, and data bits are lost out of bit position 14 of the B-register. If any one of the lost bits is a significant data bit ("1" for positive numbers, "0" for negative numbers), the overflow bit will be set; otherwise, overflow will be cleared during execution. See ASL example in figure 3-4. Note that two additional shifts in this example would cause an error by losing a significant '1'. Arithmetically shifts the combined contents of the B- and A-registers right n places. The value of n may be any number from 1 through 16. The sign bit is unchanged and Figure 3-4. Examples of Double-Word Shifts and Rotates is extended into bit positions vacated by the right shift. Data bits shifted out of the least-significant end of the A-register are lost. Overflow cannot occur because the instruction clears the overflow bit. Logically shifts the combined contents of the B- and A-registers left n places. The value of n may be any number from 1 through 16. Zeros are filled into vacated low-order bit positions of the A-register; data bits are lost out of the high-order bit positions of the B-register. Number of Shifts Logically shifts the combined contents of the B- and A-registers right n places. The value of n may be any number from 1 through 16. Zeros are filled into vacated high-order bit positions of the B-register; data bits are lost out of the low-order bit positions of the A-register. **Number of Shifts** Rotates the combined contents of the B- and A-registers left n places. The value of n may be any number from 1 through 16. No bits are lost or filled in. Data bits shifted out of the high-order end of the B-register are rotated around to enter the low-order end of the A-register. Rotates the combined contents of the B- and A-registers right n places. The value of n may be any number from 1 through 16. No bits are lost or filled in. Data bits shifted out of the low-order end of the A-register are rotated around to enter the high-order end of the B-register. #### 3-23. EXTENDED INSTRUCTION GROUP 3-24. INDEX REGISTER INSTRUCTIONS. The index registers (X and Y) are two 16-bit registers accessible by the following instructions. Adds the contents of the addressed memory location to the contents of the X-register. The sum remains in the X-register and the contents of the memory cell are unaltered. The result of this addition may set the extend bit or the overflow bit. Adds the contents of the addressed memory location to the contents of the Y-register. The sum remains in the Y-register and the contents of the memory cell are unaltered. The result of this addition may set the extend bit or the overflow bit. Copies the contents of the A-register into the X-register. The contents of the A-register are unaltered. Copies the contents of the A-register into the Y-register. The contents of the A-register are unaltered. Copies the contents of the B-register into the X-register. The contents of the B-register are unaltered. Copies the contents of the B-register into the Y-register. The contents of the B-register are unaltered. Copies the contents of the X-register into the A-register. The contents of the X-register are unaltered. Copies the contents of the X-register into the B-register. The contents of the X-register are unaltered. Copies the contents of the Y-register into the A-register. The contents of the Y-register are unaltered. | CY | В | | | | | | | | | | CC | PY | ′ Y | TO | <u>B</u> | |----|----|----|----|----|----|---|---|---|---|---|----|----|-----|----|----------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0 | Ó | 2 | 1 | 0 | | | | | | 0 | 1 | 1 | 0 | 0 | Copies the contents of the Y-register into the B-register. The contents of the Y-register are unaltered. Subtracts one from the contents of the X-register. If the result of this operation is zero (X-register decremented from 000001 to 000000), the next instruction is skipped; i.e., the P-register count is advanced two counts instead of one count. If the result is not zero, the next sequential instruction is executed. Subtracts one from the contents of the Y-register. If the result of this operation is zero (Y-register decremented from 000001 to 000000), the next instruction is skipped; i.e., the P-register count is advanced two counts instead of one count. If the result is not zero, the next sequential instruction is executed. Adds one to the contents of the X-register. If the result of this operation is zero (X-register rolls over to 000000 from 177777), the next instruction is skipped; i.e., the P-register count is advanced two counts instead of one count. If the result is not zero, the next sequential instruction is executed. Adds one to the contents of the Y-register. If the result of this operation is zero (Y-register rolls over to 000000 from 177777), the next instruction is skipped; i.e., the P-register count is advanced two counts instead of one count. If the result is not zero, the next sequential instruction is executed. Loads the A-register with the contents indicated by the effective address, which is computed by adding the contents of the X-register to the operand address. The effective address is loaded into the M-register; the X-register and memory contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Loads the A-register with the contents indicated by the effective address, which is computed by adding the contents of the Y-register to the operand address. The effective address is loaded into the M-register; the Y-register and memory contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Loads the contents of the addressed memory location into the X-register. The A- and B-registers may be addressed as locations 00000 and 00001, respectively; however, if it is desired to load from the A- or B-register, copy instructions CAX or CBX should be used since they are more efficient. Loads the B-register with the contents indicated by the effective address, which is computed by adding the contents of the X-register to the operand address. The effective address is loaded into the M-register; the X-register and memory contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Loads the contents of the addressed memory location into the Y-register. The A- and B-registers may be addressed as locations 00000 and 00001, respectively; however, if it is desired to load from the A- or B-register, copy instructions CAY or CBY should be used since they are more efficient. Loads the B-register with the contents indicated by the effective address, which is computed by adding the contents of the Y-register to the operand address. The effective address is loaded into the M-register; the X-register and memory contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Stores the contents of the A-register into the location indicated by the effective address, which is computed by adding the contents of the X-register to the operand address. The effective address is loaded into the M-register; the A- and X-register contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Stores the contents of the A-register into the location indicated by the effective address, which is computed by adding the contents of the Y-register to the operand address. The effective address is loaded into the M-register; the A- and Y-register contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. **Operand Address** Stores the contents of the B-register into the location indicated by the effective address, which is computed by adding the contents of the X-register to the operand address. The effective address is loaded into the M-register; the B- and X-register contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. **Operand Address** Stores the contents of the B-register into the location indicated by the effective address, which is computed by adding the contents of the Y-register to the operand address. The effective address is loaded into the M-register; the B- and Y-register contents are not altered. Indirect addressing is resolved before indexing; bit 15 of the effective address is ignored. Memory Address Stores the contents of the X-register into the addressed memory location. The A- and B-registers may be addressed as locations 00000 and 00001, respectively. The X-register contents are not altered. Stores the contents of the Y-register into the addressed memory location. The A- and B-registers may be addressed as locations 00000 and 00001, respectively. The Y-register contents are not altered. | XA | <b>X</b> | | | | | | | E | XC | HA | NG | E / | <u>А</u> А | ND | X | |----|----------|----|----|----|----|---|---|---|----|----|----|-----|------------|----|---| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0 | 0 | | | | | | 0 | 0 | | 1 | 1 | Exchanges the contents of the A- and X-registers. | XA | Y | | | | | | | E | <u>xc</u> | HΑ | NG | E | 4 A | NE | ) <u>Y</u> | |----|----|----|----|----|----|---|---|---|-----------|----|----|---|-----|----|------------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 0 | | | | | | | 0 | 1 | | 1 | 1 | Exchanges the contents of the A- and Y-registers. | XB | X | | | | | | | E | XCI | HAI | ٧G | EE | 3 A | ND | Χ | |----|----|----|----|----|----|---|---|---|-----|-----|----|----|-----|----|---| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 0 | | 1 | | | | | | | 0 | 0 | 1 | 1 | 1 | Exchanges the contents of the B- and X-registers. | XE | BY | | | | | | | E | ХC | HΑ | NG | E I | 3 A | ND | Υ | |----|----|----|----|----|----|---|---|---|----|----|----|-----|-----|----|---| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 1 | Û | | | | | | 0 | 1 | 1 | 1 | 1 | Exchanges the contents of the B- and Y-registers. JUMP INSTRUCTIONS. The following two 3-25. jump instructions involving the Y-register allow a program to either jump to or exit from a subroutine. This instruction is designed for entering a subroutine. The instruction, executed in location P, causes computer control to jump unconditionally to the memory location specified in the memory address. Indirect addressing may be specified. The contents of the P-register plus two (return address) is loaded into the Y-register. A return to the main program sequence at P + 2 may be effected by a JPY instruction (described next). A memory protect check is performed by this instruction. The effective address may not be below the fence, including the addressable A-and B-registers. Transfers control to the effective address, which is computed by adding the contents of the Y-register to the operand address. Indirect addressing is not allowed. The effective address is loaded into the P-register; the Y-register contents are not altered. A memory protect check is performed by this instruction. The effective address may not be below the fence, including the addressable A- and B-registers. # 3-26. BYTE MANIPULATION INSTRUCTIONS. A byte address is defined as two times the word address plus zero or one, depending on whether the byte is in the high-order position (bits 8 through 15) or low-order position (bits 0 through 7) of the word containing it. If the byte of interest is in bit positions 8 through 15 of memory location 100, for example, then the address of that byte is 2\*100+0, or 200; the address of the low-order byte in the same location is 201 (2\*100+1). Because of the way byte addresses are defined, 16 bits are required to cover all possible byte addresses in a 32K-word memory configura- Byte addresses 000 through 003 reference bytes in the Aand B-registers. These addresses will not cause memory violations. The user should, however, be careful in referencing these byte addresses; for example, storing into byte address 002 or 003 would destroy the byte address originally contained in the B-register. tion. Hence, for byte addressing, bit 15 does not indicate Compares the bytes in string 1 with those in string 2. This is a three-word instruction where Word 1 = Instruction code, Word 2 = Address of word containing the string count, and Word 3 = All-zeros word reserved for use by microcode. The operand addresses are in the A- and B-registers. The A-register contains the first byte address of string 1 and the B-register contains the first byte address of string 2. The number of bytes to be compared is given in the memory location addressed by Word 2 of the instruction; the number of bytes to be compared is restricted to a positive integer greater than zero. The strings are compared one byte at a time; the ith byte in string 1 is compared with the ith byte in string 2. The comparison is performed arithmetically; i.e., each byte is treated as a positive number. If all bytes in string 1 are identical with all bytes in string 2, the "equal" exit is taken. As soon as two bytes are compared and found to be different, the "less than" or "greater than" exit is taken, depending on whether the byte in string 1 is less than or greater than the byte in string 2. The three ways this instruction exits are as follows: - a. No skip if string 1 is equal to string 2; the P-register advances one count from Word 3 of the instruction. The A-register contains its original value incremented by the count stored in the address specified in Word 2. - b. Skips one word if string 1 is less than string 2; the P-register advances two counts from Word 3 of the instruction. The A-register contains the address of the byte in string 1 where the comparison stopped. - c. Skips two words if string 1 is greater than string 2; the P-register advances three counts from Word 3 of the instruction. The A-register contains the address of the byte in string 1 where the comparison stopped. For all three exits, the B-register will contain its original value incremented by the count stored in the address specified in Word 2. This instruction is interruptible. The interrupt routine is expected to save and restore the contents of the A- and B-registers. During the interrupt, the remaining count is stored in Word 3 of the instruction. | LBT | • | | | | | | | | | | L | OA | D E | ۲Y | Έ | |------|----|----|----|----|----|---|---|---|---|---|----|-----|-----|----|---| | 15 1 | 4 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ĺ. | | | | | | | | 1 | | 11 | le. | 0 | 1 | 1 | This one word instruction loads into the A-register the byte whose address is contained in the B-register. The byte is right-justified with leading zeros in the left byte. The B-register is incremented by one. indirect addressing. Moves bytes in a left-to-right manner; i.e., the byte having the lowest address from the source is moved first. This is a three word instruction where Word 1 = Instruction code, Word 2 = Address of word containing the byte count, and Word 3 = All-zeros word reserved for use by microcode. The operand addresses are in the A- and B-registers. The A-register contains the first byte address source and the B-register contains the first byte address destination. The number of bytes to be moved is given by a 16-bit positive integer greater than zero addressed by Word 2 of the instruction. The byte address in the A- and B-registers are incremented as each byte is being moved. Thus, at the end of the operation, the A- and B-registers are incremented by the number of bytes moved. Wraparound of the byte address would result from a carry out of bit position 15; therefore, if the destination became 000, 001, 002, or 003, the next byte would be moved into the A- or B-register and destroy the proper byte addresses for the move operation. For each byte move, a memory protect check is performed. This instruction is interruptible. The interrupt routine is expected to save and restore the contents of the A- and B-registers. During the interrupt, the remaining count is stored in Word 3 of the instruction. | SB | T | | | | | | | | | | ST | OF | RE | BY | TE | |----|----|----|----|----|----|---|---|---|---|---|----|----|----|----|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | | | | | 1 | 0 | 0 | Stores the A-register low-order (right) byte in the byte address contained in the B-register. The B-register is incremented by one. A memory protect check is performed before the byte is stored. The left byte in the A-register does not have to be zeros. The other byte in the same word of the stored byte is not altered. This is a one word instruction with the operands in the A-and B-registers. The A-register contains a termination byte (high-order byte) and a test byte (low-order byte). The B-register contains the first byte address of the string to be scanned. A string of bytes is scanned starting at the byte address given in the B-register. Scanning terminates when a byte in the string matches either the test byte or the termination byte in the A-register. The manner in which the instruction exits depends on which byte is matched first. If a byte in the string matches the test byte, the instruction will not skip upon exit; the B-register will contain the address of the byte matching the test byte. If a byte in the string matches the termination byte, the instruction will skip one word upon exit; the B-register will contain the address of the byte matching the termination byte plus one. The scanning operation will not continue indefinitely even if neither the termination byte nor test byte exists in memory. These bytes are in the A-register with byte addresses 000 and 001, respectively. Thus, if no match is made by the time the B-register points to the last byte in memory, the B-register will roll over to zero and the next test will match the termination byte in the A-register with itself. This instruction is interruptible. The interrupt routine is expected to save and restore the contents of the A- and B-registers. Museum # 3-27. BIT MANIPULATION INSTRUCTIONS. The following three instructions allow any number of bits in a specified memory location to be cleared, set, or tested. Clears bits in the addressed location. This is a three-word instruction where Word 1 = Instruction code. Word 2 = Address of a 16-bit mask, and Word 3 = Address of word where bits are to be cleared. The bits to be cleared correspond to logic 1's in the mask. The bits corresponding to logic 0's in the mask are not affected. A memory protect check is performed prior to modifying the word in memory. Sets bits in the addressed location. This is a three-word instruction where Word 1 = Instruction code. Word 2 = Address of a 16-bit mask, and Word 3 = Address of word where bits are to be set. The bits to be set correspond to logic 1's in the mask. The bits corresponding to logic 0's in the mask are not affected. A memory protect check is performed prior to modifying the word in memory. Tests (compares) bits in the addressed location. This is a three-word instruction where Word 1 = Instruction code, Word 2 = Address of a 16-bit mask, and Word 3 = Address of word in which bits are to be tested. The bits in the addressed memory word corresponding to logic 1's in the mask are tested. If all the bits tested are 1's, the instruction will not skip; otherwise the instruction will skip one word (i.e., the P-register will advance two counts from Word 3 of the instruction). **3-28. WORD MANIPULATION INSTRUCTIONS.** The following instructions facilitate the comparing and moving of word arrays. Compares the words in array 1 with those in array 2. This is a three-word instruction where Word 1 = Instruction code. Word 2 = Address of word containing the word count, and Word 3 = All-zeros word reserved for use by microcode. The operand addresses are in the A- and B-registers. The A-register contains the first word address of array 1 and the B-register contains the first word address of array 2. Bit 15 of the addresses in the A- and B-registers are ignored; i.e., no indirect addressing allowed. The number of words to be compared is given in the memory location addressed by Word 2 of the instruction; the number of words to be compared is restricted to a positive integer greater than zero. The arrays are compared one word at a time; the ith word in array 1 is compared with the ith word in array 2. This comparison is performed arithmetically; i.e., each word is considered a two's complement number. If all words in array 1 are equal to all words in array 2, the "equal" exit is taken. As soon as two words are compared and found to be different, the "less than" or "greater than" exit is taken, depending on whether the word in array 1 is less than or greater than the word in array 2. The three ways this instruction exits are as follows: - a. No skip if array 1 is equal to array 2; the P-register advances one count from Word 3 of the instruction. The A-register contains its original value incremented by the word count stored in the address specified in Word 2. - b. Skips one word if array 1 is less than array 2; the P-register advances two counts from Word 3 of the instruction. The A-register contains the address of the word in array 1 where the comparison stopped. - c. Skips two words if array 1 is greater than array 2; the P-register advances three counts from Word 3 of the instruction. The A-register contains the address of the word in array 1 where the comparison stopped. For all three exits, the B-register will contain its original value incremented by the word count stored in the address specified in Word 2. This instruction is interruptible. The interrupt routine is expected to save and restore the contents of the A- and B-registers. During the interrupt, the remaining count is stored in Word 3 of the instruction. Moves words in a left-to-right manner; i.e., the word having the lowest address in the source is moved first. This is a three-word instruction where Word 1 = Instruction code, Word 2 = Address of word containing the count, and Word 3 = All-zeros word reserved for use by microcode. The operand addresses are in the A- and B-registers. The A-register contains the first word address source and the B-register contains the first word address destination. The number of words to be moved is a 16-bit positive integer greater than zero addressed by Word 2 of the instruction. The word addresses in the A- and B-registers are incremented as each word is being moved. Thus, at the end of the operation, the A- and B-registers are incremented by the number of words moved. Wraparound of the word address would result from a carry into bit position 15 (i.e., at 32767). If the destination address became 000 or 001, the next word would be moved into the A- or B-register and destroy the proper word addresses for the move operation. For each word move, a memory protect check is performed. This instruction is interruptible. The interrupt routine is expected to save and restore the contents of the A- and B-registers. During the interrupt, the remaining count is stored in Word 3 of the instruction. #### 3-29. FLOATING POINT INSTRUCTIONS The following six floating point instructions make it possible to add, subtract, multiply, and divide floating point numbers and to convert quantities from floating point format to integer format or vice versa. Each of the four arithmetic instructions requires two words of memory: one for the instruction code and one for the operand address. Since a full 15 bits are available for the operand address, these instructions can directly address any location in memory. As with all memory reference instructions, indirect addressing to any number of levels is permitted. A logic 0 in bit position 15 specifies direct addressing; a logic 1 specifies indirect addressing. The execution times of the floating point instructions are specified under paragraph 3-28. These instructions are noninterruptible; any attempted interrupt is held off for the full execution time of the currently active floating point instruction. However, data transfer via the dual-channel port controller (DCPC) is not held off. Adds the floating point quantity in the A- and B-registers to the floating point quantity in the specified memory locations. The floating point result is returned in the A- and B-registers. Overflow occurs if the result lies outside the range $[-2^{127}, (1-2^{-23})\ 2^{127}]$ . In such a case, the overflow flag is set and the result $(1-2^{-23})\ 2^{127}$ is returned to the A- and B-registers. Underflow occurs if the result lies within the range $[-2^{-129}(1+2^{-22}),\ 2^{-129}]$ . In such a case, the overflow flag is set and the result 0 is returned to the A- and B-registers. Divides the floating point quantity in the A- and B-registers by the floating point quantity in the specified memory locations. The floating point quantity is returned to the A- and B-registers. Overflow and underflow are as described for the FAD instruction. | FIX | | | | | FL | OA | TI | NG | PO | IN. | ТТ | 0 | NT | EG | ER | |-----|----|----|----|----|----|----|----|----|----|-----|----|---|----|----|----| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Converts the floating point quantity in the A- and B-registers to integer format. The integer result is returned to the A-register. If the magnitude of the floating point number is <1, regardless of sign, the integer 0 is returned. If the magnitude of the exponent of the floating point number is $\ge 2^{16}$ , regardless of sign, the integer 32767 (077777 octal) is returned and the overflow flag is set. # FLT INTEGER TO FLOATING POINT 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 16 0 0 1 0 1 0 1 0 0 0 0 Converts the integer quantity in the A-register to floating point format. The floating point result is returned to the A- and B-registers. Multiplies the floating point quantity in the A- and B-registers by the floating point quantity in the specified memory locations. The floating point result is returned to the A- and B-registers. Overflow and underflow are as described for the FAD instruction. Subtracts the floating point quantity in the specified memory locations from the floating point quantity in the A- and B-registers. The floating point result is returned to the A- and B-registers. Overflow and underflow are as described for the FAD instruction. #### 3-30. INSTRUCTION EXECUTION TIMES Table 3-5 lists the execution times required for the various base set instructions. Table 3-5. Typical Base Set Instruction Execution Times<sup>1</sup> (sheet 1 of 3) | INSTRUCTION | EXECUTION TIME (us) | | | | | | | | |----------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------------------------------|-------------------|-----------------------------|--|--|--|--| | | Standard Pe<br>Mem | Minutes 1017-000000 page 1010-2410-27-10-01-27-21- | | formance<br>nory | | | | | | | Non-DMS | DMS | Non-DMS | DMS | | | | | | Memory Reference Group | | | | | | | | | | ADA/B,AND,IOR,LDA/B,XOR | 1.190 | 1.330 | 0.910 | 0.910 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.455 | 0.455 | | | | | | Each Additional Level | 0.630 | 0.665 | 0.630 | 0.630 | | | | | | STA/B | 1.855 | 1.995 | 1.260 | 1.330 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.455 | 0.455 | | | | | | Each Additional Level | 0.630 | 0.665 | 0.630 | 0.630 | | | | | | CPA/B (no skip) | 1.225 | 1.330 | 1.085 | 1.085 | | | | | | (skip) | 1.715 | 1.855 | 1.435 | 1.435 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.455 | 0.455 | | | | | | Each Additional Level | 0.630 | 0.665 | 0.630 | 0.630 | | | | | | ISZ (no skip) | 2.030 | 2.170 | 1.540 | 1.540 | | | | | | (skip) | 2.030 | 2.170 | 1.610 | 1.610 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.455 | 0.455 | | | | | | Each Additional Level | 0.630 | 0.665 | 0.630 | 0.630 | | | | | | JMP | 0.735 | 0.735 | 0.735 | 0.735 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.350 | 0.420 | | | | | | 2nd Indirect Level | 0.595 | 0.665 | 0.560 | 0.490 | | | | | | Each Additional Level | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | JSB | 1.855 | 1.925 | 1.610 | 1.680 | | | | | | 1st Indirect Level | 0.595 | 0.665 | 0.350 | 0.420 | | | | | | 2nd Indirect Level | 0.595 | 0.665 | 0.560 | 0.490 | | | | | | Each Additional Level | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | Shift/Rotate Group | | | | | | | | | | (no skip) | 1.190 | 1.330 | 0.910 | 0.910 | | | | | | (skip) | 1.785 | 1.995 | 1.260 | 1.330 | | | | | | Alter/Skip Group | | | | | | | | | | (no skip) | 1.190 | 1,330 | 0.910 | 0.910 | | | | | | (skip) | 1.785 | 1.995 | 1.260 | 1.330 | | | | | | | | | 1.200 | 1.330 | | | | | | Input/Output Group <sup>2</sup> | | | | | | | | | | SFS, SFC, SOS, SOC (no skip) | 1.575 to | 1,575 to | 1.575 to | 1.575 to | | | | | | (skip) | 2.275 | 2.275 | 2.275 | 2.275 | | | | | | | 2.030 to 2.730 | 2.170 to<br>2.870 | 1.960 to<br>2.660 | 1.960 to | | | | | | | 5/3V | 2.070 | | 2.660 | | | | | | Extended Arithmetic Group ASL | 2.065 | 2.135 | | | | | | | | | +0.175/ | +0.175/ | 1.820<br>+0.175/ | 1.890<br> +0.175/ | | | | | | | shift | shift | shift | shift | | | | | | ASR | 1.610 | 1.680 | 1.470 | 1.470 | | | | | | | +0.175/ | +0.175/ | +0.175/ | +0.175/ | | | | | | | shift | shift | shift | shift | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | autoritation de la company | 400.00500500000000000000000000000000000 | | | or a leaster for each \$470 | | | | | Table 3-5. Typical Base Set Instruction Execution Times<sup>1</sup> (sheet 2 of 3) | INSTRUCTION | | EXECUTIO | N TIME (us) | | |----------------------------------------------------------|---------------------------|---------------------------|---------------------------|--------------------------| | | Standard Pe<br>Mem | | High Perf<br>Mem | | | | Non-DMS | DMS | Non-DMS | DMS | | Extended Arithmetic Group<br>(Cont.) | | | | | | LSL,LSR,RRL,RRR | 1.715<br>+0.175/<br>shift | 1.785<br>+0.175/<br>shift | 1.470<br>+0.175/<br>shift | 1.540<br>+0.175<br>shift | | DLD | 3.185 | 3.500 | 2.065 | 2.135 | | DST | 3.710 | 3.990 | 2.695 | 2.765 | | <b>WPY</b> | 5.740 to<br>6.720 | 5.985 to<br>7.035 | 5.320 to<br>6.055 | 5.320 to 6.125 | | DIV | 8.085 to<br>9.625 | 8.295 to<br>9.940 | 7.665 to<br>9.065 | 7.665 to 9.065 | | Floating Point Group | | | | | | FAD | 13.125 to<br>27.650 | 13.300 to<br>27.825 | 12.195 to<br>27.440 | 12.985 to<br>27.510 | | FDV | 34.020 to<br>47.320 | 34.195 to<br>47.495 | 33.810 to<br>47.110 | 33.880 to<br>47.180 | | FIX | 4.302 to<br>7.595 | 4.375 to<br>7.665 | 4.060 to<br>7.350 | 4.130 to<br>7.420 | | FUT | 6.965 to<br>10.815 | 7.000 to<br>10.850 | 6.965 to<br>10.815 | 6.965 to<br>10.815 | | FMP | 25.480 to<br>35.105 | 25.655 to<br>35.280 | 25.270 to 34.895 | 25.340 to<br>34.965 | | FSB | 13.825 to<br>29.435 | 14.000 to<br>29.610 | 13.615 to<br>29.225 | 13.685 to<br>29.295 | | Extended Instruction Group (Index Register Instructions) | | | | | | CAX,CBX,CAY,CBY<br>CXA,CXB,CYA,CYB | 1.435 | 1.505 | 1.295 | 1.295 | | XAX,XBX,XAY,XBY | 2.065 | 2.170 | 1.925 | 1.925 | | DSX,DSY (no skip) | 2.030 | 2.170 | 1.750 | 1.750 | | (skip) | 2.520 | 2.730 | 1.995 | 2.065 | | ISZ,ISY (no skip) | 2.030 | 2.170 | 1.750 | 1.750 | | (skip) | 2.520 | 2.730 | 1.750 | 1.750 | | LDX,LDY | 3.045 | 3.185 | 2.660<br>0.805 | 2.730<br>0.875 | | Each Indirect Level | 1.190<br>3.430 | 1.330<br>3.570 | 2.940 | 2.940 | | STX,STY Each Indirect Level | 3.430<br>1.190 | 1.330 | 0.805 | 0.875 | | LAX,LBX,LAY,LBY | 3.745 | 3.885 | 3.185 | 3.255 | | Each Indirect Level | 1.190 | 1.330 | 0.805 | 0.875 | | SAX,SAY,SBX,SBY | 3.815 | 3,885 | 3.465 | 3.465 | | Each Indirect Level | 1 190 | 1.330 | 0.805 | 0.875 | | ADX,ADY | 2.975 | 3.045 | 2.730 | 2.800 | | Each Indirect Level | 1.190 | 1.330 | 0.805 | 0.875 | | JLY | 2.800 | 2.905 | 2.660 | 2.660<br>0.875 | | Each Indirect Level | 1.190 | 1.330 | 0.805 | 2.275 | | JPY | 2.625 | 2.835 | 2.275 | | Table 3-5. Typical Base Set Instruction Execution Times<sup>1</sup> (sheet 3 of 3) | INSTRUCTION | EXECUTION TIME (us) | | | | | | | | |---------------------------------------|---------------------|--------------------|---------------|------------------|--|--|--|--| | | Standard Po<br>Men | erformance<br>nory | | formance<br>nory | | | | | | | Non-DMS | DMS | Non-DMS | DMS | | | | | | Extended Instruction Group<br>(Cont.) | | | | | | | | | | (Byte Manipulation Instructions) | | | | | | | | | | LBT (from high byte) | 3.780 | 3.885 | 3.640 | 3.640 | | | | | | (from low byte) | 3.500 | 3.605 | 3.360 | 3.360 | | | | | | SBT (to high byte) | 4.830 | 4.970 | 4.340 | 4.410 | | | | | | (to low byte) | 4.445 | 4.620 | 3.885 | 4.025 | | | | | | MBT | 4.270 | 4.515 | 3.745 | 3.815 | | | | | | | +4.235/ | +4.340/ | +4.045/ | +4.080/ | | | | | | Each Indirect Level | byte | byte | byte | byte | | | | | | | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | СВТ | 4.270 | 4.515 | 3.745 | 3.815 | | | | | | | +4.445/ | +4.550/ | +4.480/ | +4.480/ | | | | | | Each Indirect Level | byte | byte | byte | byte | | | | | | | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | SFB (if compare exit) | 2.170 | 2.240 | 1.9 <b>25</b> | 1.995 | | | | | | | +2.735/ | +2.770/ | +2.735/ | +2.735/ | | | | | | (if terminal exit) | byte | byte | byte | byte | | | | | | | 2.590 | 2.660 | 2.450 | 2.450 | | | | | | | +2.735/ | +2.770/ | +2.735/ | +2.735/ | | | | | | | byte | byte | byte | byte | | | | | | (Word Manipulation Instructions) | | | | | | | | | | CMW | 4.270 | 4.515 | 3.745 | 3.815 | | | | | | | +2.870/ | +3.010/ | +2.380/ | +2.520/ | | | | | | Each Indirect Level | word | word | word | word | | | | | | | 1.190 | 1,330 | 0.805 | 0.875 | | | | | | MVW | 4.270 | 4.515 | 3.745 | 3.815 | | | | | | | +1.750/ | +1.820/ | +1.680 | +1.680 | | | | | | | word | word | word | word | | | | | | Each Indirect Level | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | (Bit Manipulation Instructions) | | | | | | | | | | CBS,SBS | 5.215 | 5.425 | 4.480 | 4.550 | | | | | | Each Indirect Level | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | TBS (no skip) | 5.355 | 5,565 | 4.935 | 4.935 | | | | | | (skip) Each Indirect Level | 5.670 | 5.950 | 4.725 | 4.795 | | | | | | | 1.190 | 1.330 | 0.805 | 0.875 | | | | | | Each intorrect Level | 1.190 | 1.330 | 0.805 | 0.875 | | | | | <sup>&</sup>lt;sup>1</sup> Semiconductor memory refresh may increase program execution times by up to 3%. <sup>&</sup>lt;sup>2</sup> Depends on which I/O time period (T2,3,4,5,6) the instruction begins. 4-2. The basic addressing space of the HP 21MX E-Series computer is 32,768 words, which is referred to as logical memory. The amount of MOS memory actually installed in the computer system is referred to as physical memory. An HP 21MX E-Series computer with the optional Dynamic Mapping System (DMS) has an addressing capability for one million words of physical memory. The DMS allows logical memory to be mapped into physical memory through the use of four dynamically alterable memory maps. Figure 4-2. Expanded Memory Addressing Scheme MAP REGISTER LOADING #### 4-1. **MEMORY ADDRESSING** The basic memory addressing scheme provides for addressing 32 pages of logical memory, each of which consists of 1,024 words. This memory is addressed through a 15-bit memory address bus shown in figure 4-1. The upper 5 bits of this bus provide the page address and the lower 10 bits provide the relative word address within the page. # Conversion of the basic 16-bit word data format to and from the map register 12-bit word data format is shown in figure 4-3. Bits 13 through 10 of the basic data format are not used by the memory map registers. Read and write memory protect violations are discussed in paragraph 4-3. Figure 4-1. Basic Memory Addressing Scheme The Memory Expansion Module (MEM), which is part of the DMS option, converts the 5-bit page address into a 10-bit page address and thereby allows 1,024 (210) pages to be addressed. This conversion is accomplished by allowing the original 5-bit address to identify one of the 32 12-bit registers within a "memory map." Each of these map registers contains the new user-specified 10-bit page address. This new page address is combined with the original 10-bit relative address to form a 20-bit memory address bus as shown in figure 4-2. BIT 11 SET= READ PROTECTED PAGE BIT 10 SET= WRITE PROTECTED PAGE Figure 4-3. Basic Word Format Vs Map Register Format #### 4-3. STATUS AND VIOLATION REGISTERS The MEM also includes a status register and a violation register. As shown in table 4-1, the MEM status register Dynamic Mapping System 21MXE contents enable the programmer to determine whether the MEM was enabled or disabled at the time of the last interrupt and the address of the base page fence. The MEM violation register contents enable the programmer to determine whether a fault occurred in the hardware or the software so that the proper corrective steps may be taken. Refer to table 4-2. Table 4-1. MEM Status Register Format | BIT | SIGNIFICANCE | |-----------|--------------------------------------------------------------------------------------| | 15 | 0 = MEM disabled at last interrupt<br>1 = MEM enabled at last interrupt | | 14 | 0 = System map selected at last interrupt<br>1 = User map selected at last interrupt | | 13 | 0 = MEM disabled currently<br>1 = MEM enabled currently | | <b>12</b> | 0 = System map selected currently<br>1 = User map selected currently | | 11 | 0 = Protected mode disabled currently 1 = Protected mode enabled currently | | 10 | Portion mapped* | | 9 | Base page fence bit 9 | | 8 | Base page fence bit 8 | | 7 | Base page fence bit 7 | | 6 | Base page fence bit 6 | | 5 | Base page fence bit 5 | | 4 | Base page fence bit 4 | | 3 | Base page fence bit 3 | | 2 | Base page fence bit 2 | | | Base page fence bit 1 | | 0 | Base page fence bit 0 | | *Bit 10 | Mapped Address (M) | | |---------|-------------------------------|------| | 0 | Fence ≤ M < 2000 <sub>8</sub> | 1.14 | | 1 | 1 < M < Fence | | Note: The base page fence separates the reserved (mapped) memory from the shared (unmapped) memory. Bit 10 specifies which area is reserved (mapped). (Refer to LFA and LFB instructions contained in paragraph 4-6.) Table 4-2. MEM Violation Register Format | BIT | SIGNIFICANCE | |------------------|--------------------------------------------------------------------------| | 15 | Read violation* | | 14 | Write violation* | | 13 | Base page violation* | | 12 | Privileged instruction violation* | | 11 | Reserved | | 10 | Reserved | | 9 | Reserved | | 8 | Reserved | | 7 | 0 = ME bus disabled at violation<br>1 = ME bus enabled at violation | | 6 | 0 = MEM disabled at violation<br>1 = MEM enabled at violation | | 5 | 0 = System map enabled at violation<br>1 = User map enabled at violation | | 4 | Map address bit 4 | | 6. <b>3</b> 6. 6 | Map address bit 3 | | 2 | Map address bit 2 | | | Map address bit 1 | | 0 | Map address bit 0 | Any attempt to read from a read-protected page will result in a read violation and the memory read will not occur. Any attempt to write into a write-protected page will result in a write violation and the memory will not be altered. In addition, if a page is write protected, a jump or jump indirect instruction to that page will cause a write violation and the jump will not occur. It should be noted that all violation rules are ignored for DCPC signals. If a read or write violation occurs, the MEM signals the memory protect logic that a violation has occurred which causes the memory protect logic to generate an interrupt. As discussed in paragraph 6-3, memory violations are interrupted to select code 05 and a DMS violation can be distinguished from a memory protect violation by executing an SFS 05 instruction. If the skip occurs, DMS is in violation; if no skip occurs, memory protect is in violation. #### 4-4. MAP SEGMENTATION All registers within the memory map are dynamically alterable. To maximize the system performance capability, the MEM includes four separate memory maps: the User Map, System Map, and two Dual-Channel Port Controller (DCPC) Maps. (See figure 4-4.) These maps, which are manipulated through the use of 38 machine-language instructions, are addressed as a contiguous register block. It should be noted that the base page fence applies to both the System Map and the User Map. Figure 4-4. Map Segmentation #### 4-5. POWER FAIL CHARACTERISTICS A power failure automatically enables the System Map, and a minimum of 500 microseconds is assured the programmer for executing a power fail routine. Since all maps are disabled and none are considered valid upon the restoration of power, the power fail routine should include instructions to save as many maps as desired. #### 4-6. DMS INSTRUCTION CODING Machine language coding and definitions of the 38 Dynamic Mapping System instructions are provided on this and following pages. A sample map load and enable routine is given in paragraph 4-8. Disables the translation and protection features of the MEM hardware. Prior to disabling, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Disables the translation and protection features of the MEM hardware. Prior to disabling, the P-register is set one count past the effective memory address (m + 1) and the return address is stored in location m. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Causes the status of the MEM to be restored. This is a three-word instruction where Word 1 = Instruction code, Word 2 = Status word address, and Word 3 = Jump address. Only bits 15 and 14 of the status word are used; the remaining bits (13-0) of the status word are ignored. Bits 15 and 14 restore the MEM status as follows: Bit $$15 = 0 = MEM$$ will be disabled = $1 = MEM$ will be enabled As a result of executing this instruction, normal I/O interrupt are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. # LFA LOAD FENCE FROM A 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 0 0 6 0 1 1 1 1 0 1 0 1 1 1 Loads the contents of the A-register into the base page fence register. Bits 9-0 of the A-register specify the address in page zero where shared (unmapped) memory is separated from reserved (mapped) memory. Bit 10 is used as follows to specify which portion is mapped: | Bit 10 | Mapped Address (M) | |--------|--------------------------------------| | 0 | Fence $\leq$ M $<$ 2000 <sub>8</sub> | | 1 | 1 $<$ M $<$ Fence | This instruction will normally generate an MEM violation when executed in the protected mode; however, it is allowed if the System map is enabled. When an MEM violation does occur, the fence is not altered. | LFB | i | | | | | | ١ | LO. | AD | FE | EN( | Œ | FR | ON | 1 B | |-----|---|---|---|---|---|----|---|-----|----|----|-----|---|----|----|-----| | | | | | | | 9 | | | | | | | | | | | 1 | 0 | Û | 0 | 1 | 0 | 1. | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | | Loads the contents of the B-register into the base page fence register. Bits 9-0 of the B-register specify the address in page zero where shared (unmapped) memory is separated from reserved (mapped) memory. Bit 10 is used as follows to specify which portion is mapped: | Bit 10 | Mapped Address (M) | |--------|-----------------------------------------------------------| | 0 | Fence $\leq$ M $<$ 2000 <sub>8</sub><br>1 $<$ M $<$ Fence | This instruction will normally generate an MEM violation when executed in the protected mode; however, it is allowed if the System map is enabled. When an MEM violation does occur, the fence is not altered. ## MBF MOVE BYTES FROM ALTERNATE MAP | 15 | 14 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-------|----|----|----|---|---|---|---|---|---|---|---|---|---| | | | T | | T. | | | | | | 0 | 0 | 0 | | 1 | Moves a string of bytes using the alternate program map for source reads and the currently enabled map for destination writes. The A-register contains the source byte address and the B-register contains the destination byte address. The initial byte addresses in the A- and B-registers must be even byte addresses. The byte in bits 15 through 8 of a word is the even byte. The X-register contains the octal number of bytes to be moved. The number of bytes to be moved is restricted to a positive integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. Both the source and destination must begin on word boundaries. The instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction can cause an MEM violation only if read or write protection rules are violated. | МВ | I | | | | | | IN | ITC | ) A | | | | | | ES<br>IAP | |---------------------|---------------|--|--|--|--|---|----|-----|-----|---|---|---|---|---|-----------| | 15 14 13 12 11 10 9 | | | | | | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1 | 1 0 0 0 1 0 1 | | | | | | | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Moves a string of bytes using the currently enabled map for source reads and the alternate program map for destination writes. The A-register contains the source byte address and the B-register contains the destination byte address. The initial byte addresses in the A- and B-registers must be even byte addresses. The byte in bits 15 through 8 of a word is the even byte. The X-register contains the octal number of bytes to be moved. The number of bytes to be moved is restricted to a positive integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. Both the source and destination must begin on word boundaries. The instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction will always cause an MEM violation when executed in the protected mode and no bytes will be transferred. | MΒ | N | | | | | W | /IΤ | ш | N A | LT | | | TE | | | |----|----|----|----|---------------------|---|---|-----|---|-----|----|---|---|----|---|---| | 15 | 14 | 13 | 12 | 11 10 9 8 7 6 5 4 3 | | | | | | | | | | 1 | 0 | | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | | 0 | 0 | 0 | 1 | 0 | 0 | Moves a string of bytes with both the source and destination addresses established through the alternate program map. The A-register contains the source byte address and the B-register contains the destination byte address. The initial byte addresses in the A- and B-registers must be even byte addresses. The byte in bits 15 through 8 of a word is the even byte. The X-register contains the octal number of bytes to be moved. The number of bytes to be moved is restricted to a positive integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. Both the source and destination must begin on word boundaries. The instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction will always cause an MEM violation when executed in the protected mode and no bytes will be transferred. | MW | F | | | | | | FR | ON | / A | | | | XTE | | . – - | |----|----|----|--------------------------------|---------------------------|--|--|----|----|-----|--|--|--|-----|--|-------| | 15 | 14 | 13 | 3 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | | 1 | 0 | 0 | 0 | 0 1 0 1 1 1 1 0 0 0 1 1 0 | | | | | | | | | | | | MOVE WORDS Moves a string of words using the alternate program map for source reads and the currently enabled map for destination writes. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. The number of words to be moved is restricted to a positive integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. The instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction can cause an MEM violation only if read and write protection rules are violated. | MW | 1 | | | | | | | IN | )TC | ) A | | | | W<br>TE | | | |---------------------|---------------|--|--|--|--|--|--|----|-----|-----|---|---|---|---------|---|---| | 15 14 13 12 11 10 9 | | | | | | | | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1 | 1 0 0 0 1 0 1 | | | | | | | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | Moves a string of words using the currently enable map for source addresses and the alternate program map for destination addresses. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. The number of words to be moved is restricted to a positive integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. The instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction will always cause an MEM violation when executed in the protected mode and no words will be transferred. | MW | W | | | | | W | /IΤ | ни | N A | ا<br>LT | | NA<br>RNA | | | | |----|----|----|------------------------------|---|---|---|-----|----|-----|---------|---|-----------|---|--|---| | 15 | 14 | 13 | 12 11 10 9 8 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | | 1 | | 0 | 0 | 1 | 0 | 1 | | 1 | 1 | 0 | 0 | 0 | 1 | | 1 | Moves a string of words with both the source and destination addresses established through the alternate program map. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. The number of words to be moved is restricted to a integer greater than zero. If the contents of the X-register is zero, the instruction will be a NOP. If the contents of the X-register is a negative integer, a large indeterminate block of memory will be transferred. The instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction will always cause an MEM violation when executed in the protected mode and no words will be transferred. #### PAA LOAD/STORE PORT A MAP PER A | 15 14 13 1 | 2 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|-----|------|---|---|---|---|---|---|---|---|---|---| | 1000 | | 0 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | Transfers the 32 Port A map registers to or from memory. If bit 15 of the A-register is clear, the Port A map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the Port A map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause an MEM violation. An attempt to store the Port A map is allowed within the constraints of write protected memory. #### PAB LOAD/STORE PORT A MAP PER B | 15 14 13 | | | | | | | | | | | 1 | 0 | |----------|---|---|---|---|---|---|---|---|---|---|---|---| | 100 | 8 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | Transfers the 32 Port A map registers to or from memory. If bit 15 of the B-register is clear, the Port A map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the Port A map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause an MEM violation. An attempt to store the Port A map is allowed within the constraints of write protected memory. Transfers the 32 Port B map registers to or from memory. If bit 15 of the A-register is clear, the Port B map is *loaded* from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the Port B map is *stored* into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause an MEM violation. An attempt to store the Port B map is allowed within the constraints of write protected memory. #### PBB LOAD/STORE PORT B MAP PER B | 15 14 13 12 | 11 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|-------|---|---|---|---|---|---|---|---|---|---| | 1000 | 1 0 | 1 | | 1 | 1 | | 0 | 1 | 0 | 1 | 1 | Transfers the 32 Port B map registers to or from memory. If bit 15 of the B-register is clear, the Port B map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the Port B map is stored into memory starting at the address specified in bit 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause an MEM violation. An attempt to store the Port B map is allowed within the constraints of the write protected memory. #### RSA READ STATUS REGISTER INTO A | 15 14 13 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|----|----|---|---|---|---|---|---|---|---|---|---| | 1 0 0 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Reads the contents of the MEM status register into the A-register. This instruction can be executed at any time. The format of the MEM status register is given in table 4-1. #### RSB READ STATUS REGISTER INTO B | 15 14 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|----|----|----|---|---|---|---|---|---|---|---|---|---| | 1 0 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Reads the contents of the MEM status register into the B-register. This instruction can be executed at any time. The format of the MEM status register is given in table 4-1. #### RVA READ VIOLATION REGISTER INTO A | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | <br> | _ | | | | 0 | |----|----|----|----|----|----|---|---|---|------|---|---|---|---|---| | | | | | 0 | V | | | | · | 1 | 1 | 0 | 0 | 1 | Reads the contents of the MEM violation register into the A-register. This instruction can be executed at any time. The format of the MEM violation register is given in table 4-2 Reads the contents of the MEM violation register into the B-register. This instruction can be executed at any time. The format of the MEM violation register is given in table 4-2. Causes the MEM hardware to use the set of 32 map registers, referred to as the System map, for translating all programmed memory references. Prior to enabling the System map, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed and effectively executes a JMP \*+1.I. Causes the MEM hardware to use the set of 32 map registers, referred to as the System map, for translating all programmed memory references. Prior to enabling the System map, the P-register is set one count past the effective memory address (m+1). After enabling the System map, the return address is stored in m. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the system map is enabled, the instruction is allowed and effectively executes a JSB \*+1,I. Stores the 16-bit contents of the MEM status register into the address memory location. The status register contents are not altered. This instruction is used in conjunction with the JRS instruction to allow easy processing of interrupts, which always select the System map (if the MEM is enabled). The format of the MEM status register is listed in table 4-1. This instruction can cause an MEM violation only if write protection rules are violated. Transfers the 32 System map registers to or from memory. If bit 15 of the A-register is clear, the System map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the System map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause an MEM violation. An attempt to store the System map is allowed within the constraints of write protected memory. | SYB | | | | | _ , | | | | _ | TEI | | | | | | |-----|----|----|----|----|-----|---|---|---|---|-----|---|---|---|---|---| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | 1 | | | | | | | 0 | 1 | 0 | 0 | 0 | Transfers the 32 System map registers to or from memory. If bit 15 of the B-register is clear, the System map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the System map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause an MEM violation. An attempt to store the System map is allowed within the constraints of write protected memory. Causes the MEM hardware to use the set of 32 map registers, referred to as the User map, for translating all programmed memory references. Prior to enabling the User map, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Causes the MEM hardware to use the set of 32 map registers, referred to as the User map, for translating all pro- grammed memory references. Prior to enabling the User map, the P-register is set one count past the effective memory address (m+1). After enabling the System map, the return address is stored in m. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate an MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. | USA | | | L | AC | D/S | TO | RE | U | SE | R | MΑ | PF | PER | A | |-------|----|----|----|---------|-----|----|----|---|----|---|----|----|-----|---| | 15 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | 0 | A SHEET | | | | | | 0 | 1 | 0 | 0 | 1 | Transfers the 32 User map registers to or from memory. If bit 15 of the A-register is clear, the User map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the User map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause an MEM violation. An attempt to store the User map is allowed within the constraints of write protected memory. Transfer the 32 User map registers to or from memory. If bit 15 of the B-register is clear, the User map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the User map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. Any attempt to load any map in the protected mode will cause an MEM violation. An attempt to store the User map is allowed within the constraints of write protected memory. Compares the contents of the A-register with the contents of the addressed memory location. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances three counts instead of two counts. If the two words are identical, the next instruction is executed. Neither the A-register contents nor memory cell contents are altered. This instruction uses the alternate program map to determine the addressed memory location. If the MEM is currently disabled, then a compare directly with physical memory occurs. This instruction will cause an MEM violation only if read protection rules are violated. Compares the contents of the B-register with the contents of the addressed memory location. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances three counts instead of two counts. If the two words are identical, the next instruction is executed. Neither the B-register contents nor memory cell contents are altered. This instruction uses the alternate program map to determine the addressed memory location. If the MEM is currently disabled, then a compare directly with physical memory occurs. This instruction will cause an MEM violation only if read protection rules are violated. Loads the contents of the specified memory address into the A-register. The contents of the memory cell are not altered. This instruction uses the alternate program map to fetch the operand. If the MEM is currently disabled, then a load directly from physical memory occurs. This instruction will cause an MEM violation only if read protection rules are violated. Loads the contents of the specified memory address into the B-register. The contents of the memory cell are not altered This instruction uses the alternate program map to fetch the operand. If the MEM is currently disabled, then a load directly from physical memory occurs. This instruction will cause an MEM violation only if read protection rules are violated. Transfers a copy of the entire contents (32 map registers) of the System map or the User map to the Port A map or the Port B map as determined by the control word in the A-register: | Bit* | Significance | | | | | | | | | |------|----------------------------------|--|--|--|--|--|--|--|--| | 15 | 0 = System Map<br>1 = User Map | | | | | | | | | | 0 | 0 = Port A Map<br>1 = Port B Map | | | | | | | | | <sup>\*</sup>Bits 14-1 are ignored. This instruction will always generate an MEM violation when executed in the protected mode. | ХМВ | | | | | | | | | TRANSFER MAPS<br>INTERNALLY PER B | | | | | | | | | |-----|----|----|----|----|----|---|---|---|-----------------------------------|---|---|---|---|---|---|--|--| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 4 | 1 | | Ű. | | I | 1 | 1 | 1 | 1 | Ĺ | 1 | 0 | 0 | 1 | 0 | | | Transfers a copy of the entire contents (32 map registers) of the System map or the User map to the Port A map or the Port B map as determined by the control word in the B-register: | Bit* | Significance | |------|----------------------------------| | 15 | 0 = System Map<br>1 = User Map | | 0 | 0 = Port A Map<br>1 = Port B Map | \*Bits 14-1 are ignored. This instruction will always generate an MEM violation when executed in the protected mode. | XMI | •• | | | - | | | _ | ER MAPS OR MEMOR | | | | | | | | |-----|----|----|----|----|----|---|---|------------------|---|---|---|---|---|---|---| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Ō | | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | Transfers a number of words either from sequential memory locations to sequential map registers or vice versa. The A-register points to the first map register to be accessed and the B-register points to the first word of a group of words (table) in sequential memory locations. The X-register indicates the number of maps (0 to 127<sub>10</sub>) to be transferred. If the content of the X-register is a positive integer, words are moved from memory to map registers; if the content is a negative integer, words are moved from map registers to memory. Map registers are addressed as a contiguous space and a wraparound count from 127 to 0 can and will occur. It is the programmer's responsibility to avoid this error. The contents of the maps are transferred in blocks of 16 registers or less. This instruction is interruptible only after each block has been completely transferred. An attempt to load any map register in the protected mode will generate an MEM violation. An attempt to store map registers is allowed within the constraints of write protected memory. # XMS TRANSFER MAPS SEQUENTIALLY 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 0 0 1 0 1 1 1 1 0 1 0 0 0 1 Transfers a number of words to sequential map registers. The A-register points to the first register to be accessed, the B-register contains the base quantity, and the X-register indicates the number of maps (0 to 127 $_{10}$ ) to be loaded. If the contents of the X-register is a positive integer, the contents of the B-register will be used as the base quantity to be loaded into the first map register. The second register will be loaded with the base quantity plus one, the third register will be loaded with the base quantity plus one, the third register will be loaded with the base quantity plus two, and so forth up to the number of map registers specified in the X-register. If the contents of the X-register is less than or equal to zero, an effective NOP will occur, leaving the contents of the A-, B-, and X-registers unaltered. This instruction is interruptible after each group of 16 registers has been transferred. The A-, B-, and X-registers are then reset to allow reentry at a later time. The X-register will always be zero at the completion of the instruction and the A- and B-registers will be advanced by the number of registers moved. An attempt to load any map register in the protected mode will generate an MEM violation. Stores the contents of the A-register into the addressed memory location. The previous contents of the memory cell are lost; the A-register contents are not altered. This instruction uses the alternate program map for the write operation. If the MEM is currently disabled, then a store directly into physical memory occurs. This instruction will always cause an MEM violation when executed in the protected mode. Stores the contents of the B-register into the addressed memory location. The previous contents of the memory cell are lost; the B-register contents are not altered. This instruction uses the alternate program map for the write operation. If the MEM is currently disabled, then a store directly into physical memory occurs. This instruction will always cause an MEM violation when executed in the protected mode. # 4-7. INSTRUCTION EXECUTION TIMES Table 4-3 lists the execution times required for the various DMS instructions. # 4-8. SAMPLE MAP LOAD/ENABLE ROUTINE Table 4-4 provides a sample DMS map load and enable routine. This routine begins by loading 32 registers for the System map and 32 registers for the User map and continues by setting the Port A map to the area for User number one. The Port B map is then set to point into a new area where a third User's program would be loaded. Next, the Base Page Fence is set so that the System Fence value is used. Finally, the mapping functions of the DMS are enabled and program control is transferred to the System area beginning at address $1000_8$ . #### 4-9. ADDITIONAL DMS DEFINITIONS The following paragraphs further define the terms "alternate map" and "protected mode" and contain definitive discussions for MEM violations and DCPC operation in a DMS environment. #### 4-10. ALTERNATE MAP If the system map is currently enabled, the user map is the alternate map. If the user map is currently enabled, the system map is the alternate map. The DCPC maps are never the alternate maps. #### 4-11. PROTECTED MODE If the DMS and memory protect are enabled, the computer is in the protected mode. DMS will operate in the unprotected mode (DMS enabled, memory protect disabled), but none of the DMS safeguards will be operative. #### 4-12. MEM VIOLATIONS The MEM violations are designed to safeguard DMS. The four types of violations are read protect, write protect, base page, and privileged instruction. Throughout the following paragraphs, references to logical memory refers to the memory address before mapping and references to physical memory refers to the memory address after mapping. If the computer is in the protected mode and bit 11, the read protect bit, of a system or user map register equals 1, any attempt by the system or user to read from the associated memory page causes a read protect violation and the read does not occur. If the computer is in the unprotected mode, the read occurs. In either case, bit 15 of the MEM violation register will be set to 1. For example, suppose the computer is in the protected mode and the system or user map register 3 contains 4043<sub>8</sub>. Any attempt by the system or user to read from page 43<sub>8</sub> using map register 3 (i.e., read from physical addresses in the $106000_8$ to $107777_8$ range), causes a read protect violation. If the computer is in the protected mode and bit 10, the write protect bit, of a system or user map register equals 1, any attempt by the system or user to write onto the associated memory page causes a write protect violation and the write does not occur. If the computer is in the unprotected mode, the write occurs. In either case, bit 14 of the MEM violation register will be set to 1. For example, suppose the computer is in the protected mode and the system or user map register 3 contains 2043<sub>8</sub>. Any attempt by the system or user to write onto page 43<sub>8</sub> using map register 3 (i.e., write onto physical addresses in the $106000_8$ to $107777_8$ range), causes a write protect violation. If the computer is in the protected mode, any attempt by the system or user to write onto the physical base page causes a base page violation and the write does not occur. If the computer is in the unprotected mode, the write occurs. In either case, bit 13 of the MEM violation register will be set to 1. For example, suppose the computer is in protected mode, the system or user map register 0 contains $0040_8$ , the base page fence is set at $1000_8$ , and bit 10 of the MEM status register equals 1 (i.e., logical addresses below the base page fence are mapped). If the system or user attempts to write to a logical memory address of 1500<sub>8</sub>, MEM detects that the base page addresses above the base page fence are not mapped and begins to access physical memory address 1500<sub>8</sub>. However, MEM then detects that a write to physical base page is being attempted which causes a base page violation and the write does not occur. If the computer was in the unprotected mode, the write would have occurred. In either case, bit 13 of the MEM violation register will be set to 1. If the system or user attempts to write to a logical memory address of 5008, MEM detects that addresses below the base page fence are mapped and begins to access physical memory address $100000_8 + 500_8 = 100500_8$ where the write will occur providing standard memory protect is not violated. Note that standard memory protect checks the logical address (i.e., 500<sub>8</sub>), not the physical address (i.e., 100500<sub>8</sub>). Reading from logical or physical base page will not generate a base page violation. From the previous discussion, it can be seen that a DMS memory space has its base page in two pieces which may or may not be contiguous. Regardless, the total base page available for any DMS memory space is 1024 locations. The part of the physical base page accessible by all memory spaces is also referred to as the unmapped or shared part of the base page. Note that the logical addresses of 0 and 1 access the A and B registers, respectively. If the computer is in the protected mode, any attempt by the user to load into any MEM register, except the MEM address register, will cause a privileged instruction violation and the load will not occur. Any attempt by the system to load into any of the MEM map registers will cause a privileged instruction violation and the load will not occur. If the computer is in the unprotected mode, the load occurs. In either case, bit 12 of the MEM violation register will be set to 1. The system can always load into the MEM state register or MEM fence register. Under microprogrammed control the user can always load into the MEM state register or MEM fence register. The system or user can always load into the MEM address register, and can always read the MEM map registers. All MEM violations cause an interrupt to select code 5. Instruction SFS 5 will skip only for an MEM violation, allowing DMS interrupts to be differentiated from memory protect or parity error interrupts. # 4-13. DCPC OPERATION IN A DMS ENVIRONMENT DCPC activity disables the MEM violation logic. Therefore, the DCPC's can read or write physical memory without generating MEM violations. Note that mapping remains enables during DCPC activity and that the base page partitioning is the same. For example, if a DCPC input transfer were aimed at logical memory addresses 0 to 777778, which happened to map to physical addresses 1000008 to 1777778, and the conditions cited in the base page examples prevailed, then the input data would be written into physical addresses 1000008 to 1007778, 10008 to 177778, and 1020008 to 1777778. 21MXE Dynamic Mapping System Table 4-3. Typical DMS Instruction Execution Times (sheet 1 of 2) | INSTRUCTION | EXEC | CUTION TIME (us) | | |------------------------------|-----------------------------------|-------------------------------|-------------------| | | Standard<br>Performance<br>Memory | High<br>Performance<br>Memory | | | DJP,SJP ' | 3.745 | 3.290 | | | Each Indirect Level | 1.330 | 0.875 | | | DJS,SJS | 4.410 | 3.710 | | | Each Indirect Level | | 0.875 | | | JRS | 5.320 to | 4.340 to | | | | 6.055 | 5.215 | | | Each Indirect Level | 1.330 | 0.875 | | | LFA/B<br>Each Indirect Level | 2.170 | 2.100 | | | MBF | 1.330 | 0.875 | | | | 4.935 to | 4.900 to | | | | 8.260<br>+1.820/ | 7.490 | <b>化</b> 可模式 2006 | | | # 1.620/<br>byte | +1.680/<br>byte | | | MBI | 4.760 to | 4.725 to | | | | 8.120 | 7.385 | | | | +1.820/ | +1.680/ | | | | byte | byte | | | MBW | 4.935 to | 4.900 to | | | | 7.490 | 6.965 | | | | +1.995/ | +1.680/ | | | | byte | byte | | | MWF | 2.765 | 2.520 | | | | +1.820/ | +1.680/ | | | | word | word | | | MWI,MWW | 2.590 | 2.520 | | | | +1.820/ | +1.680/ | | | PAA/B 4 JA | word | word | | | PAA/B (load)<br>(store) | 50.505 | 42.420 | | | PBA/B (load) | 47.145 | 35.665 | | | (store) | 50.680 | 42.595 | | | SYA/B (load) | 47.320 | 35.840 | | | (store) | 50.330 | 42.245 | | | RSA/B | 45.955 | 34.510 | | | RVA/B | 2.170<br>2.170 | 1.715 | | | SSM | | 1.680 | | | Each Indirect Level | 3.710<br>1.330 | 3.360 | | | UJP | 3.500 | 0.875 | | | Each Indirect Level | 1.330 | 3.010 | | | UJS | 4.165 | 0.875 | | | Each Indirect Level | 1.330 | 3.430<br>0.875 | | | USA/B (load) | 50.400 | | | | (store) | 46.025 | 42.345<br>34.580 | | | XCA/B (no skip) | 3.570 | 34.580 | | | (skip) | 4.235 | 3.500 | | | Each Indirect Level | 1.330 | 3.500<br>0.875 | | | XLA/B | 3.500 | 3.255 | | | Each Indirect Level | 1.330 | 0.875 | | | | | | | Table 4-3. Typical DMS Instruction Execution Times (sheet 2 of 2) | INSTRUCTION | | EXECUTION TIME (us) | | |------------------------------|-------------------------------------------------|-------------------------------------------------|--| | | Standard<br>Performance<br>Memory | High<br>Performance<br>Memory | | | XMA/B | 28.980 to<br>29.750 | 28.735 to<br>29.255 | | | XMM (from memory to map) | 4.165<br>+1.820/<br>word<br>+0.175/<br>16 words | 3.920<br>+1.575/<br>word<br>+0.175/<br>16 words | | | (from map to memory) | 4.270<br>+1.470/word<br>+0.175/<br>16 words | 4.025<br>+1.330/<br>word<br>+0.175<br>16 words | | | XMS | 4.095<br>+1.330/<br>word<br>+0175/<br>16 words | 3.850<br>+1.330/<br>word<br>+0.175/<br>16 words | | | XSA/B<br>Each Indirect Level | 3.570<br>1.330 | 3.080<br>0.875 | | # MICROPROGRAMMING V This section contains an introductory discussion of Hewlett-Packard's microprogramming techniques and development. For additional information, refer to the HP 21MX E-Series Computer Microprogramming Reference Manual, part no. 02109-90004. # 5-1. THE MICROPROGRAMMED COMPUTER The control section of a computer is the portion of the computer that directs and controls the other sections; i.e., the memory section, input-output section, and the arithmetic-logic section. In totally hardwired computers, the control section logic is normally "spread out" physically throughout the computer. This design approach makes it impossible to enhance the computer's instruction set without redesign. In contrast, E-Series computers have a fully microprogrammed control section, which means that the sequence in which the control functions are performed are made programmable through the use of a technique called microprogramming. The action taken when any one of the E-Series base set of 128 assembly language instructions is executed is determined by a microprogram associated with the assembly language instruction (these microprograms reside in a special memory called control store); the control section oversees the translation and controls the execution of the microprogram. With this design approach, instruction set enhancements can be made by changing or adding to the set of microprograms that control the machine's execution. Many computers are microprogrammed; however, Hewlett-Packard has taken the concept one step further to offer the power of microprogramming to the user. # 5-2. THE MICROPROGRAMMABLE COMPUTER E-Series computer users can more fully take advantage of the computer's power by utilizing microprogramming. The microprogrammer has more instructions, a more flexible word format, more registers, and faster execution times to work with than does the assembly language programmer. The microinstruction word length is 24 bits which enables concurrent operations to be performed in a single instruction and provides an instruction set of 211 microinstructions. Microprogrammers can access 12 scratch pad registers in addition to those available to the assembly language programmer and have up to 16,384 24-bit words of memory (termed control store) in which to store microprograms. Up to three levels of nested subroutines are possible in E-Series computers. The microprogrammer works in a much faster environment than does the assembly language programmer for two reasons. One, since microinstructions have access to most of the internal parts of the computer's architecture, fewer memory fetches are required to accomplish most tasks. Two, the microinstruction execution time of 175 or 280 nanoseconds is much faster than the typical assembly instruction execution time of 1 to 2 microseconds. These capabilities are easily taken advantage of by E-Series computer users through the extensive support provided by Hewlett-Packard. Some of the more important benefits of Hewlett-Packard's microprogramming are given in the following paragraphs. #### 5-3. CUSTOMIZED INSTRUCTIONS Through the use of microprogramming, the computer's assembly language instruction set can be expanded with instructions tailored for specific applications. By adding special purpose instruction sets, the general purpose computer can be uniquely adapted for a certain job and thus become very efficient at that job. E-Series users can easily design their own instructions or purchase HP-supplied instruction sets such as the Dynamic Mapping System instructions or the Fast FORTRAN Processor. Applications that may be profitably microcoded include arithmetic calculations, I/O device driver programs, sorts and table searches, pseudo-DCPC operations, and special IBL loaders. Microprogramming is very similar to assembly language programming, although it is more powerful in many ways. Some knowledge of the internal structure of the computer is required, but once this knowledge is attained, the increased power and flexibility of microprogramming can ease the solution of many programming tasks. Microprograms are easily callable by assembly or higher level language programs. An extensive set of debugging aids, software analysis aids, and documentation is available to make microprogramming easy and efficient. #### 5-4. SYSTEM SPEED Microprogramming often-used routines will typically decrease program execution time by factors of two to ten and sometimes by as much as twenty or more. Software routines can be made to execute at the hardware speeds of the microprogram environment and the additional registers available to the microprogrammer can serve to eliminate many time-consuming memory fetches. Microprogramming 21MXE #### 5-5. MEMORY SPACE AND SECURITY By converting software routines into microprograms, space in main memory that would normally be required for time-critical routines can be freed for other uses. The routines remain instantly callable, as opposed to routines stored in a peripheral device. Microprograms are also less accessible than conventional software which affords a higher degree of security to microcoded routines. #### 5-6. DEVELOPING MICROPROGRAMS Developing microprograms is similar to developing assembly language programs; assembling and interactive debugging of microprograms is done with the aid of the standard HP Micro Assembler and Micro Debug Editor. Since the user will not normally want to microcode all of a certain program, some analysis is required to determine which segment(s) of the assembly language program can be most profitably converted to microcode. This analysis is easily done with the use of an HP contributed library program called the Activity Program Generator (ACP). The ACP enables the user to determine where in a program the CPU is spending most of its time; by substituting this section of code with a microprogrammed subroutine that is callable by the assembly or higher level program, overall execution time may often be reduced. Once the microprogrammer has determined what segment to implement in microcode, the microprogram is developed as shown in figure 5-1. The Micro Assembler program (in main memory) is used to assemble the source microprogram into an object program. Then, the object microprogram is loaded into Writable Control Store (WCS) with the aid of the Micro Debug Editor program. Interactive debugging may be performed with the aid of the Debug Editor while the object microprogram resides in WCS. When the microprogram is fully checked out, the user may choose to have his program reside permanently in programmable Read-Only Memory (pROM) or in WCS where it may be altered programmatically. Implementation in ROM is accomplished by programming the pROM's with a pROM writer and installing the programmed ROM's in the computer. The mask tapes shown in figure 5-1 are required by the pROM writer and are generated by the Debug Editor at the user's command. ROM-resident microprograms are permanent and do not have to be reloaded each time the computer is powered up; this implementation also prevents users from erroneously destroying the microprogram. The user who does not require such permanence for microprogram storage may skip the ROM burning step and execute his microcode from WCS. Microprograms used in this manner may be loaded with the WCS I/O utility routine and may be altered under program control to suit a variety of users. User-written microprograms are easily accessed by assembly or higher level programs. Once the microprogram is developed and loaded into control store, it may be called in a very similar manner to a software subroutine. # 5-7. SUPPORT FOR THE MICROPROGRAMMER Hewlett-Packard provides a comprehensive set of hardware manuals, software manuals, and training courses to make user microprogramming easy to learn and implement. For permanent implementation of microprograms, programmed pROM's may be installed in the HP 13304A Firmware Accessory Board or in the HP 13047A 2K User Control Store Board. The Firmware Accessory Board mounts under the main CPU board of the E-Series computer and is used to house Hewlett-Packard provided optional instruction sets such as the Dynamic Mapping System and the Fast FORTRAN Processor instructions. Additional space is available on this board for mounting 4K bit and 1K bit pROM's. Up to 2,048 24-bit words of control store in the form of 1K bit pROM's may be installed in the optional 2K User Control Store Board which occupies a slot in the I/O section of the computer mainframe. The 1K Writable Control Store (WCS) option provides a read-write control store module which can be used for the development and execution of user-supplied microprograms. Microprograms in WCS are executed at the same speed as those in the read-only control store. Each WCS module consists of a single card which plugs into the I/O PCA cage, thus eliminating the need for extensive cabling or an additional power supply. A WCS card contains 1,024 24-bit locations of Random-Access-Memory (RAM), including all necessary address and read/write circuits. WCS can be written into or read under computer control using standard input/output instructions. An I/O utility routine makes it possible for FORTRAN and ALGOL programs to write into or read from a WCS module using a conventional subroutine call. A WCS module is read at full speed by way of a flat cable connecting it to the control section of the processor. Available microprogramming software includes the Micro Assembler and Micro Debug Editor as well as diagnostics, driver program, and I/O utility routine for use with the Writable Control Store module. These software aids operate under the Hewlett-Packard Real Time Executive (RTE) operating systems. A course is offered at HP facilities in Cupertino, California for customer training. Requiring only a knowledge of E-Series assembly language as a prerequisite, the course features in-depth coverage of microprogram development and implementation, and provides hands-on experience for the microprogrammer. The E-Series microprogrammer may also take advantage of other user-written microprograms via the HP Contributed Library, which contains many tested and documented microprograms. 21MXE Microprogramming Figure 5-1. Microprogram Development Cycle Microprogramming 21MXE #### 5-8. OPTIONAL INSTRUCTION SETS #### 5-9. DYNAMIC MAPPING SYSTEM The Dynamic Mapping System (DMS) option gives the user the capability to address physical memory configurations larger than the standard 32,768 word limitation. The DMS provides a 20-bit-wide memory address bus which allows an addressing space of 1,048,576 words of main memory and allows the user to specify each 1,024-word page within physical memory to be read and/or write protected for program security. Separate memory translation maps provide isolation of system, user, DCPC channel 1, and DCPC channel 2. The DMS consists of a Memory Expansion Module (MEM) and a Memory Protect PCA which plug into the memory PCA cage; microcode for implementing the additional 38 machine language instructions associated with the DMS is mounted in the Firmware Accessory Board. #### 5-10. FAST FORTRAN PROCESSOR The Fast FORTRAN Processor (FFP) option provides the system with 18 subroutines implemented in three control store ROM modules. Included are ten fast FORTRAN subroutines and eight extended precision subroutines. These subroutines are executed up to 28 times faster than the same routines executed under software control. #### 5-11. CONCLUSION Microprogramming is a very powerful tool that gives the user many advantages in terms of speed, flexibility, and program security. Experience has shown that microprogramming once learned, is in many cases much more flexible while being just as simple in concept as assembly language programming. Microprogramming does have its limitations however, and the potential user should examine very closely the extent of support provided by the computer manufacturer. Hewlett-Packard has by far sold and supported the greatest number of microprogrammable computers in the world, and provides world-wide customer support. Customer training courses and documentation have been refined from years of customercontributed feedback and actual implementation is made easy through extensive software support packages and inexpensive hardware tools. # INTERRUPT SYSTEM M The vectored priority interrupt system has up to 60 distinct interrupt levels, each of which has a unique priority assignment. Each interrupt level is associated with a numerically corresponding interrupt location in memory. Of the 60 interrupt levels, the two highest priority levels are reserved for hardware faults (power fail and parity error), the next two are reserved for Dual-Channel Port Controller completion interrupts, and the remaining levels are available for I/O device channels. Tables 6-1 and 6-2 list the interrupt levels in priority order for the HP 2109A and HP 2113A Computers, respectively. Table 6-1. HP 2109A Interrupt Assignments | CHANNEL<br>(Octal) | INTERRUPT<br>LOCATION | ASSIGNMENT | | | |--------------------|-----------------------|------------------------------------------------|--|--| | 04 | 00004 | Power Fail Interrupt | | | | 05 | 00005 | Memory Parity/Memory Protect/<br>DMS Interrupt | | | | 06 | 00006 | DCPC Channel 1 Completion Interrupt | | | | 07 | 00007 | DCPC Channel 2 Completion<br>Interrupt | | | | 10 | 00010 | I/O Device (highest priority) | | | | 11 – 20 | 00011-00020 | I/O Device (Mainframe) | | | | 21 - 42 | 00021-00042 | I/O Device (Extender No. 1) | | | | 43 - 64 | 00043-00064 | I/O Device (Extender No. 2) | | | Table 6-2. HP 2113A Interrupt Assignments | CHANNEL<br>(Octal) | INTERRUPT<br>LOCATION | ASSIGNMENT | | | |--------------------|-----------------------|------------------------------------------------|--|--| | 04 | 00004 | Power Fail Interrupt | | | | 05 | 00005 | Memory Parity/Memory Protect/<br>DMS Interrupt | | | | 06 | 00006 | DCPC Channel 1 Completion<br>Interrupt | | | | 07 | 00007 | DCPC Channel 2 Completion Interrupt | | | | 10 | 00010 | I/O Device (highest priority) | | | | 11 - 25 | 00011-00025 | I/O Device (Mainframe) | | | | 26 - 47 | 00026-00047 | I/O Device (Extender No. 1) | | | | 50 - 71 | 00050-00071 | I/O Device (Extender No. 2) | | | As an example of the simplicity of the interrupt system, an interrupt request from I/O channel 12 will cause an interrupt to memory location 00012. This request for service will be granted on a priority basis higher than afforded to channel 13 but lower than that afforded to channel 11. Thus, a transfer in progress via channel 13 would be suspended to allow channel 12 to proceed. On the other hand, a transfer in progress via channel 11 cannot be interrupted by channel 12. Any device can be selectively enabled or disabled under program control, thus switching the device into or out of the interrupt structure. In addition, the entire interrupt system, except power fail and parity error interrupts, can be enabled or disabled under program control using a single instruction. Interrupt requests received while the computer is in the halt mode will be processed, in order of priority, when the computer is placed in the run mode. Input/output priority is covered in more detail in Section VII. #### 6-1. POWER-FAIL INTERRUPT The computer is equipped with power-sensing circuits. When primary line power fails or drops below a predetermined operating level while the computer is running, an interrupt to memory location 00004 is automatically generated. This interrupt is given the highest priority in the system and cannot be turned off or otherwise disabled. Memory location 00004 is intended to contain a jump-to-subroutine (JSB) instruction referencing the entry point of a power fail subroutine; however, location 00004 may alternatively contain a halt (HLT) instruction. The interrupt cabability of lower-priority operations is automatically inhibited while a power fail subroutine is in process. A minimum of 500 microseconds is available between the detection of a power failure and the loss of usable power supply power to execute a power fail subroutine; the purpose of such a subroutine is to transfer the current state of the computer system into memory and then halt the computer. A sample power fail subroutine is given in table 6-3. The optional battery will supply enough power to preserve the contents of memory for a sustained line power outage of up to 2 hours. If the optional Dynamic Mapping System (DMS) is installed and a power failure occurs, the System Map is automatically enabled just prior to fetching the instruction in location 00004. Since all maps are disabled and none are considered valid upon the restoration of Table 6-3. Sample Power Fail Subroutine | LABEL | OPCODE | OPERAND | COMMENTS | |-----------------|---------|---------------------|-----------------------------------------------------------------------| | PFAR | NOP | | Power Fail/Auto Restart Subroutine | | | SFC | 4B | Skip if interrupt was caused by a power-failure | | | JMP | UP | Power is being restored, reset state of computer system | | DOWN | STA | SAVA | Save A-register contents | | | CCA | | Set switch indicating that the computer was running | | | STA | SAVR | when power failed | | | STB | SAVB | Save B-register contents | | | ERA,ALS | | Transfer E-register content to A-register bit 15 | | 1 | SOC | | Increment A-register if Overflow | | | INA | | is set | | 6_1111 | STA | SAVEO | Save E- and O-register contents | | | LDA | PFAR | Save contents of P-register at time of | | | STA | SAVP | power failure | | | LIA | JAVF<br>1B | Save contents of | | | STA | SAVS | S-register | | | STX | SAVS | Save contents of X-register | | | STY | SAVY | Save contents of Y-register | | | | SAVI | Insert user-written routine to save I/O | | | | | device states | | | CLC . | | Turn on restart logic so computer will restart when power is restored | | | ULC | 48 | after momentary power failure | | | HLT | 4B | Shutdown | | | | | | | UP | LDA | SAVR | Was computer running | | | SZA,RSS | 2 H. 1983-995-18-18 | when power failed? | | | HLT | 4B | No No | | | CLA | | Yes, reset computer Run switch to | | | STA | SAVR | initial state | | | LDA | FENCE | Restore the memory protect | | | OTA | 5B | fence register contents | | | | The state of the | Insert user-written routine to restore | | e dad we | | er out me | I/O device states | | | LDA | SAVEO | Restore the contents | | | CLO | | of the | | | SLA,ELA | | E-register and | | | STF | 1B | O-register | | | LDA | SAVS | Restore the contents of the | | | OTA | 1B | S-register | | | LDA | SAVA | Restore A-register contents | | | LDB | SAVB | Restore B-register contents | | | LDX | SAVX | Restore X-register contents | | | LDY | SAVY | Restore Y-register contents | | | STC | 4B | Reset power fail logic for next power failure | | | JMP | SAVP,I | Transfer control to program in execution at time of power failure | | | | | <b>一种的现在分</b> 数,但是是是一种特殊的一种特殊的。 | | | | The Late Market A | Fence address storage (must be updated each time fence is changed | | FENCE | OCT | 2000 | Storage for E and O | | SAVEO | ОСТ | 0 | Storage for A | | SAVA | OCT | 0 | Storage for B | | SAVB<br>SAVS | OCT | Ö | Storage for S | | SAVX | OCT | ŏ | Storage for X | | SAVY | OCT | 0 | Storage for Y | | SAVP | OCT | 0 | Storage for P | | SAVR | ОСТ | 0 | Storage for Run switch | | | | | | | | | | | | | | | | | I THE THE PARTY | | | | 21MXE Interrupt System power, the power fail subroutine should include the necessary instructions to save as many maps as desired and restore them prior to enabling the DMS. Since the computer might be unattended by an operator, the user has a switch-selectable option of what action the computer will take upon the restoration of primary power. When the switch (A1S2) is set to the ARS position, the computer will halt when power is restored regardless of whether the computer was running or halted when the failure occurred. (No operator panel indication is given.) Note: Switch A1S2 is mounted on the CPU and is not considered an operator control. The setting of this switch is normally determined prior to or during system installation. When A1S2 is in the ARS position, the automatic restart feature is enabled. After a built-in delay of about half a second following the return to normal power levels, another interrupt to location 00004 occurs. This time the power-down portion of the subroutine is skipped and the power-up portion begins. (Refer to table 6-3). If the computer was not running when the power failure occurred, the computer is halted immediately. If the computer was running, those conditions existing at the time of the power fail interrupt are restored and the computer continues the program from the point of the interruption. Alternatively, if location 00004 contains a HLT instruction instead of a JSB instruction, the computer will halt and light the POWER FAIL indicator. To allow for the possibility of a second power failure occurring while the power-up portion of the subroutine is in process, the user should limit the combined power-down and power-up instructions to less than 100. If the computer memory does not contain a subroutine to service the interrupt, location 00004 should contain a HLT 04 instruction (102004 octal). A Set Control instruction (STC 04) must be given at the end of any restart routine. This instruction re-initializes the power-fail logic and restores the interrupt capability to the lower priority functions. Pressing the PRESET switch on the operator panel performs the same function as the STC 04 instruction. Pressing and holding the PRESET switch will force a halt when the key-operated switch is set to OPERATE. The optional battery sustains the contents of memory when the line power is off. If the battery becomes discharged when the line power is off, the operator must turn the operator panel key switch to the reset (R) position before the computer will operate with the line power restored. #### 6-2. PARITY ERROR INTERRUPT Parity checking of memory is a standard feature in the computer. The parity logic continuously generates correct parity for all words written into memory and monitors the parity of all words read out of memory. Correct parity is defined as having the total number of "1" bits in a 17-bit memory word (16 data bits plus the parity bit) equal to an odd value. If a "1" bit (or any odd number of "1" bits) is either dropped or added in the transfer process, a Parity Error signal is generated when that word is read out of memory. The Parity Error signal may either halt the computer or cause the computer to take some other action as determined by an internal switch (A1S1) mounted on the CPU. When the switch is in the HALT position and a parity error occurs, the computer will halt and light the PARITY indicator. The PARITY indicator will remain lighted until the PRESET switch is pressed. Note: Switch A1S1 is mounted on the CPU and is not considered an operator control. The setting of this switch is normally determined prior to or during installation or when the memory protect PCA is installed at the user's site. If switch A1S1 is in the INT/IGNORE position, the action that the computer will take when a parity error occurs is as follows: - a. If the memory protect PCA is installed and the parity error logic has not been disabled by a CLF 05 instruction, an interrupt to memory location 00005 is generated. This location may contain a JSB instruction referencing the entry point of a userwritten memory protect subroutine, or alternatively contain a HLT instruction. - b. If the memory protect PCA is not installed, or if the memory protect option is installed but the parity error logic has been disabled by a CLF 05 instruction, the parity error will be ignored and the PARITY indicator will light. In conjunction with memory protect, it is possible to determine the memory address containing the parity error. The error address will be loaded automatically into the violation register of the memory protect logic and from there it is accessible to the user by programming an LIA 05 or LIB 05 instruction. When a parity error occurs, it is recommended that the entire program or set of data containing the error location be reloaded. However, by knowing the address and the contents of the error location, the user may be able to determine what operations have taken place as a result of reading the erroneous word. For example, if the erroneous word was an instruction, several other locations may be affected. By individually checking and correcting the contents of all affected memory locations, the user may resume running the program without the necessity of a complete reload. If software is being generated, this may also need correcting. #### 6-3. MEMORY PROTECT/DMS INTERRUPT The memory protect option provides the capability of protecting a selected block of memory of any size, from a settable fence address downward, against alteration or entry by programmed instructions. The memory protect logic, when enabled by an STC 05 instruction, also prohibits the execution of all I/O instructions (including HLT 01) except those referencing I/O select code 01 (the S-register and the overflow register). This feature limits the control of I/O operations to interrupt control only. Thus, an executive program residing in protected memory can have exclusive control of the I/O system. The memory protect logic is disabled automatically by any interrupt (except when the interrupt location contains an I/O instruction) and must be re-enabled by an STC 05 instruction at the end of each interrupt subroutine. The optional DMS hardware includes additional memory protect features, which are enabled or disabled simultaneous with the memory protect hardware. When enabled by an STC 05 instruction, the DMS hardware provides the capability of read/write protecting memory on a 1024-word page basis. Included in the DMS are several privileged instructions which are not allowed when the memory protect logic is enabled. Upon detection of a violation, an interrupt to location 00005 is generated. Since the DMS will set the flag on channel 05, executing either an SFS 05 or an SFC 05 instruction will permit the programmer to know whether the DMS or memory protect interrupted. Programming rules pertaining to the use of memory protect are as follows (assuming that an STC 05 instruction has been given): a. The upper protected memory boundary address is loaded into the fence register from the A- or B-register by an OTA 05 or OTB 05 instruction, respectively. Memory addresses below but not including this address are protected. b. Execution will be inhibited and an interrupt to location 00005 will occur if one of the following instructions either directly or indirectly modifies or enters a location in protected memory, or if any I/O instruction is attempted (including HLT but excluding those I/O instructions addressing select code 01). | DST | ISZ | JLY | JMP | JPY | JSB | |-----|-----|-----|-----|-----|-----| | MVB | MVW | SAX | SAY | SBX | SBY | | STA | STB | STX | STY | | | Location 00002 is normally the lower boundary of protected memory. (Locations 00000 and 00001 are the A- and B-register addresses and may be freely addressed.) JMP, JLY, and JPY instructions may not reference the A- or B-register. After three successive levels of indirect addressing, the memory protect logic will allow a pending I/O interrupt if the memory protect logic is installed. c. Any instruction not mentioned in step b of this paragraph is legal even if the instruction directly references a protected memory address. In addition, indirect addressing through protected memory by those instructions listed in step b is legal provided that the ultimate effective address is outside the protected memory area. Following a memory protect interrupt, the address of the illegal instruction will be present in the violation register. This address is made accessible to the programmer by an LIA 05 or LIB 05 instruction, which loads the address into the A- or B-register. Since parity error and memory protect share the same interrupt location, it is necessary to distinguish which type of error is responsible for the interrupt. A parity error is indicated if, after the LIA (or LIB) 05 instruction is executed, bit 15 of the selected register is a logic 1; a memory protect violation is indicated if bit 15 is a logic 0. In either case, the remaining 15 bits of the selected register contains the logical address of the error location. Table 6-4 illustrates a sample memory protect, DMS, and parity error subroutine. An assumption made for this example is that the location immediately following the error location is an appropriate return point. This may not always be the case, however, because it may be deemed advisable to abort the program in process and return to a supervisory program. 21MXE Interrupt System Table 6-4. Sample Memory Protect, Parity Error, and DMS Subroutine | LABEL | OPERCODE | - OPERAND | COMMENTS | |-------|----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MPEDM | NOP | | Memory Protect/Parity Error/DMS Subroutine | | | CLF | 0B | Turn off interrupt system | | | STA | SAVA | Save A-register contents | | | STB | SAVB | Save B-register contents | | | LIA | 5B | Get contents of violation register | | | CLF | 5B | Turn off parity error interrupts | | | SFC | 5B | Check flag for DMS violation | | | JMP | DMS | If flag is set, then DMS interrupted | | | SSA | | Check bit 15 of violation register | | | JMP | PE | If bit 15 is set, then parity error occurred | | | JMP | MP | If bit 15 is clear, then memory protect interrupted | | MP | | | User's routine for memory protect violation | | | | | | | | etc. | | | | | | | Carlo de la companya | | | JMP | REST | | | PE | | | User's routine for parity error condition | | | | | | | | etc. | | ONE LANGUAGE CONTRACTOR OF THE | | | | | | | | JMP | REST | d | | DMS | | | User's routine for DMS violation | | | | | dense ad Milan de Carlos Carlos de C | | | etc. | | | | | | | | | | | | | | | JMP | REST | 74 | | REST | LDA | SAVA | Restore A-register | | | LDB | SAVB | Restore B-register | | | STF | OB | Enable interrupt system | | | STF | 5B | Enable parity error interrupt | | | STC | 5B | Turn on memory protect | | | JMP | MPEDM,I | Exit | | SAVA | ост | 0 | Storage for A | | SAVB | ост | 0 | Storage for B | Interrupt System 21MXE # 6-4. DUAL-CHANNEL PORT CONTROLLER INTERRUPT The optional Dual-Channel Port Controller (DCPC) allows high-speed block transfer of data between input/output devices and memory. For the most part, the DCPC operates independently of the interrupt system in that the only time that a DCPC interrupt occurs is when the specified block of data has been transferred. Since there are two DCPC channels, two interrupt locations are reserved for this purpose; location 00006 is reserved for channel 1 and location 00007 is reserved for channel 2. Channel 1 interrupt has priority over the channel 2 interrupt. Because DCPC interrupts are primarily completion signals to the programmer, and are therefore application dependent, no interrupt subroutine example is considered necessary. #### 6-5. INPUT/OUTPUT INTERRUPT The remaining interrupt locations (00010 through 00077 octal) are reserved for I/O devices; this represents a total of 56 (decimal) locations, one for each I/O channel. In a typical I/O operation, the computer issues a programmed command such as Set Control/Clear Flag (STC,C) to one or more external devices to initiate an input (read) or an output (write) operation. Each device will then either put data into or accept data from an input/output buffer on its associated interface PCA. During this time, the computer may continue running a program or may be programmed into a waiting loop to wait for a specific device to complete a read or write operation. Upon the completion of a read or write operation, each device returns a Flag signal to the computer. These Flag signals are passed through a priority network which allows only one device to be serviced regardless of the number of Flag signals present at that time. The Flag signal with the highest priority generates an Interrupt signal at the end of the current machine cycle except under the following circumstances: - Interrupt system disabled or interface PCA interrupt disabled. - b. JMP indirect or JSB indirect instruction not sufficiently executed. These instructions inhibit all interrupts except power fail or memory protect until the succeeding instruction is executed. After three successive levels of indirect addressing, the memory protect logic will allow a pending I/O interrupt if the memory protect logic is installed. - c. Instruction in an interrupt location not sufficiently executed, even if that interrupt is of lower priority. Any interrupt inhibits the entire interrupt system until the succeeding instruction is executed. - Optional dual-channel port controller in the process of transferring data. - e. Current instruction is one that may affect the priorities of I/O devices; e.g., STC, CLC, STF, CLF, SFS, and SFC. The interrupt in this case must wait until the succeeding instruction is executed. After an interface PCA has been issued a Set Control command and its Flag flip-flop becomes set, all interrupt requests from lower-priority devices are inhibited until this Flag flip-flop is cleared by a Clear Flag (CLF) instruction. A service subroutine in process for any device can be interrupted only by a higher-priority device; then, after the higher-priority device is serviced, the interrupted service subroutine may continue. In this way it is possible for several service subroutines to be in the interrupt state at one time; each of these service subroutines will be allowed to continue after the higher-priority device is serviced. All such service subroutines normally end with a JMP indirect instruction to return the computer to the point of the interrupt. #### 6-6. CENTRAL INTERRUPT REGISTER Each time an interrupt occurs, the address of the interrupt location is stored in the central interrupt register. The contents of this register are accessible at any time by executing an LIA 04 or LIB 04 instruction. This loads the address of the most recent interrupt into the A- or B-register. As described in section II, the central interrupt register contents can be accessed from the operator panel. #### 6-7. INTERRUPT SYSTEM CONTROL I/O address 00 is the master control address for the interrupt system. An STF 00 instruction enables the entire interrupt system and a CLF 00 disables the interrupt system. The two exceptions to this are the power fail interrupt, which cannot be disabled, and parity error interrupt, which can only be selective enabled or disabled by an STF 05 or CLF 05, respectively. Whenever power is initially applied, the interrupt system is disabled. # INPUT/OUTPUT SYSTEM VII The purpose of the input/output system is to transfer data between the computer and external devices. As shown in figure 7-1, data is normally transferred through the A- or B-register. An input transfer of this type occurs in three distinct steps: (1) between the external device and its interface PCA in the computer, (2) between the interface PCA and the A- or B-register via the I/O bus and CPU, and (3) between the A- or B-register and memory via the S-bus and memory controller. This three-step process also applies to an output transfer except in reverse order. This type of transfer, which is executed under program control, allows the computer logic to manipulate the data during the transfer process. Also shown in figure 7-1, data may be transferred automatically under control of the Dual-Channel Port Controller (DCPC) option. Once the DCPC has been initialized, no programming is involved and the transfer is reduced to a two-step process: (1) between the external device and its interface PCA in the computer and (2) between the interface PCA and memory via the I/O bus, S-bus, and memory controller. The two DCPC channels are assignable to operate with any two device interface PCA's. Figure 7-1. Input/Output System Since a DCPC transfer eliminates programmed loading and storing via the accumulators, the time involved is very short. Thus, the DCPC is used with high-speed devices. Further information on the DCPC option is given under paragraph 7-13. #### 7-1. INPUT/OUTPUT ADDRESSING As shown in figure 7-2, an external device is connected by cable directly to an interface PCA located inside the computer mainframe. The interface PCA, in turn, plugs into one of the input/output slots, each of which is assigned a fixed address commonly referred to as the device select code. The computer can then communicate with a specific device on the basis of its select code. Figure 7-2 shows an interface PCA inserted in the I/O slot having the highest priority; this channel is assigned select code 10 (octal). If it is decided that the associated device should have lower priority, its interface PCA and cable may simply be exchanged with those occupying some other I/O slot. This will change both the priority and the I/O address; however, due to priority chaining (refer to paragraph 7-2), there can be no vacant slots from select code 10 to the highest used select code (if the interrupt mode is to be used). Only select codes 10 through 77 (octal) are available for input/output devices; the lower select codes (00 through 07) are reserved for other features. Figure 7-2 illustrates the I/O select codes available in the HP 2109A and HP 2113A Computer mainframes. Select codes (channels) higher than those shown in figure 7-2 are available through the use of one or two I/O extenders. Each I/O extender provides an additional 16 I/O channels, which are an extension of the computer's vectored priority interrupt system. Select codes in the extender(s) operate at the same speed and with the same versatility as those in the computer mainframe. #### 7-2. INPUT/OUTPUT PRIORITY When a device is ready to be serviced, it causes its interface PCA to request an interrupt so that the computer will interrupt the current program and service the device. Since many device interface PCA's will be requesting service at random times, it is necessary to establish an orderly sequence for granting interrupts. Secondly, it is desirable that high-speed devices should not have to wait for low-speed device transfers. Both of these requirements are met by a series-linked priority structure illustrated by Figure 7-2. I/O Address Assignments figure 7-3. The bold line, representing a priority enabling signal, is routed in series through each PCA capable of causing an interrupt. The PCA cannot interrupt unless this enabling signal is present at its input. Figure 7-3. Priority Linkage Each device (or other interrupt function) can break the enabling line when it requests an interrupt. If two devices simultaneously request an interrupt, obviously the device with the lowest select code will be the first one that can interrupt because it has broken the enable line for the higher select code. The other device cannot begin its service routine until the first device is finished; however, a still higher priority device (one with a lower select code) may interrupt the service routine of the first device. Figure 7-4 illustrates a hypothetical case in which several devices require service by interrupting a CPU program. Both simultaneous and time-separated interrupt requests are considered. 21MXE Input/Output System Figure 7-4. Interrupt Sequences Assume that the computer is running a CPU program when an interrupt from I/O channel 12 occurs (at reference time t1). A JSB instruction in the interrupt location for select code 12 causes a program jump to the service routine for the channel 12 device. The JSB instruction automatically saves the return address (in a location which the programmer must reserve in his routine) for a later return to the CPU program. The routine for channel 12 is still in progress when several other devices request service (set flag). First, channels 13 and 14 request simultaneously at t2; however, since neither one has priority over channel 12, their flags are ignored and channel 12 continues its transfer. But at t3, a higher priority device on channel 10 requests service. This request interrupts the channel 12 transfer and causes the channel 10 transfer to begin. The JSB instruction saves the return address for return to the channel 12 routine. During the channel 10 transfer, device 11 sets the channel 11 flag (t4). Since it has lower priority than channel 10, device 11 must wait until the end of the channel 10 routine. And since the channel 10 routine, when it ends, contains a return address to the channel 12 routine, program control temporarily returns to channel 12 (even though the waiting channel 11 has higher priority). The JMP,I instruction used for the return inhibits all interrupts until fully executed. At the end of this short interval, the channel 11 interrupt request is granted. When channel 11 has finished its routine, control is returned to channel 12, which at last has sufficient priority to complete its routine. Since channel 12 has been saving a return address in the main CPU program, it returns control to this point. The two waiting interrupt requests from channels 13 and 14 are now enabled. Channel 13 has the higher priority and goes first. At the end of the channel 13 routine, control is temporarily returned to the CPU program. Then, the lowest priority channel (channel 14) interrupts and completes its transfer. Finally, control is returned to the CPU program, which resumes processing. #### 7-3. INTERFACE ELEMENTS The interface PCA provides the communication link between the computer and an external device. The interface PCA includes three basic elements which either the computer or the device can control in order to effect the necessary communication. These three elements are the control bit, flag bit, and buffer. #### 7-4. CONTROL BIT This is a one-bit register used by the computer to turn on the device channel. When set, the control bit generates a start command to the device, allowing it to perform one operation cycle (e.g., read or write one character or word). The interface PCA cannot interrupt unless the control bit is set. The control bit is set by an STC (set control) instruction and cleared by a CLC (clear control) instruction, both of which must be accompanied by a specific select code (e.g., STC 12 or CLC 12). The device cannot affect the control bit. #### 7-5. FLAG BIT This is a one-bit register primarily used by the device to indicate (when set) that a transmission between the device and the interface PCA buffer has been completed. Computer instructions can also set the flag (STF), clear the flag (CLF), test if it is set (SFS), and test if it is clear (SFC). The device cannot clear the flag bit. If the corresponding control bit is set, priority is high, and the interrupt system is enabled, setting the flag bit will cause an interrupt to the location corresponding to the device select code. #### 7-6. BUFFER The buffer register is used for intermediate storage of data. Typically, the data capacity is 8 or 16 bits, but this is entirely dependent on the type of device. #### 7-7. INPUT/OUTPUT DATA TRANSFER The following paragraphs describe how data is transferred between memory and input/output devices. A summary of I/O group instructions pertinent to the computer interrupt and control functions is provided in the appendix. The sequences presented for interrupt and noninterrupt methods of data transfer are highly simplified in order to present an overall view without the involvement of software operating systems and device drivers. For more detailed information, refer to the documentation supplied with the appropriate software system or I/O subsystem. ## 7-8. INPUT DATA TRANSFER (INTERRUPT METHOD) Figure 7-5 illustrates the sequence of events required to input data using the interrupt method. Note that some operations are under control of the computer program (programmer's responsibility) and some of the operations are automatic. Note also that the interface PCA (device controller) is installed in the slot assigned to select code 12. The operations begins (1) with the programmed instruction STC 12,C which sets the Control flip-flop and clears the Flag flip-flop on the interface PCA. Since the next few operations are under control of the hardware, the computer program may continue the execution of other instructions. Setting the Control flip-flop causes the PCA to output a Start signal (2) to the device, which reads out a data character and asserts the Done signal (3). The device Done signal sets the PCA Flag flip-flop, which in turn generates an interrupt (4) assuming that the interrupt conditions are met; i.e., the interrupt system must be on (STF 00 previously given), no higher priority interrupt is pending, and the Control flip-flop is set (done in step 1). The interrupt causes the current computer program to be suspended and control is transferred to a service subroutine (5). It is the programmer's responsibility to provide the linkage between the interrupt location (00012 in this case) and the service subroutine. It is also the programmer's responsibility to include in his service subroutine the instructions for processing the data (loading into an accumulator, manipulating if necessary, and storing into memory). The subroutine may then issue further STC 12,C commands to transfer additional data characters. One of the final instructions in the service subroutine must be CLC 12. This step (6) restores the interrupt capability to lower priority devices and returns the interface PCA to its static "ready" condition (Control clear and Flag set). This condition is initially established by the computer at power turn-on and it is the programmer's responsibility to return the interface PCA to the same condition on the completion of each data transfer operation. At the end of the subroutine, control is returned to the interrupted program via previously established linkages. Figure 7-5. Input Data Transfer (Interrupt Method) # 7-9. OUTPUT DATA TRANSFER (INTERRUPT METHOD) Figure 7-6 illustrates the sequence of events required to output data using the interrupt method. Again note the distinction between programmed and automatic instructions. It is assumed that the data to be transferred has been loaded into the A-register and is in a form suitable for output. The interface PCA in this example is assumed to be in the slot assigned to select code 13. The output operation begins with a programmed instruction (OTA 13) to transfer the contents of the A-register to the interface PCA buffer (1). This is followed (2) by the instruction STC 13,C which sets the Control flip-flop and clears the Flag flip-flop on the interface PCA. Since the next few operations are under control of the hardware, the computer program may continue the execution of other instructions. Setting the Control flip-flop causes the PCA to output the buffered data and a Start signal (3) to the device, which writes (e.g., punches, stores, etc.) the data character and asserts the Done signal (4). The device Done signal sets the PCA Flag flip-flop, which in turn generates an interrupt (5) provided that the interrupt system is on, priority is high, and the Control flip-flop is set (done in step 2). The interrupt causes the current computer program to be suspended, and control is transferred to a service subroutine (6). It is the programmer's responsibility to provide the linkage between the interrupt location (00013 in this case) and the service subroutine. The detailed contents of the subroutine are also the programmer's responsibility, and the contents will vary with the type of device. The subroutine may then output further data to the interface PCA and reissue the STC 13,C command for additional data character transfers. One of the final instructions in the service subroutine must be a clear control (CLC 13). This step (7) allows lower priority devices to interrupt, and restores the channel to its static "ready" condition (Control clear and Flag set). At the end of the subroutine, control is returned to the interrupted program via previously established linkages. #### 7-10. NONINTERRUPT DATA TRANSFER It is also possible to transfer data without using the interrupt system. This involves a "wait-for-flag" method in which the computer commands the device to operate and then waits for the completion response. In using this method to transfer data, it is assumed that the computer time is relatively unimportant. The programming is very simple, consisting of only four words of in-line coding as shown in table 7-1. Each of these routines will transfer one word or character of data. It is also assumed that the interrupt system is turned off (STF 00 not previously given). 7-11. INPUT. As described under paragraph 7-8, an STC 12,C instruction begins the operation by commanding the device to read one word or character. The computer then goes into a waiting loop, repeatedly checking the status of the flag bit. If the Flag flip-flop is not set, the JMP \*-1 instruction causes a jump back to the SFS instruction. (The \*-1 operand is assembler notation for "this location minus one.") When the Flag flip-flop is set, the skip condition for SFS is met and the JMP instruction is skipped. The computer thus exits from the waiting loop Figure 7-6. Output Data Transfer (Interrupt Method) Input/Output System 21MXE and the LIA 12 instruction loads the device input data into the A-register. Table 7-1. Noninterrupt Transfer Routines | INSTRUCTIONS | COMMENTS | |---------------------|---------------------------------------------| | STC 12,C | Start device | | SFS 12 | Is input ready? | | JMP *-1 | No, repeat previous instruction | | LIA 12 | Yes, load input into A-register | | <b>TPUT</b> | | | TPUT INSTRUCTIONS | COMMENTS | | | COMMENTS Output A-register to buffer | | INSTRUCTIONS | | | INSTRUCTIONS OTA 13 | Output A-register to buffer | | OTA 13<br>STC 13,C | Output A-register to buffer<br>Start device | 7-12. OUTPUT. The first step, which is to transfer the data to the interface PCA buffer, is the OTA 13 instruction. Then STC 13,C commands the device to operate and accept the data. The computer then goes into a waiting loop as described in the preceding paragraph. When the Flag flip-flop becomes set, indicating that the device has accepted the output data, the computer exits from the loop. (The final NOP is for illustration purposes only.) #### 7-13. DUAL-CHANNEL PORT CONTROLLER The optional Dual-Channel Port Controller (DCPC) provides a direct data path, software assignable, between memory and a high-speed peripheral device; the DCPC accomplishes this by stealing an I/O cycle instead of interrupting to a service subroutine. The DCPC logic is capable of stealing every consecutive I/O cycle and can transfer input data at rates up to 1.0 million words per second; see Direct Memory Access specifications in table 1-1 for output data rates and the DCPC latency times. There are two DCPC channels, each of which may be separately assigned to operate with any I/O interface PCA, including those installed in the optional HP 12979A Input/Output Extender (assuming that the I/O extender DCPC option is installed). When both DCPC channels are operating simultaneously, channel 1 has priority over channel 2. The combined maximum transfer rate for both channels operating concurrently can reach the above rates if the channels are transferring in the same direction. Channels working in opposite directions will achieve an effective transfer rate between these rates. Since the memory cycle rate is somewhat faster than the I/O cycle rate, it is possible for the CPU to interleave memory cycles while the DCPC is operating at full bandwidth. Transfers via the DCPC are on a full-word basis; hardware packing and unpacking of bytes are not provided. The word count register is a full 16 bits in length, and data transfers are accomplished in blocks. The transfer is initiated by an initialization routine, and from then on the operation is under automatic control of the hardware. The initialization routine specifies the direction of the data transfer (in or out), where in memory to read or write. which I/O channel to use, and how much data to transfer. Completion of the block transfer is signalled by an interrupt to location 00006 (for channel 1) or to location 00007 (for channel 2) if the interrupt system is enabled. It is also possible to check for completion by testing the status of the flag for select code 06 or 07, or by interrogating the word count register with an LIA/B to select code 02 (for channel 1) or to select code 03 (for channel 2). A block transfer in process can be aborted with an STF 06 or 07 instruction. 7-14. DCPC OPERATION. Figure 7-7 illustrates the sequence of operations for a DCPC input data transfer. A comparison with the conventional interrupt method (figure 7-5) shows that much more of the DCPC operation is automatic. Remember that the procedure in figure 7-5 must be repeated for each word or character. In figure 7-7, the automatic DCPC operation will transfer a block of data of any size limited only by the available memory space. The sequence of events is as follows. (An input data transfer is illustrated; the minor differences for an output transfer are explained in text.) The initialization routine sets up the control registers on the DCPC (1) and issues the first start command (STC 12,C) directly to the interface PCA. (If the operation is an output, the interface PCA buffer is also loaded at this time.) The DCPC logic is now turned on and the computer program continues with other instructions. Setting the Control and clearing the Flag flip-flops (2) causes the interface PCA to send a Start signal (with a data word if it is an output transfer) to the external device (3). The device goes through a read or write cycle and returns a Done signal (with a data word if it is an input transfer). The Done signal (4) sets the PCA Flag flip-flop which, regardless of priority, immediately requests the DCPC logic to steal an I/O cycle (5) and transfer a word into (or out of) memory. The process now repeats back to the beginning of this paragraph to transfer the next word. After the specified number of words have been transferred, the interface PCA Control flip-flop is cleared (7) and the DCPC logic generates a completion interrupt (8). The program control is now forced to a completion routine (9), the contents of which is the programmer's responsibility. Figure 7-7. DCPC Input Data Transfer 7-15. DCPC INITIALIZATION. The information required to initialize the DCPC (direction, memory allocation, I/O channel assignment, and block length) are given by three control words. These three words must be addressed specifically to the DCPC. Figure 7-8 illustrates the format of the three control words. Control Word 1 (CW1) identifies the I/O channel to be used and provides two options selectable by the programmer: Bit 15 1 = give STC (in addition to CLF) to I/O channel at end of each DCPC cycle (except on last cycle, if input) 0 = no STC Bit 13 1 = give CLC to I/O channel at end of block transfer 0 = no CLC Control Word 2 (CW2) gives the starting memory address for the block transfer and bit 15 determines whether data is to go into memory (logic 1) or out of memory (logic 0). Control Word 3 (CW3) is the two's complement of the number of words to be transferred into or out of memory (i.e., the block length). This number can be from 1 to 32,768, although it is limited in the practical case by available memory. Figure 7-8. DCPC Control Word Formats Table 7-2 gives the basic program sequence for outputting the control words to the DCPC. As shown in this table, CLC 2 and STC 2 perform switching functions to prepare the logic for either CW2 or CW3. The device is assumed to be in I/O slot channel 10, and it is also assumed that its start command is STC 10B, C. The sample values of CW1, CW2, and CW3 will read a block of 50 words and store these in locations 200 through 261 (octal). The STC 06B,C Input/Output System 21MXE instruction starts the DCPC operation. A flag-status method of detecting the end-of-transfer is used in this example; an interrupt to location 00006 could be substituted for this test. The program in table 7-2 could easily be changed to operate on channel 2 by changing select codes 2 to 3 and 6 to 7. One important difference should be noted when doing a DCPC input operation from a disc or a drum. Due to the synchronous nature of disc or drum memories and the design of the interface PCA, the order of starting must be reversed from the order given; i.e., start the DCPC first and then start the disc (or drum). Table 7-2. DCPC Initialization Program | LABEL | OPCODE | OPERAND | COMMENTS | | | | |-------|------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | ASGN1 | LDA | in CW1 almos utlanding | Fetches control word 1 (CW1) from memory and loads it in A-register. | | | | | | ОТА | 6B | Outputs CW1 to DCPC Channel 1. | | | | | MAR1 | CLC | <b>2</b> B | Prepares Memory Address Register to receive control word 2 (CW2). | | | | | | LDA | CW2 | Fetches CW2 from memory and loads it in A-register. | | | | | | ОТА | <b>2</b> B | Outputs CW2 to DCPC Channel 1. | | | | | WCR1 | STC | 2В | Prepares Word Count Register to receive control word 3 (CW3). | | | | | | LDA | CW3 | Fetches CW3 from memory and loads it in A-register. | | | | | | ОТА | 28 | Outputs CW3 to DCPC Channel 1. | | | | | STRT1 | STC | 10B,C | Start input device. | | | | | | STC | 6B,C | Activate DCPC Channel 1. | | | | | | SFS<br>JMP | 6B<br>*-1 | Wait while data transfer takes place or, if interrupt processing is used continue program. | | | | | | | | The state of the control cont | | | | | | HLT | | Halt | | | | | CW1 | OCT | 120010 | Assignment for DCPC Channel 1 (ASGN1); specifies I/O channel selected code address (10 <sub>8</sub> ), STC after each word is transferred, and CLC affinal word is transferred. | | | | | CW2 | OCT | 100200 | Memory Address Register control. DCPC Channel 1 (MAR1); specifie memory input operation and starting memory address (200 <sub>8</sub> ). | | | | | CW3 | DEC | -50 Jungaria | Word Count Register control. DCPC Channel 1 (WCR1); specifies the 2's complement of the number of character words in the block of dat to be transferred ( $50_{10}$ ). | | | | # APPENDIX #### **COMPUTER PHYSICAL LAYOUT** ## **CHARACTER CODES** | ASCII<br>Character | First Character<br>Octal Equivalent | Second Character<br>Octal Equivalent | |--------------------|-------------------------------------|--------------------------------------| | Α | 040400 | 000101 | | В | 041000 | 000102 | | C | 041400<br>042000 | 000103 | | E E | 042000 | 000104<br>000105 | | F | 043000 | 000106 | | G | 043400 | 000107 | | H | 044000 | 000110 | | j | 044400 | 000111 | | ĸ | 045000<br>045400 | 000112<br>000113 | | L. | 046000 | 000113 | | M | 046400 | 000115 | | N | 047000 | 000116 | | O | 047400 | 000117 | | ١٠٥ | 050000<br>050400 | 000120 | | R | 050400 | 000121<br>000122 | | S | 051400 | 000122 | | Τ | 052000 | 000124 | | U | 052400 | 000125 | | v<br>w | 053000 | 000126 | | X | 053400<br>054000 | 000127 | | Ŷ | 054400 | 000130<br>000131 | | Z | 055000 | 000131 | | a<br>b | 060400 | 000141 | | C | 061000<br>061400 | 000142<br>000143 | | d | 062000 | 000143 | | е | 062400 | 000145 | | f | 063000 | 000146 | | 9 | 063400 | 000147 | | h<br>i | 064000<br>064400 | 000150 | | i | 065000 | 000151<br>000152 | | k | 065400 | 000152 | | | 066000 | 000154 | | m | 066400 | 000155 | | n<br>O | 067000 | 000156 | | P | 067400<br>070000 | 000157<br>000160 | | 9 | 070400 | 000160 | | 1 | 071000 | 000162 | | \$ | 071400 | 000163 | | • | 072000 | 000164 | | u<br>V | 072400<br>073000 | 000165 | | w | 073400 | 000166<br>000167 | | × | 074000 | 000170 | | У | 074400 | 000171 | | 2 S. 19 S. 10 | 075000 | 000172<br> | | 0 1 | 030000<br>030400 | 000060<br>000061 | | 2 | 031000 | 000062 | | 3 | 031400 | 000063 | | 4<br>5 | 032000 | 000064 | | 6 | 032400<br>033000 | 000065 | | 7 | 033400 | 000066<br>000067 | | 8 | 034000 | 000070 | | 9 | 034400 | 000070 | | NUL<br>SOH | 000000<br>000400 | 000000 | | STX | 001000 | 000001<br>000002 | | ETX | 001400 | 000002 | | EOT | 002000 | 000004 | | ENQ | 002400 | 000005 | | ASCII<br>Character | First Character<br>Octal Equivalent | Second Character<br>Octal Equivalent | |--------------------|-------------------------------------|--------------------------------------| | ACK | 003000 | 000006 | | BEL | 003400 | 000007 | | BS | 004000 | 000010 | | HT | 004400 | 000011 | | LF | 005000 | 000012 | | VT | 005400 | 000013 | | FF | 006000 | 000014 | | CR | 006400 | 000015 | | SO | 007000 | 000016 | | SI | 007400 | 000017 | | DLE | 010000 | 000020 | | DC1 | 010400 | 000021 | | DC2 | 011000 | 000022 | | DC3 | 011400 | 000023 | | DC4 | 012000 | 000024 | | NAK | 012400 | 000025 | | SYN | 013000 | 000026 | | ETB | 013400 | 000027 | | CAN | 014000 | 000030 | | EM | 014400 | 000031 | | SUB | 015000 | 000032 | | ESC | 015400 | 000033 | | FS | 016000 | 000034 | | G <b>S</b> | 016400 | 000035 | | RS | 017000 | 000036 | | US | 017400 | 000037 | | SPACE | 020000 | 000040 | | ! | 020400 | 000041 | | . " | 021000 | 000042 | | # | 021400 | 000043 | | \$ | 022000 | 000044 | | % | 022400 | 000045 | | & | 023000 | 000046 | | | 023400 | 000047 | | 200 | 024000 | 000050 | | ) 55 | 024400 | 000051 | | | 025000 | 000052 | | + 53 | 025400 | 000053 | | | 026000 | 000054 | | - <u>i</u> | 026400 | 000055 | | | 027000 | 000056 | | | 027400 | 000057 | | . : Afri | 035000 | 000072 | | | 035400 | 000073 | | < | 036000 | 000074 | | | 036400 | 000075 | | > | 037000 | 000076 | | ? | 037400 | 000077 | | @ | 040000 | 000100 | | 1 | 055400 | 000133 | | \ \\ | 056000 | 000134 | | ] | 056400 | 000135 | | 1. August 2. | 057000 | 000136 | | | 057400 | 000137 | | -54 - PEL-0588 | 060000 | 000140 | | | 075400 | 000173 | | 1, 1 | 076000 | 000174 | | } | 076400 | 000175 | | _~_ | 077000 | 000176 | | DEL | 077400 | 000177 | ## **OCTAL ARITHMETIC** #### **ADDITION** **TABLE** | 0 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | |---|-----|-----|----|-----|-----|------|----| | 1 | 02 | ij, | 04 | 06 | Œ | , OZ | io | | 2 | | 64 | 05 | 96 | 07 | -10 | 11 | | 3 | QJ. | 15 | 06 | 07 | 10 | 11 | 12 | | 4 | 68 | 18 | 17 | 10 | .11 | 12 | 13 | | 5 | OĞ. | 07 | 10 | 11: | 12 | 13 | 14 | | 6 | | 10 | 11 | | 19 | 14 | 15 | | 7 | | 11 | 12 | 13 | 14 | 15 | 10 | #### **EXAMPLE** Add: 3677 octal + 1331 octal (111-) carries 5230 octal #### MULTIPLICATION **TABLE** | 1 | 02 | 03 | 04 | 05 | 06 | 07 | |---|----|----------|----|-----|----|-----| | 2 | | <b>a</b> | 10 | 17 | 14 | | | 3 | 13 | 11 | 14 | 17 | 22 | 25 | | 4 | 10 | 14 | 20 | 24 | 30 | 34 | | 5 | | 117 | 24 | 91 | 38 | 43 | | 6 | | 77 | 30 | 406 | 40 | 102 | | 7 | 10 | | 94 | 43 | 62 | 61 | #### **EXAMPLE** #### COMPLEMENT To find the two's complement form of an octal number. (Same procedure whether converting from positive to negative or negative to positive.) #### RULE - Subtract from the maximum representable octal value. - 2. Add one. #### **EXAMPLE** Two's complement of $556_8$ : ## OCTAL/DECIMAL CONVERSIONS #### OCTAL TO DECIMAL **TABLE** | OCTAL | DECIMAL | |-------|---------| | 0.7 | 0-7 | | 10-17 | 8-15 | | 20-27 | 16-23 | | 30-37 | 24-31 | | 40-47 | 32-39 | | 50-57 | 40-47 | | 60-67 | 48-55 | | 70-77 | 56-63 | | 100 | 64 | | 200 | 128 | | 400 | 256 | | 1000 | 512 | | 2000 | 1024 | | 4000 | 2048 | | 10000 | 4096 | | 20000 | 8192 | | 40000 | 16384 | | 77777 | 32767 | #### **EXAMPLE** Convert 4638 to a decimal integer. $$400_8 = 256_{10}$$ $$60_8 = 48_{10}$$ $$3_8 = 3_{10}$$ $$307 \text{ decimal}$$ #### DECIMAL TO OCTAL **TABLE** | DECIMAL | OCTAL - | |----------------|----------------| | | | | 10 | 12 | | 20<br>40 | 24<br>50 | | 100 | 144 | | 200<br>500 | 310<br>764 | | 1000<br>2000 | 1750<br>3720 | | 5000 | 11610 | | 10000 | 23420 | | 20000<br>32767 | 47040<br>77777 | #### **EXAMPLE** Convert 5229<sub>10</sub> to an octal integer. $$5000_{10} = 11610_8$$ $200_{10} = 310_8$ $20_{10} = 24_8$ $9_{10} = 11_8$ $12155_8$ (Reminder: add in octal) #### **NEGATIVE DECIMAL TO TWO'S COMPLEMENT OCTAL** **TABLE** | DECIMAL | 2's COMP | |------------------|------------------| | | 177777 | | -10 | 177766 | | -20<br>-40 | 177754<br>177730 | | -100 | 177634 | | -200<br>-500 | 177470<br>177014 | | -1000<br>-2000 | 176030<br>174060 | | -5000 | 166170 | | -10000<br>-20000 | 154360<br>130740 | | -32768 | 100000 | #### **EXAMPLE** Convert -629<sub>10</sub> to two's complement octal. $$-500_{10} = 177014_{8}$$ $$-100_{10} = 177634_{8}$$ $$-20_{10} = 177754_{8}$$ (Add in octal) $$-9_{10} = \frac{177767_{8}}{176613_{8}}$$ For reverse conversion (two's complement octal to negative decimal): - 1. Complement, using procedure on facing page. - 2. Convert to decimal, using OCTAL TO DECIMAL table. ## MATHEMATICAL EQUIVALENTS | | | | The state of s | g Kray in process | LIVIAI | | | | at year | , L | | | /// mps = | | | | | | | | |----------------------|-----------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------|--------------|--------------|-----|------------|-----------|-----------------------|---------|-----------|----------------|------------|-------|-------|-----|-----|------| | | | | | | | | | | | | | | | | | | | | | | | | | | | 1-3-2 | Vilia: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <b>阿拉克拉克斯</b> | | F-715+11 | 04 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | \$11. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <b>2</b> ± <i>n</i> | IN | DE | CIM | ٩L | | | | | | | | | | | -1 % | | 2 <sup>n</sup> | n | $2^{-n}$ | | | | 6 | 5 53 | 16 | 16 | | 0.00 | 001 | E2E07 | 89062 | | | | | | | | 1 | 0 | 1.0 | | | | | 1 07 | | 17 | | | | | 94531 | | | | | | | | 2 | 1 | 0.5 | | | | | | | | | | | | | | | | | | | | 4 | 2 | 0.25 | | | | | 2 14 | | 18 | | | | | 97265 | | | | | | | | 8 | 3 | 0.125 | | | • | | 4 28<br>8 57 | | 19<br>20 | | | | | 48632<br>74316 | | | | | | | | 16 | 4 | 0.0625 | | | • | | 0 0, | Ū | | | 0.00 | 000 | 00000 | 74010 | 7002 | 23 | | | | | | 32 | 5 | 0.03125 | | | | | 7 15 | _ | 21 | | | | | 37158 | | | | | | | | 64 | 6 | 0.01562 5 | | | | | 4 30<br>8 60 | | 22 | | | | | 18579 | | | | | | | | 128 | 7 | 0.01562 5 | | | | , 30 | 00 | Ю | 23 | | 0.00 | JUU | 01192 | 09289 | 5 550 | /8 1 | 25 | | | | | 256 | 8 | 0.00390 625 | | | | | 7 21 | | 24 | | | | | 04644 | | | | | | | | F40 | • | 0.004.00 | _ | | | | 4 43 | | 25 | | | | | 02322 | | | | | | | | 512<br>1 024 | 9<br>10 | 0.00195 312<br>0.00097 656 | | | 67 | 10 | 8 86 | 4 | 26 | | 0.00 | 000 | 00149 | 01161 | 1938 | 34 7 | 6562 | 5 | | | | 2 048 | 11 | 0.00037 030 | | 3.75 | 134 | 21 | 7 72 | 8 | 27 | | 0.00 | 000 | 00074 | 50580 | 5969 | 92 3 | 8281 | 25 | | | | | | | | | | | 5 45 | | 28 | | | | | 25290 | | | | | 5 | | | 4 096<br>8 192 | 12<br>13 | 0.00024 414 | | 9517 | 536 | 87 | 0 91 | 2 | 29 | | 0.00 | 000 | 00018 | 62645 | 1492 | 23 0 | 9570 | 312 | 25 | | | 16 384 | 14 | 0.00012 207<br>0.00006 103 | | 4 | 1 073 | 3 74 | 1 82 | 24 | 30 | | 0.00 | 000 | ററററ | 31322 | 5746 | S1 F3 | 4785 | 156 | 325 | | | | | | | | 2 147 | | | | 31 | | | | | 65661 | | | | | | 5 | | 32 768 | 15 | 0.00003 051 | 75 78125 | | 4 294 | 96 | 7 29 | 96 | 32 | | 0.00 | 000 | 00002 | 32830 | 6436 | 35 | 8696 | 289 | 906 | 25 | | | | | # 1 2 4 5 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | | | | | | | | | | | | | | | | | | | | | | | | 10 ± | <sup>n</sup> | N O | СТА | L | | | | | | | | | | | | | | 10 <sup>n</sup> | n | 10- <i>n</i> | | | | | | | | <b>0</b> <sup>n</sup> | | n | | | 10 | -n | | | | | | | 0 1.000 000 | 000 000 | 000 00 | 00 00 | | | | 112 | 402 | 762 | 000 | 10 | 0.000 | 000 | 000 | 006 | 676 | 337 | 66 | | | | 2 0.005 075 | 341 217 | 270 24 | 13 66 | | | 16 | 351<br>432 | 451 | 210 | 000 | 12 | 0.000 | 000 ( | 000 | 000 | 043 | 136 | 3: | | 1 | | 3 0.000 406 | 111 564 | 570 65 | 1 77 | | | 221 | 411 | 634 | 520 | 000 | 13 | 0.000 | 000 | 000 | 000 | 003 | 411 | 3 | | 23 | 420 | 4 0.000 032 | 155 613 | 530 70 | 4 15 | | 2 | 657 | 142 | 036 | 440 | 000 | 14 | 0.000 | 000 | 000 | 000 | 000 | 264 | 1 | | 303 | 240 | 5 0.000 002 | 476 132 | 610 70 | 06 64 | | 34 | 327 | 724 | 461 | 500 | იიი | 15 | 0.000 | 000 4 | റററ | OOO | ეიი | 022 | 0 | | 3 641 | | 6 0.000 000 | | | | | | | | | | | | | | | | | | | | 46 113 | | 7 0.000 000 | | | | | | | | | | | | | | | | | | | | 575 360<br>7 346 545 | | 8 0.000 000<br>9 0.000 000 | | | | 67 | 405 | 553 | 164 | 731 | 000 | 000 | 18 | 0.000 | 000 | 000 | 000 | 000 | 000 | 0 | | | | 9 0.000 000 | | 300 21 | | | | | | | | hjerit. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ا<br>القائد عام المالية العالم | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | and indigending | 어머니 되었다 | | | Athena in | | | H. W & C. | | | MA LICE | | The second | | | | | | #### MATHEMATICAL EQUIVALENTS | | | | | | | The state of s | | |-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------| | | | 100 mg/s | | | | | | | | | 2 <sup>x</sup> II | N DECIMAL | | | | | | x | <b>2</b> <sup>x</sup> | x | <b>2</b> <sup>x</sup> | | x | | <b>2</b> <sup>x</sup> | | 0.001 | 1.00069 33874 62581 | 0.01 | 1.00695 55500 5 | 6719 | 0.1 | 1.07177 | 34625 362 | | 0.002 | 1.00138 72557 11335 | | 1.01395 94797 9 | | 0.2 | 1.14869 | 83549 970 | | 0.003 | 1.00208 16050 79633 | , + % | 1.02101 21257 0 | E of the | 0.3 | | 44133 449 | | 0.004<br>0.005 | 1.00277 64359 01078<br>1.00347 17485 09503 | | 1.02811 38266 5 | | 0.4 | | 79107 728 | | 0.006 | 1.00416 75432 38973 | | 1.03526 49238 4<br>1.04246 57608 4 | | 0.5<br>0.6 | | 35623 730<br>65665 103 | | 0.007 | 1.00486 38204 23785 | | 1.04971 66836 2 | | 0.7 | | 47927 124 | | 0.008 | 1.00556 05803 98468 | W134 5 | 1.05701 80405 6 | | 0.8 | | 11265 922 | | 0.009 | 1.00625 78234 97782 | 0.09 | 1.06437 01824 5 | 3360 | 0.9 | 1.86606 | 59830 736 | | | | | | | | | | | | | | | | | | | | | | 2 5 7 0 de a 20 de a 3 c | | | | | | | | | n log <sub>10</sub> 2, n | log <sub>2</sub> 10 IN DECI | MAL | | | | | n | <sup>n</sup> log <sub>10</sub> 2 | n log <sub>2</sub> 10 | n | $n \log_{10}$ | - | | n log <sub>2</sub> 10 | | 1 | 0.30102 99957 | n log <sub>2</sub> 10<br>3.32192 80949 | _<br> | n log <sub>10</sub> | 99740 | 19.9 | 93156 8569 | | 1<br>2 | 0.30102 99957<br>0.60205 99913 | n log <sub>2</sub> 10<br>3.32192 80949<br>6.64385 61898 | n<br>6<br>7 | n log <sub>10</sub><br>1.80617<br>2.10720 | 99740<br>99696 | 19.9<br>23.2 | 93156 8569<br>25349 6664 | | 1 | 0.30102 99957 | n log <sub>2</sub> 10<br>3.32192 80949 | _<br> | n log <sub>10</sub> | 99740<br>99696<br>99653 | 19.9<br>23.2<br>26.5 | 93156 8569 | | 1<br>2<br>3 | 0.30102 99957<br>0.60205 99913<br>0.90308 99870 | n log <sub>2</sub> 10<br>3.32192 80949<br>6.64385 61898<br>9.96578 42847 | n<br>6<br>7<br>8 | n log <sub>10</sub><br>1.80617 9<br>2.10720 9<br>2.40823 9 | 99740<br>99696<br>99653<br>99610 | 19.9<br>23.2<br>26.9<br>29.8 | 93156 8569<br>25349 6664<br>57542 4759 | | 1<br>2<br>3<br>4 | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827 | n log <sub>2</sub> 10<br>3.32192 80949<br>6.64385 61898<br>9.96578 42847<br>13.28771 23795 | n<br>6<br>7<br>8<br>9 | n log <sub>10</sub> 1.80617 1 2.10720 1 2.40823 1 2.70926 1 | 99740<br>99696<br>99653<br>99610 | 19.9<br>23.2<br>26.9<br>29.8 | 93156 8569<br>25349 6664<br>57542 4759<br>39735 2854 | | 1<br>2<br>3<br>4 | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827 | n log <sub>2</sub> 10<br>3.32192 80949<br>6.64385 61898<br>9.96578 42847<br>13.28771 23795<br>16.60964 04744 | n<br>6<br>7<br>8<br>9 | n log <sub>10</sub> 1.80617 1 2.10720 1 2.40823 1 2.70926 1 | 99740<br>99696<br>99653<br>99610 | 19.9<br>23.2<br>26.9<br>29.8 | 93156 8569<br>25349 6664<br>57542 4759<br>39735 2854 | | 1<br>2<br>3<br>4 | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783 | n log <sub>2</sub> 10<br>3.32192 80949<br>6.64385 61898<br>9.96578 42847<br>13.28771 23795<br>16.60964 04744 | n<br>6<br>7<br>8<br>9<br>10 | n log <sub>1(</sub> 1.80617 2.10720 2.40823 2.70926 3.01029 | 99740<br>99696<br>99653<br>99610<br>99566 | 19.9<br>23.2<br>26.9<br>29.8 | 93156 8569<br>25349 6664<br>57542 4759<br>39735 2854 | | 1<br>2<br>3<br>4<br>5 | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783 | n log <sub>2</sub> 10 3.32192 80949 6.64385 61898 9.96578 42847 13.28771 23795 16.60964 04744 | n<br>6<br>7<br>8<br>9<br>10<br>DNSTANTS IN OC | n log <sub>1(</sub> 1.80617 1 2.10720 1 2.40823 1 2.70926 1 3.01029 1 | 99740<br>99696<br>99653<br>99610<br>99566 | 19.5<br>23.2<br>26.5<br>29.8<br>33.2 | 93156 8569<br>25349 6664<br>57542 4759<br>39735 2854<br>21928 0948 | | $\pi = \pi^{-1} = \pi^{-1}$ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub> | n log <sub>2</sub> 10 3.32192 80949 6.64385 61898 9.96578 42847 13.28771 23795 16.60964 04744 ATHEMATICAL CC e = ((e <sup>-1</sup> = (( | n<br>6<br>7<br>8<br>9<br>10<br>0<br>0.27426 521305)(8)<br>0.27426 530661) | n log <sub>10</sub> 1.80617 2.10720 2.40823 2.70926 3.01029 | 99740<br>99696<br>99653<br>99610<br>99566<br><b>E</b> γ = In γ = | 19.5<br>23.2<br>26.5<br>29.8<br>33.2<br>(0.44742<br>-(0.43127 : | 93156 8569<br>25349 6664<br>57542 4759<br>89735 2854<br>21928 0948<br>147707)(8)<br>233602)(8) | | $ \begin{array}{ccc} 1 & 2 & \\ 3 & 4 & \\ 5 & & \\ \pi & = \\ \pi^{-1} & = \\ \sqrt{\pi} & = & \\ \end{array} $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CO $e = (6)$ $e = (6)$ $e = (6)$ | n<br>6<br>7<br>8<br>9<br>10<br>DNSTANTS IN OC<br>2.55760 521305) <sub>(8)</sub><br>0.27426 530661) <sub>(8)</sub><br>1.51411 230704) <sub>(8)</sub> | n log <sub>1(</sub> 1.80617 1 2.10720 1 2.40823 1 2.70926 1 3.01029 1 | 99740<br>99696<br>99653<br>99610<br>99566<br>E $\gamma = \frac{1}{1000} \frac$ | 19.5<br>23.2<br>26.5<br>29.8<br>33.2<br>(0.44742<br>- (0.43127 : | 93156 8569<br>25349 6664<br>57542 4759<br>89735 2854<br>21928 0948<br>147707)(8)<br>233602)(8)<br>030645)(8) | | $ \begin{array}{rcl} 1 & & \\ 2 & & \\ 3 & & \\ 4 & & \\ 5 & & \\ \end{array} $ $ \pi = \\ \pi^{-1} = \\ \sqrt{\pi} = \\ \ln \pi = \\ $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub><br>(1.11206 404435) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CC $e = (0)$ $e = (0)$ $e = (0)$ $e = (0)$ $e = (0)$ | n<br>6<br>7<br>8<br>9<br>10<br>0.255760 521305)(8)<br>0.27426 530661)(8)<br>1.51411 230704)(8)<br>0.33626 754251)(8) | n log1(<br>1.80617 )<br>2.10720 )<br>2.40823 )<br>2.70926 )<br>3.01029 ) | 99740<br>99696<br>99653<br>99610<br>99566<br>E | 19.5<br>23.2<br>26.5<br>29.8<br>33.2<br>(0.44742<br>-(0.43127<br>-(0.62573 (1.32404) | 93156 8569<br>95349 6664<br>97542 4759<br>89735 2854<br>21928 0948<br>147707)(8)<br>233602)(8)<br>030645)(8)<br>746320)(8) | | $ \begin{array}{rcl} 1 & 2 & \\ 3 & 4 & \\ 5 & & \\ \end{array} $ $ \pi = \\ \pi^{-1} = \\ \sqrt{\pi} = \\ \ln \pi = \\ \log_2 \pi = \\ $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub><br>(1.11206 404435) <sub>(8)</sub><br>(1.51544 163223) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CC $e = (0)$ $e = (0)$ $e = (0)$ $e = (0)$ $e = (0)$ | n<br>6<br>7<br>8<br>9<br>10<br>DNSTANTS IN OC<br>2.55760 521305) <sub>(8)</sub><br>0.27426 530661) <sub>(8)</sub><br>1.51411 230704) <sub>(8)</sub> | n log1(<br>1.80617 )<br>2.10720 )<br>2.40823 )<br>2.70926 )<br>3.01029 ) | 99740<br>99696<br>99653<br>99610<br>99566<br>E | 19.5<br>23.2<br>26.5<br>29.8<br>33.2<br>(0.44742<br>- (0.43127 : | 93156 8569<br>95349 6664<br>97542 4759<br>89735 2854<br>21928 0948<br>147707)(8)<br>233602)(8)<br>030645)(8)<br>746320)(8) | | $ \begin{array}{rcl} 1 & 2 & \\ 3 & 4 & \\ 5 & & \\ \end{array} $ $ \pi = \\ \pi^{-1} = \\ \sqrt{\pi} = \\ \ln \pi = \\ \log_2 \pi = \\ $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub><br>(1.11206 404435) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CO $e = (0.60964 - 0.60964)$ $e = (0.60964 - 0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ | n<br>6<br>7<br>8<br>9<br>10<br>0.255760 521305)(8)<br>0.27426 530661)(8)<br>1.51411 230704)(8)<br>0.33626 754251)(8) | n log <sub>1(</sub> 1.80617 2.10720 2.40823 2.70926 3.01029 2.40821 2.70926 3.01029 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70 | 99740<br>99696<br>99653<br>99610<br>99566 | 19.5<br>23.2<br>26.5<br>29.8<br>33.2<br>(0.44742<br>-(0.43127<br>-(0.62573 (1.32404) | 93156 8569<br>25349 6664<br>57542 4759<br>89735 2854<br>21928 0948<br>233602)(8)<br>030645)(8)<br>746320)(8) | | $ \begin{array}{rcl} 1 & 2 & \\ 3 & 4 & \\ 5 & & \\ \end{array} $ $ \pi = \\ \pi^{-1} = \\ \sqrt{\pi} = \\ \ln \pi = \\ \log_2 \pi = \\ $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub><br>(1.11206 404435) <sub>(8)</sub><br>(1.51544 163223) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CO $e = (0.60964 - 0.60964)$ $e = (0.60964 - 0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ | n<br>6<br>7<br>8<br>9<br>10<br>2.55760 521305) <sub>(8)</sub><br>0.27426 530661) <sub>(8)</sub><br>1.51411 230704) <sub>(8)</sub><br>0.33626 754251) <sub>(8)</sub><br>1.34252 166245) <sub>(8)</sub> | n log <sub>1(</sub> 1.80617 2.10720 2.40823 2.70926 3.01029 2.40821 2.70926 3.01029 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70 | 99740<br>99696<br>99653<br>99610<br>99566 | (0.44742<br>- (0.43127<br>(0.54271) | 93156 8569<br>25349 6664<br>57542 4759<br>89735 2854<br>21928 0948<br>233602)(8)<br>030645)(8)<br>746320)(8) | | $ \begin{array}{rcl} 1 & 2 & \\ 3 & 4 & \\ 5 & & \\ \end{array} $ $ \pi = \\ \pi^{-1} = \\ \sqrt{\pi} = \\ \ln \pi = \\ \log_2 \pi = \\ $ | 0.30102 99957<br>0.60205 99913<br>0.90308 99870<br>1.20411 99827<br>1.50514 99783<br>MA<br>(3.11037 552421) <sub>(8)</sub><br>(0.24276 301556) <sub>(8)</sub><br>(1.61337 611067) <sub>(8)</sub><br>(1.11206 404435) <sub>(8)</sub><br>(1.51544 163223) <sub>(8)</sub> | $n \log_2 10$ $3.32192 80949$ $6.64385 61898$ $9.96578 42847$ $13.28771 23795$ $16.60964 04744$ ATHEMATICAL CO $e = (0.60964 - 0.60964)$ $e = (0.60964 - 0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ $e = (0.60964)$ | n<br>6<br>7<br>8<br>9<br>10<br>2.55760 521305) <sub>(8)</sub><br>0.27426 530661) <sub>(8)</sub><br>1.51411 230704) <sub>(8)</sub><br>0.33626 754251) <sub>(8)</sub><br>1.34252 166245) <sub>(8)</sub> | n log <sub>1(</sub> 1.80617 2.10720 2.40823 2.70926 3.01029 2.40821 2.70926 3.01029 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.40821 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70926 2.70 | 99740<br>99696<br>99653<br>99610<br>99566 | (0.44742<br>- (0.43127<br>(0.54271) | 93156 8569<br>25349 6664<br>57542 4759<br>89735 2854<br>21928 0948<br>233602)(8)<br>030645)(8)<br>746320)(8) | ## OCTAL COMBINING TABLES ## **MEMORY REFERENCE INSTRUCTIONS** ## **Indirect Addressing** Refer to octal instruction codes given on the following page. To combine code for indirect addressing, merge "100000" with octal instruction code. ## **REGISTER REFERENCE INSTRUCTIONS** #### Shift-Rotate Group (SRG) - 1. select to operate A or B. - 2. select 1 to 4 instructions, not more than one from each column. - combine octal codes (leading zeros omitted) by inclusive or. - 4. order of execution is from column 1 to column 4. #### A Operations | | 1 | 2 | 3 | 4 | |---------------------------------|-------------------------------------------|----------|------------------------|------------------------------------------------------| | ALS | (1000) | CLE (40) | SLA (10) | ALS (20) | | ARS | (1100) | | | ARS (21) | | RAL | (1200) | | | RAL (22) | | RAR | (1300) | | | RAR (23) | | ALR | (1400) | | | ALR (24) | | ERA | (1500) | | | ERA (25) | | ELA | (1600) | | | ELA (26) | | ALF | (1700) | | | ALF (27) | | | | | | | | | | | | | | ВОр | erations | | | | | ВОр | erations<br>1 | 2 | 3 | 4 | | - | 1 | 2 | <b>3</b><br>SLB (4010) | • | | BLS | 1 | 2 | • | • | | BLS<br>BRS | <b>1</b><br>(5000) | 2 | • | BLS (4020) | | BLS<br>BRS<br>RBL | <b>1</b><br>(5000)<br>(5100) | 2 | • | BLS (4020)<br>BRS (4021) | | BLS<br>BRS<br>RBL<br>RBR | 1<br>(5000)<br>(5100)<br>(5200) | 2 | • | BLS (4020)<br>BRS (4021)<br>RBL (4022) | | BLS<br>BRS<br>RBL<br>RBR<br>BLR | 1<br>(5000)<br>(5100)<br>(5200)<br>(5300) | 2 | • | BLS (4020)<br>BRS (4021)<br>RBL (4022)<br>RBR (4023) | #### Alter-Skip Group (ASG) - 1. select to operate on A or B. - select 1 to 8 instructions, not more than one from each column. - combine octal codes (leading zeros omitted) by inclusive or. - 4. order of execution is from column 1 to column 8. #### **A Operations** | 1 | 2 | 3 | 4 | |--------------|------------|------------|------------| | CLA (2400) | SEZ (2040) | CLE (2100) | SSA (2020) | | CMA (3000) | | CME (2200) | | | CCA (3400) | | CCE (2300) | | | | | | | | 5 | 6 | 7 | 8 | | SLA (2010) | INA (2004) | SZA (2002) | RSS (2001) | | | | | | | | | | | | | | | | | B Operations | | | | | | | | | | 1 | 2 | 3 | 4 | | 1 | 2 | 3 | 4 | |------------|------------|------------|------------| | CLB (6400) | SEZ (6040) | CLE (6100) | SSB (6020) | | CMB (7000) | | CME (6200) | | | CCB (7400) | | CCE (6300) | | | | | | | | 5 | 6 | 7 | 8 | | SLB (6010) | INB (6004) | SZB (6002) | RSS (6001) | | | | | | #### INPUT/OUTPUT INSTRUCTIONS #### Clear Flag BLF (5700) Refer to octal instruction codes given on the following page. BLF (4027) To clear flag after execution (instead of holding flag), merge "001000" with octal instruction code. ## INSTRUCTION CODES IN OCTAL | ADB 04(1XX) CMB AND 01(0XX) CME CPA 05(0XX) INA CPB 05(1XX) INB | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | Ext. Inst. ADX ADY CAX CAY CBS CBT CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | Group 105746 105756 101741 101751 105774 105766 105741 105751 105776 101744 105754 105754 105761 105771 105760 105770 105762 105772 101742 | Dynamic Map DJP DJS JRS LFA LFB MBF MBI MBW MWF MWI MWW PAA PAB PBB RSA RSB RVA | 105732<br>105733<br>105715<br>101727<br>105727<br>105703<br>105702<br>105704<br>105706<br>105706<br>105707<br>101712<br>105712<br>105713<br>105713<br>101730<br>105730<br>101731 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADB 04(1XX) AND 01(0XX) CPA 05(0XX) INA CPB 05(1XX) INB IOR 03(0XX) ISZ 03(1XX) JSZ 03(1XX) JSB 01(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA LDB 06(1XX) SSB STA 07(0XX) LB 07(1XX) SZB XOR 02(0XX) LB 001400 ALS 001000 ALS 001000 ALS 001100 BLF 005700 BLF 005700 BLR 005400 BLR 005400 BLS 005000 BRS 005100 CLE 000040 CLE 000040 CLE 0005600 ELA 001500 CME CMB | 007000<br>002200<br>002200<br>002004<br>006004<br>002001<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>0010<br>002002<br>006002 | ADY CAX CAY CBS CBT CBX CBY CMW CXA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105756<br>101741<br>101751<br>105774<br>105766<br>105741<br>105751<br>105776<br>101744<br>105744<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762 | DJS JRS LFA LFB MBF MBI MBW MWF MWI MWW PAA PAB PBA PBB RSA RSB | 105733<br>105715<br>101727<br>105727<br>105703<br>105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | AND 01(0XX) CPA 05(0XX) INA CPB 05(1XX) INB IOR 03(0XX) ISZ 03(1XX) JSB 01(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA LDB 06(1XX) SSB STA 07(0XX) LB 07(1XX) SSB STA 07(0XX) LB 001700 ALF 001700 ALF 001700 ALS 001000 ALS 001100 BLF 005700 BLF 005700 BLR 005400 BLR 005400 BLS 005000 BRS 005100 CLE 000040 CLE 000040 ELA 001600 ELA 001500 ERA 001500 CME INA INA INB | 002200<br>002004<br>006004<br>002001<br>002040<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002 | CAX CAY CBS CBT CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 101741<br>101751<br>105774<br>105766<br>105741<br>105751<br>105776<br>101744<br>105744<br>105754<br>105761<br>105761<br>105770<br>105762<br>105772 | JRS LFA LFB MBF MBI MBW MWF MWI MWW PAA PAB PBA PBB RSA RSB | 105715<br>101727<br>105727<br>105703<br>105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | CPA 05(0XX) CPB 05(1XX) INA INB IOR 03(0XX) ISZ 03(1XX) JSZ 03(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA LDB 06(1XX) SSB STA 07(0XX) SSB STA 07(0XX) LBinary Input/Outp Shift-Rotate ALF 001700 ALS 001000 ALS 001000 ALS 001100 BLF 005700 BLF 005700 BLR 005400 BLR 005400 BLS 005000 BLS 005000 BRS 005100 CLE 000040 CLE 000040 CLE 0005600 ELA 001500 ENSS SOC | 002004<br>006004<br>002001<br>002040<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>001002<br>005002<br>005002 | CAY CBS CBT CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 101751<br>105774<br>105766<br>105741<br>105751<br>105776<br>101744<br>105744<br>105754<br>105761<br>105761<br>105770<br>105760<br>105770 | LFA LFB MBF MBI MBW MWF MWI MWW PAA PAB PBA PBB RSA RSB | 101727<br>105727<br>105703<br>105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | CPB 05(1XX) IOR 03(0XX) ISZ 03(1XX) JMP 02(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA LDB 06(1XX) SSB STA 07(0XX) SSB STA 07(0XX) LBinary Shift-Rotate ALF 001700 ALS 001000 ALS 001000 ALS 001100 BLF 005700 BLF 005700 BLR 005400 BLR 005400 BLS 005000 BLR 005400 BLS 005000 BRS 005100 CLE 000040 CLE 000040 CLE 0005600 ELA 001500 SFC ELB 005600 ERA 001500 CSEC SSS SOC | 006004<br>002001<br>002040<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002 | CBS CBT CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105774<br>105766<br>105741<br>105751<br>105776<br>101744<br>105744<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762 | LFB MBF MBI MBW MWF MWI MWW PAA PAB PBA PBB RSA RSB | 105727<br>105703<br>105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | IOR 03(0XX) ISZ 03(1XX) JMP 02(1XX) JSB 01(1XX) SLB LDA 06(0XX) LDB 06(1XX) STA 07(0XX) STB 07(1XX) XOR 02(0XX) L Binary Input/Outp CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 SFC ELB 005600 SFS ERA 001500 SOC | 002001<br>002040<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>00107 | CBT CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105766<br>105741<br>105751<br>105776<br>101744<br>105744<br>101754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762 | MBF<br>MBI<br>MBW<br>MWF<br>MWI<br>MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105703<br>105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | ISZ 03(1XX) JMP 02(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA SSB STA 07(0XX) STB 07(1XX) XOR 02(0XX) LBinary Input/Outp CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 002040<br>002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002 | CBX CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105741<br>105751<br>105776<br>101744<br>105744<br>101754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762 | MBI<br>MBW<br>MWF<br>MWI<br>MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105702<br>105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | JMP 02(1XX) JSB 01(1XX) LDA 06(0XX) LDB 06(1XX) SSA STA 07(0XX) STB 07(1XX) XOR 02(0XX) L Binary Shift-Rotate ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 BLF 005700 LIB BLF 005700 MIA BLF 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 SFC ELB 005600 SFS ERA 001500 SOC | 002010<br>006010<br>002020<br>006020<br>002002<br>006002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002<br>001002 | CBY CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105751<br>105776<br>101744<br>105744<br>105754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762 | MBW<br>MWF<br>MWI<br>MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105704<br>105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | JSB 01(1XX) LDA 06(0XX) SSA LDB 06(1XX) SSB STA 07(0XX) STB 07(1XX) XOR 02(0XX) LBinary Input/Outp CLC CLF CLC ALF 001700 CLO ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 006010<br>002020<br>006020<br>002002<br>006002<br>006002 | CMW CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 105776<br>101744<br>105744<br>105754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762<br>105772 | MWF<br>MWI<br>MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105706<br>105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | LDA 06(0XX) LDB 06(1XX) STA 07(0XX) STB 07(1XX) XOR 02(0XX) LBinary Input/Outp CLC ALF 001700 ALR 001400 ALS 001000 ALS 001000 ALS 001100 BLF 005700 BLR 005400 BLR 005400 BLR 005400 BLS 005000 BLS 005000 BLS 005000 BLS 05100 CLE 000040 CLE 000600 ELA 001600 SFC ELB 005600 SFS SOC | 002020<br>006020<br>002002<br>006002<br>006002<br>004<br>004<br>005<br>005<br>005<br>005<br>005<br>005<br>005<br>005 | CXA CXB CYA CYB DSX DSY ISX ISY JLY JPY LAX LAY | 101744<br>105744<br>101754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762<br>105772 | MWI<br>MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105705<br>105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | LDB 06(1XX) SSB STA 07(0XX) SZA STB 07(1XX) SZB XOR 02(0XX) Linput/Outp LBinary CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 MIA BLS 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 006020<br>002002<br>006002<br>out<br>1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | CXB<br>CYA<br>CYB<br>DSX<br>DSY<br>ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105744<br>101754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762<br>105772 | MWW<br>PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105707<br>101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | STA 07(0XX) STB 07(1XX) XOR 02(0XX) L Binary Input/Outp CLC | 002002<br>006002<br>out<br>1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | CYA<br>CYB<br>DSX<br>DSY<br>ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 101754<br>105754<br>105761<br>105771<br>105760<br>105770<br>105762<br>105772 | PAA<br>PAB<br>PBA<br>PBB<br>RSA<br>RSB | 101712<br>105712<br>101713<br>105713<br>101730<br>105730 | | STB 07(1XX) XOR 02(0XX) L Binary Input/Outp Shift-Rotate | 006002<br>out<br>1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | CYB<br>DSX<br>DSY<br>ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105754<br>105761<br>105771<br>105760<br>105770<br>105762<br>105772 | PAB<br>PBA<br>PBB<br>RSA<br>RSB | 105712<br>101713<br>105713<br>101730<br>105730 | | XOR 02(0XX) Languary Shift-Rotate ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | DSX<br>DSY<br>ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105761<br>105771<br>105760<br>105770<br>105762<br>105772 | PBA<br>PBB<br>RSA<br>RSB | 101713<br>105713<br>101730<br>105730 | | L Binary Input/Output | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | DSY<br>ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105771<br>105760<br>105770<br>105762<br>105772 | PBB<br>RSA<br>RSB | 105713<br>101730<br>105730 | | Shift-Rotate CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | ISX<br>ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105760<br>105770<br>105762<br>105772 | RSA<br>RSB | 101730<br>105730 | | Shift-Rotate CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | ISY<br>JLY<br>JPY<br>LAX<br>LAY | 105770<br>105762<br>105772 | RSB | 105730 | | Shift-Rotate CLC ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLS 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1067<br>1031<br>103101<br>1020<br>1025<br>1065<br>1024 | JLY<br>JPY<br>LAX<br>LAY | 105762<br>105772 | | | | ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1031<br>103101<br>1020<br>1025<br>1065<br>1024 | JPY<br>LAX<br>LAY | 105772 | RVA | | | ALF 001700 CLF ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1031<br>103101<br>1020<br>1025<br>1065<br>1024 | LAX<br>LAY | | | | | ALR 001400 CLO ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 103101<br>1020<br>1025<br>1065<br>1024 | LAY | 101742 | RVB | 105731 | | ALS 001000 HLT ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1020<br>1025<br>1065<br>1024 | | | SJP | 105734 | | ARS 001100 LIA BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1025<br>1065<br>1024 | 1 157 | 101752 | SJS | 105735 | | BLF 005700 LIB BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1065<br>1024 | LBT | 105763 | SSM | 105714 | | BLR 005400 MIA BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1024 | LBX | 105742 | SYA | 101710 | | BLS 005000 MIB BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | | LBY | 105752 | SYB | 105710 | | BRS 005100 OTA CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1064 | LDX | 105745 | UJP | 105736 | | CLE 000040 OTB ELA 001600 SFC ELB 005600 SFS ERA 001500 SOC | 1026 | LDY | 105755 | UJS | 105737 | | ELA 001600 SFC<br>ELB 005600 SFS<br>ERA 001500 SOC | 1066 | МВТ | 105765 | USA | 101711 | | ELB 005600 SFS<br>ERA 001500 SOC | 1022 | MVW | 105777 | USB | 105711 | | ERA 001500 SOC | 1023 | SAX | 101740 | XCA | 101726 | | | 102201 | SAY | 101750 | ХСВ | 105726 | | | 102301 | SBS | 105773 | XLA | 101724 | | NOP 000000 STC | 1027 | SBT | 105764 | XLB | 105724 | | RAL 001200 STF | 1021 | SBX | 105740 | XMA | 101722 | | RAR 001300 STO | 102101 | SBY | 105750 | XMB | 105722 | | RBL 005200 | 102101 | SFB | 105767 | XMM | 105720 | | RBR 005300 | | STX | 105743 | XMS | 105721 | | SLA 000010 Extended A | Arithmetic | STY | 105753 | XSA | 101725 | | | 1000(01X)- | TBS | 105775 | XSB | 105725 | | ASR | 1010(01X)- | XAX | 101747 | | | | | 100400 | XAY | 101757 | | | | | 104200 | XBX | 105747 | | | | | 104400 | XBY | 105757 | | | | | 1000(10X)- | | | | | | | 1010(10X)- | | | | | | | 100200 | | | | | | | 1001(00X)- | | | | | | 1 - | 1011(00X)- | | | | | | | Binary | | | | | | | ~ Binary | <b>-</b> | | | | | | | Floating P | oint | | | | *Assuming: no indirect addressing | | FAD | 105000 | | | | no combined instructions | | FDV | 105060 | | | | shifts taken in first position | n only | FIX | 105100 | | | | hold flag after I/O execution | on | FLT | 105120 | | | | <b>3</b> | | FMP | 105040 | | | | lefer to preceding page for octal combinit | ng tables | FSB | 105020 | | | ## BASE SET INSTRUCTION CODES IN BINARY | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | |------------|------------|-------|------------|---------|--------------|------------|------------|-----------------|-----------------------|------------------------------------------|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|-------|------------|-----| | D/I<br>D/I | AND<br>XOR | | 001<br>010 | | 0 | Z/C | | | | | - Mem | ory Add | ress — | | | | | | | D/I | IOR | | 011 | | 0 | Z/C<br>Z/C | | | | | | | | | | | | | | D/I | JSB | | 001 | | Ť | Z/C | | | ing in the second | | | | | | | | | | | D/I | JMP | | 010 | | | Z/C | | | | | | anti: | | | | | | | | D/I | ISZ | | 011 | 101 | | Z/C | | | | | | | | | | | | | | D/I | AD* | | 100 | | A/B | Z/C | | | | | | | | | | | | | | D/I | CP* | | 101 | | A/B | Z/C | | | Marti | | | 504 | | | | | | | | D/I | LD* | | 110 | | A/B | Z/C | | | | | | | | | | | | | | ווכ | ST* | | 111 | | A/B | Z/C | | | | | | | | 1=3 | | | | | | 15 | 14 | 13 | | 12 | | 10 | 9 | 8 | | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | 0 | SRG | | 000 | | A/B<br>A/B | 0 | D/E<br>D/E | *LS<br>*RS | | 000 | | tCLE | D/E | ‡sL* | *LS | | 000 | | | | | | | 169 | A/B | 0 | D/E | R*L | | 001 | | | D/E | | *RS | | 001 | | | | | | | | A/B | 0 | D/E | R*R | race i | 010<br>011 | 555 | | D/E | | RL | | 010 | | | | | | | 17.3 | A/B | 0 | D/E | *LR | | 100 | | | D/E | | R*R | | 011 | | | 334 | | | | | A/B | 0 | D/E | ER* | | 101 | | | D/E<br>D/E | | *LR<br>ER* | | 100 | | | | | | | i in | A/B | Ö | D/E | EL* | | 110 | | | D/E | | EL. | | 101<br>110 | | | | | hijk | | | A/B | Ō | D/E | *LF | | 311 | | | D/E | | *LF | | 111 | | | | | | | | NOP | 000 | | | | 000 | | | 000 | | | | 000 | | | 15 | 14 | 13 | | 12 | | 10 | | - 8 | | | 6 | | 4 | 3 | 2 | 1 | | 0 | | 0 | ASG | | 000 | | A/B | | CL* | 01 | CLE | | 01 | SEZ | SS* | SL* | IN* | sz* | | RSS | | | | | y Er | | A/B | Spekie | CM. | 10 | CME | | 10 | | | | | | | | | | | | | | A/B | | cc. | 14 | CCE | | 11 | | | | | | 75 | | | 15 | 14 | 13 | | 12 | . 11 | 10 | 9 | 8 | 7 | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | 1 | IOG | | 000 | | | 1 | H/C | HLT | | 000 | | | | Sele | ect Code | | | | | | | | | | | | 0 | STF | | 001 | | | | | | 56. | | | | 751 | | | | . 11.11 | | 91 | | CLF | | 001 | | | | | | | | | | | | | 4. j | 52 | | 9 | 0 | SFC | | 010 | | | | | | | | | | | | Kij | | | | 1 | 0 | SFS | | 011 | | | | | | | | | | | | | | | A/B | 1 | н/с | MI* | | 100 | | | | | | | | | | | | | | | A/B | 1 | H/C | LI* | | 101 | | | arw | | | | | | | | | | | | A/B | | H/C | OT* | | 110 | 165 | | | | | | | | | | | | | | 0 | | H/C | STC | | | | | | | | | | | | KH | | | | | 1 | 1 | H/C<br>0 | STO | | 111<br>001 | | | 000 | | | 001 | | | | | Raini | | | | | F. | | CLO | | 001 | | | 000 | | | 001 | | | | | | | | | li de o | 1 | H/C | SOC | | 010 | | | 000 | | | 001 | | | | | | | | | | | H/C | sos | | 011 | | | 000 | | | 001 | | | | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | | 6 | 5 | | 3 | 2 | | | 0 | | | EAG | | 000 | | MPY** | | 000 | | 010 | | | | 000 | | | 000 | | | | | | | a.E. | | DIV** | fall: | 000 | | 100 | | | | 000 | | | 000 | | | | | | | | | DLD** | | 100 | | 010 | | | | 000 | | | 000 | | | | | No. E | | | | DST** | | 100 | | 100 | | | | 000 | | | 000 | | | | | | | 171 | | ASR | | 001 | | 000 | | | 0 | | | | | | | | 14-1 | | | | | ASL | | 000 | | 000 | | | 0 | 1 | | | umber | | | | | | | | | LSR | | 001 | | 000 | | | | 0 | | | - of | | 11 | | | | | | | LSL | | 000<br>001 | | 001 | en e | | 0 | 0 | | | bits | | | | | | | | | RRR | | 000 | | 001 | | | 0 | o | | | | | | | 15 | 14 | 13 | | 12 | 11 | -10 | 9 | 8 | 7 | | 8 | Б | 4 | 3 | 2 | | | 0 | | 1 | FLTP | T | 000 | | | 101 | | | 00 | | FAD | - 00 | | 0 | | 000 | | | | | | 54. | | | | | | | | | FSB | 00 | | | KKO | MIT | | | | | | | | | | | | | | 3 T 1 M 1 T 1 | FMP | . 01 | | | | | | TH | | | | | | | | | SPANIE | | | The second second | FDV | 0 | | | | | | | | AG. | B. A. | | | | er it englis | | | | | | FIX | 10 | | | KAY | | | | | | | | | | | | | | | | FLT | | | | | | | | | N | tes: | * = A | or B | ccord | ing to bit 1 | | | | | | | tCLE: | Only | this bit | is requi | red. | | | | | | | | | E, H/C cod | | | | | | | tsL*: | | this bit | | | B as | | | | | | | | Memory A | | | | | | 5.655 | BEST N | A STATE OF THE STA | cable) a | | | | | | | | 366 | OLIO AA | 010 12 | INCHIOLY A | adi cas. | | Att Day Park to | ACTIVITIES OF THE SEC | | | | CPP | cubic, a | ic icada | | | | ## **BASE SET INSTRUCTION CODES IN BINARY (CONT)** | EXTENDED INSTRUCTION SPROUP | 15 | 14 | 13 | 12 | <b>,11</b> | 10 | 9 | 8 | 7 | . 6 | 5 | ٨ | 3 | 2 | 1 | 0 | |-----------------------------|-----------------------------|----|----|----|------------|----|----|----|---|-----|---|-----|-------------------------------------------|-------------|-----------------------|------------------| | SAX/SAY/SBX/SBY | | 0 | 0 | 0 | A/B | 0 | | 1 | 1 | | 1 | 0 | X/Y | 0 | 0 | 0 | | CAX/CAY/CBX/CBY | | 0 | 0 | 0 | ]а/в | 0 | 1 | | 1 | | | 0 | [x/Y] | 0 | 0 | | | LAX/LAY/LBX/LBY | | o | O | 0 | А/В | 0 | | Į. | | 1 | 1 | 0 | X/Y | 0 | 1 | 0 | | STX/STY | | 0 | 0 | 0 | 51 | 0 | | 11 | 1 | 1 | 1 | 0 | ×M | 0 | 1 | | | CXA/CYA/CXB/CYB | | o | 0 | 0 | А/в | 0 | 1 | | 1 | 1 | 1 | 0 | ΧΛΛ | 1 | 0 | 0 | | LDX/LDY | arratulli<br>131 a<br>131 a | 0 | 0 | 0 | | 0 | | | 1 | 1 | 1 | 0 | ×/Y | | 0 | | | ADX/ADY | 1. | o | 0 | 0 | 11 | 0 | | | 1 | | ī | 0 | x/Y | 1 | 1 | 0 | | XAX/XAY/XBX/XBY | | o | 0 | 0 | A/B | 0 | | | | | 1 | 0 | x/Y | 123 i | 1 | • | | ISX/ISY/DSX/DSY | | 0 | 0 | 0 | | 0 | 4 | | | 1 | 1 | f | ]×/Y | 0 | 0 | 1/0 | | JUMP INSTRUCTIONS | | 0 | 0 | 0 | | 0 | | 1 | | 1 | | | <i>V//</i> // | 0 | | 0 | | | | | | | | | | | | | | JPY | = 0.<br>= 1 | | | | | BYTE INSTRUCTIONS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | 1 | • • | | | | | | | | | | | | | | | | | | LBT =<br>SBT =<br>MBT =<br>CBT =<br>SFB = | 1 | 1<br>0<br>0<br>1<br>1 | 1<br>0<br>1<br>0 | | BIT INSTRUCTIONS | 1 | 0 | 0 | 0 | 134 | 0 | 46 | | | | 1 | 1 | 1 / | | | | | | | | | | | | | | | | | 410 | CBS = | 0<br>1<br>1 | 1<br>0<br>0 | 1<br>0<br>1 | | WORD INSTRUCTIONS | 1 | 0 | 0 | 0 | | 0 | 7 | | | | | 1 | | | 1 | //// | | | | | | | | | | | | | | | | | 1W =<br>/W = | | ## DYNAMIC MAPPING SYSTEM INSTRUCTION CODES IN BINARY | DJP/DJS/UJP/UJS | 15 14 13 12<br>1 0 0 0 | 11 10 9 | 8 7 6 | 5 4 3 | 2 1 0<br>D/U 1 P/S | |-----------------|------------------------|---------|-------|-------|--------------------| | JRS | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 1 | 1 0 1 | | LFA/LFB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 1 0 | 1 1 1 | | MBI/MBF | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 0 | 0 1 I/F | | MBW | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 0 | 1 0 0 | | MWF | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 0 | 1 1 0 | | MWI/MWW | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 0 | 1 I/W 1 | | PAA/PAB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 0 1 | 0 1 0 | | PBA/PBB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 0 1 | 0 1 1 | | RSA/RSB/RVA/RVB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 1 1 | 0 0 S/V | | SJP/SJS | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 1 1 | 1 0 P/S | | SSM | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 0 1 | 1 0 0 | | SYA/SYB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 0 1 | 0 0 0 | | USA/USB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 0 1 | 0 0 1 | | XCA/XCB/XLA/XLB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 1 0 | 1 L/C 0 | | XMA/XMB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 1 0 | 0 1 0 | | XMM/XMS | 1 0 0 0 | 1 0 1 | 1 1 1 | 0 1 0 | 0 0 M/S | | XSA/XSB | 1 0 0 0 | A/B 0 1 | 1 1 1 | 0 0 1 | 1 0 1 | | | | | | | | #### **EXTEND AND OVERFLOW EXAMPLES** ## INTERRUPT AND I/O CONTROL SUMMARY | S.C. 00 | \$.C. 01 | s.c. 02 | S.C. 03 | |-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NOP | NOP | Prepares DCPC channel 1 to receive and store the block length in 2's complement form. | Prepares DCPC channel 2 to receive and store the block length in 2's complement form. | | Clears all Control FF's from S.C. 06 and up; effectively turns off all I/O devices. | NOP | Prepares DCPC channel 1 to receive and store the direction of data flow and the starting memory address. | Prepares DCPC channel 2 to receive and store the direction of data flow and the starting memory address. | | Turns on interrupt system. | STO sets overflow bit. | NOP | NOP | | Turns off interrupt system except power fail (S.C. 04) and parity error (S.C. 05). | CLO clears overflow bit. | NOP | NOP | | Skip if interrupt system is on. | sos | NOP | NOP | | Skip if interrupt system is off. | soc | NOP | NOP | | Loads A/B register with all zeros. (Equivalent to CLA/B instruction.) | Loads display register contents into A/B register. | Loads present contents<br>of DCPC channel 1<br>word count register<br>into A/B register. | Loads present contents<br>of DCPC channel 2<br>word count register<br>into A/B register. | | Equivalent to a NOP. | Merges display register contents into A/B register. | Merges present contents of DCPC channel 1 word count register into A/B register. | Merges present contents of DCPC channel 2 word count register into A/B register. | | NOP | Outputs A/B register contents into display register. | 1. Outputs to DCPC channel 1 the block length in 2's complement form (previously prepared by an STC 02 instruction). 2. Outputs to DCPC channel 1 the direction of data flow and the starting memory address (previously | 1. Outputs to DCPC channel 2 the block length in 2's complement form (previously prepared by an STC 03 instruction). 2. Outputs to DCPC channel 2 the direction of data flow and the starting memory address (previously prepared by a | | | Clears all Control FF's from S.C. 06 and up; effectively turns off all I/O devices. Turns on interrupt system. Turns off interrupt system except power fail (S.C. 04) and parity error (S.C. 05). Skip if interrupt system is on. Skip if interrupt system is off. Loads A/B register with all zeros. (Equivalent to CLA/B instruction.) Equivalent to a NOP. | NOP Clears all Control FF's from S.C. 06 and up; effectively turns off all I/O devices. Turns on interrupt system. STO sets overflow bit. Turns off interrupt system except power fail (S.C. 04) and parity error (S.C. 05). Skip if interrupt system is on. Skip if interrupt system is off. Loads A/B register with all zeros. (Equivalent to CLA/B instruction.) Equivalent to a NOP. Merges display register contents into A/B register. NOP Outputs A/B register contents into A/B register contents into A/B register. | NOP NOP NOP NOP Prepares DCPC channel 1 to receive and store the block length in 2's complement form. Clears all Control FF's from S.C. 06 and up; effectively turns off all I/O devices. Turns on interrupt system. STO sets overflow bit. Turns off interrupt system except power fail (S.C. 04) and parity error (S.C. 05). Skip if interrupt system is on. Skip if interrupt system is off. Loads A/B register with all zeros. (Equivalent to CLA/B instruction.) Equivalent to a NOP. Merges display register contents into A/B register. NOP NOP Outputs A/B register contents of DCPC channel 1 word count register into A/B register. NOP Outputs A/B register contents of DCPC channel 1 word count register into A/B register. NOP Outputs A/B register contents of DCPC channel 1 word count register into A/B register. NOP Outputs A/B register contents of DCPC channel 1 word count register into A/B register. Outputs to DCPC channel 1 word count register into A/B register. Outputs to DCPC channel 1 the block length in 2's complement form (previously prepared by an STC 02 instruction). 2. Outputs to DCPC channel 1 the direction of data flow and the starting memory | | S.C. 04 | S.C. 05 | s.C. 06 | S.C. 07 | S.C. 10-77 | |------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------| | Re-initializes power-fail<br>logic and restores inter-<br>rupt capability to lower<br>priority functions. | Turns on memory protect. | Sets Control FF on DCPC channel 1 (activates DMA). | Sets Control FF on DCPC channel 2 (activates DMA). | Sets PCA Control FF and<br>turns on device on chan-<br>nel specified by S.C. | | Re-initialize power-fail logic and restores inter-<br>rupt capability to lower priority functions. | NOP | Clears Control FF on DCPC channel 1 (reestablishes priority with STF; does not turn off DCPC). | Clears Control FF on DCPC channel 2 (reestablishes priority with STF; does not turn off DCPC). | Clears PCA Control FF and turns off device. | | Flag FF sets auto-<br>matically when power<br>comes up. (No pro-<br>gram control<br>possible.) | Turns on parity error interrupt capability. | Aborts DCPC channel 1 data transfer. | Aborts DCPC channel 2 data transfer. | Sets PCA Flag FF. Computer Museum | | Flag FF clears auto-<br>matically when power<br>fail occurs. (No pro-<br>gram control<br>possible.) | Turns off parity error interrupt capability and clears violation register bit 15. | Clears Flag FF on DCPC channel 1. | Clears Flag FF on DCPC channel 2. | Clears PCA Flag FF. | | NOP | Skip if Dynamic Map-<br>ping System (DMS)<br>interrupt. | Tests if DCPC channel 1 data transfer is complete. | Skip if DCPC channel 2 data transfer is complete. | Skip if I/O channel Flag FF is set. | | Skip if power fail has occurred. | Skip if memory pro-<br>tect interrupt. | Tests if DCPC channel 1 data transfer is still in progress. | Skip if DCPC channel 2 data transfer is still in progress. | Skip if I/O channel Flag FF is clear. | | Loads contents of central interrupt register (S.C. of last interrupting device) into least-significant bits of A/B register. | Loads contents of violation register into A/B register: Bit 15 = 1 = PE Bit 15 = 0 = MPV | Loads A/B register with all ones. (Equivalent to CCA/CCB instruction.) | Loads A/B register with all ones. (Equivalent to CCA/CCB instruction.) | Loads contents of PCA data buffer into A/B register. | | Merges contents of central interrupt register into least-significant bits of A/B register. | Merges contents of violation register into A/B register. | Same as LIA/B 06 above. | Same as LIA/B 07 above. | Merges contents of PCA data buffer into A/B register. | | NOP | Outputs first address of unprotected memory to fence register. | Outputs to DCPC channel 1 the S.C. of I/O channel. Specify STC after each word; CLC after block. | Outputs to DCPC channel 2 the S.C. of I/O channel. Specify STC after each word; CLC after block. | Outputs data from A/B register into PCA data buffer. | | | | | | | ## **SALES & SERVICE OFFICES** AFRICA, ASIA, AUSTRALIA ANGOLA Telectra Telectra Empresa Técnica de Equipamentos Pléctricos, S.A.R.L. R. Barbosa Rodrigues, 42-1°0T.° Caixa Postal, 6487 Luanda Tel: 35515/6 Cable: TELECTRA Luanda AUSTRALIA Hewlett-Packard Australia Pty. Ltd. 31-41 Joseph Street Blackburn, Victoria 3130 P. 0. 80x 36 Doncaster East, Victoria 3109 Tel: 89-6351 Telby: 31.004 Telex: 31-024 Cable: HEWPARD Melbourne Hewlett-Packard Australia Pty. Ltd. 31 Bridge Street Pymble New South Wales, 2073 Tel: 449-6566 Telex: 21561 Cable: HEWPARD Sydney Cable: HEWPARD Sydney Hewlett-Packard Australia Pty. Ltd. 153 Greenhill Road Parkalde, S. A., 5063 Tel: 272-5911 Telex: 82536 ADEL Cable: HEWPARD ADELAIDE Hewlett-Packard Australia Pty. Ltd. 141 Stirling Highway Nedlands, W.A. 6009 Tel: 86-5455 Telex: 93859 PERTH Cable: HEWPARD PERTH Hewlett-Packard Australia Pty. Ltd. 121 Wollongong Street Fyshwick, A.C.T. 2609 Tel: 95-2733 Tel: 95-2733 Telex: 62650 Canberra Cable: HEWPARD CANBERRA Hewlett Packard Australia Pty. Ltd. 5th Floor Teachers Union Building 495-499 Boundary Street Spring Hill, 4000 Queensland Tel: 229-1544 Cable: HEWPARD Brisbane GUAM Medical/Pocket Calculators Only Guam Medical Supply, Inc. Jay Ease Building, Room 210 P.O. Box 8947 P.O. Box 8947 Tamuning 96911 Tel: 646-4513 Cable: EARMED Guam HONG KONG Schmidt & Co. (Hong Kong) Ltd. P 0. 80x 297 Connalight Centre 39th Floor Connaught Road, Central Hong Kong Tei: H-255-291-5 Telex: 74766 SCHMC HX Cable: SCHMIDTCO Hong Kong INDIA Blue Star Ltd. Blue Star Ltd. Kasturi Buildings Jamshedji Tata Rd. Bombay 400 020 Tel: 29 50 21 Telex: 2156 Cable: BLUEFROST Blue Star Ltd. Sahas 414/2 Vir Savarkar Marg Prabhadevi Bombay 400 025 Tel: 45 78 87 Telex: 4093 Cable: FROSTBLUE Blue Star Ltd. Band Box House Prabhadevi **Bombay** 400 025 Tel: 45 73 01 Telex: 3751 Cable: BLUESTAR Blue Star Ltd. 14/40 Civil Lines Kanpur 208 001 Tel: 6 88 82 Telex: 292 Cable: BLUESTAR Blue Star Ltd. 7 Hare Street P.O. Box 506 Calcutta 700 001 Tel: 23-0131 Telex: 7655 Cable: BLUESTAR Cable: BLUESTAN Blue Star Ltd. 7th & 8th Floor Bhandari House 91 Nehru Place New Delhi 110024 Tel: 634770 & 635166 Telex: 2463 Cable: BLUESTAR Blue Star Ltd. Blue Star House 11/11A Magarath Road Bangaiore 560 025 Tel: 55668 Telex: 430 Cable: BLUESTAR Blue Star Ltd. Meeakshi Mandiran xxx/16/8 Mahatma Gandhi Rd. Cochin 680 016 Tel: 32059, 32161, 32282 Telex: 046-514 Cable: BLUESTAR Blue Star Ltd. 1-1-117/1 Sarojiini Devi Road Secunderabed 500 003 Tel: 70126, 70127 Cable: BLUEFROST Telex: 459 Blue Star Ltd. 2/34 Kodambakkan High Road Madras 600034 Tel: 82056 Telex: 041-379 Cable: BLUESTAR Blue Star Ltd. Nathraj Mansions 2nd Floor Bistupur Jamahedpur 831 001 Tel: 7383 Cable: BLUESTAR Telex: 240 INOONESIA BERCA Indonesia P.T. P.O. Box 496 1st Floor JL, Cikini Raya 61 Jakarta Tel: 56038, 40369, 49886 Telex: 42895 Cable: BERCACON BERCA Indonesia P.T 63 JL. Raya Gubeng ISRAEL ISRAEL Electronics & Engineering Div. of Molorola Israel Ltd. 17. Kremenetski Street P. O. Box 25016 Tel-Aviv Tel: 38973 Telex: 33569 Cable: BASTEL Tel-Aviv JAPAN Yokogawa-Hewlett-Packard Ltd. Ohashi Building 59-1 Yoyogi 1-Chome Shibuya-ku. Tokyo 151 Tel: 03-370-2281/92 Telex: 232-2024YHP Cable: YHPMARKET TOK 23-724 Vokogawa-Hewlett-Packard Ltd. Seiko Ibaraki Building 2-8 Kasuga 2-chome, Ibaraki-shi Osaka,567 Tel: (0726) 23-1641 Telex: 5332-385 YHP OSAKA Yokogawa-Hewlett-Packard Ltd. Nakamo Building 24 Kami Sasajima-cho Nakamura-ku, **Nagoya** . 450 Tel: (052) 571-5171 Tel: (US2) 5/1-51/7 Yokogawa-Hewlett-Packard Ltd. Tanigawa Building 2-24-1 Tsuruya-cho Kanagawa-ku Yokohama, 221 Tel: 045-312-1252 Telex: 382-3204 YHP YOK Yokogawa-Hewlett-Packard Ltd. Mito Mitsu Building 105. Chome-1,San-no-maru Mito. Ibaragi 310 Tel:: 0292-25-7470 Yokogawa-Hewlett-Packard Ltd. Inoue Building 1348-3. Asahi-cho. 1-chome Atsugi. Kanagawa 243 Tel: 0462-24-0452 Yokogawa-Hewlett-Packard Ltd. Kimura Building 3rd Floor 20 2-chome. Tsukuba Kumagaya, Saitama 360 Tel: 0485-24-6563 KENYA Technical Engineering Services (E.A.)Ltd., P.O. Box 18311 Nairobi Tel: 557726/556762 Cable: PROTON Medical Only International Aeradio(E.A.)Ltd., P.O. Box 19012 Nairobi Airport Nairobi Tel: 336055/56 Telex: 22201/22301 Cable: INTAERID Nairobi KOREA Samsung Electronics Co., Ltd. 20th Ft. Dongbang Bldg.250,2-KA C.P.O. Box 2775 Taepyung-Ro, Chung-Ku Seoul Tel: (23) 6811 Telex: 22575 Cable: ELEKSTAR Seoul MALAYSIA Teknik Mutu Sdn. Bhd. 2 Lorong 13/6A Section 13 Petaling Jaya, Selangor Tel: 54994/54916 Telex: MA 37605 Telex: MA 37605 Protel Engineering P.O. Box 1917 Lot 259. Satok Road Kuching, Sarawak Tel: 2400 Cable: PROTEL ENG MOZAMBIQUE A.N. Goncalves, Lta. 162, 1° Apt. 14 Av. O. Luis Caixa Postal 107 Caixa Postal 107 Louranco Marques Tel: 27091, 27114 Telex: 6-203 NEGON Mo Cable: NEGON NEW ZEALAND NEW ZEALAND Hewlett-Packard (N.Z.) Ltd. P.O. Box 9443 Courtney Place Wellington Tel: 877-199 Telex: NZ 3839 Cable: HEWPACK Wellington Hewlett-Packard (N.Z.) Ltd. Pakuranga Professional Centre 267 Pakuranga Highway Box 51092 Pakuranga Tel: 569-651 Cable: HEWPACK, Auckland Analytical/Medical Only Medical Supplies N. Z. Ltd. Scientific Division 79 Cartino Gore Rd. . Newmarket P. O. Box 1234 Auckland Tel: 75-289 Telex: 2958 MEDISUP Cable: DENTAL Auckland Anatylical/Medical Deb. Analytical Medical Only Medical Supplies N.Z. Ltd. P.O. Box 1994 147-161 Tory St. Wellington Telex: 3859 Cable: DENTAL. Wellington Analytical/Medical Only Medical Supplies N.Z. Ltd. P.O. Box 309 239 Stanmore Road Christchurch Tel: 892-019 Cable: DENTAL, Christchurch Analytical/Medical Only Medical Supplies N.Z. Ltd. 303 Great King Street P.O. Box 233 P.U. BOX 233 **Dunedin** Tel: 88-817 Cable: DENTAL, Dunedin NIGERIA NIGERIA The Electronics Instrumentations Ltd. N6B/770 Oyo Road Oluseun House P.M.B. 5402 Ibadan Tel: 61577 Telex: 31231 TEIL Nigeria Cable: THETEIL Ibadan The Electronics Instrumenta-tions Ltd. 144 Agege Motor Road, Mushin P.O. Box 6645 Lagos Cable: THETEIL Lagos PAKISTAN Mushko & Company, Ltd Oosman Chambers Abduilah Haroon Road Karachi-3 Tel: 511027, 512927 Telex: KR894 Cable: COOPERATOR Karachi Mushko & Company, Ltd. 38B. Satellite Town Rewelpindi Tel: 41924 Cable: FEMUS Rawalpindi PHILIPPINES The Online Advanced Systems The Unline Advanced Systems Corporation 6th Floor, Yujui Co. Bldg. 560 Quintin Paredes St. Binondo, Manila Tel: 48-71-49, 48-68-53 In Makati: 85-35-81, 85-34-91 Telex: 3274 ONLINE RHODESIA Field Technical Sales 45 Kelvin Road North P.O. Box 3458 Salisbury Tel: 705231 (5 lines) Telex: RH 4/22 SINGA PORE Hewlett-Packard Singapore (Pte.) Ltd. 3841F. Jalan Bukit Merah Bik. 2. 6th Floor. Jalan Redhill industrial Estate Alexandra P. 0. Box 58. Singapore 3. Tel. 63,3022 Telex. HPSC RS 21486 Cable: HEWPACK. Singapore Cable, HEWPACK, Singapore SOUTH AFRICA Hewlett-Packard South Africa (Pty.), Ltd. Private Bag Wendywood Sandton, Transvaal 2144 Hewlett-Packard Center Daphne Street, Wendywood, Sandton, Transvaal 2144 Tel: 802-104018 Cleex: 8-4782 Cable, HEWPACK JOHANNESBURG Service Quantiment Lable. HEWPACK JOHANNESI Service Oepartment Hewlett-Packard South Africa (Pty.), Ltd. P. 0. Box. 39325 Gramley. Sandton. 2018 451 Wyhberg Extension 3. Sandton. 2001 Tel: 636-8188/9 Telex. 8-2391 Hewlett-Packard South Africa (PV, ). Ltd. P. 0. Box 120 Howard Place. Cape Province. 7450 Pine Park Center. Forest Drive. PireBands. Cape Province. 7405 Tel: 53-7955 btu 9 Telex. 57-0006 Service Department Hewlett-Packard South Africa Hewlett-Packard South. (Pty.). Ltd. P.O. Box 37099 Overport. Durban 4067 Braby House 641 Ridge Road Durban, 4001 Tel: 88-7478 Telex: 6-7954 TAIWAN Hewlett-Packard Far East Ltd.. Taiwan Branch 39 Chung Shao West Road Sec. 1, 7th Floor Taipei Tel: 3819160-4 Telex: 21824 HEWPACK Cable: HEWPACK TAIPEI Manufatt-Devard Far Fast Ltd. Hewlett-Packard Far East Ltd. Taiwan Branch 68-2, Chung Cheng 3rd. Road Kaohsiung Tel: (07) 242318-Kaohsiung Analytical Only San Kwang Instruments Co., Ltd. No. 20, Yung Sui Road Talpei Tel: 3715171-4 (5 lines) Telex: 22894 SANKWANG Cable: SANKWANG TAIPEI TANZANIA Medical Only International Aeradio (E.A.). Ltd. P.O. Box 861 Der es Saleam Tel: 21251 Ext. 265 Telex: 41030 THAILAND UNIMESA Co. Ltd Elcom Research Building Bangjak Sukumvit Ave. Bangkok Tel: 932387, 930338 Cable: UNIMESA Bangkok UGANDA Medical Only International Aeradio(E.A.), Ltd. P.O. Box 2577 Kampala Tel. 54388 Cable: INTAERIO Kampala ZAMBIA R.J. Tilbury (Zambia) Ltd. P.O. Box 2792 Lusaka Tel: 7,37.93 Cable: ARJAYTEE, Lusaka OTHER AREAS NOT LISTED, CONTACT: Hewlett-Packard Intercontinental 3200 Hilbirew Ave Palo Alto. California 94304 Tel: (415) 493-1501 TWX. 910-373-1267 Cable: HEWPACK Palo Alto Telex: 034-8300, 034-8493 #### **CANADA** ALBERTA Hewlett-Packard (Canada) Ltd. 11620A - 168 Street Edmonton T5M 3T9 Tel: (403) 452-3670 TWX: 610-831-2431 EDTH Hewlett-Packard (Canada) Ltd. 915-42 Ave S.E. Suite 102 Calgary T2G 121 Tel: (403) 287-1672 Twx: 610-82I-6141 BRITISH COLUMBIA Hewlett-Packard (Canada) Ltd. 837 E. Cordova Street Vancouver V6A 3R2 Tel: (604) 254-0531 TWX: 610-922-5059 VCR MANITOBA MANITOB A Hewlett-Packard (Canada) Ltd. 513 Century St. St. James Winnipog R3H OL8 Tel: (204) 786-7581 TWX: 610-671-3531 NOVA SCOTIA Hewlett-Packard (Canada) Ltd. 800 Windmill Road P. 0. 80x 9331 Dartmouth 82Y 3Z6 Tel: (902) 459-7820 TWX: 6I0-27I-4482 HFX ONTARIO Hewlett-Packard (Canada) Ltd. 1020 Morrison Dr. Ottawa K2H 8K7 Tel: (613) 820-6483 TWX: 610-513-1636 QUEBEC Hewlett-Packard (Canada) Ltd. 275 Hymus Blvd.. Pointe Claire H9R 1G7 Tel: (514) 697-4232 TWX: 610-422-3022 TLX: 05-821521 HPCL FOR CANADIAN AREAS NOT LISTED: Contact Hewiett-Packard (Canada) Ltd in Mississauga ### CENTRAL AND SOUTH AMERICA ARGENTINA Hewlett-Packard Argentina S.A. Ay. Leandro N. Alem 822 - 12° 1001Buenos Aires Tel: 31-6063,4,5,6 and 7 Telex: Public Booth N° 9 Cable: HEWPACK ARG BOLIVIA Stambuk & Mark (Bolivia) Ltda. Av. Mariscal, Santa Cruz 1342 La Paz Tel: 40626, 53163, 52421 Telex: 3560014 Cable: BUKMAR BRAZIL Hewlett-Packard do Brasil I.e.C. Ltda. Avenida Rio Negro, 980 Alphaville 06400 Barueri Sao Paulo Tel: 429-2148/9;429-2118/9 rer. 429-2148/9/429-2118/9 Hewlett-Packard do Brasil i.e.C. Ltda. Rua Padre Chagas, 32 90000-Pôrto Alegre-RS Tel: (0512) 22-2998, 22-5621 Cable: HEWPACK potto Alegre Hewlett-Packard do Brasil I.E.C. Lttda. Rua Siqueira Campos. 53 Copacabana 20000-Rto de Janeiro Tel: 257-80-94-DDD (021) Telex: 39I-212-1905 HEWP-BR Cable: HEWPACK Rio de Janeiro CHILE Calcagni y Metcalfe Ltda. Alameda 580-07. 807 Casilla 2118 Santiago, 1 Tel: 398613 Telex: 3520001 CALMET Cable: CALMET Santiago COLOMBIA COLOMBIA Instrumentación Henrik A. Langebaek & Kier S.A. Carrera 7 No. 48-75 Aparlado Aéreo 6287 Bogotás I.D.E. Tel: 69-88-77 Cable: AARIS Cable: AARIS Telex: 044-400 CQSTA RICA Cientifica Costarricense S. A. Calle Central, Avenidas 1 y 3 Apartado 10159 San José Tel: 21-86-13 Cable: GALGUR San José ECUADOR ECUADOR Medical Only A.F. Viscaino Compañía Ltda. Av. Rio Amazonas No. 239 P.O. Box 2925 Oulto Tei: 242-150,247-033/034 Cable: Astor Quito Calculators Only Computators x Equipos Electrónicos P. O. Box 2595 990 Toledo (y Cordero) Culto Tel: 525-982 Telex: 02-2113 Sagita Ed Cable: Sagita-Quito EL SALVADOR Instrumentacion y Procesamiento Electronico de el Salvador Bulevar de los Heroes II-48 San Salvador Tel: 252787 GUATEMALA IPESA Avenida La Reforma 3-48. Zona 9 Zona 9 Guatemala City Tel: 63627, 64786 Telex: 4192 Teletro Gu MEXICO Hewlett-Packard Mexicana. MEAN-CO Hewlett-Packard Mexicana. S.A. de C.V. Torres Adalid No. 21, 11° Piso Col. del Valte Mexico 12, D.F. Tel: (905) 543-42-32 Telex: 017-74-507 Hewlett-Packard Mexicana, S.A. de C.V. Ave. Constitución No. 2184 Monterrey, N.L. Tel: 48-71-32, 48-71-84 Telex: 038-843 NICARAGUA Roberto Terán G. Apartado Postal 689 Edificio Terán Managua Tel: 25114, 23412,23454 Cable: ROTERAN Managua PANAMA Electrónico Balboa, S.A. P. O. Box 4929 Calle Samuel Lewis Culded de Panama Tel: 64-2700 Telex: 3431103 Curunda, Canal Zone Canal Zone Cable: ELECTRON Panama PARAGUAY Z.J. Melamed S.R.L. Division: Aparatos y Equipos Médicos División: Aparatos y Equipos Científicos y de Investigación P. O. Box 676 Chile-482, Edificio Victoria Asunción Tel: 91-271, 91-272 Cable: RAMEL PERU Compañía Electro Médica S.A. Los Flamencos 145 San Isidro Casilla 1030 Lima 1 Tel: 41-4325 Cable: ELMEO Lima PUERTO RICO PUERTO RICO Hewlett-Packard Inter-Americas Puerto Rico Branch Office Calle 272, No. 203 Urb. Country Club Carolina 00924 Tel: (809) 762-7255 Telex: 345 0514 URUGUAY Pablo Ferrando S A. Comercia e Industrial Avenida Italia 2877 Casilla de Correo 370 Montavideo Tel: 40-3102 Cable: RADIUM Montevideo VENEZUELA VENEZUELA Packard de Venezuela Hewlett-Packard de Venez C.A. P.O. Box 50933 Caracas 105 Los Ruices Norte 3a Transversal Editicio Segre Caracas 107 Tel: 35-00-11 (20 lines) Telex: 25146 HEWPACK Cable. HEWPACK Caracas FOR AREAS NOT LISTED, CONTACT: Hewlett-Packard Inter-Americas 3200 Hillview Ave. Pato Atto. California 94304 Tei: (415) 493-1501 TWX: 910-373-1260 Cable: HEWPACK Palo Alto Telex: 034-8300, 034-8493 #### EUROPE, NORTH AFRICA AND MIDDLE EAST AUSTRIA Hewlett-Packard Ges.m.b.H. Handelskai 52 P.D. box 7 A-1205 Vienna Tei (0222) 351621 to 27 cable: HEWPAK Vienna Telex: 75923 hewpak a BELGIUM Hewlett-Packard Benelux S.A./N.V. Avenue de Col-Vert. 1. (Groenkraaglaan) B-1170 Brussels Tal: (603 873 92 40 Tel: (02) 672 22 40 Cable: PALOBEN Brussels Telex: 23 494 paloben bru CYPRUS Kypronics 8 Xenopoulos Rd. P.D. Box 1152 CY-Nicosia Tel: 45628/29 CAble: KypPONICS PANDEHIS Telex: 3018 CZECHOSLOVAKIA CZECHOSLOVAKIA Vyvojova a Provozni Zakladna Vyskumnych Ustavu v Bechovicich CSSR-25097 Bechovice u Prahy Tel: 89 93 41 Telex: 121333 Institute of Medical Bionics Vyskummy Ustav Lekarskej Bioniky Jedlova 6 CS-88346 **Bratislava-Kramare** Tel: 44-551/45-541 DDR Entwicklungslabor der TU Dresden Forschungsinstitut Meinsberg DDR-7305 Waldheim/Meinsberg Tel: 37-667 Telex: 112145 Export Contact AG Zuerich Guenther Forgber Schlegeistrasse 15 1040 **Berlin** Tel: 42-74-12 Telex: 111889 DENMARK Hewiett-packard A/S Datavej 52 DK-3460 Birkerod Tel: (02) 81 66 40 Cable: HEWPACK AS Telex: 166 40 hpas Hewlett-Packard A.S. Navervel 1 DK-8600 Silkeborg Tel: (06) 82 71 66 Telex: 166 40 hpas Cable: HEWPACK AS FINLAND Hewlett-Packard OY Nahkahousuntie 5 P.O. Box 6 SF-00211 Helsinki 21 Tel: (90) 6923031 Cable: HEWPACKOY Helsinki Telex: 12-1563 HEWPA SF FRANCE FRANCE Hewlett-Packard France Ouartier de Courtaboeuf Boite Postale No. 6 F-91401 Orsay Cedex Tel: (1) 907 78 25 Cable. HEWPACK Orsay Telex: 600048 Hewlett-Packard France Agency Régionale "Le Saquin" Chemin des Mouilles B.P. 162 F-69130 Ecully Tel: (78) 33 81 25. Cable: HEWPACK Eculy Telex. 31 06 17 reiex. 3.1 0b 17 Hewlett-Packard France Agence Régionale Péricentre de la Cépière Chemin de la Cépière. 20 F-31300 Toulouse-Le Mirail Tel.(61) 40 11 12 Cabie. HEWPACK 51957 Telex: 510957 reiex: 510957 Hewiett-Packard France Agence Régionale Aéroport principal de Marselle-Marignane F-13721Marignane Tel: (91) 89 12 50 Cable HEWPACK MARGN Telex: 410770 Hewiett-Packard Telex: 410770 Hewlett-Packard France Agence Régionale 63. Avenue de Rochester B.P. 1124 F-35014 Rennes Cédex Tel: (99) 36 33 21 Cable: HEWPACK 74912 Telex: 740912 Telex: 740912 Hewlett-Packard France Agence Régionale 74. Allée de la Robertsau F-67000 Strasbourg Tel: (88) 35 23 20/21 Telex: 890141 Cable: HEWPACK STRBG Hewlett-Packard France Agence Régionale Centre Vauban 201 rue Cotbert Entrée A2 F-59000 Lille Tel: (20) 51 44 14 Telex: 820744 retex: 820744 Hewlett-Packard France Centre d Affaires Paris-Nord Batiment Ampère Rue de La Commune de Paris B.P. 300 F-93153 Le Blanc Mesnil Cédex Tel: (01) 931 88 50 GERMAN FEDERAL REPUBLIC Hewlett-Packard GmbH Vertinebszentrale Franklurt Bernerstrasse 117 Postach 560 140 D-8000 Franklurt 56 Tel (0611) 30 04-1 Telex: 04 13249 hglfmd Telex: 04 13249 hptfmd Hewlett-Packard GmbH Technisches Buero Böblingen Herrenbergerstrasse 110 0-7030 **Böblingen**. Wurttemberg Tel: (07031) 667-1 Cable. HEPAK Böblingen Telex: 07265739 bbn Teiex: 07265739 00n Hewiett-Packard GmbH Technisches Buero Dusseldort Emanuel-Leutze-Str 1 (Seestern) D-4000 Düsseldorf 11 Tei: (0211) 59711 Telex: 085/86 533 hpdd d Telex: 085/86 533 hpdd d Hewlett-Packard GmbH Technisches Buero Hamburg Wendenstrasse 23 D-2000 Hamburg 1 Tel: (040) 24 13 93 Cable: HEWPACKSA Hamburg Telex: 21 63 032 hphh d Hewlett-Packard GmbH Technisches Buero Hannover Am Grossmarkt 6 D-3000 Hannover-Kleefeld 91 Tel: (0511) 46 60 01 Telex: 092 3259 Hewlett-Packard GmbH Newton-Packard Gridin Neumeyer Str. 90 0-8500 Nuremberg Tel: (0911) 56 30 83/85 Telex: 0623 860 reiex: Ub23 8b0 Hewlett-Packard GmbH Technisches Buero Munchen Unterhachinger Strasse 28 ISAR Center D-8012 Ottobrunn Telex: (089) 601 30 61/7 Cable: HEWPACKSA München Telex: 0524985 Hewlett-Packard GmbH Technisches Buero Berli Keith Strasse 2-4 D-1000 Berlin 30 Tel: (030) 24 90 86 Telex: 18 3405 hpbln d GREECE GREECE Kassa Karayannis 18. Ermou Street GR-Athens 126 Tel: 3237731 Cable: RAKAR Athens Telex: 21 59 62 rkar gr Analytical Dnly "INTECO" G. Papathanassiou & Co. Marni 17 GR - Athens 103 Tel: 522 1915 Cable: INTEKNIKA Athens Telex: 21 5329 INTE GR Medical Only Technomed Helias Ltd. 52.Skoufa Street GR - Athena 135 Tel: 362 6972, 363 3830 Cable etalak athens Telex: 21-4693 ETAL GR HUNGARY MTA Műszerügyi és Méréstechnikai Szolgalata Lenin Krt. 67 1391 Budapest VI Tel: 42 03 38 Telex: 22 51 14 ICELAND Medical Only Elding Trading Company Inc. Hafnarhvoli - Tryggvatotu IS-Reykjavík Tel: 1 58 20 Cable: ELDING Reykjavík IRAN Hewlett-Packard Iran Ltd. Hewlett-Packard Iran Ltd No. 13. Fourteenth St. Miremad Avenue P.O. Box 41/2419 IR-**Tehran** Tel: 851082-7 Telex: 213405 HEWP IR HRAQ Hewlett-Packard Trading Co Mansoor City Baghdad Tel 5517827 Telex: 2455 Hepairaq ik Cable: HEWPACDAD. Baghdad Iraq IRELAND Hewlett-Packard Ltd. King Street Lane GB-Winnersh, Wokingham Berks. RG11 5AR Tel: (0734) 78 47 74 Telex: 847178/848179 Trally Hewlett-Packard Italiana S p A Via Amerigo Vespuco 2 Casella postale 3645 I-20100 Milano Tel: (2) 625 (1 0 lines) Cable HEWPACKIT Milano Telex: 32046 Hewlett-Packard Italiana S.p.A. Via Pietro Maroncelli 40 Via Pietro Marolicelli 4 (ang. Via Visentin) I-35100 **Padova** Tel: (49) 66 48 88 Telex: 41612 Hewpacki Medical only Hewlett-Packard Italiana S.p.A. Via d'Aghiardi, 7 I-56100 Pisa Tel: (050) 2 32 04 Telex: 32046 via Milano Hewlett-Packard Italiana S.p.A. Via G. Armellini 10 I-00143 **Roma** Tel: (06) 54 69 61 Telex: 61514 Cable: HEWPACKIT Roma Hewlett-Packard Italiana S.p.A Corso Giovanni Lanza 94 I-10130 **Torino** Tel: (011) 682245/659308 Medical/Calculators Dnly Hewlett-Packard Italiana S.p.A. Via Principe Nicola 43 G/C I-95126 **Catania** Tel:(095) 37 05 04 Hewlett-Packard Italiana S.p.A. Via Amerigo Vespucci, 9 I-80142 **Napoli** Tel: (081) 33 77 11 Hewlett-Packard Italiana S.p.A. Via E. Masi, 9/8 I-40137 Bologna Tel: (051) 30 78 87 KUWAIT Al-Khaldiya Trading & Contracting Co. P.O. Box 830 Kuwait Tel: 42 49 10 Cable: VISCOUNT LUXEMBURG Hewiett-Packard Benelux S.A./N.V. Avenue du Coi-Vert, 1. Avenue du Col-Verc, T. (Groenkraaglaan) B-1170 **Brussels** Tel: (02) 672 22 40 Cable: PALOBEN Brussels Telex: 23 494 MOROCCO Gerep 190, Blvd Brahim Roudani Casablanca Tel: 25-16-76:25-90-99 Cable: Gerep-Casa Telex: 23739 NETHERLANDS Hewlett-Packard Beneliux N.V. Van Heuven Goedhardiaan 121 P.O. Box 667 NL-1134 Amstelveen Tel. (020) 47 20 21 Cable: PALOBEN Amsterdam Telex: 13 216 hepa ni NORWAY Hewlett-Packard Norge A/S Nesveien 13 Box 149 N-1344 Haslum Tei: (02) 53 83 60 Telex: 16621 hpnas n Telex: 16621 hpnas n POLAND Biuro Informacji Technicznej Hewlett-Packard U1 Stawki 2. 6P 00-950Warszawa Tel: 395962/395187 Telex: 81 24 53 hepa pl Telex: 81 24 93 hepa pi UNIPAN Zakład Ooswiadczalny Budowy Aparatury Naukowej U1 Krajowej Hady Narodowej 51:55 00-800 **Warszawa** Tel: 36190 Telex: 81 46 48 Zakłady Naprawcze Sprzetu Medycznego Piac Komuny Paryskiej 6 90-007 **Lódź** Tel: 334-41, 337-83 Tei: 334-41, 337-83 PORTUGAL Telectra-Empresa Técnica de Equipamentos Eléctricos S a r 1. Rua Rodrigo da Fonseca 103 P. 0. Box 2531 Fel: 199, 68 60 72 Cable: TELECTRA Lisbon Telex: 12598 Medical only Mundinter Intercambio Mundial de Comércio Intercambio Mundial de Comi S.a.r.i. Av.A.A.de Aguiar 138 P.D. Box 2761 P.- Lisbon Tel. (19) 53 21 31/7 Cable: INTERCAMBIO Lisbon RUMANIA Hewlett-Packard Reprezentanta Bd. N. Balcescu 16 Bucharest Tel: 158023/138885 Telex: 10440 Telex: 10440 L.R.U.C. Intreprinderea Pentru Intretinerea Si Repararea Utilajelor de Calcul B-dul prof. Dimitrie Pompei 6 Buchareat-Sectorul 2 Tal: 119 45 1 SAUDI ARABIA Modern Electronic Establishment King Abdul Aziz str. (Head office) P. 0. Box 128 Jeddah Tel: 31173-332201 Cable ELECTRA P.O. Box 2778 (Service center) Riyadh Tel: 62596-66232 Cable: RAOUFCO SPAIN Hewlett-Packard Española, S.A. Jerez No. 3 E-**Madrid** 16 Tel.(1) 458 26 00 (10 lines) Telex: 23515 hpe Hewlett-Packard Española, S.A. Milanesado 21-23 E-Barcelona 17 Tel: (3) 203 6200 (5 lines) Telex: 52603 hpbe e Hewlett-Packard Española, S.A Av Ramon y Cajal, 1 Edificio Sevilla, planta 9, E-Seville 5 Tel: 64 44 54:58 Hewlett-Packard Española S.A Edificio Albia II 7° B E-Bilbao-1 Tel: 23 83 06/23 82 06 Calculators Dnly Hewlett-Packard Española S.A. Gran Via Fernando El Catdiico, 67 E-Valencia-8 Tel: 326 67 28/326 85 55 SWEDEN Hewlett-Packard Sverige AB Enighetsvägen 1-3 Fack S-161 20 Bromma 20 Tel: (08) 730 05 50 Cable: MEASUREMENTS Stockholm Telex: 10721 Hewlett-Packard Sverige AB Dstra Vintergatan 22 S-702 40 **Orebro** Tel: (019) 14 07 20 Hewlett-Packard Sverige AB Erdtalispatan 30 Frötalisgatan 30 S-421 32 **Yästra Frölunda** Tel: (031) 49 09 50 Telex: 10721 Via Bromma Office SWITZERLAND Hewlett-Packard (Schweiz) AG Zurcherstrasse 20 P. 0. Box 307 CH-8952 Schlieren-Zurich Tel: (01) 730 52 40/730 18 21 Cable: HPAG CH Telex: 53933 hpag ch Hewlett-Packard (schweizer) Telex: 53933 hpag ch Hewleth-Packard (schweiz) AG Château Bioc 19 CH-1219 Le Lignon-Geneva Tel: (022) 96 03 22 Cable: HEWPACKAG Geneva Telex: 27 333 hpag ch SYRIA Medical Calculator only Sawah & Co. Place Arme B.P. 2308 SYR-Demascus Tel: 15367, 19697, 14268 Cable: SAWAH, Damascus TURKEY TURKEY Telekom Engineering Bureau P.O. Box 437 P.O. Box 437 Beyodiu TR-Istanbul Tel: 49 40 40 Cable: TELEMATION Istanbul Telex: 23609 Herica: Zabu9 Medical only E.M.A. Muhendislik Kollekti† Sirketi Adakaie Sokak 41/6 TR. Ankara Tel. 173622 Analytical only Yilmaz Ozyurek Milli Mudafaa Cad No. 16/6 Kizilav Milli Mudataa Cad Ni Kizilay TR-**Ankara** Tel: 25 03 09 Telex: 42576 Ozek tr Telex: 42576 Ozek tr UNITED KINGDOM Hewlett-Packard Ltd. King Street Lane GB-Winnersh, Wokingham Berks. RG11 5AR Tel: (0734) 78 47 74 Cable: Hewpie London Telex: 847178/9 rerex:847178/9 Hewleft-Packard Ltd. Trafalger House, Navagation Road Altrincham Cheshire WA14 1NU Tel: (061) 928 6422 Cable: Hewpie Manchester Telex: 668068 Hewlett-Packard Ltd. Lygon Court Hereward Rise Dudley Road Halesowen, West Midlands B62 8SD Tel: (021) 550 9911 Telex: 339105 Hewlett-Packard Ltd. Wedge House 799, London Road GB-Thornton Heath Surrey CR4 6XL Tel: (01) 684 0103/8 Telex: 946825 Hewlett-Packard Ltd. c/o Makro South Serviceholesate Centre Wear Industrial Estate Washington GB-New Town, County Durham Tel: Washington 464001 ext. 57/58 Hewlett-Packard Ltd 10, Wesley St. GB-Castleford West Yorkshire WF10 1AE Tel: (09775) 50402 Telex: 557355 Hewlett-Packard Ltd 1, Wallace Way GB-Hitchin Herts Tel: (0462) 52824/56704 Telex: 825981 USSR Hewlett-Packard Representative Office USSR Pokrovsky Boulevard 4/17-KW 12 Moscow 101000 Table204 2024 Tel:294-2024 Telex: 7825 hewpak su YUGOSLAVIA Iskra-standard/Hewlett-F Miklosiceva 38/VII 61000 Lļubljane Tel: 31 58 79/32 16 74 Telex: 31583 SOCIALIST COUNTRIES MOT SHOWN PLEASE CONTACT: Hewlett-Packard Ges.m.b.H P. 0. 80x 7 A-1205 Vienna, Austria Tel: (0222) 35 16 21 to 27 Cable: HEWPAK Vienna Telex: 75923 hewpak a Telex: 75923 hewpak a MEDITERRANEAN AND MIDDLE EAST COUNTRIES NOT SHOWN PLEASE CONTACT: Hewiett-Packard S. A. Mediterranean and Middle Additional Street Platia Kefallariou GR-Kifissia Athens. Greece Tel: 8080337/359/429 Telex: 21-5588 Cable: HEWPACKSA Athens FOR OTHER AREAS NOT LISTED CONTACT Hewleft-Packard S.A. 7, rue du Bois-du-Lan P.O. Box CH-1217 Meyrin 2 - Geneva Switzerland Tel: (022) 82 70 00 Cable: HEWPACKSA Geneva Telex: 2 24 86 ### **UNITED STATES** ALABAMA 8290 Whitesburg Dr., S.E. P.O. Box 4207 Huntsville 35802 Tel: (205) 881-4591 Medical Only 228 W. Valley Ave.. Room 220 Birmingham 35209 Tel: (205) 942-2081/2 ARIZONA 2336 E. Magnolia St. Phoenix 85034 Tel: (602) 244-1361 2424 East Aragon Rd Tucson 85706 Tel: (602) 294-3148 · ARKANSAS \*ARKANSAS Medical Service Only P.O. Box 5646 Brady Station Little Rock 72205 Tel: (501) 376-1844 CALIFORNIA 1430 East Orangethorpe Ave. Fullerton 9263. 161: (714) 870-1000 3939 Lankershim Boulevard North Hollywood 91604 Tet: (213) 877-1282 TWX: 910-499-2671 6205 Airson, Plaze 6305 Arizona Piace **Los Angeles 9**0045 Tel: (213) 649-2511 TWX: 910-328-6147 \*Los Angeles Tel: (213) 776-7500 3003 Scott Boulevard Santa Clara 95050 Tel: (408) 249-7000 TWX: 910-338-0518 \*Ridgecrest Tel: (714) 446-6165 646 W. North Market Blvd Sacramento 95834 Tel: (916) 929-7222 9606 Aero Drive P.O. Box 23333 San Diego 92123 Tel: (714) 279-3200 COLORADO 5600 South Ulster Parkway Englewood 80110 Tal: (303) 771-3455 CONNECTICUT 12 Lunar Drive New Haven 06525 Tel: (203) 389-6551 TWX: 710-465-2029 FLORIDA P. D. Box 24210 2806 W. Oakland Park Blvd. Ft. Lauderdale 33311 Tel: (305) 731-2020 \*Jacksonville Medical Service only Tel: (904) 398-0663 P.O. box 13910 6177 Lake Ellenor Dr. **Oriando** 32809 Tel: (305) 859-2900 P.O. Box 12826 Pensacola 32575 Tel: (904) 476-8422 GEORGIA P.O. Box 105005 Atlants 30348 Tel: (404) 955-1500 TWX:810-766-4890 Medical Service Only \*Augusta 30903 Tel: (404) 736-0592 P.O. Box 2103 **Warner Robins** 31098 Tel: (912) 922-0449 HAWAII 2875 So. King Street Honolulu 96814 Tei: (808) 955-4455 Telex: 723-705 ILLINOIS 5201 Tollview Dr Rolling meadows 60008 Tel: (312) 255-9800 TWX: 910-687-2260 INDIANA 7301 North Shadeland Ave Indianapolis46250 Tel: (317)842-1000 TWX: 810-260-1797 IOWA 1902 Broadway Iowa City 52240 Tel: (319) 338-9466 KENTUCKY Medical Only Atkinson Square 3901 Atkinson Dr.. Sbite 207 Louiaville 40218 Tel: (502) 456-1573 LOUISIANA P.O. Box 840 3229-39 Williams Boulevard Kenner 70063 Tel: (504) 443-6201 MARYLAND 6707 Whitestone Road Battimore 21207 Tel: (301) 944-5400 TWX: 710-862-9157 2 Choke Cherry Road **Rockville** 20850 Tel: (301) 948-6370 TWX: 710-828-9684 MASSACHUSETTS 32 Hartwell Ave. Lexington 02173 Tel: (617) 861-8960 TWX: 710-326-6904 MICHIGAN 23855 Research Drive Farmington Hills 48024 Tel: (313) 476-6400 MINNESOTA 2400 N. Prior Ave. St. Paul 55113 Tel: (612) 636-0700 MISSISSIPPI \*Jackson Medical Service only Tel: (601) 982-9363 MISSOURI 11131 Colorado Ave. **Kansas City** 64137 Tel: (816) 763-8000 TWX: 910-771-2087 148 Weldon Parkway Maryland Heights 63043 Tel: (314) 567-1455 TWX: 910-764-0833 NEBRASKA Medical Only 717! Mercy Road Suite IIO Omaha 68106 Tel: (402) 392-0948 NEW JERSEY W. 120 Century Rd. Paramus 07652 Tel: (201) 265-5000 TWX: 710-990-4951 Crystal Brook Professional Building Eatontown 07724 Tel:(201) 542-1384 NEW MEXICO P.O. Box 11634 P.O. Box 11634 Station E 11300 Lomas Blvd., N.E. Albuquerqus 87123 Tel: (505) 292-1330 TWX: 910-989-1185 156 Wyatt Drive **Las Cruces** 88001 Tel: (505) 526-2484 TWX: 910-983-0550 NEW YORK 6 Automation Lane Computer Park Albany 12205 Tel: (518) 458-1550 201 South Avenue **Poughkeepsie** 12601 Tel: (914) 454-7330 TWX: 510-253-5981 39 Saginaw Drive Rochester 14623 Tel: (716) 473-9500 TWX: 510-253-5981 5858 East Molioy Road **Syracuse** 13211 Tel: (315) 454-2486 TWX: 710-541-0482 1 Crossways Park West **Woodbury** 11797 Tel: (516) 921-0300 TWX: 710-990-4951 NORTH CAROLINA P.O. Box 5188 1923 North Main Street High Point 27262 Tel: (919) 885-8101 OHIO 16500 Sprague Road Cleveland 44130 Tel: (216) 243-7300 TWX: 810-423-9430 330 Progress Rd. **Dayton** 45449 Tel: (513) 859-8202 1041 Kingsmill Parkway **Columbus** 43229 Tel: (614) 436-1041 OKLAHOMA P.O. Box 32008 Oklahoma City 73132 Tel: (405) 721-0200 OREGON 17890 SW Lower Boones Ferry Road Tualatin 97062 Tel: (503) 620-3350 PENNSYLVANIA 111 Zeta Orive Pittsburgh 15238 Tel: (412) 782-0400 1021 8th Avenue King of Prussia Industrial Park King of Prussia 19406 Tel: (215) 265-7000 TWX: 510-660-2670 SOUTH CAROLINA 6941-0 N. Trenholm Columbia 29260 Tel: (803) 782-6493 TENNESSEE \*Knoxville Medical Service only Tel: (615) 523-5022 1473 Madison Avenue Memphis 38104 Tel: (901) 274-7472 Nashville Medical Service only Tel: (615) 244-5448 TeX AS P.O. Box 1270 201 E. Arapaho Rd Richardson 75080 Richardson 75080 Richardson 75080 Richardson 75080 Richardson 75087 Ric (713) 781-6000 Richardson 77057 Tei: (713) 781-6000 205 Billy Mitchell Road San Antonio 78226 Tel: (512) 434-8241 UTAH 2160 South 3270 West Street Salt Lake City 84119 Tel: (801) 487-0715 VIRGINA P. O. Box 12778 No. 7 Koger Exec. Center Suite 212 Norfolk 23502 Tel:(804) 461-4025/6 P.O. Box 9669 2914 Hungary Springs Road Richmond 23228 Tel: (804) 285-3431 Tel: (804) 200 WASHINGTON Martield Office Pk. Bellefield Office Pk. 1203-114th Ave. S.E Bellevue 98004 Tel: (206) 454-3971 TWX: 910-443-2446 \*WEST VIRGINIA Medical/Analytical Only Charleston Tel: (304) 345-1640 WISCONSIN 9004 West Lincoln Ave West Allis 53227 Tel: (414) 541-0550 FOR U.S. AREAS NOT LISTED: Contact the regional office nearest you: Atlanta, Georgia... North Hollywood, California... Rockville, Maryland...Rolling Meadows, Illinois.Their complete addresses are listed above. Service Only