INTEL CORP. 3065 Bowers Avenue, Santa Clara, California 95051 • (408) 246-7501 # 8008 8-BIT PARALLEL CENTRAL PROCESSOR UNIT MICRO COMPUTER SET **USERS MANUAL** NOV. 1972 # INTEL MAKES IT EASY WITH UNPRECEDENTED DESIGN SUPPORT # For MCS-8 systems - 1. Prototyping board, SIM8-01. Forms operational micro-programmed computer with Intel's erasable PROMs in place of mask-programmed ROMs. Holds up to 16K bits of PROM and 8K bits of RAM. - **2. PROM programmer,** MP7-03. Intel erasable PROMs plug into this board for programming using a teletypewriter. - **3. SIM8 hardware assembler.** Eight PROMs plug into SIM8 board, enabling the prototype to assemble its own programs. - 4. System interface and control module interconnects all other support hardware and a TTY for program assembly, simulation, PROM programming, prototype operation and debugging. Intel MCB8-10. - 5. TTY transmit/receive test program on PROM which plugs into prototyping board. Intel AO-800. - Chip-select and I/O test program on PROM which plugs into prototyping board. Intel AO-801. - 7. RAM test program on PROM that plugs into prototyping board. Intel AO-802. - 8. Bootstrap loader enables you to enter data or a program into the RAMs from a teletypewriter paper tape or keyboard, and execute the program from the RAMs. Consists of three PROMs (AO-860, 861 and 862) that plug into the prototyping board. - **9. Fortran IV assembler** gives you the assistance of any general-purpose computer in developing MCS-8 programs. - **10. Fortran IV simulator** permits any generalpurpose computer to simulate the micro computer you are designing. - 11. Library of programs, contributed by users, free to users. Intel has formed a Micro Computer Systems Group with the sole mission of helping you build systems using micro computer sets. They developed the design aids above and will assist you in every other way possible. All this makes it quite practical and economical to design and build your own systems. # 8008 8 Bit Parallel Central Processor Unit The 8008 is a complete computer system central processor unit which may be interfaced with memories having capacities up to 16K bytes. The processor communicates over an 8-bit data and address bus and uses two leads for internal control and four leads for external control. The CPU contains an 8-bit parallel arithmetic unit, a dynamic RAM (seven 8-bit data registers and an 8x14 stack), and complete instruction decoding and control logic. # **Features** - 8-Bit Parallel CPU on a Single Chip - 48 Instructions, Data Oriented - Complete Instruction Decoding and Control Included - Instruction Cycle Time— 12.5 $\mu$ s with 8008-1 or 20 $\mu$ s with 8008 - TTL Compatible (Inputs, Outputs and Clocks) - Can be used with any type or speed semiconductor memory in any combination - Directly addresses 16K x 8 bits of memory (RAM, ROM, or S.R.) - Memory capacity can be indefinitely expanded through bank switching using I/O instructions - Address stack contains eight 14-bit registers (including program counter) which permit nesting of subroutines up to seven levels - Contains seven 8-bit registers - Interrupt Capability - Packaged in 18-Pin DIP # **CONTENTS** | | | Page | |-------|---------------------------------------------------|------| | I. | Introduction | 3 | | 11. | Processor Timing | 4 | | Ш. | Basic Functional Blocks | 7 | | IV. | Basic Instruction Set | 8 | | V. | Processor Control Signals | 10 | | VI. | Electrical Specification | 13 | | VII. | The SIM8-01 — An MCS-8 Micro Computer | 16 | | /111. | MCS-8 PROM Programming System | 25 | | IX. | Program Assembly and Execution (Bootstrap Loader) | 36 | | | APPENDIX | | | ١. | Functional Definition | 42 | | 11. | Internal Processor Operation | 47 | | III. | Programming Examples | 51 | | IV. | Intel Device Specifications | 55 | NOTICE: The circuits contained herein are suggested applications only. Intel Corporation makes no warranties whatsoever with respect to the completeness, accuracy, patent or copyright status, or applicability of the circuits to a user's requirements. The user is cautioned to check these circuits for applicability to his specific situation prior to use. The user is further cautioned that in the event a patent or copyright claim is made against him as a result of the use of these circuits, Intel shall have no liability to user with respect to any such claim. 8008 Photomicrograph With Pin Designations #### I. INTRODUCTION The 8008 is a single chip MOS 8-bit parallel central processor unit for the MCS-8 micro computer system. A micro computer system is formed when the 8008 is interfaced with any type or speed standard semiconductor memory up to 16K 8-bit words. Examples are INTEL's 1101, 1103, 2102 (RAMs), 1301, 1601, 1701 (ROMs), 1404, 2401 (Shift Registers). The processor communicates over an 8-bit data and address bus ( $D_0$ through $D_7$ ) and uses two input leads (READY and INTERRUPT) and four output leads ( $S_0$ , $S_1$ , $S_2$ and Sync) for control. Time multiplexing of the data bus allows control information, 14 bit addresses, and data to be transmitted between the CPU and external memory. This CPU contains six 8-bit data registers, an 8-bit accumulator, two 8-bit temporary registers, four flag bits, and an 8-bit parallel binary arithmetic unit which implements addition, subtraction, and logical operations. A memory stack containing a 14-bit program counter and seven 14-bit words is used internally to store program and subroutine addresses. The 14-bit address permits the direct addressing of 16K words of memory (any mix of RAM, ROM or S.R.). The control portion of the chip contains logic to implement a variety of register transfer, arithmetic control, and logical instructions. Most instructions are coded in one byte (8 bits); data immediate instructions use two bytes; jump instructions utilize three bytes. Presently operating with a 500 kHz clock, the CPU executes non-memory referencing instructions in 20 microseconds. All inputs (including clocks) are TTL compatible and all outputs are low-power TTL compatible. The instruction set of the 8008 consists of 48 instructions including data manipulation, binary arithmetic, and jump to subroutine. The normal program flow of the 8008 may be interrupted through the use of the "INTERRUPT" control line. This allows the servicing of slow I/O peripheral devices while also executing the main program. The "READY" command line synchronizes the 8008 to the memory cycle allowing any type or speed of semiconductor memory to be used. STATE and SYNC outputs indicate the state of the processor at any time in the instruction cycle. #### II. PROCESSOR TIMING The 8008 is a complete central processing unit intended for use in any arithmetic, control, or decision-making system. The internal organization is centered around an 8-bit internal data bus. All communication within the processor and with external components occurs on this bus in the form of 8-bit bytes of address, instruction or data. (Refer to the accompanying block diagram for the relationship of all of the internal elements of the processor to each other and to the data bus.) For the MCS-8 a logic "1" is defined as a high level and a logic "0" is defined as a low level. # A. State Control Coding The processor controls the use of the data bus and determines whether it will be sending or receiving data. State signals $S_0$ , $S_1$ , and $S_2$ , along with SYNC inform the peripheral circuitry of the state of the processor. A table of the binary state codes and the designated state names is shown below. | So | S <sub>1</sub> | S <sub>2</sub> | STATE | |----|----------------|----------------|---------| | 0 | 1 | 0 | T1 | | 0 | 1 | 1 | T1I | | 0 | 0 | 1 | T2 | | 0 | 0 | 0 | WAIT | | 1 | 0 | 0 | T3 | | 1 | 1 | 0 | STOPPED | | 1 | 1 | 1 | T4 | | 1 | 0 | 1 | T5 | #### B. Timing Typically, a machine cycle consists of five states, two states in which an address is sent to memory (T1 and T2), one for the instruction or data fetch (T3), and two states for the execution of the instruction (T4 and T5). If the processor is used with slow memories, the READY line synchronizes the processor with the memories. When the memories are not available for either sending or receiving data, the processor goes into the WAIT state. The accompanying diagram illustrates the processor activity during a single cycle. Figure 1. Basic 8008 Instruction Cycle The receipt of an INTERRUPT is acknowledged by the T11. When the processor has been interrupted, this state replaces T1. A READY is acknowledged by T3. The STOPPED state acknowledges the receipt of a HALT instruction. Many of the instructions for the 8008 are multi-cycle and do not require the two execution states, T4 and T5. As a result, these states are omitted when they are not needed and the 8008 operates asynchronously with respect to the cycle length. The external state transition is shown below. Note that the WAIT state and the STOPPED may be indefinite in length (each of these states will be 2n clock periods). The use of READY and INTERRUPT with regard to these states will be explained later. Figure 2. CPU State Transition Diagram # C. Cycle Control Coding As previously noted, instructions for the 8008 require one, two, or three machine cycles for complete execution. The first cycle is always an instruction fetch cycle (PCI). The second and third cycles are for data reading (PCR), data writing (PCW), or I/O operations (PCC). The cycle types are coded with two bits, $D_6$ and $D_7$ , and are only present on the data bus during T2. | D <sub>6</sub> | D <sub>7</sub> | CYCLE | FUNCTION | |----------------|----------------|-------|---------------------------------------------------------------------------------------------| | 0 | 0 | PCI | Designates the address is for a memory read (first byte of instruction). | | 0 | 1 | PCR | Designates the address is for a memory read data (additional bytes of instruction or data). | | 1 | 0 | PCC | Designates the data as a command I/O operation | | 1 | 1 | PCW | Designates the address is for a memory write data. | Figure 3. 8008 Block Diagram #### III. BASIC FUNCTIONAL BLOCKS The four basic functional blocks of this Intel processor are the instruction register, memory, arithmetic-logic unit, and I/O buffers. They communicate with each other over the internal 8-bit data bus. ### A. Instruction Register and Control The instruction register is the heart of all processor control. Instructions are fetched from memory, stored in the instruction register, and decoded for control of both the memories and the ALU. Since instruction executions do not all require the same number of states, the instruction decoder also controls the state transitions. # B. Memory Two separate dynamic memories are used in the 8008, the pushdown address stack and a scratch pad. These internal memories are automatically refreshed by each WAIT, T3, and STOPPED state. In the worst case the memories are completely refreshed every eighty clock periods. #### 1. Address Stack The address stack contains eight 14-bit registers providing storage for eight lower and six higher order address bits in each register. One register is used as the program counter (storing the effective address) and the other seven permit address storage for nesting of subroutines up to seven levels. The stack automatically stores the content of the program counter upon the execution of a CALL instruction and automatically restores the program counter upon the execution of a RETURN. The CALLs may be nested and the registers of the stack are used as last in/first out pushdown stack. A three-bit address pointer is used to designate the present location of the program counter. When the capacity of the stack is exceeded the address pointer recycles and the content of the lowest level register is destroyed. The program counter is incremented immediately after the lower order address bits are sent out. The higher order address bits are sent out at T2 and then incremented if a carry resulted from T1. The 14-bit program counter provides direct addressing of 16K bytes of memory. Through the use of an I/O instruction for bank switching, memory may be indefinitely expanded. # 2. Scratch Pad Memory or Index Registers The scratch pad contains the accumulator (A register) and six additional 8-bit registers (B, C, D, E, H, L). All arithmetic operations use the accumulator as one of the operands. All registers are independent and may be used for temporary storage. In the case of instructions which require operations with a register in external memory, scratch pad registers H & L provide indirect addressing capability; register L contains the eight lower order bits of address and register H contains the six higher order bits of address (in this case bit 6 and bit 7 are "don't cares"). #### C. Arithmetic/Logic Unit (ALU) All arithmetic and logical operations (ADD, ADD with carry, SUBTRACT, SUBTRACT with borrow, AND, EXCLUSIVE OR, OR, COMPARE, INCREMENT, DECREMENT) are carried out in the 8-bit parallel arithmetic unit which includes carry-look-ahead logic. Two temporary resisters, register "a" and register "b", are used to store the accumulator and operand for ALU operations. In addition, they are used for temporary address and data storage during intra-processor transfers. Four control bits, carry flip-flop (c), zero flip-flop (z), sign flip-flop (s), and parity flip-flop (p), are set as the result of each arithmetic and logical operation. These bits provide conditional branching capability through CALL, JUMP, or RETURN on condition instructions. In addition, the carry bit provides the ability to do multiple precision binary arithmetic. #### D. I/O Buffer This buffer is the only link between the processor and the rest of the system. Each of the eight buffers is bi-directional and is under control of the instruction register and state timing. Each of the buffers is low power TTL compatible on the output and TTL compatible on the input. #### IV. BASIC INSTRUCTION SET The following section presents the basic instruction set of the 8008. For a detailed description of the execution of each instruction, refer to Appendix I. #### **Data and Instruction Formats** Data in the 8008 is stored in the form of 8-bit binary integers. All data transfers to the system data bus will be in the same format. The program instructions may be one, two, or three bytes in length. Multiple byte instructions must be stored in successive words in program memory. The instruction formats then depend on the particular operation executed. | One Byte Instructions | | TYPICAL INSTRUCTIONS | |-------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------| | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$ | OP CODE | Register to register, memory reference, I/O arithmetic or logical, rotate or | | Two Byte Instructions | | return instructions | | D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | OP CODE | | | D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | OPERAND | Immediate mode instructions | | Three Byte Instructions | | | | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$ | OP CODE | | | D <sub>7</sub> D <sub>6</sub> D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | LOW ADDRESS | JUMP or CALL instructions | | X X D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | HIGH ADDRESS* | *For the third byte of this instruction, D <sub>B</sub> and D <sub>7</sub> are "don't care" bits, | For the MCS-8 a logic "1" is defined as a high level and a logic "0" is defined as a low level. # **Index Register Instructions** The load instructions do not affect the flag flip-flops. The increment and decrement instructions affect all flip-flops except the carry. | | MINIMUM<br>STATES<br>REQUIRED | INSTRUCTION CODE | | CODE | | | |----------------------|-------------------------------|-------------------------------|-------------|----------------------------------------------|----------------------------------------------------------------------------------------|--| | MNEMONIC | | D <sub>7</sub> D <sub>6</sub> | $D_5D_4D_3$ | D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | DESCRIPTION OF OPERATION | | | (1) <sub>Lr1r2</sub> | (5) | 1 1 | DDD | s s s | Load index register r <sub>1</sub> with the content of index register r <sub>2</sub> . | | | (2) <sub>LrM</sub> | (8) | 1 1 | DDD | 1 1 1 | Load index register r with the content of memory register M. | | | LMr | (7) | 1 1 | 1 1 1 | SSS | Load memory register M with the content of index register r. | | | (3) <sub>Lrl</sub> | (8) | 0 0 | DDD | 1 1 0 | Load index register r with data B B. | | | | | ВВ | ввв | ввв | | | | LMI | (9) | 0 0 | 1 1 1 | 1 1 0 | Load memory register M with data B B. | | | | | ВВ | ввв | ВВВ | | | | INr | (5) | 0 0 | D D D | 0 0 0 | Increment the content of index register r (r # A). | | | DCr | (5) | 0 0 | DDD | 0 0 1 | Decrement the content of index register r (r # A). | | #### **Accumulator Group Instructions** The result of the ALU instructions affect all of the flag flip-flops. The rotate instructions affect only the carry flip-flop. | ADr | (5) | 1 0 | 0 0 0 | SSS | Add the content of index register r, memory register M, or data | |-----|-----|-----|-------|-------|----------------------------------------------------------------------| | ADM | (8) | 1 0 | 0 0 0 | 1 1 1 | BB to the accumulator. An overflow (carry) sets the carry | | ADI | (8) | 0 0 | 0 0 0 | 1 0 0 | flip-flop. | | | | ВВ | ввв | ввв | | | ACr | (5) | 1 0 | 0 0 1 | s s s | Add the content of index register r, memory register M, or data | | ACM | (8) | 1 0 | 0 0 1 | 1 1 1 | B B from the accumulator with carry. An overflow (carry) | | ACI | (8) | 0 0 | 0 0 1 | 1 0 0 | sets the carry flip-flop. | | | | ВВ | B | ввв | | | SUr | (5) | 1 0 | 0 1 0 | S S S | Subtract the content of index register r, memory register M, or | | SUM | (8) | 1 0 | 0 1 0 | 1 1 1 | data B B from the accumulator. An underflow (borrow) | | SUI | (8) | 0 0 | 0 1 0 | 1 0 0 | sets the carry flip-flop. | | | | вв | ввв | ввв | | | SBr | (5) | 1 0 | 0 1 1 | S S S | Subtract the content of index register r, memory register M, or data | | SBM | (8) | 1 0 | 0 1 1 | 1 1 1 | data B B from the accumulator with borrow. An underflow | | SBI | (8) | 0 0 | 0 1 1 | 1 0 0 | (borrow) sets the carry flip-flop. | | | | ВВ | ввв | ввв | | | | MINIMUM | IN | STRUCTION | CODE | | | |----------|----------|--------------------|-------------------------------|----------------------------------------------|----------------------------------------------------------------|--------------------------| | MNEMONIC | MNEMONIC | STATES<br>REQUIRED | D <sub>7</sub> D <sub>6</sub> | D <sub>5</sub> D <sub>4</sub> D <sub>3</sub> | D <sub>2</sub> D <sub>1</sub> D <sub>0</sub> | DESCRIPTION OF OPERATION | | NDr | (5) | 1 0 | 1 0 0 | S S S | Compute the logical AND of the content of index register r, | | | NDM | (8) | 1 0 | 1 0 0 | 1 1 1 | memory register M, or data B B with the accumulator. | | | NDI | (8) | 0 0<br>B B | 1 0 0<br>B B B | 1 0 0<br>B B B | | | | XRr | (5) | 1 0 | 1 0 1 | S S S | Compute the EXCLUSIVE OR of the content of index register | | | XRM | (8) | 1 0 | 1 0 1 | 1 1 1 | r, memory register M, or data B B with the accumulator. | | | XRI | (8) | 0 0 | 1 0 1 | 1 0 0 | | | | ORr | (5) | B B<br>1 0 | B B B<br>1 1 0 | B B B<br>S S S | Compute the INCLUSIVE OR of the content of index register | | | ORM | (8) | 1 0 | 1 1 0 | 1 1 1 | r, memory register m, or data B B with the accumulator . | | | ORI | (8) | 0 0<br>B B | 1 1 0<br>B B B | 1 0 0<br>B B B | , , , , , , , , , , , , , , , , , , , , | | | CPr | (5) | 1 0 | 1 1 1 | S S S | Compare the content of index register r, memory register M, | | | СРМ | (8) | 1 0 | 1 1 1 | 1 1 1 | or data B B with the accumulator. The content of the | | | СРІ | (8) | 0 0<br>B B | 1 1 1<br>B B B | 1 0 0<br>B B B | accumulator is unchanged, | | | RLC | (5) | 0 0 | 0 0 0 | 0 1 0 | Rotate the content of the accumulator left. | | | RRC | (5) | 0 0 | 0 0 1 | 0 1 0 | Rotate the content of the accumulator right. | | | RAL | (5) | 0 0 | 0 1 0 | 0 1 0 | Rotate the content of the accumulator left through the carry. | | | RAR | (5) | 0 0 | 0 1 1 | 0 1 0 | Rotate the content of the accumulator right through the carry. | | #### **Program Counter and Stack Control Instructions** | (11) | 0 1 | × × × | 1 0 0 | Unconditionally jump to memory address B3B3B2B2. | |-----------|-----------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | | B <sub>2</sub> B <sub>2</sub> | $B_2 B_2 B_2$ | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | | | | хх | B3 B3 B3 | B3 B3 B3 | | | (9 or 11) | 0 1 | 0 C <sub>4</sub> C <sub>3</sub> | 0 0 0 | Jump to memory address B3B3B2B2 if the condition | | | B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | B2 B2 B2 | | | | x x | B3 B3 B3 | B3 B3 B3 | | | (9 or 11) | 0 1 | 1 C <sub>4</sub> C <sub>3</sub> | 0 0 0 | Jump to memory address B3B3B2B2 if the condition | | | B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | flip-flop c is true. Otherwise, execute the next instruction in sequence. | | | x x | B3 B3 B3 | B3 B3 B3 | | | (11) | 0 1 | x x x | 1 1 0 | Unconditionally call the subroutine at memory address B3 | | | B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | B <sub>3</sub> B <sub>2</sub> B <sub>2</sub> . Save the current address (up one level in the stack). | | | x x | B3 B3 B3 | B3 B3 B3 | - | | (9 or 11) | 0 1 | 0 C <sub>4</sub> C <sub>3</sub> | 0 1 0 | Call the subroutine at memory address B3B3B2B2 if the | | | B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | condition flip-flop c is false, and save the current address (up one | | | x x | B3 B3 B3 | B3 B3 B3 | level in the stack.) Otherwise, execute the next instruction in sequence. | | (9 or 11) | 0 1 | 1 C <sub>4</sub> C <sub>3</sub> | 0 1 0 | Call the subroutine at memory address B3B3B2B2 if the | | | B <sub>2</sub> B <sub>2</sub> | $B_2 \ B_2 \ B_2$ | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | condition flip-flop c is true, and save the current address (up one | | | хх | B3 B3 B3 | B3 B3 B3 | level in the stack). Otherwise, execute the next instruction in sequence. | | (5) | 0 0 | XXX | 1 1 1 | Unconditionally return (down one level in the stack). | | (3 or 5) | 0 0 | 0 C <sub>4</sub> C <sub>3</sub> | 0 1 1 | Return (down one level in the stack) if the condition flip-flop c is | | | | | | false. Otherwise, execute the next instruction in sequence. | | (3 or 5) | 0 0 | 1 C <sub>4</sub> C <sub>3</sub> | 0 1 1 | Return (down one level in the stack) if the condition flip-flop c is | | | | . • | | true. Otherwise, execute the next instruction in sequence. | | (5) | 0 0 | AAA | 1 0 1 | Call the subroutine at memory address AAA000 (up one level in the stac | | | (9 or 11) (9 or 11) (11) (9 or 11) (9 or 11) (5) (3 or 5) | (9 or 11) | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> B <sub>3</sub> | B <sub>2</sub> | #### Input/Output Instructions | | INP | (8) | 0 1 | 0 0 M | M M 1 | Read the content of the selected input port (MMM) into the | | |--|-----|-----|-----|-------|-------|---------------------------------------------------------------|-----| | | | | | | | accumulator. | - } | | | OUT | (6) | 0 1 | RRM | M M 1 | Write the content of the accumulator into the selected output | | | | | | | | | port (RRMMM, RR ≠ 00). | | # Machine Instruction | HLT | (4) | 0 0 | 0 0 0 | 0 0 X | Enter the STOPPED state and remain there until interrupted. | |-----|-----|-----|-------|-------|-------------------------------------------------------------| | HLT | (4) | 1 1 | 1 1 1 | 1 1 1 | Enter the STOPPED state and remain there until interrupted, | #### NOTES: - (1) SSS = Source Index Register These registers, $r_i$ , are designated A(accumulator-000), DDD = Destination Index Register B(001), C(010), D(011), E(100), H(101), L(110). - (2) Memory registers are addressed by the contents of registers H & L. - (3) Additional bytes of instruction are designated by BBBBBBBB. - (4) X = "Don't Care". - (5) Flag flip-flops are defined by C<sub>4</sub>C<sub>3</sub>: carry (00-overflow or underflow), zero (01-result is zero), sign (10-MSB of result is "1"), parity (11-parity is even). #### V. PROCESSOR CONTROL SIGNALS # A. Interrupt Signal (INT) # 1) INTERRUPT REQUEST If the interrupt line is enabled (Logic "1"), the CPU recognizes an interrupt request at the next instruction fetch (PCI) cycle by outputting $S_0 S_1 S_2 = 011$ at T1I time. The lower and higher order address bytes of the program counter are sent out, but the program counter is not advanced. A successive instruction fetch cycle can be used to insert an arbitrary instruction into the instruction register in the CPU. (If a multi-cycle or multi-byte instruction is inserted, an interrupt need only be inserted for the first cycle.) When the processor is interrupted, the system INTERRUPT signal must be synchronized with the leading edge of the $\phi_1$ or $\phi_2$ clock. To assure proper operation of the system, the interrupt line to the CPU must not be allowed to change within 200ns of the falling edge of $\phi_1$ . An example of a synchronizing circuit is shown on the schematic for the SIM8-01 (Section VII). This is a new circuit recently added to the SIM8-01 board. Figure 4. Recognition of Interrupt If a HALT is inserted, the CPU enters a STOPPED state; if a NOP is inserted, the CPU continues; if a "JUMP to 0" is inserted, the processor executes program from location 0, etc. The RESTART instruction is particularly useful for handling interrupt routines since it is a one byte call. Figure 5. 8008 Interrupt #### 2) START-UP OF THE 8008 When power ( $V_{DD}$ ) and clocks ( $\phi_1$ , $\phi_2$ ) are first turned on, a flip-flop internal to the 8008 is set by sensing the rise of $V_{DD}$ . This internal signal forces a HALT (00000000) into the instruction register and the 8008 is then in the STOPPED state. The following sixteen clock periods after entering the STOPPED state are required to clear (logic "0") memories (accumulator, scratch pad, program counter, and stack). During this time the interrupt line has been at logic "0". Any time after the memories are cleared, the 8008 is ready for normal operation. To reset the flip-flop and also escape from the stopped state, the interrupt line must go to a logic "1"; It should be returned to logic "0" by decoding the state T1I at some time later than $\phi_{11}$ . Note that whenever the 8008 is in a T1I state, the program counter is not incremented. As a result, the same address is sent out on two successive cycles. Three possible sequences for starting the 8008 are shown on the following page. The RESTART instruction is effectively a one cycle call instruction, and it is convenient to use this instruction to call an initiation subroutine. Note that it is not necessary to start the 8008 with a RESTART instruction. The selection of initiation technique to use depends on the sophistication of the system using the 8008. If the interrupt feature is used only for the start-up of the 8008 use the ROM directly, no additional external logic associated with instructions from source other than the ROM program need be considered. If the interrupt feature is used to jam instructions into the 8008, it would then be consistent to use it to jam the initial instruction. The timing for the interrupt with the start-up timing is shown on an accompanying sheet. The jamming of an instruction and the suppression of the program counter update are handled the same for all interrupts. #### **EXAMPLE 1:** Shown below are two start-up alternatives where an instruction is not forced into the 8008 during the interrupt cycle. The normal program flow starts the 8008. | a. 8008 Al | DDRESS OUT | INSTRUCTION IN ROM | | |------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------| | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0 0 0 0 0 0 0 0<br>0 0 0 0 0 0 0 0<br>0 0 0 0 0 0 0 1<br>0 0 0 0 | NOP (LAA 11 000 000) NOP INSTR <sub>1</sub> INSTR <sub>2</sub> | ntry Directly To<br>ain Program | | b. <b>8008</b> AI | DDRESS OUT | INSTRUCTION IN ROM | | | | | | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0 0 0 0 0 0 0 0<br>0 0 X Y Z 0 0 0<br>0 0 X Y Z 0 0 1 | RST $(RST = 00 \text{ XYZ } 101)$ A $(RST = 00 \text{ XYZ } 101)$ A $(RST = 00 \text{ XYZ } 101)$ | Jump To The<br>ain Program | # **EXAMPLE 2:** A RESTART instruction is jammed in and first instruction in ROM initially ignored. | 8008 A | ADDRESS OUT | INSTRUCT | INSTRUCTION IN ROM | | | | | |-----------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------|-----------------------------------|---------------------|--|--|--| | $ \begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 &$ | 0 0 0 0 0 0 0 0<br>0 0 X Y Z 0 0 0<br>0 0 X Y Z 0 0 1 | INSTR <sub>1</sub><br>INSTR <sub>a</sub><br>INSTR <sub>b</sub> | (RST = 00 XYZ 101) | Start-up<br>Routine | | | | | | • | • | | | | | | | $ \begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 &$ | 0 0 n n n n n n<br>0 0 0 0 0 0 0 0<br>0 0 0 0 | RETURN<br>INSTR <sub>1</sub><br>INSTR <sub>2</sub> | (INSTR <sub>1</sub> executed now) | Main Program | | | | | | • | • | | | | | | | | • | • | | | | | | | | | | | | | | | Note that during the interrupt cycle the flow of the instruction to the 8008 either from ROM or another source must be controlled by hardware external to 8008. START-UP OF THE 8008 # B. Ready (RDY) The 8008 is designed to operate with any type or speed of semiconductor memory. This flexibility is provided by the READY command line. A high-speed memory will always be ready with data (tie READY line to $V_{\rm CC}$ ) almost immediately after the second byte of the address has been sent out. As a result the 8008 will never be required to wait for the memory. On the other hand, with slow ROMs, RAMs or shift registers, the data will not be immediately available; the 8008 must wait until the READY command indicates that the valid memory data is available. As a result any type or any combination of memory types may be used. The READY command line synchronizes the 8008 to the memory cycle. When a program is being developed, the READY signal provides a means of stepping through the program, one cycle at a time. #### VI. ELECTRICAL SPECIFICATION The following pages provide the electrical characteristics for the 8008. All of the inputs are TTL compatible, but input pull-up resistors are recommended to insure proper $V_{\rm IH}$ levels. All outputs are low-power TTL compatible. The transfer of data to and from the data bus is controlled by the CPU. During both the WAIT and STOPPED states the data bus output buffers are disabled and the data bus is floating. Figure 6. Data Bus I/O Buffer Figure 7. I/O Circuitry #### **ABSOLUTE MAXIMUM RATINGS\*** Ambient Temperature **Under Bias** 0°C to +70°C -55°C to +150°C Storage Temperature Input Voltages and Supply Voltage With Respect to V<sub>CC</sub> Power Dissipation 1.0 W @ 25°C +0.5 to -20V \*COMMENT Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. # D.C. AND OPERATING CHARACTERISTICS $T_A$ = 0°C to 70°C, $V_{CC}$ = +5V ±5%, $V_{DD}$ = -9V ±5% unless otherwise specified. Logic "1" is defined as the more positive level ( $V_{IH}$ , $V_{OH}$ ). Logic "0" is defined as the more negative level ( $V_{II}$ , $V_{OL}$ ). | SYMBOL | PARAMETER | | LIMITS | | | TEST | | |-----------------|--------------------------------------------|----------------------|--------|----------------------|------|-----------------------------------------------------|--| | STWBOL | FANAMETER | MIN. | TYP. | MAX. | UNIT | CONDITIONS | | | I <sub>DD</sub> | AVERAGE SUPPLY CURRENT-<br>OUTPUTS LOADED* | | 30 | 60 | mA | T <sub>A</sub> = 25°C | | | lu | INPUT LEAKAGE CURRENT | | | 10 | μА | V <sub>IN</sub> = 0V | | | V <sub>IL</sub> | INPUT LOW VOLTAGE<br>(INCLUDING CLOCKS) | V <sub>DD</sub> | | V <sub>cc</sub> -4.2 | v | | | | V <sub>IH</sub> | INPUT HIGH VOLTAGE<br>(INCLUDING CLOCKS) | V <sub>cc</sub> -1.5 | | V <sub>cc</sub> +0.3 | v | | | | V <sub>OL</sub> | OUTPUT LOW VOLTAGE | | | 0.4 | V | I <sub>OL</sub> = 0.44mA<br>C <sub>L</sub> = 200 pF | | | V <sub>oh</sub> | OUTPUT HIGH VOLTAGE | V <sub>CC</sub> -1.5 | | | ٧ | I <sub>OH</sub> = 0.2mA | | \*Measurements are made while the 8008 is executing a typical sequence of instructions. The test load is selected such that at $V_{OL} = 0.4V$ , $I_{OL} = 0.44$ mA on each output. # A.C. CHARACTERISTICS $T_A$ = 0°C to 70°C; $V_{CC}$ = +5V ±5%, $V_{DD}$ = -9V ±5%. All measurements are referenced to 1.5V levels. | | | 80 | 80 | 800 | <b>)</b> 8-1 | | | | |--------------------------------|-----------------------------------------------------------------------|------|------|------|--------------|-------|---------------------------------------|--| | SYMBOL | PARAMETER | LIN | IITS | LIN | NITS | LIAUT | TEST CONDITIONS | | | STIVIBUL | PARAMETER | MIN. | MAX. | MIN. | MAX. | UNIT | TEST CONDITIONS | | | t <sub>CY</sub> | CLOCK PERIOD | 2 | 3 | 1.25 | 3 | μs | t <sub>R</sub> ,t <sub>F</sub> = 50ns | | | t <sub>R</sub> ,t <sub>F</sub> | CLOCK RISE AND FALL TIMES | | 50 | | 50 | ns | | | | $t_{\phi_1}$ | PULSE WIDTH OF $\phi_1$ | .70 | | .35 | | μs | | | | t <sub>Ø2</sub> | PULSE WIDTH OF $\phi_2$ | .55 | | .35 | | μs | | | | t <sub>D1</sub> | CLOCK DELAY FROM FALLING EDGE OF $\phi_1$ TO FALLING EDGE OF $\phi_2$ | .90 | 1.1 | | 1.1 | μs | | | | t <sub>D2</sub> | CLOCK DELAY FROM $\phi_2$ TO $\phi_1$ | .40 | | .35 | | μs | | | | t <sub>D3</sub> | CLOCK DELAY FROM $\phi_1$ TO $\phi_2$ | .20 | | .20 | | μs | "- | | | t <sub>DD</sub> | DATA OUT DELAY | | 1.0 | | 1.0 | μs | C <sub>L</sub> = 100 pF | | | t <sub>OH</sub> | HOLD TIME FOR DATA OUT | .10 | | .10 | | μs | | | | t <sub>IH</sub> | HOLD TIME FOR DATA IN | [1] | | [1] | | μs | | | | t <sub>SD</sub> | SYNC OUT DELAY | | .70 | | .70 | μs | C <sub>L</sub> = 100pF | | | <sup>t</sup> S1 | STATE OUT DELAY (ALL STATES EXCEPT T1 AND T11) [2] | | 1.1 | | 1.1 | μs | C <sub>L</sub> = 100pF | | | t <sub>S2</sub> | STATE OUT DELAY (STATES<br>T1 AND T1I) | | 1.0 | | 1.0 | μs | C <sub>L</sub> = 100pF | | | t <sub>RW</sub> | PULSE WIDTH OF READY DURING $\phi_{22}$ TO ENTER T3 STATE | .35 | | .35 | | μs | | | | t <sub>RD</sub> | READY DELAY TO ENTER WAIT<br>STATE | .20 | | .20 | | μs | | | $<sup>^{[1]}</sup>t_{IH}MIN \ge t_{SD}$ $<sup>^{[2]}</sup>$ If the INTERRUPT is not used, all states have the same output delay, $t_{\rm S1}$ . # **TIMING DIAGRAM** - READY line must be at "0" prior to $\phi_{22}$ of T<sub>2</sub> to guarantee entry into the WAIT state. INTERRUPT line must not change levels within 200ns (max.) of the falling edge of $\phi_1$ . # TYPICAL D.C. CHARACTERISTICS # TYPICAL A.C. CHARACTERISTICS **CAPACITANCE** f = 1MHz; $T_A = 25^{\circ}C$ ; Unmeasured Pins Grounded | SYMBOL | TEST | LIMIT (pF) | | | | |------------------|--------------------------|------------|------|--|--| | STWIBOL | 1231 | TYP. | MAX. | | | | CIN | INPUT CAPACITANCE | 5 | 10 | | | | C <sub>DB</sub> | DATA BUS I/O CAPACITANCE | 5 | 10 | | | | C <sub>OUT</sub> | OUTPUT CAPACITANCE | 5 | 10 | | | # VII THE SIM8-01 — AN MCS-8<sup>T,M.</sup> MICRO COMPUTER During the development phase of systems using the 8008, Intel's single chip 8-bit parallel central processor unit, both hardware and software must be designed. Since many systems will require similar memory and I/O interface to the 8008, Intel has developed a prototyping system, the SIM8-01. Through the use of this system and Intel's programmable and erasable ROMs (1702), MCS-8 systems can be completely developed and checked-out before committing to mask programmed ROMs (1301). The SIM8-01 is a complete byte-oriented computing system including the processor (8008), 1K $\times$ 8 memory (1101), six I/O ports (two in and four out), and a two-phase clock generator. Sockets are provided for 2K $\times$ 8 of ROM or PROM memory for the system microprogram. The SIM8-01 may be used with either the 8008 or 8008-1. To operate at clock frequencies greater than 500kHz, former SIM8-01 boards must be modified as detailed in the schematic and the following system description. Note that all Intel-developed 8008 programs interface with TTY and require system operation at 500kHz. Currently, the SIM8-01 is supplied with the 8008-1 CPU and the system clock preset to 500kHz. The following block diagram shows the basic configuration of the SIM8-01. All interface logic for the 8008 to operate with standard ROM and RAM memory is included on the board. The following pages present the SIM8-01 schematic and detailed system description. Figure 8. MCS-8 Basic System # SIM8-01 SPECIFICATIONS # Card Dimensions: - 11.5 inches high - 9.5 inches deep # System Components Included on Board: - 8008-1 - Complete TTL interface to memory - 1K x 8 RAM memory - Sockets for 2K x 8 PROM memory - TTY interface ckts. - Two input and four output ports - Two phase clock generator # Maximum Memory Configuration: - 1K x 8 RAM - 2K x 8 PROM - All control lines are provided for memory expansion # **Operating Speed** - 2 μs clock period - 20 µs typical instruction cycle # D.C. Power Requirement: Voltage: $$V_{CC}$$ = 5V ±5% TTL GRD = 0V $V_{DD}$ = -9V ±5% • Current: # Eight ROMs | | Typical | Maximum | |-------------------|----------|-----------| | <b>▶</b> CC = | 2.5 amps | 4.0 amps. | | I <sub>DD</sub> = | 1.0 amps | 1.5 amps. | #### Connector: Wire wrap type Amphenol 86 pin connector P/N 261-10043-2 Figure 9. MCS-8 Memory System # SYSTEM DESCRIPTION The 8008 processor communicates over an 8-bit data bus ( $D_0$ through $D_7$ ) and uses two input lines (READY and INTERRUPT) and four output lines ( $S_0$ , $S_1$ , $S_2$ , and SYNC) for control. Time multiplexing of the data bus allows control information, 14-bit addresses, and data to be transmitted between the CPU, memory, and I/O. All inputs, outputs, and control lines for the SIM8-01 are positive-logic TTL compatible. #### Two Phase Clock Generator The basic system timing for the SIM8-01 is provided by two non-overlapping clock phases generated by 9602 single shot multivibrators $(A_1, A_2)$ . The clocks are factory adjusted as shown in the timing diagram below. Note that this is the maximum specified operating frequency of the 8008. An option is provided on the board for using external clocks. If the jumper wires in box A are removed, external clocks may be connected at pins J1-52 and J1-12 (Normally these pins are the output of the clock generators on the board). The clock generator may be adjusted for operation up to 800kHz when using the 8008-1. Figure 11. SIM8-01 Timing Diagram # **Memory Organization** The SIM8-01 has capacity for $2K \times 8$ of ROM or PROM and $1K \times 8$ of RAM. The memory can easily be expanded to $16K \times 8$ using the address and chip select control lines provided. Further memory expansion may be accomplished by dedicating an output port to the control of memory bank switching. In an MCS-8 system, it is possible to use any combination of memory elements. The SIM8-01 is shipped from the factory with the ROM memory designated from address 0 $\rightarrow$ 2047, RAM memory from 2048— $\rightarrow$ 3071, and memory expansion for all addresses 3072 and above. Jumper wires provided on the board (boxes C, D, E) allow complete flexibility of the memory organization. They may be rearranged to meet any requirement. the Intel 3205 data sheet provides a complete description of the one of eight decoder used in this system. the 3205 truth table is shown below. | А | DDRE | SS | SS ENABLE | | | | OUTPUTS | | | | | | | |----------------|------|----------------|----------------|----------------|----|---|---------|---|----|---|---|---|---| | A <sub>0</sub> | Α1 | A <sub>2</sub> | Ε <sub>1</sub> | E <sub>2</sub> | E3 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | L | L | ٦ | L | L | Н | L | H | Н | Н | Н | Н | Н | Н | | H | L | L | L | L | H | Н | L | Н | Н | Н | Н | Н | Н | | L | Н | L | L | L | Н | Н | Н | L | Н | Н | Н | Н | Н | | H | Н | L | L | L | Н | Н | Н | Н | L. | Н | Н | Н | Н | | L | L | Н | L | L | Н | Н | Н | Н | Н | L | H | Н | Н | | H | L | Н | L | L | Н | Н | Н | Н | Н | Н | L | Н | Н | | L | Н | Н | L | L | Н | Н | Н | Н | Н | Н | Н | L | Н | | H | Н | Н | L | L | Н | Н | Н | Н | H | Н | Н | Н | L | | X | X | Х | L | L | L | Н | Н | Н | Н | Н | Н | Н | Н | | X | Х | X | Н | L | L | Н | Н | Н | Н | Н | Н | Н | н | | X | Х | X | L | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | | X | Х | X | Н | Н | L | н | Н | Н | Н | Н | Н | Н | н | | X | X | X | Н | L | Н | Н | Н | Н | Н | Н | н | Н | н | | X | Х | X | L | Н | H | Н | Н | Н | H | H | H | Н | н | | X | Х | X | H | Н | Н | Н | Н | Н | Н | Н | Н | н | н | # **CONTROL LINES** #### Interrupt The interrupt control line is directly available as an input to the board. For manual control, a normally open push-button switch may be connected to terminals J1-50 and J1-53. The interrupt may be inserted under system control on pin J1-1. An external flip-flop (A33) latches the interrupt and is reset by T11 when the CPU recognizes the interrupt. Instructions inserted under interrupt control may be set up automatically or by toggle switches at the interrupt input port as shown on the schematic. Use the interrupt line and interrupt input port to start up the 8008. Note that the interrupt line has two different connections to the input to the board (box B). The path from J1-1 directly to pin 4 of package A3 is the normal interrupt path (the board is shipped from the factory with this connection). If the connection from pin 8 of package A15 to pin 4 of package A3 is made instead, the processor will recognize an interrupt only when it is in the STOPPED state. This is used to recognize the "start character" when entering data from TTY. #### Ready The ready line on the 8008 provides the flexibility for operation with any type of semiconductor memory. On the SIM8-01 board, the ready line is buffered; and at the connector (J1-30), the READY line is active low. During program development, the READY line may be used to step the system through a program. #### NORMAL OPERATION OF SYSTEM The 8008 CPU exercises control over the entire system using its state lines ( $S_0$ , $S_1$ , $S_2$ ) and two control bits (CC0, CC1) which are sent onto the data bus with the address. The state lines are decoded by a 3205 (A44) and gated with appropriate clock and SYNC signals. The two control bits form part of the control for the multiplexers to the data bus (A55, A56), the memory read/write line (A33) and the I/O line (A17). In normal operation, the lower order address is sent out of the CPU at state T1, stored in 3404 latches (A59, A72) and provided to all memories. The high order address is sent out at a state T2 and stored in 3404 latches (A72, A73). These lines are decoded as the chip selects to the memory. The two highest order bits (CC0, CC1) are decoded for control. To guarantee that instructions and data are available to the CPU at the proper time, the T3 state is anticipated by setting a D-type flip-flop (A16) at the end of each T2 state. This line controls the multiplexing of data to the 8008. This flip-flop is reset at the end of each T3 state. In addition, switched pull-up resistors are used on the data-bus to minimize data bus loading and increase bus response. The use of switched resistors on the data bus is mandatory when using the 8008-1. SIM8-01 boards built prior to October, 1972 must be modified in order to operate with the 8008-1 at clock frequencies greater than 500kHz. Normally, the 8008 executes instructions and has no interaction with the rest of the system during states T4 and T5. In the case of the INP instruction, the content of the flag flip-flops internal to the 8008 is sent out at state T4 and stored in a 3404 latch (A43). Instructions and data are multiplexed onto the 8008 data bus through four multiplexers (A55, A56, A69, A70). In normal operation, line J1-29 should be at +5V in order for "true" data to reach the 8008 data bus. #### System I/O The SIM8-01 communicates with other systems or peripherals through two input ports and four output ports. All control and I/O selection decoding lines are provided for expansion to the full complement of eight input ports and twenty-four output ports. To expand the number of input ports, break the trace at the output of Device A68, pin 11, and generate input port decoding external to the SIM8-01. Control the input multiplexer through pin J1-69. The output ports latch data and remain unchanged until referenced again under software control. Note that all output ports complement data. When power is first applied to the board, the output ports should be cleared under software control to guarantee a known output state. To enable the I/O device decoder, pin J2-8 should be at ground. #### Teletype Interface The 8008 is designed to operate with all types of terminal devices. A typical example of peripheral interface is the teletype (ASR-33). The SIM8-01 contains the three simple transistor TTY interface circuits shown on the following page. One transistor is used for receiving serial data from the teletype, one for transmitting data back to the teletype, and the third for tape reader control. The teletype must be operating in the full duplex mode. Refer to your teletype operating manual for making connections within the TTY itself. Many models include a nine terminal barrier strip in the rear of the machine. It is at this point where the connections are made for full duplex operation. The interconnections to the SIM8-01 for transmit and receive are made at this same point. (See Figure 12) A micro computer bulletin describing the interconnection of Intel micro computers and the ASR-33 teletype is available on request. Figure 12. Teletype Terminal Strip Figure 13. SIM8-01 Teletype Interface Circuitry To use the teletype tape reader with the SIM8-01, the machine must contain a reader power pack. The contacts of a 10V dc relay must be connected in series with the TTY automatic reader (refer to TTY manual) and the coil is connected to the SIM8-01 tape reader control as shown. For all Intel developed TTY programs for the SIM8-01, the following I/O port assignments have been made: - 1. DATA IN -- INPUT PORT 0, BIT 0 (J2-83 connected to J1-11) - 2. DATA OUT -- OUTPUT PORT 2, BIT 0 (J1-84 connected to J2-36) - READER CONTROL -- OUTPUT PORT 3, BIT 0 (J2-27 connected to J2-44) Note that the SIM8-01 clock generator must remain set at 500 kHz. All Intel developed TTY programs are synchronized to operate with the SIM8-01 at 500 kHz. In order to sense the start character, data in is also sensed at the interrupt input (J2-83 connected to J1-1) and the interrupt jumper (box B) must be between pin 8 of A15 and pin 4 of A3. It requires approximately 110ms for the teletype to transmit or receive eight serial data bits plus three control bits. The first and last bits are idling bits, the second is the start bit, and the following eight bits are data. Each bit stays 9.09ms. While waiting for data to be transmitted, the 8008 is in the STOPPED state; when the start character is received, the processor is interrupted and forced to call the TTY processing routine. Under software control, the processor can determine the duration of each bit and strobe the character at the proper time. A listing of a teletype control program is shown in Appendix III. # SIM8-01 MICRO COMPUTER BOARD PIN DESCRIPTION | | Connector | Symbol | Description | Pin No. | Connector | Symbol | Description | |------------------|-----------|-------------------------------------------|----------------------------|----------|-----------|----------------------------------------|---------------------------------------------------------------------| | 2,4 | J1 | +5V | +5VDC POWER SUPPLY | 57<br>65 | J1 | D <sub>5</sub> | RAM DATA IN D <sub>5</sub> | | 84 & 86 | J2 | -9V | -9VDC POWER SUPPLY | 55 | J1 | D <sub>6</sub> | RAM DATA IN D <sub>6</sub> | | 1,3 | J2 | GND | GROUND | 54 | J1 | D <sub>7</sub> | RAM DATA IN D <sub>7</sub> | | 60 | Jl | MD <sub>0</sub> | DATA FROM MEMORY Ø BIT Ø | 48 | J1 | WAIT | STATE COUNTER | | 63 | J1 | MD <sub>1</sub> | DATA FROM MEMORY 1 BIT 1 | 49 | J1 | T 3 | STATE COUNTER | | 17 | Jl | MD <sub>2</sub> | DATA FROM MEMORY 2 BIT 2 | 46 | J1 | <u>T</u> 1 | STATE COUNTER | | 77 | Jl | MD <sub>3</sub> | DATA FROM MEMORY 3 BIT 3 | 45 | Jl | STOP | STATE COUNTER | | 38 | J2 | MD <sub>4</sub> | DATA FROM MEMORY 4 BIT 4 | 42 | J1 | $\frac{\overline{T_2}}{T_5}$ | STATE COUNTER | | 41 | J2 | MID <sub>5</sub> | DATA FROM MEMORY 5 BIT 5 | 44 | Jl | T <sub>5</sub> | STATE COUNTER | | 45 | J2 | MD <sub>6</sub> | DATA FROM MEMORY 6 BIT 6 | 47 | J1 | 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | STATE COUNTER | | 74 | J2 | MD <sub>7</sub> | DATA FROM MEMORY 7 BIT 7 | 43 | Jl | 7'4 | STATE COUNTER | | 11 | Jl | IA | DATA INPUT PORT # BIT # | 79 | Jl | Č™ <sub>g</sub> | RAM CHIP SELECT Ø | | 10 | Jl | IA <sub>1</sub> | DATA INPUT PORT Ø BIT 1 | 81 | Jl | CM, | RAM CHIP SELECT 1 | | 14 | J1 | tA <sub>2</sub> | DATA INPUT PORT Ø BIT 2 | 83 | Jl | cm, | RAM CHIP SELECT 2 | | 19 | Jl | IA3 | DATA INPUT PORT Ø bIT 3 | 6 | J2 | CM, | RAM CHIP SELECT 3 | | 28 | J1 | IA <sub>4</sub> | DATA INPUT PORT Ø BIT 4 | 2 | J2 | cm₄ | RAM CHIP SELECT 4 | | 33 | J1 | TA <sub>5</sub> | DATA INPUT PORT @ BIT 5 | 4 | J2 | ĒΜ, | RAM CHIP SELECT 5 | | 37 | J1 | _ | | 85 | J1 | CM <sub>6</sub> | RAM CHIP SELECT 6 | | | | tA <sub>6</sub> | DATA INPUT PORT Ø bIT 6 | 82 | Jl | CM, | | | 36 | J1 | TA <sub>7</sub> | DATA INPUT PORT Ø BIT 7 | l . | | | RAM CHIP SELECT 7 | | 6 | J1 | TB <sub>0</sub> | DATA INPUT PORT 1 BIT 9 | 85 | J2 | ĊS <sub>Ø</sub> | ROM CHIP SELECT Ø | | 13 | Jl | IB1 | DATA INPUT PORT 1 BIT 1 | 78 | J1 | cs <sub>1</sub> | ROM CHIP SELECT 1 | | 16 | Jl | LB2 | DATA INPUT PORT 1 BIT 2 | 62 | Jl | ĊŜ <sub>2</sub> | ROM CHIP SELECT 2 | | 21 | J1 | IB3 | DATA INPUT PORT 1 BIT 3 | 64 | Jl | cs <sub>3</sub> | ROM CHIP SELECT 3 | | 26 | J1 | IB <sub>4</sub> | DATA INPUT PORT 1 BIT 4 | 70 | Jl | cs <sub>4</sub> | ROM CHIP SELECT 4 | | 31 | Jl | IB <sub>5</sub> | DATA INPUT PORT 1 BIT 5 | 35 | J2 | cs, | ROM CHIP SELECT 5 | | 34 | J1 | tB <sub>6</sub> | DATA INPUT PORT 1 BIT 6 | 46 | , ј2 | cs <sub>6</sub> | ROM CHIP SELECT 6 | | 39 | Jl | IB <sub>7</sub> | DATA INPUT PORT 1 BIT 7 | 72 | J2 | CS, | ROM CHIP SELECT 7 | | 61 | J2 | ΣÄ <sub>α</sub> | OUTPUT PORT Ø BIT Ø | 5 | J2 | $\sigma_7^7$ | I/O DECODE OUT O | | 67 | J2 | 7A₁ | | 13 | J2 | $\overline{\sigma}_{6}^{7}$ | I/O DECODE OUT O2 | | | | | OUTPUT PORT Ø bit 1 | 12 | J2 | $\tilde{\sigma}_{s}^{6}$ | I/O DECODE OUT O <sub>5</sub> | | 54 | J2 | <sup>⊋A</sup> 2 | OUTPUT PORT # LIT 2 | 15 | J2 | δ <sub>4</sub> | 1/O DECODE OUT O <sub>A</sub> | | 51 | J2 | ŌĀ₃ | OUTPUT PORT Ø BIT 3 | 14 | | | 7 | | 53 | J2 | ŌA 4 | OUTPUT PORT # BIT 4 | 1 | J2 | <b>ნ</b> ვ | I/O DECODE OUT O | | 49 | J2 | DA <sub>5</sub> | OUTPUT PORT Ø BIT 5 | 11 | J2 | $\overline{\sigma}_{2}$ | I/O DECODE OUT O2 | | 50 | J2 | ŌĀ <sub>6</sub> | OUTPUT PORT # BIT 6 | 9 | J2 | $\sigma_1$ | I/O DECODE OUT O | | 47 | J2 | ōĀ, | OUTPUT PORT # BIT 7 | 7 | J2 | ত্ <sub>ঞ্জ</sub><br>ই | I/O DECODE OUT O | | 75 | J2 | ŌB <sub>a</sub> | OUTPUT PORT 1 BIT Ø | 3 | Jl | | FLAG FLIP FLOP-Sign | | 80 | J2 | OB <sub>g</sub><br>OB, | OUTPUT PORT 1 BIT 1 | 5 | Jl | $\overline{z}$ | FLAG FLIP FLOP-Zero | | 78 | J2 | ± | | 23 | Jl | $\overline{\mathtt{P}}$ | FLAG FLIP FLOP_parity | | 7 <b>6</b><br>60 | | <del>0</del> 82 | OUTPUT PORT 1 BIT 2 | 25 | Jl | ₹ | FLAG FLIP FLOP-Carry | | | J2 | <u>⊙B</u> 3 | OUTPUT PORT 1 BIT 3 | 7 | J1 | D <sub>0</sub> | INTERRUPT INSTRUCTION INPUT # | | 65 | J2 | <u>o</u> 8 | OUTPUT PORT 1 BIT 4 | 9 | Jl | D <sub>1</sub> | INTERRUPT INSTRUCTION INPUT 1 | | 57 | J2 | <u>ов</u> <sub>5</sub> | OUTPUT PORT 1 BIT 5 | 18 | Jl | | INTERRUPT INSTRUCTION INPUT 2 | | 62 | J2 | <del>ов</del> 6 | OUTPUT PORT 1 BIT 6 | 20 | Jl | D <sub>2</sub> | INTERRUPT INSTRUCTION INPUT 3 | | 55 | J2 | ŌB <sub>7</sub> | OUTPUT PORT 1 BIT 7 | 24 | Jl | D 3 | INTERRUPT INSTRUCTION INPUT 4 | | 36 | J2 | $\overline{oc}_g$ | OUTPUT PORT 2 BIT Ø | 27 | J1 | D <sub>4</sub> | | | 34 | J2 | $\overline{oc}_1$ | OUTPUT PORT 2 BIT 1 | L. | | D <sub>5</sub> | INTERRUPT INSTRUCTION INPUT 5 | | 25 | J2 | ठट 2 | OUTPUT PORT 2 BIT 2 | 38 | J1 | D <sub>6</sub> | INTERRUPT INSTRUCTION INPUT 6 | | 24 | J2 | oc, | OUTPUT PORT 2 BIT 3 | 40 | J1 | D <sub>7</sub> | INTERRUPT INSTRUCTION INPUT 7 | | 22 | J2 | ठट₄ | OUTPUT PORT 2 BIT 4 | 59 | Ј2 | | FROM TTY TRANSMITTER IN } | | 19 | Ј2 | <del>oc</del> 5 | OUTPUT PORT 2 BIT 5 | 37 | J2 | | FROM TTY TRANSMITTER OUT | | 16 | J2 | $\frac{\overline{oc}_5}{\overline{oc}_6}$ | OUTPUT PORT 2 BIT 6 | 83 | J2 | | DATA FROM TTY TRANSMITTER BUFFER | | 21 | J2 | | OUTPUT PORT 2 BIT 7 | 27 | J2 | | TAPE READER CONTROL IN | | 44 | | ਨੋਟ<br>ਨੋਲ | | 18 | J2 | | TAPE READER CONTROL OUT | | | | <u>ठ</u> Б, | OUTPUT PORT 3 BIT # | 28 | J2 | | TAPE READER CONTROL (-9VDC) | | 43 | J2 | <u>od</u> 1 | OUTPUT PORT 3 BIT 1 | 84 | J1 | | DATA TO TTY RECEIVER BUFFER | | 39 | J2 | OD <sub>2</sub> | OUTPUT PORT 3 BIT 2 | 10 | J2 | | TO TTY RECEIVER OUT | | 12 | J2 | $\overline{DD}_3$ | OUTPUT PORT 3 BIT 3 | 86 | J1 | | | | 33 | J2 | ರ್_4 | OUTPUT PORT 3 BIT 4 | 40 | J2 | | TO TTY RECEIVER OUT TTY BUFFER | | 29 | J2 | oD <sub>5</sub> | OUTPUT PORT 3 BIT 5 | 81 | J2 | | TO TTY RECEIVER OUT | | 26 | J2 | ō0 € | OUTPUT PORT 3 BIT 6 | | | tα | READ/WRITE | | 31 | J2 | <u>ॼ</u> , | OUTPUT PORT 3 BIT 7 | 72 | J1 | 1 Ø | MULTIPLEXER CONTROL LINES N8263 | | 9 | | A <sub>g</sub> | LOW ORDER ADDRESS OUT | 41 | Jl | SLØ | MULTIPLEXER CONTROL LINES N8267 | | 32 | | | LOW ORDER ADDRESS OUT | 69 | J1 | 11 | MULTIPLEXER CONTROL LINES N8263 | | 58 | | A <sub>1</sub> | LOW ORDER ADDRESS OUT | 8 | Jl | SL1 | MULTIPLEXER CONTROL LINES N8267 | | 23 | | A <sub>2</sub> | | 29 | Jl | | DATA COMPLEMENT | | | | A <sub>3</sub> | LOW ORDER ADDRESS OUT | 52 | Jl | ø <sub>1</sub> | <pre>\$ CLOCK (alternate clock)</pre> | | 3 | | A <sub>4</sub> | LOW ORDER ADDRESS OUT | 12 | Jl | ø 2 | \$2 CLOCK (alternate clock) | | .7 | | A <sub>5</sub> | LOW ORDER ADDRESS OUT | 75 | Jl | SYNC | SYNC OUT | | 12 | | A <sub>O</sub> | LOW ORDER ADDRESS OUT | 30 | J1 | READY | READY IN | | 8 | | A <sub>7</sub> | LOW ORDER ADDRESS OUT | 1 | J1 | | T INTERRUPT IN | | 8 | J1 | A <sub>8</sub> | HIGH ORDER ADDRESS OUT | 8 | J2 | | LE ENABLE OF 1/O DEVICE DECODER | | 7 | | A <sub>9</sub> | HIGH ORDER ADDRESS OUT | | | OUT | | | 30 | Jl | A <sub>10</sub> | HIGH ORDER ADDRESS OUT | 79 | J2 | | SYSTEM OUTPUT CONTROL | | ib | | | HIGH ORDER ADDRESS OUT | 77 | J2 | IN | SYSTEM INPUT CONTROL | | | | A <sub>11</sub> | | 50 | J1 | N.O. | PUSH BUTTON SWITCH INTERRUPT | | 76 | J1 | A <sub>12</sub> | HIGH ORDER ADDRESS OUT | 53 | Jl | N.C. | PUSH BUTTON SWITCH | | 1 | | A <sub>13</sub> | HIGH ORDER ADDRESS OUT | 52 | J2 | w <sub>ø</sub> | OUTPUT LATCH STROBE PORT Ø | | 7.4 | | CC <sub>g</sub> | CYCLE CONTROL CODING | 71 | J2 | พ <sub>้</sub> เ | OUTPUT LATCH STROBE PORT 1 | | 13 | | ccı | CYCLE CONTROL CODING | 20 | J2 | w <sub>2</sub> | OUTPUT LATCH STROBE PORT 2 | | 1 | Jl | D <sub>g</sub> | RAM DATA IN Dg | 30 | Ј2 | w <sub>3</sub> | OUTPUT LATCH STROBE PORT 3 | | .5 | | ם<br>1 | RAM DATA IN D | 22 | J1 | | E INTERRUPT CYCLE INDICATOR | | 6 | | D <sub>2</sub> | RAM DATA IN D | 32 | J1 | | _ | | 9 | | D <sub>3</sub> | RAM DATA IN D <sub>3</sub> | 35 | J1 | T3 <sub>A</sub> | ANTICIPATED T <sub>3</sub> OUTPUT ANTICIPATED T <sub>3</sub> OUTPUT | | | | | | | -11 | T3A | | Figure 14. SIM8-01 Assembly Diagram #### VIII. PROM PROGRAMMING SYSTEM # A. General System Description and Operating Instructions Intel has developed a low-cost micro computer programming system for its electrically programmable ROMs. Using Intel's eight bit micro computer system and a standard ASR 33 teletype (TTY), a complete low cost and easy to use ROM programming system may be assembled. The system features the following functions: - 1) Memory loading - 2) Format checking - 3) ROM programming - 4) Error checking - 5) Program listing For specifications of the Intel ROMs, refer to the Intel Data Catalog. Figure 15. MCS-8 PROM Programming System This programming system has four basic parts: - The micro computer (SIM8-01) This is the MCS-8 prototype board, a complete micro-computer which uses 1702 PROMs for the microprogram control. The total system is controlled by the 8008 CPU. - 2) The control program (AO860, AO861, AO862) These control ROMs contain the microprograms which control the bootstrap loading, programming, format and error checking, and listing functions. For high speed programming of Intel's new 1702A PROM (three minutes) use control PROM AO863 in place of AO862. - 3) The programmer (MP7-03) This is the programmer board which contains all of the timing and level shifting required to program the Intel ROMs. This is the successor of the MP7-02. - 4) ASR 33 (Automatic Send Receive) Teletype This provides both the keyboard and paper tape I/O devices for the programming system. In addition, a short-wave ultraviolet light is required if the erasable and reprogrammable 1701's or 1702's are used. This system has two modes of operation: - 1) Automatic A paper tape is used in conjunction with the tape reader on the teletype. The tape contains the program for the ROM. - 2) Manual The keyboard of the TTY is used to enter the data content of the word to be programmed. Information is introduced by selectively programming "1"s (output high) and "0"s (output low) into the proper bit locations. Note that these ROMs are defined in terms of positive logic. Word address selection is done by the same decoding circuitry used in the READ mode. The eight output terminals are used as data inputs to determine the information pattern in the eight bits of each word. A low data input level (ground — P on tape) will leave a "1" and a high data input level (+48V — N on tape) will allow programming of "0". All eight bits of one word are programmed simultaneously by setting the desired bit information patterns on the data input terminals. #### TAPE FORMAT The tape reader used with a model 33 ASR teletype accepts 1" wide paper tape using 7 or 8 bit ASCII code. For a tape to correctly program a 1601/1701 or 1602/1702, it must follow exactly the format rules below: The format requirements are as follows: - 1) There must be exactly 256 word fields in consecutive sequence, starting with word field 0 (all address lines low) to program an entire ROM. If a short tape is needed to program only a portion of the ROM, the same format requirements apply. - 2) Each word field must consist of ten consecutive characters, the first of which must be the start character B. Following that start character, there must be exactly eight data characters (P's or N's) and ending with the stop character F. NO OTHER CHARACTERS ARE ALLOWED ANYWHERE IN A WORD FIELD. If an error is made while preparing a tape and the stop character "F" has not been typed, a typed "B" will eliminate the previous characters entered. This is a feature not available on Intel's 7600 programmer; the format shown in the 1601/1701 data sheet must be used when preparing tapes for other programming systems. An example of this error correcting feature is shown below: If any character other than P or N is entered, a format error is indicated. If the stop character is entered before the error is noticed, the entire word field, including the B and F, must be rubbed out. Within the word field, a P results in a high level output, and N results in a low level output. The first data character corresponds to the desired output for data bit 8 (pin 11), the second for data bit 7 (pin 10), etc. 3) Preceding the first word field and following the last word field, there must be a leader/trailer length of at least 25 characters. This should consist of rubout punches. 4) Between word fields, comments not containing B's or F's may be inserted. It is important that a carriage return and line feed characters be inserted (as a "comment") just before each word field or at least between every four word fields. When these carriage returns are inserted, the tape may be easily listed on the teletype for purposes of error checking. It may also be helpful to insert the word number (as a "comment") at least every four word fields. # **PROM PIN CONFIGURATION** \*THIS PIN IS THE DATA INPUT LEAD FOR THE 1601/1701 AND 1602/1702 DURING PROGRAMMING #### **IMPORTANT** It should be noted that the PROM's are described in the data sheet with respect to positive logic (high level = p-logic 1). The MCS-8 system is also defined in terms of positive logic. Consider the instruction code for LHD (one of the 48 instructions for the MCS-8). #### 11101011 When entering this code to the programmer it should be typed, #### BPPPNPNPF This is the code that will be put into the 1301, Intel's mask programmed ROM, when the final system is defined. # OPERATING THE PROGRAMMER The SIM8-01 is used as the micro computer controller for the programming. The control program performs the function of a bootstrap loader of data from the TTY into the RAM memory. It then presents data and addresses to the PROM to be programmed and controls the programming pulse. The following steps must be followed when programming a PROM: - 1) Place control ROMs in SIM8-01 - 2) Turn on system power - 3) Turn on TTY to "line" position - 4) Reset system with an INTERRUPT (Instr. RST = 00 000 101) - 5) Change instruction at interrupt port to a NO OP - 6) Start system with an INTERRUPT (Instr NO OP = 11 000 000) - 7) Load data from TTY into micro computer memory - 8) Insert PROM into MP7-03 - 9) Program PROM - 10) Remove PROM from MP7-03. To prevent programming of unwanted bits, never turn power on or off while the PROM is in the MP7-03. # LOADING DATA TO THE MICRO COMPUTER (THE BOOTSTRAP LOADER) The programming system operates in an interactive mode with the user. After resetting and starting the system with an INTERRUPT [steps 4), 5), 6)], a "\*" will appear on the TTY. This is the signal that the system is ready for a command. To load a data tape, the following sequence must be followed: This RAM bank may be edited by re-entering blocks of data prior to programming a PROM. More than one RAM bank may be loaded in preparation for programming several different PROMs or to permit the merging of blocks of data from different banks into a single PROM. (See the explanation of the CONTINUE command in section IX.) #### FORMAT CHECKING When the system detects the first format error (data words entered either on tape or manually), it will stop loading data and it will print out the address where the format error occurred. At this time, an "R" may be typed and the data can be RE-ENTERED manually. This is shown below. #### **EXAMPLE 1:** # **PROGRAMMING** After data has been entered, the PROM may be programmed. Data from a designated address field in a designated RAM bank is programmed into corresponding addresses in the PROM. A complete PROM or any portion of a PROM may be programmed in the following manner: #### **ERROR CHECKING** After each location in ROM is programmed, the content of the location is read and compared against the programming data. In the event that the programming is not correct, the ROM location will be programmed again. The MCS-8 programming system allows each location of the ROM to be reprogrammed up to four times. A "\$" will be printed for each reprogramming. If a location in ROM will not accept a data word after the fourth time, the system will stop programming and a "?" will be printed. This feature of the system guarantees that the programmed ROM will be correct, and incompletely erased or defective ROMs will be identified. If a location in the ROM will not program, a new ROM must be inserted in the programmer. The system must be reset before continuing. (If erasable ROMs are being used, the "faulty" ROM should be erased and reprogrammed). #### PROGRAM LISTING Before or after the programming is finished, the complete content of the ROM, or any portion may be listed on the teletype. A duplicated programming tape may also be made using the teletype tape punch. To list the ROM: The listing feature may also be used to verify that a 1701 or 1702 is completely erased. **EXAMPLE 3:** #### 1701, 1702 ERASING PROCEDURE The 1701 and 1702 may be erased by exposure to high intensity short-wave ultraviolet light at a wavelength of 2537 Å. The recommended integrated dose (i.e., UV intensity x exposure time) is 6W-sec/cm<sup>2</sup>. Example of ultraviolet sources which can erase the 1701 or 1702 in 10 to 20 minutes is the Model S-52 and Model UVS-11 short-wave ultraviolet lamps manufactured by Ultra-Violet Products, Inc. (San Gabriel, California). The lamps should be used without short-wave filters, and the 1701 or 1702 to be erased should be placed about one inch away from the lamp tubes. # B. MP7-03 Programming System The MP7-03 is the PROM programming board which easily interfaces with the SIM8-01. All address and data lines are completely TTL compatible. The MP7-03 requires +5VDC @ 0.8 amps, —9 VDC @ 0.1 amps, and 50 Vrms @ 1 amp. Two Stancor P8180 (or equivalent) filament transformers (25.2 Vrms @ 1 amp) with their secondaries connected in series provide the 50 Vrms. This programmer board is the successor of the MP7-02. The MP7-03 enables programming of Intel's new 1702A, a pin-for-pin replacement for the 1702. When the MP7-03 is used under SIM8-01 control with control ROM A0862 replaced by A0863, the 1702A may be programmed an order of magnitude faster than the 1702, less than three minutes. #### IMPORTANT: Only use the A0863 control PROM when programming the new 1702A. Never use it when programming the 1702. The programming duty cycle is too high for the 1702 and it may be permanently damaged. The MP7-03 features three data control options: - 1) Data-in switch (Normal-Complement). If this switch is in the complement position, data into the PROM is complemented. - 2) Data-out switch (Normal-Complement). If this switch is in the complement position, data read from the PROM is complemented. - 3) Data-out switch (Enable-Disable). If this switch is in the enable position, data may be read from the PROM. In the disable position, the output line may float up to a high level (logic "1"). As a result, the input ports on the prototype system may be used for other functions without removing the MP7-03 card. # MP7-03 Programmer Board Specifications #### Features: - High speed programming of Intel's new 1702A (three minutes) - Inputs and outputs TTL compatible - Board sold complete with transformers, capacitor and connector - Directly interfaces with SIM8-01 Board #### Dimensions: 8.4 inches high 9.5 inches deep Power Requirement: $V_{CC} = +5 @ 0.8 amps$ TTL GRD = 0V $*V_{DD} = -9V @ 0.1 amps$ $V_{P} = 50Vrms @ 1 amp$ #### Connector: - a. Solder lug type/Amphenol72 pin connectorP/N 225-23621-101 - b. Wire wrap type Amphenol72 pin connectorP/N 261-15636 \*This board may be used with a -10V supply because a pair of diodes (i.e. 1N914 or equivalent) are located on the board in series with the supply. Select the appropriate pin for either -9V or -10V operation. A micro computer bulletin which describes the modification of the MP7-02 for programming the 1602A/1702A is available on request. These modifications include complete failsafe circuitry (now on MP7-03) to protect the PROMs and the 50V power supply. # C. Programming System Interconnection Figure 16. MP7-03/Sim8-01 PROM Programming System Solder Connector P/N 225-23621-101 R P N M L K J H F E D C B A Z Y X W V U T S R P N M L K J H F E D C B A Wirewrap Connector P/N 261-15636-2 71 69 67 65 63 61 59 57 55 53 51 49 47 45 43 41 39 37 35 33 31 29 27 25 23 21 19 17 15 13 11 9 7 5 3 1 Figure 17a. Component Side of MP7-03 Card Solder Connector P/N 225-23621-101 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 36 36 Wirewrap Connector P/N 261-15636-2 2 4 6 8 10 12 14 16 18 20 22 24 26 28 30 32 34 36 38 40 42 44 46 48 50 52 54 56 58 60 62 64 66 68 70 72 Figure 17b. Pin Definition - Reverse Side of MP7-03 Card Figure 18. MP7-03 PROM Programmer Board Schematic #### IX. PROGRAM ASSEMBLY AND EXECUTION #### A. 8008 Assembler Software Package The 8008 Assembler generates object programs from symbolic assembly language instructions. Programs are written in the assembly language using mnemonic symbols both for 8008 instruction and for special assembler operations. Symbolic addresses can be used in the source program; however, the assembled program will use absolute addresses. The Assembler is designed to operate from a time shared terminal with input by paper tape or directly from the terminal keyboard. The assembled program is punched out at the terminal in 8 level binary paper tape. The Assembler is written in batch FORTRAN IV and is designed to run on an XDS 940 or on other machines having FORTRAN IV capability and a word length of 24 bits or more. Modifications to the program may be required for machines other than the XDS 940. This program is currently available from nationwide computer timesharing services for timesharing computer users or as a software package for adaptation to another machine. Assembler software specifications are available on request. ## B. Execution of Programs From RAM on SIM8-01 Using Memory Loader Control Programs. The previous section provided a description of the preparation of tapes and the programming of PROMs for permanently storing the micro computer programs. During the system development, programs may be loaded, stored, and executed directly from RAM memory. This section explains these additional features. MCS-8 Operating System The system has three basic parts - 1) The micro computer (SIM8-01) - 2) The bootstrap memory loader control program (AO860, AO861, AO862) - 3) ASR 33 (Automatic Send Receive) Teletype The control program provides the complete capability for executing programs from RAM. Two additional program commands are required; "C", the CONTINUE command for loading more than one bank of memory, and "E", the program EXECUTION command. #### OPERATING THE MICRO COMPUTER SYSTEM To use the SIM8-01 as the micro computer controller for the bootstrap loading of a program from the TTY into RAM memory and the execution of programs stored in RAM, the following steps must be followed: - 1) Place control ROMs in SIM8-01 - 2) Turn on system power - 3) Turn on TTY to "line" position - 4) Reset system with an INTERRUPT (Instr. RST = 00 000 101) - 5) Change instruction at interrupt port to a NO OP - 6) Start system with an INTERRUPT (Instr. NO OP = 11 000 000) - 7) Load data from TTY into micro computer RAM memory - 8) Execute the program stored in RAM #### LOADING OF MULTIPLE RAM BANKS Through the use of the command "C", (CONTINUE) subsequent RAM banks may be loaded with data without entering a new data entry command and new memory bank and address designations. Note that the CONTINUE command should only be used when the subsequent RAM will be completely loaded with 256 bytes of data. For partial loading of RAM banks, always use the DATA ENTRY command. The content of a RAM bank may be edited by using the DATA ENTRY command and revising and re-entering sections of the bank. When a program is being stored in memory, the first instruction of the program should be located at address ØØØ in a RAM bank. The entire RAM memory with the exception of the last fifteen bytes of RAM bank 3 may be used for program or data storage in conjunction with the bootstrap loader. #### PROGRAM EXECUTION The program which has been loaded into RAM may be executed directly from RAM. **CAUTION:** When executing a program from a single RAM bank or multiple RAM banks, care must be taken to insure that all JUMP addresses and subroutine CALL addresses are appropriately assigned within the memory storage being used. #### SUMMARY OF SYSTEM COMMANDS Using Intel's special control ROMs (AO860, AO861, AO862) the following control commands are available: | COMMAND | EXPLANATION | |---------|----------------------------------------------------------------------------------------------| | Т | DATA ENTRY — Enter data from TTY into a RAM bank | | С | CONTINUE — Continue entering 256 byte blocks of data into subsequent RAM banks | | R | RE-ENTER — Re-enter a data word where a format error has occurred and continue entering data | | E | EXECUTE — Execute the program stored in RAM memory | | Р | PROGRAM — Program a PROM using data stored in RAM memory | | L | LIST — List the content of the PROM on the TTY | #### Listing of Bootstrap Loader Program (Intel tape numbers A0860, A0861, A0862, October 2, 1972) ``` BECIN LAI 1 *TYPE A AND IDENTIFY INITIAL AND FINAL LOCATION SUPPRESS TTY OUT 12B OUTPUT 2 XRA CLEAR AC ADRESI, CAL CRIE LBI 301B LOAD (A) OUT 13B OUTPUT 3 - TAPE READER CONTROL CAL TYPE (A) HLT TTYOUT JMP START AD1 CAL CRLF LCI 253 *TELETYPE TAPE READER & I/O CONTROL AD2 CAL TTY CALL FOR TTY KB INPUT INL L=L+1 TAPE TAPE READER ENABLE CODE LMB LOAD TTY KB INPUT TO M OUTPUT 3 - ENABLE TAPE READER WAIT FOR TTY START PULSE TTY DELAY - 4 MSEC- OUT 13B INC C=C+1 TTY HLT JFZ AD2 JUMP IF C IS NOT ZERO LDI 194 RET ST2 IND JFZ ST2 *DATA INPUT ROUTINE XRA TAPE READER DISABLE CODE OUTPUT 3, DISABLE TAPE READER OUTPUT 2, OUTPUT START PULSF TTY DATA SAMPLING COUNTER OUT 13B DATAIN CAL TAPE READ TAPE LAI 102B OUT 12B LOAD (B) SEARCH FOR (B) CPB LEI 248 JFZ DATAIN CAL TTYDI TTY DELAY - 8.7 MSEC. JUMP IF IT IS NOT (B) INP OB READ TTY DATA INPUT DATA1 LHI 11 H=11 COMPLEMENT TTY DATA OUTPUT 2, TTY DATA OUT STORE TTY DATA XRI 255 LLI 255 L=255 LAI 248 OUT 128 DATA BIT COUNTER LMA STORE DATA BIT CONTR RAR READ TAPE MEMORY LOC. FOR DATA LAB LOAD TTY DATA TO REG. B DATA2 CAL TAPE LLI 250 RAR LBA LOAD AC TO REG. B LAI 120B LOAD (P) INE E = E + 1 Jump if Zero F/F is Not set LOAD REG. B TO AC CPB SEARCH FOR (P) JFZ TTYIN JTZ PDATA IF (P) STORE (1) LOAD (N) LAB LAI 116B REMOVE PARITY BIT CPB SEARCH FOR (N) LBA STORE TTY INPUT DATA JTZ NDATA IF (N) STORE (O) LOAD (B) SEARCH FOR (B) TTYDI LAI 102B CAL LAI CPB OUT 12B SUPPRESS TTY JTZ DATAI IF (B) DELETE LAST INSTRCTION LOAD (RO) SEARCH FOR RUBOUT RET LAI 177B NOP CPB LAA JUMP IF NOT RUBOUT LAA JFZ FMEROR LAA CAL RUBOUT CALL FOR RUBOUT ROUTINE JMP LAA DATAS LAA FMEROR CAL FORMAT CALL FOR FORMAT ERROR ROUTINE JMP DATAEN *TTY DELAY - 8.7 MSEC. PDATA LAI 1 REPLACE (P) WITH (1) RAR ROTATE RICHT TTYD1 LDI 121 8.7 MSEC. DELAY LAM RAL. ROTATE LEFT ST IND D=D+1 LMA JFZ ST JMP DATA3 RET NDATA XRA CLEAR AC AND CARRY *BCD TO BINARY CONVERSION LAM RAL ROTATE LEFT BCDBIN LAM LOAD LSD TO A SUI 48 AC=AC-48 DATA3 L.L. I 255 LOAD A TO B LBM LBA LOAD M TO B L=L-1 INB INC DATA BIT COUNTER LOAD M TO A LMB LAM SUI 48 A=A-48 JEZ DATAS JUMP IF B IS NOT ZERO CALL FOR TAPE INPUT LOAD A TO E FDATA CAL TAPE LEA BB 1 JTZ BB2 IF A=O JUMP LAI 106B LOAD (F) LAI 10 AC=10 CPB SEARCH FOR (F) AC=AC+B ADB JTZ DATA4 STORE DATA IF IT IS (F) LOAD AC TO REG. B LAI 102B LOAD (B) LBA DCE E=E-1 CPB SEARCH FOR (B) JMP BB1 JTZ DATAL DELETE LAST INSTRUCTION IF IT IS (B) BB2 DCL L=L-1 LAI 177B LOAD (RO) LOAD M TO A SEARCH FOR (RO) CPB JUMP IF IT IS NOT (RO) CALL FOR (RO) ROUTINE SUI 48 A=A-48 JFZ FMEROR LOAD A TO E LEA CAL RUBOUT BB3 JTZ BB4 JMP DATAS LAI 100 AC=100 DATA4 CLEAR AC AND CARRY ADB AC=AC+B DATAEN RET LBA LOAD AC TO REG. B *RUBOUT ROUTINE DCE JMP BB3 BB4 RUBOUT LAA RET NOP *BINARY TO BCD CONVERSION LAA LAA LAA LAA BINBCD LHI 11 LAA LLI 241 RET BNBD LCI O CLEAR REG. C *FORMAT ERROR ROUTINE LAR BDI SUI 100 AC=AC-100 JUMP IF AC<100 FORMAT LBI 240B JTC BD2 LOAD (SP) INC C=C+1 CAL TTYOUT TYPE (SP) JMP BD1 LBI 306B LOAD (F) BD2 LBI 100 CAL TTYOUT LOAD 100 TO REC. B TYPE (F) AC=AC+B LBI 305B ADB LOAD (E) LBA LOAD AC TO REC. B CAL TTYOUT TYPE (E) LISTA LAI 48 A=A+48 CAL CRLF PRINTA LLI 253 ADC A=A+C LBM LOAD MEMORY TO B LMA LOAD A TO MEMORY LCI O CLEAR REG. C CAL BINBCD BIN TO BCD CONV LEI 253 LAB LOAD B TO A E=253 ``` | BD3 | SUI 10 | AC=AC-10 | DCL | L=L-1 | |------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | JTC BD4<br>INC | JUMP IF AC<10<br>C=C+1 | DCL<br>FM1 LAM | L=L-1<br>Load MSD to AC | | | JMP BD3 | C=C+1 | ADI 128 | AC=AC+128 | | BD4 | LBI 10 | B = 10 | LBA | LOAD AC TO B | | | ADB | AC=AC+B | CAL TTYOUT | TYPE BCD LOCATION | | | LBA | LOAD AC TO REG B | INL<br>INE | L=L+1<br>E=E+1 | | | LAI 48<br>ADC | A=A+C | JFZ FM1 | JUMP IF E IS NOT O | | | INL | L=L+1 | LAI 1 | FORMAT ERROR FLAG | | | LMA | LOAD A TO M | RET | | | | LAI 48<br>ADB | A=A+48<br>A=A+B | * *ENTER ADDRESS AND CONVERS | THEM INTO BINARY REP. | | | INL | L=L+1 | * | | | | LMA | LOAD A TO M | ENTERA LHI 11 | H=11 | | _ | RET | RETURN | LLI 240<br>ENTERH CAL ADRESH | L=240<br>Enter bank no. | | *TTY 0 | UTPUT ROUTINE | | ENTERL CAL ADRESL | ENTER INITIAL ADDRESS | | * | | | CAL AD1 | ENTER FINAL ADDRESS | | | LCI 253 | C=253<br>DELAY - 9.012 MSEC. | CAL CRLF<br>LLI 246 | L=246 | | TTYO | CAL TTYD1<br>INC | C=C+1 | CAL BCDBIN | FINAL ADRES-BINARY | | | JFZ TTYO | | LCB | LOAD B TO C | | | XRA | | DCL | L=L-1 | | | OUT 12B<br>LCI 248 | TTY START PULSE REG C=248 | CAL BCDBIN<br>DCL | INITIAL ADRES-BINARY<br>L=L-1 | | TTY1 | CAL TTYD1 | TTY DELAY - 9.012 MSEC. | LAM | AC=M | | | LAB | LOAD DATA TO AC | SUI 48 | AC=AC-48 | | | OUT 12B<br>RAR | OUTPUT DATA<br>STORE DATA IN CARRY | ADI 8<br>LLI 252 | AC=AC+8<br>L=252 | | | LBA | LOAD A TO B | LMA | STORE BANK NO IN M | | | LAI O | AC = 0 | INL | L=L+1=253 | | | RAR | RESTORE DATA BIT | LMB | STORE INITIAL ADRES IN M | | | ADB<br>LBA | RESTORE DATA<br>STORE | INL<br>LMC | L=L+1=254<br>STORE FINAL ADRES IN M | | | INC | C=C+1 | RET | | | | JFZ TTY1 | JUMP IF AC IS NOT ZERO | * | | | | CAL TTYD1<br>LAI 1 | TTY DELAY - 9.012 MSEC. | *SET ADDRESS TO 1101 RAM | | | | OUT 12B | SUPPRESS TTY | SETMA LHI 11 | H=11 | | | RET | | LL1 252 | L=252 | | * | | | LDM | BANK NO TO D | | *CARRI | AGE RETURN & LINE FEED | | INL<br>Lam | L=L+1=253<br>INIT ADR TO E | | CRLF | LBI 215B | CARRIAGE RETURN - CR | OUT 10B | WRITE ADDRESS TO OUT O | | | CAL TTYOUT | TYPE CR | LLA | LOAD AC TO L | | LF | TBI 515B | LINE FEED - LF | LHD | D TO H = BANK NO | | | CAL TTYOUT | TYPE LF | RET | | | | RET | | * | | | * | RET | | * *ADDRESS CHECKING | | | | RET<br>R SIGNAL | | * | | | * | R SIGNAL | (2) | * ACHECK LHI 11 | H=11<br>1.=254 | | * | | (?)<br>TYPE (?) | * | H=11<br>L=254<br>LOAD FINAL ADRES: TO AC | | *<br>Error | R SIGNAL<br>LBI 277B | | * ACHECK LHI 11 LLI 254 LAM DCL | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253 | | *<br>ERROR<br>* | R SIGNAL<br>LBI 277B<br>CAL TTYOUT<br>RET | | * ACHECK LHI 11 LLI 254 LAM DCL CPM | L=254<br>LOAD FINAL ADRES: TO AC<br>L=L-1=253<br>COMPARE:AF-AI | | *<br>ERROR<br>* | R SIGNAL<br>LBI 277B<br>CAL TTYOUT | | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0 | | * ERROR * *TYPE * | R SIGNAL<br>LBI 277B<br>CAL TTYOUT<br>RET | | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B | TYPE (?) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TTYOUT | TYPE (?) LOAD (B) TYPE (B) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TTYOUT | TYPE (?) LOAD (B) TYPE (B) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE * | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 | L=254<br>LOAD FINAL ADRES. TO AC<br>L=L-1=253<br>COMPARE:AF-AI<br>JUMP IF AF-AI=0<br>LOAD AI TO AC<br>AI=AI+1 | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TTY LMB RET CAL CRLF LBI 252B | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TTYOUT CAL TTY LAI 124B | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TTYOUT CAL TTY LBI 252B CAL TTYOUT CAL TTY LAI 124B CPB | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TTY LAI 124B CPB JTZ TAPEIN | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TTYOUT CAL TTY LBI 252B CAL TTYOUT CAL TTY LAI 124B CPB | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TYYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TYYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYYOUT CAL TY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC-BOSE, (E) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TIYOUT | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TTYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) | | * ERROR * *TYPE ADRESI | R SIGNAL LBI 277B CAL TYYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TYYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYYOUT CAL TY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC-BOSE, (E) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TIYOUT | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) | | * ERROR * *TYPE ADRESI | LBI 277B CAL TYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ READIN LAI 103B CPB | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B AC-B AC-B AC-B AC-B AC-B AC-B AC-B | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) | *ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR | | * ERROR * *TYPE ADRESI | LBI 277B CAL TTYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TTYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TTYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ READIN LAI 103B CPB JTZ CONTIN LAI 114B CPB | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O | | * ERROR * *TYPE ADRESI | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B CPB JIZ CONTIN LAI 114B CPB JIZ CONTIN LAI 114B CPB JIZ LISTIN | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 1B LIST2 RAL LLI 249 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 | | * ERROR * *TYPE ADRESI | LBI 277B CAL TYYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TYYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ READIN LAI 103B CPB JTZ CONTIN LAI 114B CPB JTZ LISTIN LAI 112B | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=120B, (P) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 1B LIST2 RAL LLI 249 LMA | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA | | * ERROR * *TYPE ADRESI | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B CPB JIZ CONTIN LAI 114B CPB JIZ CONTIN LAI 114B CPB JIZ LISTIN | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=103B, (C) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 18 LIST2 RAL LLI 249 LMA JTC PRINTP | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 | | * ERROR * *TYPE ADRESI | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ EXECUT LAI 103B CPB JTZ CONTIN LAI 103B CPB JTZ CONTIN LAI 114B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ PROGRM CAL ERROR | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=1214B, (L) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC-BOB, (P) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 1B LIST2 RAL LLI 249 LMA | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA | | * ERROR * *TYPE ADRESI | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B CPB JIZ CONTIN LAI 114B CPB JIZ LISTIN LAI 120B CPB JIZ LISTIN LAI 120B CPB JIZ PROGRM | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TIYOUT LBI 302B CAL TIYOUT LBI 302B CAL TIYOUT LLI 253 LAM OUT 10B LEI 248 INP 18 LIST2 RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TIYOUT JMP LIST3 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) | | * ERROR * *TYPE * ADRES! * START | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B CPB JIZ CONTIN LAI 114B CPB JIZ LISTIN LAI 120B CPB JIZ LISTIN LAI 120B CPB JIZ PROGRM CAL ERROR JMP START | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET ** **PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 1B LIST2 RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TTYOUT 320B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (SP) PRINT (B) L=253 LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) LOAD (P) | | * ERROR * *TYPE * ADRESE * START | LBI 277B CAL TYYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TYYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ READIN LAI 103B CPB JTZ READIN LAI 103B CPB JTZ CONTIN LAI 114B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ PROGRM CAL ERROR JMP START | LOAD (B) TYPE (B) CALL FOR TTY KB INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KB INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B, (E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=114B, (L) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET * *PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TIYOUT LBI 302B CAL TIYOUT LBI 302B CAL TIYOUT LLI 253 LAM OUT 10B LEI 248 INP 18 LIST2 RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TIYOUT JMP LIST3 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) LOAD (P) PRINT (P) | | * ERROR * *TYPE * ADRES! * START | LBI 277B CAL TYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ PEADIN LAI 103B CPB JTZ CONTIN LAI 114B CPB JTZ CONTIN LAI 114B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ PROGRM CAL ERROR JMP START DATA INPUT TO 1101 RAM CAL ENTERA | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=124B, (C) AC-B JUMP IF AC-B=0 AC=124B, (C) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 TYPE (?) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET ** **PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 18 LIST2 RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TTYOUT LBI 316B CAL TTYOUT LBI 320B CAL TTYOUT LBI 316B CAL TTYOUT LBI 320B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (SP) PRINT (B) L=253 LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) LOAD (P) | | * ERROR * *TYPE * ADRES! * START | LBI 277B CAL TIYOUT RET B AND IDENTIFY RAM BANK H CAL CRLF LBI 302B CAL TIYOUT CAL TIY LMB RET CAL CRLF LBI 252B CAL TIYOUT CAL TIY LAI 124B CPB JIZ TAPEIN LAI 105B CPB JIZ EXECUT LAI 122B CPB JIZ READIN LAI 103B CPB JIZ ROOTIN LAI 114B CPB JIZ CONTIN LAI 114B CPB JIZ LISTIN LAI 120B CPB JIZ LISTIN LAI 120B CPB JIZ PROGRM CAL ERROR JMP START DATA INPUT TO 1101 RAM CAL ENTERA CAL DATAIN | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC-105B, (E) AC-B JUMP IF AC-B=0 AC-122B, (R) AC-B JUMP IF AC-B=0 AC-133B, (C) AC-B JUMP IF AC-B=0 AC-14B, (L) AC-B JUMP IF AC-B=0 AC-120B, (P) AC-B JUMP IF AC-B=0 AC-120B, (P) AC-B JUMP IF AC-B=0 AC-120B, (P) AC-B JUMP IF AC-B=0 TYPE (?) | *ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET **PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 302B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 1B LIST? RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TTYOUT LBI 316B CAL TTYOUT LBI 320B CAL TTYOUT LST3 PRINTP LBI 320B CAL TTYOUT LIST3 LAM INE JFZ LIST2 | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) LOAD (P) PRINT (P) LOAD (P) PRINT (P) LOAD DATA TO AC E=E+1 JUMP IF E IS NOT O | | * ERROR * *TYPE * ADRES! * START | LBI 277B CAL TYOUT RET B AND IDENTIFY RAM BANK CAL CRLF LBI 302B CAL TYOUT CAL TTY LMB RET CAL CRLF LBI 252B CAL TYOUT CAL TTY LAI 124B CPB JTZ TAPEIN LAI 105B CPB JTZ EXECUT LAI 122B CPB JTZ PEADIN LAI 103B CPB JTZ CONTIN LAI 114B CPB JTZ CONTIN LAI 114B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ LISTIN LAI 120B CPB JTZ PROGRM CAL ERROR JMP START DATA INPUT TO 1101 RAM CAL ENTERA | LOAD (B) TYPE (B) CALL FOR TTY KE INPUT STORE INPUT IN MEMORY B=252B TYPE (*) CALL FOR TTY KE INPUT LOAD (T) TO AC AC-B JUMP IF AC-B=0 AC=105B,(E) AC-B JUMP IF AC-B=0 AC=122B, (R) AC-B JUMP IF AC-B=0 AC=124B, (C) AC-B JUMP IF AC-B=0 AC=124B, (C) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 AC=120B, (P) AC-B JUMP IF AC-B=0 TYPE (?) | * ACHECK LHI 11 LLI 254 LAM DCL CPM JTZ CHECK LCM INC LMC CHECK RET ** **PROGRAM BEGINS * LISTIN LHI 11 LLI 240 CAL ENTERL LISTER CAL CRLF LLI 251 LAI 252 LMA LISTI CAL PRINTA LBI 240B CAL TTYOUT LBI 302B CAL TTYOUT LLI 253 LAM OUT 10B LEI 248 INP 18 LIST2 RAL LLI 249 LMA JTC PRINTP LBI 316B CAL TTYOUT LBI 316B CAL TTYOUT LBI 320B CAL TTYOUT LBI 316B CAL TTYOUT LBI 320B | L=254 LOAD FINAL ADRES. TO AC L=L-1=253 COMPARE:AF-AI JUMP IF AF-AI=0 LOAD AI TO AC AI=AI+1 LOAD AI TO MEMORY H=11 L=240 ENTER INITIAL & FINAL ADR. L=251 NO. OF INSTR. PER LINE LOAD AC TO MEMORY PRINT ADDRESS LOAD (SP) PRINT (SP) LOAD (SP) PRINT (SP) LOAD (B) PRINT (B) L=253 LOAD AI TO AC OUTPUT AI TO OUT O READ DELAY/DATA BIT CONTR READ INPUT FROM 1702 L=249 SAVE INPUT DATA PRINT (P) IF CARRY=1 LOAD (N) PRINT (N) LOAD (P) PRINT (P) LOAD DATA TO AC E=E+1 | | | LLI | 050 | L=250 | | | | | |----------------|-------|-------------|---------------------|---------|-------|--------|----------------------------| | | LCM | 250 | LOAD MEMORY TO C | | | 240B | LOAD (SP) | | | | SETMA | SET MEMORY ADDRESS | | | TTYOUT | PRINT (SP) | | | LAC | SEIMA | SEI MEMORI ADDRESS | | | ACHECK | AF - AI | | | | 118 | | | | START | | | | LMA | 110 | LOAD DATA TO MEMORY | | | 251 | LOAD LINE CONTR. TO AC | | | | ACHECK | COMPARE AF AND AI | | LCM | | LOAD MEMORY TO C | | | | START | JUMP IF A=0 | | INC | | C=C+1 | | | | READIN | READ INPUT DATA | | LMC | | VN40 TO 1 THE GAVES | | EXECUT | | | H=11 | | | LISTER | JUMP IF LINE CONTR.=4 | | | | 240 | L=240 | * | UMP | LISTI | | | BANKO | | 4000B | BANK O LOCATION | *PROM F | 2000 | DAMMED | | | BANK1 | | 4400B | BANK 1 LOCATION | * | ימטטי | HAMMER | | | BANK2 | | 5000B | BANK 2 LOCATION | - | CAL | ENTERA | ENTER MEMORY ADDRESS | | BANK3 | | 5400B | BANK 3 LOCATION | PG1 | | 255 | REPROGRAM CONTR. | | | | ADRESH | ENTER BANK NO | FGI | | 253 | AC=253 | | | | CRLF | | | LMA | | LOAD AC TO MEMORY | | | LAM | *** | LOAD MEMORY TO AC | | | LISTA | PRINT ADDRESS | | | SUI | 48 | AC=AC-48 | PG2 | | SETMA | SET ADDRESS TO 1702 | | | ADI | | AC#AC+8 | FUE | | 255 | COMPLEMENT INPUT DATA | | | LHA | • | LOAD AC TO H | | XRM | | LOAD DATA TO AC | | | LAI | a | AC=8 | | | 118 | WRITE DATA TO OUT 1 | | | CPH | | AC=AC-H | | LAI | | AC=2, DELAY | | | | BANKO | JUMP IF AC=0 | | | 13B | PROGRAM PULSE ENABLE | | | LAI | | John , 21 110-15 | | | 254 | DELAY = 5 SEC. | | | CPH | | | PG3 | LEI | | E=0 | | | | BANK1 | | PG4 | | TTYDI | DELAY - 8.7 MSEC. | | | LAI | | | | INE | | E=E+1 | | | CPH | | | | JFZ | PG4 | JUMP IF E IS NOT 0 | | | JTZ | BANK2 | | | INC | | C=C+1 | | | LAI | 11 | | | JFZ | PG3 | JUMP IF D IS NOT O | | | CPH | | | | LAI | 0 | AC=0 | | | JTZ | BANK3 | İ | | OUT | 138 | DISABLE PROGRAM PULSE | | | CAL | ERROR | i | | INP | 18 | READ DATA FROM 1702 | | | JMP | START | | | CPM | | COMPARE DATA | | CONTIN | | | | | | PC5 | JUMP IF COMPARED | | | | 252 | | | | 244B | LOAD [\$] | | | LDM | | | | | TTYOUT | PRIN(\$) | | | IND | | D=D+1 | | LHI | | | | | LMD | | BANK=BANK+1 | | | 255 | | | | INL | | L=L+1 | | LBM | | | | | XRA | | CLEAR AC | | INB | | | | | LMA | | INITIAL ADRES=0 | | LMB | | LOAD B TO MEMORY | | | INL | | | | | PGS | | | | | 255 | ETWAL ADDEC OFF | | | ERROR | PRINT (?) | | | LMA | READIN | FINAL ADRES=255 | 50.5 | | START | | | | OMP | VEWNIA | | PG5 | | ACHECK | | | <b>-</b> 0000≃ | 1 164 | ING ROUTINE | | | | START | | | +FROM | r:21 | ING ROOTINE | | | | PG1 | CONTINUE PROG. NEXT INSTR. | | • | | | l I | | END | | | # APPENDIX I FUNCTIONAL DEFINITION | Symbols | Meaning | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | <b2></b2> | Second byte of the instruction | | <b3></b3> | Third byte of the instruction | | r | One of the scratch pad register references: A, B, C, D, E, H, L | | С | One of the following flag flip-flop references: C, Z, S, P | | C <sub>4</sub> C <sub>3</sub> | Flag flip-flop codes 00 carry 01 zero 10 sign 11 parity Condition for True Overflow, underflow Result is zero MSB of result is "1" Parity of result is even | | M | Memory location indicated by the contents of registers H and L | | () | Contents of location or register | | ^ | Logical product | | ₩ | Exclusive "or" | | V | Inclusive "or" | | $A_{m}$ | Bit m of the A-register | | STACK | Instruction counter (P) pushdown register | | Р | Program Counter | | - | Is transferred to | | XXX | A ''don't care'' | | SSS | Source register for data | | DDD | Destination register for data | | | Register # Register Name<br>(SSS or DDD) | | | 000 A 001 B 010 C 011 D 100 E 101 H 110 L | #### INDEX REGISTER INSTRUCTIONS #### LOAD DATA TO INDEX REGISTERS - One Byte Data may be loaded into or moved between any of the index registers, or memory registers. | Lr <sub>1</sub> r <sub>2</sub><br>(one cycle — PCI) | 11 | DDD | SSS | $(r_1)$ + $(r_2)$ Load register $r_1$ with the content of $r_2$ .<br>The content of $r_2$ remains unchanged. If SSS=DDD, the instruction is a NOP (no operation). | |-----------------------------------------------------|----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LrM<br>(two cycles –<br>PCI/PCR) | 11 | DDD | 111 | $(r)$ $\leftarrow$ $(M)$ Load register r with the content of the memory location addressed by the contents of registers H and L. $(DDD \neq 111 - HALT instr.)$ | | LMr<br>(two cycles —<br>PCI/PCW) | 11 | 111 | SSS | (M) $\leftarrow$ (r) Load the memory location addressed by the contents of registers H and L with the content of register r. (SSS $\neq$ 111 — HALT instr.) | #### LOAD DATA IMMEDIATE — Two Bytes A byte of data immediately following the instruction may be loaded into the processor or into the memory | tri<br>(two cycles –<br>PCI/PCR) | 00 DDD 110<br><b<sub>2&gt;</b<sub> | $(r) \leftarrow \langle B_2 \rangle$ Load byte two of the instruction into register r. | |----------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | LMI<br>(three cycles —<br>PCI/PCR/PCW) | 00 111 110 < B <sub>2</sub> > | (M) $\leftarrow$ <b<sub>2&gt; Load byte two of the instruction into the memory location addressed by the contents of registers H and L.</b<sub> | #### INCREMENT INDEX REGISTER - One Byte | INr<br>(one cycle – PCI) | 00 | DDD | 000 | $(r) \leftarrow (r)+1$ . The content of register r is incremented by | | | | |--------------------------|----|-----|-----|----------------------------------------------------------------------|--|--|--| | (one cycle — PCI) | | | | one. All of the condition flip-flops except carry are | | | | | | | | | affected by the result. Note that DDD#000 (HALT | | | | | | | | | instr.) and DDD#111 (content of memory may not | | | | be incremented). #### DECREMENT INDEX REGISTER - One Byte | DCr | 00 | DDD | 001 | $(r) \leftarrow (r) - 1$ . The content of register r is decremented | |-------------------|----|-----|-----|---------------------------------------------------------------------| | (one cycle — PCI) | | | | by one. All of the condition flip-flops except carry | | | | | | are affected by the result. Note that DDD#000 (HAI | ops except carry ult. Note that DDD#000 (HALT instr.) and DDD#111 (content of memory may not be decremented). #### ACCUMULATOR GROUP INSTRUCTIONS Operations are performed and the status flip-flops, C, Z, S, P, are set based on the result of the operation. Logical operations (NDr, XRr, ORr) set the carry flip-flop to zero. Rotate operations affect only the carry flip-flop. Two's complement subtraction is used. #### ALU INDEX REGISTER INSTRUCTIONS — One Byte (one cycle - PCI) Index Register operations are carried out between the accumulator and the content of one of the index registers (SSS=000 thru SSS=110). The previous content of register SSS is unchanged by the operation. | ADr | 10 000 | SSS | (A)→(A)+(r) Add the content of register r to the<br>content of register A and place the result into<br>register A. | |-----|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ACr | 10 001 | SSS | (A)-(A)+(r)+(carry) Add the content of register r and the contents of the carry flip-flop to the content of the A register and place the result into Register A. | | SUr | 10 010 | SSS | (A)—(A)—(r) Subtract the content of register r from the content of register A and place the result into register A. Two's complement subtraction is used. | ## ACCUMULATOR GROUP INSTRUCTIONS - Cont'd. | | SBr | 10 | 011 | SSS | (A)— $(A)$ — $(r)$ — $(borrow)$ Subtract the content of register r and the content of the carry flip-flop from the content of register A and place the result into register A. | |-----|-----|----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | NDr | 10 | 100 | SSS | $(A) \leftarrow (A) \wedge (r)$ Place the logical product of the register A and register r into register A. | | | XRr | 10 | 101 | SSS | $(A) \leftarrow (A) \forall (r)$ Place the "exclusive - or" of the content of register A and register r into register A. | | | ORr | 10 | 110 | SSS | (A)←(A)V(r) Place the "inclusive - or" of the content of register A and register r into register A. | | | CPr | 10 | 111 | SSS | (A)—(r) Compare the content of register A with<br>the content of register r. The content of register A<br>remains unchanged. The flag flip-flops are set by the<br>result of the subtraction. Equality or inequality is<br>indicated by the zero flip-flop. Less than or greater<br>than is indicated by the carry flip-flop. | | Λ ι | | | | | | ## ALU OPERATIONS WITH MEMORY — One Byte (two cycles — PCI/PCR) Arithmetic and logical operations are carried out between the accumulator and the byte of data addressed by the contents of registers H and L. | ADM | 10 000 111 | $(A)$ $\leftarrow$ $(A)$ $+$ $(M)$ ADD | |-----|------------|-----------------------------------------------------| | ACM | 10 001 111 | $(A)$ $\leftarrow$ $(A)+(M)+(carry)$ ADD with carry | | SUM | 10 010 111 | (A) <del>-</del> (A)-(M) SUBTRACT | | SBM | 10 011 111 | (A)→(A)–(M)–(borrow) SUBTRACT with borrow | | NDM | 10 100 111 | $(A)$ $\leftarrow$ $(A) \land (M)$ Logical AND | | XRM | 10 101 111 | (A)→(A)∀(M) Exclusive OR | | ORM | 10 110 111 | (A)→(A)V(M) Inclusive OR | | СРМ | 10 111 111 | (A)—(M) COMPARE | ## ALU IMMEDIATE INSTRUCTIONS — Two Bytes (two cycles —PCI/PCR) Arithmetic and logical operations are carried out between the Arithmetic and logical operations are carried out between the accumulator and the byte of data immediately following the instruction. | , , , , , , , , , , , , , , , , , , , , | <br>401.01 | •• | | |-----------------------------------------|----------------------------|-----|-------------------------------------------------------------------------------| | ADI | <br>00<br>B <sub>2</sub> > | 100 | (A) <del>←</del> (A)+ <b<sub>2&gt;<br/>ADD</b<sub> | | ACI | 01<br>B <sub>2</sub> > | 100 | $(A) \leftarrow (A) + \langle B_2 \rangle + (carry)$<br>ADD with carry | | SUI | 10<br>B <sub>2</sub> > | 100 | (A) ←(A)- <b<sub>2&gt;<br/>SUBTRACT</b<sub> | | SBI | 11<br>B <sub>2</sub> > | 100 | $(A) \leftarrow (A) - \langle B_2 \rangle - (borrow)$<br>SUBTRACT with borrow | | NDI | 00<br>B <sub>2</sub> > | 100 | (A)←(A)∧ <b<sub>2&gt;<br/>Logical AND</b<sub> | | XRI | <br>01<br>B <sub>2</sub> > | 100 | (A) <del>←</del> (A) <del>V</del> <b<sub>2&gt;<br/>Exclusive OR</b<sub> | | ORI | 10<br>B <sub>2</sub> > | 100 | (A)←(A)V <b<sub>2&gt;<br/>Inclusive OR</b<sub> | | CPI | <br>11<br>B <sub>2</sub> > | 100 | (A)— <b<sub>2&gt;<br/>COMPARE</b<sub> | #### ROTATE INSTRUCTIONS — One Byte (one cycle - PCI) The accumulator content (register A) may be rotated either right or left, around the carry bit or through the carry bit. Only the carry flip-flop is affected by these instructions; the other flags are unchanged. | RLC | 00 0 | 000 | 010 | $A_{m+1} - A_m$ , $A_0 - A_7$ , (carry) $- A_7$<br>Rotate the content of register A left one bit.<br>Rotate $A_7$ into $A_0$ and into the carry flip-flop. | |-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RRC | 00 0 | 001 | 010 | $A_m \leftarrow A_{m+1}$ , $A_7 \leftarrow A_0$ , (carry) $\leftarrow A_0$<br>Rotate the content of register A right one bit.<br>Rotate $A_0$ into $A_7$ and into the carry flip-flop. | | RAL | 00 0 | 010 | 010 | $A_{m+1} - A_m$ , $A_0 - (carry)$ , $(carry) - A_7$<br>Rotate the content of Register A left one bit.<br>Rotate the content of the carry flip-flop into $A_0$ .<br>Rotate $A_7$ into the carry flip-flop. | | RAR | 00 0 | 011 | 010 | $A_m+A_{m+1}$ , $A_7+(carry)$ , $(carry)+A_0$<br>Rotate the content of register A right one bit.<br>Rotate the content of the carry flip-flop into $A_7$ .<br>Rotate $A_0$ into the carry flip-flop. | #### PROGRAM COUNTER AND STACK CONTROL INSTRUCTIONS ### JUMP INSTRUCTIONS — Three Bytes (three cycles - PCI/PCR/PCR) Normal flow of the microprogram may be altered by jumping to an address specified by bytes two and three of an instruction. | JMP<br>(Jump Unconditionally) | 01 | XXX<br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | 100 | $(P) \leftarrow \langle B_3 \rangle \langle B_2 \rangle$ Jump unconditionally to the instruction located in memory location addressed by byte two and byte three. | |--------------------------------------------|----|---------------------------------------------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <b>JFc</b><br>(Jump if Condition<br>False) | 01 | OC <sub>4</sub> C <sub>3</sub><br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | 000 | If (c) = 0, (P) $\leftarrow$ <b<sub>3&gt;<b<sub>2&gt;. Otherwise, (P) = (P)+3. If the content of flip-flop c is zero, then jump to the instruction located in memory location <b<sub>3&gt;<b<sub>2&gt;; otherwise, execute the next instruction in sequence.</b<sub></b<sub></b<sub></b<sub> | | JTc<br>(Jump if Condition<br>True) | 01 | 1C <sub>4</sub> C <sub>3</sub><br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | 000 | If (c) = 1, (P) $\leftarrow$ <b<sub>3&gt;<b<sub>2&gt;. Otherwise, (P) = (P)+3. If the content of flip-flop c is one, then jump to the instruction located in memory location <b<sub>3&gt;<b<sub>2&gt;; otherwise, execute the next instruction in sequence.</b<sub></b<sub></b<sub></b<sub> | ### CALL INSTRUCTIONS — Three Bytes (three cycles - PCI/PCR/PCR) Subroutines may be called and nested up to seven levels. | CAL<br>(Call subroutine<br>Unconditionally) | 01 XXX 110<br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | (Stack) $\leftarrow$ (P), (P) $\leftarrow$ <b<sub>3&gt; <b<sub>2&gt;. Shift the content of P to the pushdown stack. Jump unconditionally to the instruction located in memory location addressed by byte two and byte three.</b<sub></b<sub> | |------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CFc<br>(Call subroutine<br>if Condition False) | 01 OC <sub>4</sub> C <sub>3</sub> 010<br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | If (c) = 0, (Stack) $\leftarrow$ (P), (P) $\leftarrow$ <b<sub>3&gt;<b<sub>2&gt;. Otherwise, (P) = (P)+3. If the content of flip-flop c is zero, then shift contents of P to the pushdown stack and jump to the instruction located in memory location<b<sub>3&gt;<b<sub>2&gt;; otherwise, execute the next instruction in sequence.</b<sub></b<sub></b<sub></b<sub> | | (Call subroutine if Condition True) | 01 1C <sub>4</sub> C <sub>3</sub> 010<br><b<sub>2&gt;<br/><b<sub>3&gt;</b<sub></b<sub> | If (c) = 1, (Stack) $\leftarrow$ (P), (P) $\leftarrow$ <b<sub>3&gt;<b<sub>2&gt;. Otherwise, (P) = (P)+3. If the content of flip-flop c is one, then shift contents of P to the pushdown stack and jump to the instruction located in memory location<b<sub>3&gt;<b<sub>2&gt;; otherwise, execute the next instruction in sequence.</b<sub></b<sub></b<sub></b<sub> | In the above JUMP and CALL instructions < B $_2>$ contains the least significant half of the address and < B $_3>$ contains the most significant half of the address. Note that D $_6$ and D $_7$ of < B $_3>$ are "don't care" bits since the CPU uses fourteen bits of address. RETURN INSTRUCTIONS — One Byte (one cycle - PCI) A return instruction may be used to exit from a subroutine; the stack is popped-up one level at a time. **RET** 00 XXX 111 (P)→(Stack). Return to the instruction in the memory location addressed by the last value shifted into the pushdown stack. The stack pops up one level. RFc 00 0C<sub>4</sub>C<sub>3</sub> 011 (Return Condition False) If (c) = 0, (P) - (Stack); otherwise, (P) = (P)+1. If the content of flip-flop c is zero, then return to the instruction in the memory location addressed by the last value inserted in the pushdown stack. The stack pops up one level. Otherwise, execute the next instruction in sequence. RTc 00 1C<sub>4</sub>C<sub>3</sub> 011 (Return Condition True) If (c) = 1, (P)—(Stack); otherwise, (P) = (P)+1. If the content of flip-flop c is one, then return to the instruction in the memory location addressed by the last value inserted in the pushdown stack. The stack pops up one level. Otherwise, execute the next instruction in sequence. RESTART INSTRUCTION — One Byte (one cycle - PCI) The restart instruction acts as a one byte call on eight specified locations of page 0, the first 256 instruction words. **RST** 00 AAA 101 (Stack) + (P), (P) + (000000 00AAA000) Shift the contents of P to the pushdown stack. The content, AAA, of the instruction register is shifted into bits 3 through 5 of the P-counter. All other bits of the P-counter are set to zero. As a oneword "call", eight eight-byte subroutines may be accessed in the lower 64 words of memory. #### INPUT/OUTPUT INSTRUCTIONS One Byte (two cycles - PCI/PCC) Eight input devices may be referenced by the input instruction INP 01 00M MM1 (A)→(input data lines). The content of register A is made available to external equipment at state T1 of the PCC cycle. The content of the instruction register is made available to external equipment at state T2 of the PCC cycle. New data for the accumulator is loaded at T3 of the PCC cycle. MMM denotes input device number. The content of the condition flip-flops, S,Z,P,C, is output on D<sub>0</sub>, D<sub>1</sub>, D<sub>2</sub>, D<sub>3</sub> respectively at T4 on the PCC cycle. Twenty-four output devices may be referenced by the output instruction. OUT 01 RRM MM1 (Output data lines) ← (A). The content of register A is made available to external equipment at state T1 and the content of the instruction register is made available to external equipment at state T2 of the PCC cycle. RRMMM denotes output device number (RR ≠ 00). #### MACHINE INSTRUCTION HALT INSTRUCTION — One Byte (one cycle - PCI) HLT 00 000 00X or 11 111 111 On receipt of the Halt Instruction, the activity of the processor is immediately suspended in the STOPPED state. The content of all registers and memory is unchanged. The P-counter has been updated and the internal dynamic memories continue to be refreshed. #### APPENDIX II #### INTERNAL PROCESSOR OPERATION Internally the processor operates through five different states: The 8008 is driven by two non-overlapping clocks. Two clock periods are required for each state of the processor. A SYNC signal (divide by two of $\phi_2$ ) is sent out by the 8008. This signal distinguishes between the two clock periods of each state. The following timing diagram shows the typical activity during each state. Note that $\phi_1$ is generally used to precharge all data lines and memories and $\phi_2$ controls all data transfers within the processor. #### **Typical Function** Send out lower eight bits of address and increment program counter. Send out lower eight bits of address and surpress incrementing of program counter. Send out six higher order bits of address and two control bits, $D_6$ and $D_7$ . Increment program counter if there has been a carry from T1. Wait for READY signal to come true. Refresh internal dynamic memories while waiting. Fetch and decode instruction; fetch data from memory; output data to memory. Refresh internal memories. Remain stopped until INTERRUPT occurs. Refresh internal memories. Execute instruction and appropriately transfer data within processor. Content of data bus transfer is available at I/O bus for convenience in testing. Some cycles do not require these states. In those cases, the states are skipped and the processor goes directly to T1. Figure 19. Internal Timing Activity Within Any State INSTRUCTION CODING D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> $\mathsf{D} \ \mathsf{D} \ \mathsf{D}$ $D_7D_6$ 1 1 #### INDEX REGISTER INSTRUCTIONS $D_2 D_1 D_0$ #OF STATES TO EXECUTE INSTRUCTION (5) T1(2) (4) PCLOUT T2 PCHOUT **OPERATION** Lr<sub>1</sub>r<sub>2</sub> | 1 1 | | | | | (4) | | TO IR & REG. b | (6) | | |-----------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------|-------------------------|--------------------------------------------------|-------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------| | | DDD | 1 1 1 | LrM | (8) | PCLOUT | PCHOUT | FETCH INSTR. | Ī | | | | | | <u> </u> | | | | TO IR & REG. b | (7) | | | 1 1 | 1 1 1 | S S S | LMr | (7) | PCLOUT | PCHOUT | FETCH INSTR. | SSS TO REG. b | <del></del> | | 0 0 | - D D D | 1 1 0 | 11 | (0) | DO OUT | DO 0117 | TO IR & REG. b | | - | | 0 0 | DDD | 1 1 0 | LrI | (8) | PCLOUT | PCHOUT | FETCH INSTR. | | | | 0 0 | 1 1 1 | 1 1 0 | LMI | (9) | PCLOUT | PC. OUT | TO IR & REG. b | | | | 0 0 | | 1 1 0 | LIVII | (9) | PCLOOI | PCHOUT | FETCH INSTR. | | <del></del> | | 0 0 | D D D | 0 0 0 | INr | (5) | PC <sub>i</sub> OUT | PCHOUT | FETCH INSTR. | | ADD 00 ELACO | | 0 0 | 5 5 5 | 0 0 0 | 1107 | (5) | 1 10001 | FCHOO! | TO IR & REG. b | X | ADD OP - FLAGS | | 0 0 | D D D | 0 0 1 | DCr | (5) | PC <sub>I</sub> OUT | PCHOUT | FETCH INSTR. | × | SUB OP - FLAGS | | 0 0 | 000 | 00, | | (3) | , 6[001 | TOHOU! | TO IR & REG. b | _ ^ | AFFECTED | | A CCI I | MILL ATOR | CROURING | STRUCTIONS | | l | | 1 TO THE WILLIAM | 1 | AFFECTED | | | | | 7 | | | • | · | | | | 1 0 | PPP | SSS | ALU OP r | (5) | PCLOUT | PCHOUT | FETCH INSTR. | SSS TO REG. b | ALU OP - FLAGS | | | | | | | | | TO IR & REG. b | | AFFECTED | | 1 0 | PPP | 1 1 1 | ALU OP M | (8) | PCLOUT | PCHOUT | FETCH INSTR. | | | | | | | | | | | TO IR & REG. b | | | | 0 0 | PPP | 1 0 0 | ALU OP I | (8) | PCLOUT | PCHOUT | FETCH INSTR. | | <del></del> | | 0 0 | 0 0 0 | 0.1.0 | DI O | /=\ | - DO OUT | DO 0117 | TO IR & REG. b | | | | 0 0 | 0 0 0 | 0 1 0 | RLC | (5) | PCLOUT | PCHOUT | FETCH INSTR. | × | ROTATE REG. A | | 0 0 | 0 0 1 | 0 1 0 | RRC | (5) | PC; OUT | PCHOUT | TO IR & REG, b | x - | CARRY AFFECTED | | 5 0 | 0 0 1 | 0 1 0 | RAC | (5) | - | FCHOOL | TO IR & REG. b | _ ^ | ROTATE REG. A<br>CARRY AFFECTED | | û O | 0 1 0 | 0 1 0 | RAL | (5) | PCLOUT | PCHOUT | FETCH INSTR. | x | ROTATE REG. A | | J 0 | 0 1 0 | 0 1 0 | I IIAL | (5) | 1 '5[00' | , choo! | TO IR & REG. b | ^ | CARRY AFFECTED | | 0 0 | 0 1 1 | 0 1 0 | RAR | (5) | PCLOUT | PCHOUT | FETCH INSTR. | × | ROTATE REG. A | | 0 0 | 0 1 1 | 0 1 0 | 1.70 | (3) | 10001 | I CHOO! | TO IR & REG. b | ^ | CARRY AFFECTED | | DDOC | DAM COLIN | TED AND | TACK CONT | ROL INSTRUC | FLONG | | 1 10 111 4 112 6, 8 | | OAIIIII AITECTED | | | | | | | | T | | 1 | ···· | | 0 1 | <b>x,</b> × × | 1 0 0 | JMP | (11) | PCLOUT | PCHOUT | FETCH INSTR. | · | | | | | <del>.</del> | | | | | TO IR & REG. b | | | | 0 1 | υсс | 0 0 0 | JFc | (9 or 11) | PCLOUT | PCHOUT | FETCH INSTR. | | | | | | | | | | | TO IR & REG. b | | | | 0 1 | 1 C C | 0 0 0 | JTc | (9 or 11) | PCLOUT | PCHOUT | FETCH INSTR. | | <del>-</del> | | | | | | /// | DO 0117 | PO 0117 | TO IR & REG. b | | | | 0 1 | XXX | 1 1 0 | CAL | (11) | PCLOUT | PCHOUT | FETCH INSTR. | · | | | | | | 05 | (0 11) | DO OUT | DO OUT | TO IR & REG. b | | | | 0 1 | 0.00 | | CFc | (9 or 11) | PCLOUT | PCHOUT | FETCH INSTR.<br>TO IR & REG. b | | <del></del> | | 0 1 | 0 C C | 0 1 0 | | 1 | | | | | | | | | | CTo | (0 or 11) | PC. OUT | | EETCH INCTO | | | | | 0 C C | 0 1 0 | СТс | (9 or 11) | PCLOUT | PCHOUT | FETCH INSTR. | | <del></del> | | 0 1 | 1 C C | 0 1 0 | | | | ,, | TO IR & REG. b | POP STACK | | | 0 1 | | | CTc<br>RET | (9 or 11)<br>(5) | PCLOUT | PC <sub>H</sub> OUT<br>PC <sub>H</sub> OUT | TO IR & REG. b | POP STACK | X | | 0 1 | 1 C C | 0 1 0 | RET | (5) | PCLOUT | PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b | | | | | 1 C C | 0 1 0 | | | | ,, | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. | POP STACK POP STACK (13) | X | | 0 1 0 0 0 | 1 C C X X X 0 C C | 0 1 0 | RET<br>RFc | (5)<br>(3 or 5) | PCLOUT | PC <sub>H</sub> OUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b | POP STACK (13) | X | | 0 1 0 0 0 | 1 C C | 0 1 0 | RET | (5) | PCLOUT | PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. | | | | 0 1 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C | 0 1 0 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5) | PCLOUT PCLOUT | PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b | POP STACK (13) | x | | 0 1 0 0 0 0 0 0 | 1 C C X X X 0 C C | 0 1 0 | RET<br>RFc | (5)<br>(3 or 5) | PCLOUT | PC <sub>H</sub> OUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C | 0 1 0 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5) | PCLOUT PCLOUT | PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK | POP STACK (13) | x | | 0 1 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C | 0 1 0 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5) | PCLOUT PCLOUT | PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND | POP STACK (13) | X X REG. 6 TO PCL | | 0 1<br>0 0<br>0 0<br>0 0 | 1 C C X X X 0 C C 1 C C | 0 1 0 1 1 0 1 1 1 0 1 1 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5) | PCLOUT PCLOUT | PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C A A A | 0 1 0<br>1 1 1<br>0 1 1<br>0 1 1<br>1 0 1 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0→REG. a) | POP STACK (13) | X<br>X<br>REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C | 0 1 0 1 1 0 1 1 1 0 1 1 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5) | PCLOUT PCLOUT | PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO REG. b | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 C C X X X 0 C C 1 C C A A A | 0 1 0<br>1 1 1<br>0 1 1<br>0 1 1<br>1 0 1 | RET<br>RFc<br>RTc | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0 | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO REG. b | POP STACK (13) | X<br>X<br>REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 MACH | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 UCTIONS | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0→REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b | POP STACK (13) | X<br>X<br>REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0 1 | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0 1 | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 UCTIONS | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0→REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 MACH | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 UCTIONS | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 0 0 0 1 0 1 0 1 | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 UCTIONS | RET RFc RTc RST | (5)<br>(3 or 5)<br>(3 or 5)<br>(5) | PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0-REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b & HALT (18) FETCH INSTR. | POP STACK (13) | X X REG. 6 TO PCL | | 0 1 0 0 0 0 0 0 1/O IN 0 1 0 1 MACH | 1 C C X X X 0 C C 1 C C A A A STRUCTIO 0 0 M R R M INE INSTRI | 0 1 0 1 1 1 0 1 1 1 0 1 1 0 1 1 MS M M 1 M M 1 UCTIONS 0 0 X | RET RFc RTc RST INP OUT | (5)<br>(3 or 5)<br>(3 or 5)<br>(5)<br>(8)<br>(6) | PCLOUT PCLOUT PCLOUT PCLOUT PCLOUT PCLOUT | PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT PCHOUT | TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO REG. b AND PUSH STACK (0→REG. a) FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b FETCH INSTR. TO IR & REG. b | POP STACK (13) | X X REG. 6 TO PCL | - The first memory cycle is always a PCI (instruction) cycle. Internally, states are defined as T1 through T5. In some cases more than one memory cycle is required to execute an instruction. - 3. Content of the internal data bus at T4 and T5 is available at the data bus. This is designed for testing purposes only. - 4. Lower order address bits in the program counter are denoted by PCL and higher order bits are designated by PCH. - 5. During an instruction fetch the instruction comes from memory to the instruction register and is decoded, - 6. Temporary registers are used internally for arithmetic operations and data transfers (Register a and Register b.) MEMORY CYCLE ONE (1) T4(3) SSS TO REG. b **T5** REG. b TO DDD тз FETCH INSTR.(5) TO IR & REG. b - These states are skipped. - 8. PCR cycle (Memory Read Cycle). - 9: "X" denotes an idle state. - 10, PCW cycle (Memory Write Cycle). - 11. When the JUMP is conditional and the condition fails, states T4 and T5 are skipped and the state counter advances to the next memory cycle. | MEMORY CYCLE TWO | | | | | MEMORY CYCLE THREE | | | | | |-----------------------|------------------|-------------------------|---------------------|------------------------------|--------------------|---------------|-------------------------------------------|------------------------------|-------| | T1 | T2 | Т3 | T4 | Т5 | T1 | Т2 | Т3 | T4 | TE | | REG, L OUT | REG, H OUT | DATA TO | X | REG. b | | | | | | | (8)<br>REG. L OUT | | REG. b | (9) | TO DDD | | | | | | | (10) | REG. H OUT | REG, b<br>TO OUT | | | | | | | | | PCLOUT (8) | PCHOUT | DATA TO<br>REG. b | × | REG. b<br>TO DDD | | | | | | | PCLOUT (8) | PCHOUT | DATA TO<br>REG. b | - | > | REG, L<br>OUT(10) | REG. H<br>OUT | REG. b<br>TO OUT | | - | | | | | | | | | | | | | | | | | 1 | | | | | 1 | | REG. L OUT | REG. H OUT | DATA TO<br>REG. b | х | ALU OP - FLAGS<br>AFFECTED | | | | | - | | PCLOUT (8) | PCHOUT | DATA TO<br>REG. b | х | ARITH OP - FLAGS<br>AFFECTED | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PCLOUT (8) | PCHOUT | LOWER ADD. | | | PCLOUT(8) | PCHOUT | HIGHER ADD.<br>REG. a | REG. a<br>TO PCH | REG. | | PCLOUT (8) | PCHOUT | LOWER ADD.<br>TO REG. b | | <b></b> | PCLOUT(8) | PCHOUT | HIGHER ADD.<br>REG. a (11) | REG, a<br>TO PCH | REG. | | PCLOUT (8) | PCHOUT | LOWER ADD.<br>TO REG. b | | | PCLOUT(8) | PCHOUT | HIGHER ADD. | REG. a | REG. | | PCLOUT(8) | PCHOUT | LOWER ADD. | | | PCLOUT(8) | PCHOUT | REG.a (11)<br>HIGHER ADD. | TO PC <sub>H</sub> | TO PO | | PCLOUT(8) | PCHOUT | LOWER ADD. | | | PCLOUT(8) | PCHOUT | REG. a<br>HIGHER ADD. | TO PC <sub>H</sub><br>REG. a | TO PO | | PCLOUT(8) | PCHOUT | LOWER ADD.<br>TO REG. b | | <b></b> | PCLOUT(8) | PCHOUT | REG. a (12)<br>HIGHER ADD.<br>REG. a (12) | TO PCH<br>REG, a<br>TO PCH | TO PO | | | | | | | | | REG.a (12) | ТОРСН | 10 PC | | | | | | | | | | | | | | | | | | | · | | | | | | | | | | | | | | | | REG. A | REG, b | DATA TO | COND | BEC h | | | | | | | TO OUT (15) | TO OUT | REG. b | COND ff<br>OUT (16) | REG. b<br>TO REG. A | | | | | | | REG. A (15)<br>TO OUT | REG. b<br>TO OUT | X<br>(17) | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | + | | | | | | <sup>12.</sup> When the CALL is conditional and the condition fails, states $\underline{\ }$ 12. When the CALL is conditional and the condition fails, states T4 and T5 are skipped and the state counter advances to the next memory cycle. If the condition is true, the stack is pushed at T4, and the lower and higher order address bytes are loaded into the program counter. 13. When the RETURN condition is true, pop up the stack; otherwise, advance to next memory cycle skipping T4 and T5. 14. Bits D3 through D5 are loaded into PCL and all other bits are set to zero; zeros are loaded into PCH. PCC cycle (I/O Cycle). The content of the condition flip-flops is available at the data bus: S at D<sub>0</sub>, Z at D<sub>1</sub>, P at D<sub>2</sub>, C at D<sub>3</sub>. A READY command must be supplied for the OUT operation to be completed. An idle T3 state is used and then the state counter advances to the next memory cycle. 18. When a HALT command occurs, the CPU internally remains in the T3 state until an INTERRUPT is recognized. Externally, the STOPPED state is indicated. The figure below shows state transitions relative to the internal operation of the processor. As noted in the previous table, the processor skips unnecessary execution steps during any cycle. The state counter within the 8008 operates is a five bit feedback shift register with the feedback path controlled by the instruction being executed. When the processor is either waiting or stopped, it is internally cycling through the T3 state. This state is the only time in the cycle when the internal dynamic memories can be refreshed. Figure 20. Transition State Diagram (Internal) #### **APPENDIX III** #### PROGRAMMING EXAMPLES ## A. Sample Program to Search A String Of Characters In Memory Locations 200-219 For A Period (.) | MNEMONIC | OPERAND | EXPLANATION | <b>BYTES</b> | LOCATION | ROM CODE | COMMENT | |------------|---------|--------------------------------|--------------|----------|----------|---------| | Start: LLI | 200 | Load L with 200 | 2 | 100 | 00110110 | | | | | | | 101 | 11001000 | (200) | | LHI | 0 | Load H with 0 | 2 | 102 | 00101110 | | | | | | | 103 | 00000000 | (0) | | Loop: LAM | | Fetch Character from<br>Memory | 1 | 104 | 11000111 | ASC II | | CPI | "" | Compare it with period | 2 | 105 | 00111100 | ASC II | | | | | | 106 | 00101110 | (-) | | JTZ | Found | If equal go to return | 3 | 107 | 01101000 | | | | | | | 108 | 01110111 | (4.40) | | | | | | 109 | 00000000 | (119) | | CAL | INCR | Call increment H&L | 3 | 110 | 01000110 | | | | | subroutine | | 111 | 00111100 | (60) | | | | | | 112 | 00000000 | (00) | | LAL | | Load L to A | 1 | 113 | 11000110 | | | CPI | 220 | Compare it with 220 | 2 | 114 | 00111100 | | | | | | | 115 | 11011100 | (220) | | JFZ | Loop | If unequal go to loop | 3 | 116 | 01001000 | | | | | , , | | 117 | 01101000 | (104) | | | | | | 118 | 00000000 | (104) | | Found: RET | | Return | 1 | 119 | 00000111 | | | INCR: INL | | Increment L | 1 | 60 | 00110000 | | | RFZ | | Return if not zero | 1 | 61 | 00001011 | _ | | INH | | Increment H | 1 | 62 | 00101000 | | | RET | | Return | 1 | 63 | 00000111 | | Figure 21. Subroutine to Search For Period ## B. Teletype and Tape Reader Control Program (A0800) | BEGIN | LAI 1 | SUPPRESS TTY | |---------------|-----------|--------------------------------| | | OUT 15B | OUTPUT 2 | | | XRA | CLEAR AC | | | OUT 13B | OUTPUT 3 - TAPE READER CONTROL | | | CAL TAPE | CALL FOR TAPE READER CONT. RT. | | | SMP BECIN | | | TAPE | LAI 1 | TAPE READER ENABLE CODE | | | OUT 13B | OUTPUT 3 - ENABLE TAPE READER | | | CAL TTYD1 | TAPE READER CONTROL DELAY | | TTY | HLT | WAIT FOR TTY START PULSE | | | CAL TTYD2 | TTY DELAY - 4.468 MSEC. | | | XRA | TAPE READER DISABLE CODE | | | OUT 13B | OUTPUT 3. DISABLE TAPE READER | | | INP OB | INPUT O, READ START PULSE | | | LCI 255 | COMPLEMENT TTY START PULSE | | | XRC | EXCLUSIVE-OR REG. C | | | OUT 12B | OUTPUT 2. OUTPUT START PULSE | | | LEI 248 | TTY DATA SAMPLING COUNTER | | TTYIN | | TTY DELAY - 9.012 MSEC. | | * * * * * * * | INP OB | READ TTY DATA INPUT | | | LCI 255 | COMPLEMENT TTY DATA | | | XRC | COMPLEMENT III DAIH | | | OUT 12B | AUTRUM A TAY DAMA AUT | | | | OUTPUT 2. TTY DATA OUT | | | RAR | STORE TTY DATA | | | LAB | LOAD TTY DATA TO REC. B | | | RAR | | | | LBA | LOAD AC TO REG. B | | | INE | E = E + 1 | | | JFZ TTYIN | JUMP IF ZERO F/F IS NOT SET | | | LAB | LOAD REG. B TO AC | | | OUT 11B | OUTPUT 1. TTY CHARACTER | | | SUI 128 | REMOVE PARITY BIT | | | LBA | STORE TTY INPUT DATA | | | CAL TTYDI | | | | LAI 1 | | | | OUT 12B | SUPPRESS TTY | | | RET | | | TTYD1 | LDI 115 | 9.012 MSEC. DELAY | | ST | IND | D = D + 1 | | | JFZ ST | | | | RET | | | TTYD2 | LDI 186 | 4.468 MSEC. DELAY | | | • | TO TO CONTRACT OF WARRING | | ST2 | IND | D = D + 1 | | | JFZ ST2 | | | | RET | | | | END | | | | | | ## C. Memory Chip Select Decodes and Output Test Program (A0801) ``` BEGIN LAI 15 LOAD 15 TO AC OUT 10B WRITE TO OUTPUT O OUT 11B OUT 12B OUT 13B OUT 14B OUT 15B OUT 16B OUT 17B CAL DELAY DELAY 16.436 MSEC. CAL DELAY CAL DELAY CAL DELAY XRA CLEAR AC OUT 10B OUT 11B OUT 12B OUT 13B OUT 14B OUT 15B OUT 16B OUT 17B LCI 240 LOAD 240 TO REG. C LLI 252B LOAD 252B(OCTAL) TO REC. C LHI 0 LOAD O TO REC. H CSTEST LAH LOAD H TO AC OUT 10B LAL LOAD L TO AC OUT 11B XRA CLEAR AC LMA WRITE AC TO MEMORY CAL DELAY CAL DELAY INH H = H + 1 INC C = C + 1 JFZ CSTEST JMP BEGIN DELAY LDI O LOAD O TO REC. D D1 IND D = D + 1 JFZ D1 RET END ``` #### D. RAM Test Program (A0802) ``` BECIN LAI O LOAD O TO AC OUT 10B WRITE TO OUTPUT O OUT 11B WRITE TO OUTPUT 1 WRITE TO OUTPUT 2 WRITE TO OUTPUT 3 OUT 12B OUT 13B LBI 8 LOAD 8 TO REC. B LOAD O TO REC. C LOAD 8 TO REG H LCI O LHI 8 LOAD O TO REC. L LLI 0 LM1 XRA CLEAR AC LM2 LOAD AC TO MEMORY LMA INL L = L + 1 AC - L CPL JFZ LM2 JUMP IF AC IS NOT ZERO INH H = H + 1 LAI 12 LOAD 12 TO AC CPH AC-H JUMP IF AC IS NOT ZERO JFZ LM1 LHI 8 REPT4 LAB LOAD REC. B TO AC OUT 10B LOAD REC. C TO L REPT3 LLC LOAD REC. C TO AC LAC OUT 13B LAI 255 LOAD 255 TO AC LOAD AC TO MEMORY LMA CPM AC-M JFZ ERROR JUMP IF AC IS NOT ZERO LOAD REC. H TO AC REPT2 LAH OUT 10B REPT5 XRA CLEAR AC INL L = L + 1 AC - L CPL JUMP IF AC=0 JTZ REPT1 LAL LOAD REC. L TO AC OUT 11B CLEAR AC XRA CPM AC-M JFZ ERROR JUMP IF AC IS NOT ZERO JMP REPTS REPT1 INH H = H + 1 LAI 12 CPH JTZ CONT XRA CPM JFZ ERROR JMP REPT2 CONT LHB LOAD REC. P TO H XRA INC C = C + 1 CPC AC - C JFZ REPT3 INB B = B + 1 LHB LOAD REG. P TO H LAI 12 CPB AC-B JFZ REPT4 JMP BECIN ERROR LAI 240 LOAD 240 TO AC ADB AC=AC+B OUT 10B LAL LOAD REC. L TO AC OUT 118 LOAD MEMORY TO AC LAM OUT 12B LAC LOAD REG. C TO AC OUT 13B HLT END ``` ## APPENDIX IV INTEL DEVICE SPECIFICATIONS #### A. 1101A/1101A1 256-Bit Fully-Decoded Random Access Memory - Access time below 750 ns typically, 1.0 $\mu$ sec maximum 1101A1; 1.5 $\mu$ sec maximum 1101A: over temperature - Low power dissipation—typically less than 1.5 mW/bit during access - Low power standby mode - Directly DTL and TTL compatible - OR-Tie capability - Simple memory expansion—chip-select input lead - Fully decoded—on-chip address decode and sense - Inputs protected against static charge - Ceramic and plastic package - Silicon gate MOS technology The Intel 1101A Series are 256 word by 1 bit random access memory elements using normally off P-channel MOS devices integrated on a monolithic array. Each unit uses fully dc stable (static) circuitry and therefore requires no clocks to operate. The 1101A, an improved version of the 1101, requires only two power supplies (+5V and -9V) for operation, and is a direct pin-for-pin replacement for the 1101. The 1101A Series is designed primarily for small buffer storage applications where high performance, low cost, and ease of interfacing with other standard logic circuits are important design objectives. The unit will directly interface with standard bipolar integrated logic circuits (TTL, DTL, etc.). The data output buffers are capable of driving TTL loads directly. A separate chip select (CS) lead allows easy selection of an individual package when outputs are OR-tied. For applications requiring a faster access time we recommend the 1101A1 which is a selection from the 1101A and has a guaranteed maximum access time of 1.0 usec. Applications. Scratch pad memories, buffer storage, data terminals, minicomputers, calculators, data multiplexers, automatic test equipment, sequential memories, table look up, program memories, buffers for line printers, card readers and pulse height analyzers. #### D.C. Characteristics ( T<sub>A</sub> = 0 °C to +70 °C. V<sub>CC</sub> = +5V $\pm$ 5%, V<sub>0</sub> = -9V $\pm$ 5%, V<sub>0D</sub> = -9V $\pm$ 5% unless otherwise specified) | Test | Min. | Typ. | Max. | Unit | |--------------------------------------------------|------------|------|-----------------------|------| | Input load current (All Input Pins) | | 1.0 | 500 | nΑ | | Power supply current, V <sub>00</sub> @ 25°C | | 13 | 19 | mΑ | | Power supply current, V <sub>0</sub> @ 25°C | | | 18 | mΑ | | Input ''low'' voltage | -10 | | $V_{cc} - 4.5$ | ٧ | | Input "high" voltage | $V_{cc}-2$ | | V <sub>cc</sub> + 0.3 | ٧ | | Output "low" voltage ( $I_{0L} = 2 \text{ mA}$ ) | | | +.45 | V | | Output ''high'' voltage | +3.5 | | | ٧ | #### A.C. Characteristics ( $T_A = 0$ to $70\,^{\circ}$ C, $V_{CC} = +5V \pm 5\%$ , $V_D = -9V \pm 5\%$ , $V_{DD} = -9 \pm 5\%$ ) Test Min. Typ. Max Unit Write cycle (twc) usec Read cycle access time 1101A usec $(t_A)$ 1101A1 1.0 usec Access Time Through 0.3 µsес Chip Select Input (t CS) #### Timing diagram #### B. 1601/1701, 1602/1702 Electrically Programmable ROMs The Intel 1601, 1602, 1701, and 1702 is a 256 word by 8 bit electrically programmable ROM ideally suited for uses where fast turnaround and pattern experimentation are important such as in prototype or in one of a kind systems. The 1601, 1602, 1701, and 1702 is factory reprogrammable which allows Intel to perform a complete programming and functional test on each bit position before delivery. The four devices 1601, 1602, 1701, and 1702 use identical chips. The 1601 and 1701 is operable in both the static and dynamic mode while the 1602 and 1702 is operable in the static mode only. Also, the 1701 and 1702 has the unique feature of being completely erasable and field reprogrammable. This is accomplished by a quartz lid that allows high intensity ultraviolet light to erase the 1701 and 1702. A new pattern can then be written into the device. This procedure can be repeated as many times as required. The 1301 is a direct replacement part which is programmed by a metal mask and is ideal for large volume and lower cost production runs of systems initially using the 1601/1701 or the static only 1602/1702. The dynamic mode of the 1601/1701 and 1301 refers to the decoding circuitry and not to the memory cell. Dynamic operation offers higher speed and lower power dissipation than the static operation. The 1601, 1602, 1701, and 1702 is fabricated with silicon gate technology. This low threshold technology allows the design and production of higher performance MOS circuits and provides a higher functional density on a monolithic chip than conventional MOS technologies. #### D.C. Characteristics for static operation | Test | Min. | Max. | Unit | |--------------------------------------------------------|---------------------|----------------------|----------------| | Standby power supply current @ 25°C | | 10 | μΑ | | Power supply current @ 25°C under continuous operation | | 46 | mA | | Input load current | | 1 | $\mu$ <b>A</b> | | Input "high" voltage | V <sub>cc</sub> -2 | V <sub>CC</sub> +.3 | ٧ | | Input ''low'' voltage | V <sub>CC</sub> -10 | V <sub>cc</sub> -4.2 | ٧ | | Output ''low'' voltage @ $I_{0L} = 1.6 \text{ mA}$ | • | 0.45 | V | | Output "high" voltage @ $I_{0H} = -100 \mu\text{A}$ | 3.5 | | ٧ | #### A.C. Characteristics for static operation | Repetition Rate | 1601/<br>1602/ | 1: | | | | |-------------------------|----------------|------|------|------|------| | Test | Тур. | Max. | Тур. | Max. | Unit | | Repetition Rate | | 1 | | 1 | MHz | | Address to output delay | .700 | 1 | .550 | 1 | μs | (T<sub>A</sub> = 0°C to 70°C, $V_{CC}$ = +5V $\pm 5\%$ , $V_{DD}$ = -9V $\pm 5\%$ , $V_{GG}$ = -9V #### **Switching Characteristics for Static Operation** Conditions of: Input pulse amplitudes: 0 to 4V Output load is 1 TTL gate #### Normal Operation (constant V<sub>GG</sub>) #### D.C. Characteristics for dynamic operation ( $T_A=0^\circ C$ to $70^\circ C$ . $V_{CC}=V_{BG}=+5V~\pm5\%,~V_{DO}=-9V~\pm5\%,$ unless otherwise noted) | Test | | | Max. | Unit | |--------------------------------------------------------------------------------|--------------------|----|------|------| | Unselected average power supply current at $25^{\circ}$ C ( $\phi$ = CS = +5V) | | 5 | 10 | mA | | Average power supply | <b>∫ 1601/1701</b> | 30 | 45 | mA | | current @ $T_A = 25^{\circ}C$ | 1301 | 28 | 40 | mA | #### A.C. Characteristics for dynamic operation ( $T_A = 0^{\circ}\text{C}$ to $70^{\circ}\text{C}$ , $V_{\text{CC}} = +5\text{V} \pm 5\%$ , $V_{\text{DD}} = -9\text{V} \pm 5\%$ , unless otherwise noted) 1601/1701 1301 | • | 10 | U 1/ I / | UI | | | | | |--------------------------|-------|----------|------|------|------|------|---------| | Test | Min. | Тур. | Max. | Min. | Тур. | Max. | Unit | | Ø1 Clock pulse width | 0.260 | | 2 | .260 | | 2 | $\mu$ s | | 02 Clock pulse width | 0.140 | | 2 | .140 | | 2 | μs | | 02 delay from 01 | 0.150 | | 2 | .150 | | 2 | jis | | Ø1 delay from Ø2 | .05 | | 2 | .05 | | 2 | μs | | Address to output access | | 450 | 650 | | 450 | 650 | ns | #### Switching Characteristics for Dynamic Operation Condition of test: Input pulse amplitude: 0 to 4V Input rise and fall times ≤ 50 nsec Output load is 1 TTL gate; measurements made at output of TTL gate (tpd ≤ 15 nsec) ## C. 3205 High-Speed 1-Out-Of-8 Binary Decoder - Easy memory expansion 3 enable inputs - Fast 18 nsec max. delay - TTL/DTL compatible - Low input load currents 0.25 mA max. - High fan out 10 mA min. sink current - 16 pin ceramic or plastic package The 3205 is a high-speed 1-of-8 binary decoder designed for use with fast bipolar memory components such as the Intel 3101A and 3102. **Applications.** General purpose highspeed 1-of-8 decode, bipolar memory expansion, chip-select decoder. #### A.C. Characteristics ( $T_A = 0$ °C to 75°C, $V_{CC} = 5.00 \pm 5\%$ ) | Test | Max. | | |-----------------------------------|----------------|--| | Address or enable to output delay | 18 nsec | | | Input capacitance | 4 pF (typical) | | #### D.C. Characteristics ( $T_A = 0^{\circ} C$ to $75^{\circ} C$ , $V_{CC} = 5.0 V \pm 5\%$ ) | mA | |---------| | | | $\mu$ A | | ٧ | | ٧ | | V | | V | | mA | | | #### **Timing diagram** Condition of test: Input pulse amplitudes: 2.5V Input rise and fall times: 5 nsec between 1V and 2V Measurements are made at 1.5V #### D. 3404 High-Speed 6-Bit Latch - Memory register applications - High speed 12 nsec max. input to output delay - Easy to use—independent 4-bit and 2-bit latches - High fan out—10 mA min. output sink current - High fan in 0.25 mA max. input load current - TTL/DTL compatible - Standard 16-pin DIP The 3404 is a high-speed 6-bit latch built using Schottky bipolar technology. The circuitry consists of a 4-bit latch and an independent 2-bit latch on the same chip. The latches may be used as very high-speed inverters by applying a continuous "low" at the "write" inputs. **Applications.** Memory data register, address register, inverter, high fan out buffers, "pipelined" processors. #### A.C. Characteristics $(T_A = 0 \text{ to } 75^{\circ}\text{C}, V_{cc} = 5.0\text{V} \pm 5\%)$ | Test | Min. | Max. | Unit | |--------------------------------|------|------|-------| | Data to output delay | | 12 | nsec. | | Write enable to output delay | | 17 | nsec. | | Write enable pulse width (twp) | 15 | | | #### D.C. Characteristics ( $T_A = 0^{\circ} \text{C to } 75^{\circ} \text{C}, \ V_{\text{CC}} = 5.0 \text{V} \pm 5\%$ ) | Test | Min. | Max. | Unit | |---------------------------------------------------|------|-------|------| | Data input load current | | -0.25 | mA | | Input leakage current | - | 10 | μΑ | | Output "low" voltage ( $I_{0L} = 10 \text{ mA}$ ) | | 0.45 | ٧ | | Output "high" voltage | 2.4 | | ٧ | ## **Ordering Information** The 8008 CPU is available in ceramic only and should be ordered as C8008 or C8008-1. #### (2) SIM8-01 Prototyping System This MCS-8 system for program development provides complete interface between the CPU and ROMs and RAMs. 1702 electrically programmable and erasable ROMs may be used for the program development. Each board contains one 8008 CPU, 1K x 8 RAM, and sockets for up to eight 1702's (2K x 8 PROM). This system should be ordered as SIM8-01 (the number of PROMs should also be specified). #### (3) Memory Expansion Additional memory for the 8008 may be developed from individual memory components. Specify RAM 1101 ROM 1702 SR 1404 1103 1301 2401 2102 #### (4) MP7-03 ROM Programmer This is the programmer board for 1702 or 1702A. The 1702 control ROMs used with the SIM8-01 for an automatic programming system are specified by pattern numbers A0860, A0861, A0862. Pattern A0863 should also be specified for programming the 1702A. #### (5) MCB8-10 System Interface and Control Module The MCB8-10 is a complete chassis which provides the interconnection between the SIM8-01 and MP7-03. In addition, the MCB8-10 provides the 50 Vrms power supply for PROM programming, complete output display, and single step control capability for program development. #### (6) Bootstrap Loader The same control ROM set used with the PROM programming system is used for the bootstrap loading of programs into RAM and execution of programs from RAM. Specify 1702 PROMs programmed to tapes A0860, A0861, A0862. #### (7) MCS-8 Fortran Assembler and Fortran Simulator This software program converts a list of instruction mnemonics into machine instructions and simulates the execution of instructions by the 8008. This program is written in Fortran IV and is available via time-sharing service or directly from Intel. Contact Intel for all the details. #### (8) SIM8 Hardware Assembler Eight PROMs containing the assembly program plug into the SIM8-01 prototyping board permitting assembly of all MCS-8 software. To order, specify A0840 through A0847. The complete hardware assembler description and users' guide is available on request. ## **Packaging Information** #### U. S. REGIONAL SALES OFFICES Western Tustin, California 92680 17401 Irving Blvd., Suite K (714) 838-1126, TWX 910-595-1114 Central Bloomington, Minnesota 55437 800 Southgate Office Plaza, 500 West 78th St. (612) 835-6722 Lexington, Mass. 02173 594 Marrett Road, Suite 27 (617) 861-1136, Telex: 923493 #### **ORIENT SALES OFFICE** Eastern Japan Tokyo 160 INTEL JAPAN CORP. Belgium Bruxelles Telex: 28426 Han-Ei 2nd Bldg. 216 Avenue Louise 1-1, Shinjuku, Bruxelles 1050, Belgium Shinjuku-Ku Phone: 492003 Tokyo 160, Japan Telex: 21060 03-354-8251 **EUROPEAN SALES OFFICE** INTEL CORP. #### MCS-8 INSTRUCTION SET #### Index Register Instructions The load instructions do not affect the flag flip-flops. The increment and decrement instructions affect all flip-flops except the carry. | MINIMUM | | | 10 | ISTR | UC | TION | CO | DΕ | | DESCRIPTION OF OPERATION | |--------------------------|-----|------------------|----|------|------|----------------|-----------------------------|--------------------------------------|---|---------------------------------------------------------------| | MNEMONIC STATES REQUIRED | D, | 7 <sup>D</sup> 6 | Dį | 5 D. | 4 D3 | D <sub>2</sub> | <sub>2</sub> D <sub>1</sub> | D <sub>O</sub> | | | | (1) Lr 1r2 | (5) | 1 | 1 | D | D | D | s | s | s | Load index register r1 with the content of index register r2. | | (2) LrM | (8) | 1 | 1 | D | D | D | 1 | 1 | 1 | Load index register r with the content of memory register M. | | LMr | (7) | 1 | 1 | 1 | 1 | 1 | S | s | s | Load memory register M with the content of index register r. | | (3) Lrl | (8) | 0 | 0 | D | D | D | 1 1 0 | Load index register r with data B B. | | | | | | В | В | В | В | В | В | B B B | | | | LMI | (9) | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Load memory register M with data B B. | | | | В | В | В | В | В | В | В | В | Load Michioly register in with data b b. | | INr | (5) | 0 | 0 | D | D | D | 0 | 0 | 0 | Increment the content of index register r (r # A), | | DCr | (5) | 0 | 0 | D | D | D | 0 | 0 | 1 | Decrement the content of index register r (r # A). | #### Accumulator Group Instructions The result of the ALU instructions affect all of the flag flip-flops. The rotate instructions affect only the carry flip-flop. | AÐr | (5) | 1 0 | 0 0 0 | SSS | Add the content of index register r, memory register M, or data | |-----|-----|-----|--------------|-------|----------------------------------------------------------------------| | ADM | (8) | 1 0 | 0 0 0 | 1 1 1 | B B to the accumulator. An overflow (carry) sets the carry | | ADI | (8) | 0 0 | 0 0 0 | 1 0 0 | flip-flop. | | | | B B | B B B | 8 B B | | | ACr | (5) | 1 0 | 0 0 1 | SSS | Add the content of index register r, memory register M, or data | | ACM | (8) | 1 0 | 0 0 1 | 1 1 1 | B B from the accumulator with carry. An overflow (carry) | | ACI | (8) | 0 0 | 0 0 1 | 1 0 0 | sets the carry flip-flop. | | | | B B | 8 8 B | ввв | | | SUr | (5) | 1 0 | 0 1 0 | s s s | Subtract the content of index register r, memory register M, or | | SUM | (8) | 1 0 | 0 1 0 | 1 1 1 | data B , , , B from the accumulator, An underflow (borrow) | | SUI | (8) | 0 0 | 0 1 0 | 1 0 0 | sets the carry flip-flop. | | | | ВВ | 8 B B | ввв | | | SBr | (5) | 1 0 | 0 1 1 | SSS | Subtract the content of index register r, memory register M, or data | | SBM | (8) | 1 0 | 0 1 1 | 1 1 1 | data B B from the accumulator with borrow. An underflow | | SBI | (8) | 0 0 | 0 1 1 | 1 0 0 | (borrow) sets the carry flip-flop, | | | İ | вв | 888 | ввв | | | NDr | (5) | 1 0 | 1 0 0 | s s s | Compute the logical AND of the content of index register r, | | NDM | (8) | 1 0 | 1 0 0 | 1 1 1 | memory register M, or data B B with the accumulator. | | NDI | (8) | 0 0 | 1 0 0 | 1 0 0 | , , , , , , , , , , , , , , , , , , , , | | | l | вв | B B B | ввв | | | XRr | (5) | 1 0 | 1 0 1 | s s s | Compute the EXCLUSIVE OR of the content of index register | | XRM | (8) | 1 0 | 1 0 1 | 1 1 1 | r, memory register M, or data B B with the accumulator, | | XRI | (8) | 0 0 | 1 0 1 | 1 0 0 | | | | | ВВ | B <b>B</b> B | B B B | | | ORr | (5) | 1 0 | 1 1 0 | s s s | Compute the INCLUSIVE OR of the content of index register | | ORM | (8) | 1 0 | 1 1 0 | 1 1 1 | r, memory register in, or data B B with the accumulator . | | ORI | (8) | 0 0 | 1 1 0 | 1 0 0 | , , , , , , , , , , , , , , , , , , , , | | | | вв | ввв | ввв | | | CPr | (5) | 1 0 | 1 1 1 | SSS | Compare the content of index register r, memory register M. | | CPM | (8) | 1 0 | 1 1 1 | 1 1 1 | or data B B with the accumulator. The content of the | | CPI | (8) | 0 0 | 1 1 1 | 1 0 0 | accumulator is unchanged, | | | | вв | ввв | ввв | - | | RLC | (5) | 0 0 | 0 0 0 | 0 1 0 | Rotate the content of the accumulator left, | | RRC | (5) | 0 0 | 0 0 1 | 0 1 0 | Rotate the content of the accumulator right. | | RAL | (5) | 0 0 | 0 1 0 | 0 1 0 | Rotate the content of the accumulator left through the carry. | | BAR | (5) | 0.0 | 0 1 1 | 0 1 0 | Rotate the content of the accumulator right through the carry. | #### Program Counter and Stack Control Instructions | (4) JMP | (11) | 0 1 | x x x | 1 0 0 | Unconditionally jump to memory address B <sub>3</sub> B <sub>3</sub> B <sub>2</sub> B <sub>2</sub> . | |--------------------|-----------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | B <sub>2</sub> B <sub>2</sub><br>X X | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | | | (5) <sub>JFc</sub> | (9 or 11) | 0 1<br>B <sub>2</sub> B <sub>2</sub><br>X X | 0 C <sub>4</sub> C <sub>3</sub><br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | 0 0 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | | | JTc | (9 or 11) | 0 1<br>B <sub>2</sub> B <sub>2</sub><br>X X | 1 C <sub>4</sub> C <sub>3</sub><br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | 0 0 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | | | CAL | (11) | 0 1<br>B <sub>2</sub> B <sub>2</sub><br>X X | X X X<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | 1 1 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | Unconditionally call the subroutine at memory address B <sub>3</sub> B <sub>3</sub> B <sub>2</sub> B <sub>2</sub> . Save the current address (up one level in the stack). | | CFc | (9 or 11) | 0 1<br>B <sub>2</sub> B <sub>2</sub><br>X X | 0 C <sub>4</sub> C <sub>3</sub><br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | 0 1 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | Call the subroutine at memory address B <sub>3</sub> B <sub>3</sub> B <sub>2</sub> B <sub>2</sub> if the condition flip-flop c is false, and save the current address (up one level in the stack.) Otherwise, execute the next instruction in sequence. | | CTc | (9 or 11) | 0 1<br>B <sub>2</sub> B <sub>2</sub><br>X X | 1 C <sub>4</sub> C <sub>3</sub><br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | 0 1 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub><br>B <sub>3</sub> B <sub>3</sub> B <sub>3</sub> | Call the subroutine at memory address $B_3 \ldots B_3 B_2 \ldots B_2$ if the condition flip-flop c is true, and save the current address (up one level in the stack). Otherwise, execute the next instruction in sequence. | | RET | (5) | 0 0 | xxx | 1 1 1 | Unconditionally return (down one level in the stack). | | RFc | (3 or 5) | 0 0 | 0 C <sub>4</sub> C <sub>3</sub> | 0 1 1 | Return (down one level in the stack) if the condition flip-flop c is false. Otherwise, execute the next instruction in sequence, | | RTc | (3 or 5) | 0 0 | 1 C4 C3 | 0 1 1 | Return (down one level in the stack) if the condition flip-flop c is true. Otherwise, execute the next instruction in sequence. | | RST | (5) | 0 0 | AAA | 1 0 1 | Call the subroutine at memory address AAA000 (up one level in the stack | #### Input/Output Instructions | INP | (8) | 0 1 | 0 0 M | M M 1 | Read the content of the selected input port (MMM) into the accumulator. | |-----|-----|-----|-------|-------|--------------------------------------------------------------------------------------| | OUT | (6) | 0 1 | RRM | M M 1 | Write the content of the accumulator into the selected output port (RRMMM, RR # 00). | #### Machine Instruction | HLT | (4) | 0 0 | 0 0 0 | 0 0 X | Enter the STOPPED state and remain there until interrupted, | |-------|-----|-----|-------|-------|-------------------------------------------------------------| | HLT | (4) | 1 1 | 1 1 1 | 1 1 1 | Enter the STOPPED state and remain there until interrupted, | | NOTES | | | | | <del></del> | - These registers, r<sub>1</sub>, are designated A(accumulator 000), DDD = Destination Index Register (8(001), C(010), D(011), E(100), H(101), L(110). (2) Memory registers are addressed by the contents of registers H & L. (3) Additional bytes of instruction are designated by BBBBBBB. (4) X = "Don't Care". (5) Flag flip-flops are defined by C<sub>4</sub>C<sub>3</sub>: carry (00-overflow or underflow), zero (01-result is zero), sign (10-MSB of result is "1"), parity (11-parity is even).