# 8008/8008-1 8-BIT MICROPROCESSOR - Instruction Cycle Time 1.25 μs with 8008-1 or 20 μs with 8008 - Directly Addresses 16K × 8 Bits of Memory (RAM, ROM, or S.R.) - Interrupt Capability - 48 Instructions, Data Oriented - Address Stack Contains 8 14-Bit Registers (Including Program Counter) Which Permit Nesting of Subroutines Up to 7 Levels The Intel® 8008 is a single chip MOS 8-bit parallel central processor unit (CPU) for the MCS-8 microcomputer system. This CPU contains 6 8-bit data registers, an 8-bit accumulator, 2 8-bit temporary registers, 4 flag bits (carry, zero, sign, parity), 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 7 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 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. ### PIN DESCRIPTION Figure 1. Pin Configuration ## $D_0-D_7$ BI-DIRECTIONAL DATA BUS. All address and data communication between the processor and the program memory, data memory, and I/O devices occurs on these 8 lines. Cycle control information is also available. ### INT INTERRUPT input. A logic "1" level at this input causes the processor to enter the INTERRUPT mode. ### **READY** READY input. This command line is used to synchronize the 8008 to the memory cycle allowing any speed memory to be used. #### **SYNC** SYNC output. Synchronization signal generated by the processor. It indicates the beginning of a machine cycle. $\phi_1, \phi_2$ Two phase clock inputs. $S_0, S_1, S_2$ MACHINE STATE OUTPUTS. 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. Vcc +5V ±5% VDD -9V ±5% ### **INSTRUCTION SET** #### **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. For the MCS-8<sup>TM</sup> 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 | 1 | IN | ISTR | UC | TION | CO | DE | | | | | | |----------------|--------------------|---|------------------|------|------|------|----|-----|------------------|---------------------------------------------------------------|--|--|--| | MNEMONIC | STATES<br>REQUIRED | D | 7 <sup>D</sup> 6 | Dį | 5 D. | ¹ D3 | D; | 2 D | 1 <sup>D</sup> 0 | DESCRIPTION OF OPERATION | | | | | (1) MOV r1. r2 | (5) | 1 | 1 | D | D | D | s | S | S | Load index register r1 with the content of index register r2. | | | | | (2) MOV r. M | (8) | 1 | 1 | D | D | D | 1 | 1 | 1 | Load index register i with the content of memory register M. | | | | | MOV M, r | (7) | 1 | 1 | 1 | 1 | 1 | S | S | S | Load memory register M with the content of index register r. | | | | | (3) MVI. | (8) | 0 | 0 | D | D | D | 1 | 1 | 0 | Load index register r with data B B. | | | | | | | 8 | В | В | В | В | 8 | В | В | | | | | | MVIM | (9) | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Load memory register M with data B B. | | | | | | | В | В | В | В | В | 8 | В | В | | | | | | 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. | | | В | В | В | В | _в_ | . 8 | _ | В | В | <u> </u> | |-------|-----|-----|---|---|----|-----|-----|-----|----|----|----------------------------------------------------------------------| | SBI | (8) | 1 - | 0 | 0 | | 1 | | | | 0 | (borrow) sets the carry flip-flop. | | SBB M | (8) | 1 | 0 | 0 | 1 | 1 | | | | | data B B from the accumulator with borrow. An underflow | | SB6 r | (5) | ] 1 | 0 | 0 | _1 | 1 | S | : | S | S | Subtract the content of index register r, memory register M, or data | | | | В | В | В | В | В | . 8 | . 1 | В | В | | | SUI | (8) | 0 | 0 | 0 | 1 | 0 | 1 | - 1 | 0 | 0 | sets the carry flip-flop. | | SUB M | (8) | 1 | 0 | 0 | 1 | 0 | 1 | | 1 | 1 | data B B from the accumulator. An underflow (borrow) | | SUB r | (5) | 1 | 0 | 0 | 1 | 0 | S | : | S | S | Subtract the content of index register r, memory register M, or | | | | В | В | В | В | В | В | | В | В | | | ACI | (8) | 0 | 0 | 0 | 0 | 1 | 1 | ( | 0 | 0 | sets the carry flip-flop. | | ADC M | (8) | 1 | 0 | 0 | 0 | 1 | 1 | | 1 | 1 | BB from the accumulator with carry. An overflow (carry) | | ADC r | (5) | 1 | 0 | 0 | 0 | 1 | S | _ : | s | S | Add the content of index register r, memory register M, or data | | | | В | В | В | В | В | 8 | | В | В | | | ADI | (8) | 0 | 0 | 0 | 0 | 0 | 1 | ( | 0 | 0 | flip-flop. | | ADD M | (8) | 1 | 0 | 0 | 0 | 0 | | | _ | _ | B B to the accumulator. An overflow (carry) sets the carry | | ADD r | (5) | 1 | 0 | 0 | 0 | 0 | s | - 5 | S_ | \$ | Add the content of index register r, memory register M, or data | | | MINIMUM | IN. | ISTRUCTION | CODE | | |----------|--------------------|------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------| | MNEMONIC | STATES<br>REQUIRED | 0,06 | 05 04 03 | 02 01 00 | DESCRIPTION OF OPERATION | | ANA + | (5) | 1 0 | 1 0 0 | S S S | Compute the logical AND of the content of index register r. | | ANA M | (8) | 1 0 | 1 0 0 | 1 1 1 | memory register M, or data B B with the accumulator. | | ANI | (8) | 0 0<br>B B | 1 0 0<br>8 8 8 | 1 0 0<br>B B B | | | XRAr | (5) | 1 0 | 1 0 1 | S S S | Compute the EXCLUSIVE OR of the content of index register | | XRAM | (8) | 1 0 | 1 0 1 | 1 1 1 | r, memory register M, or data B B with the accumulator. | | XRI | (8) | 0 0<br>B B | 1 0 1<br>B B B | 1 0 0<br>8 8 8 | , a sace a series and a | | ORAr | (5) | 1 0 | 1 1 0 | SSS | Compute the INCLUSIVE OR of the content of index register | | ORA M | (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 | | | CMP r | (5) | 1 0 | 1 1 1 | S S S | Compare the content of index register r, memory register M, | | CMP M | (8) | 1 0 | 1 1 1 | 1 1 1 | or data B B with the accumulator. The content of the | | CPI | (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 | x x x | 1 0 0 | Unconditionally jump to memory address B3 B3B2 B2. | |-----------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | В <sub>2</sub> В <sub>2</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> | | | | (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> | 0 0 0<br>B <sub>2</sub> B <sub>2</sub> B <sub>2</sub> | Jump to memory address B 3 B 3B 2 B 2 if the condition flip-flop is false. Otherwise, execute the next instruction in sequence. | | (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> | Jump to memory address $B_3 \dots B_3 B_2 \dots B_2$ if the condition flip-flop is true. Otherwise, execute the next instruction in sequence. | | (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> | | | | (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> | | | | (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 <sub>3</sub> B <sub>3</sub> B <sub>2</sub> B <sub>2</sub> if the condition flip-flop is true, and save the current address lup one 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 C4 C3 | 0 1 1 | Return (down one level in the stack) if the condition flip-flop is false. Otherwise, execute the next instruction in sequence. | | (3 or 5) | 0 0 | 1 C4 C3 | 0 1 1 | Return (down one level in the stack) if the condition flip-flop is true. Otherwise, execute the next instruction in sequence. | | (5) | | | | Call the subroutine at memory address AAA000 (up one level in the stac | | | (9 or 11) (9 or 11) (9 or 11) (9 or 11) (9 or 11) (5) (3 or 5) | B <sub>2</sub> B <sub>2</sub> | B <sub>2</sub> | B2 | #### Input/Output Instructions | 1 <b>N</b> | (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 | R | R M | M M 1 | Write the content of the accumulator into the selected output | | | | | | | | port (RRMMM, RR ± 00). | #### Machine Instruction | | | 40 | | | | | | | | | | |---|-----|-----|-----|---|---|---|---|---|---|---|-------------------------------------------------------------| | ì | HLT | (4) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | х | Enter the STOPPED state and remain there until interrupted. | | | ' | (4) | l 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | # NOTES - SSS = Source Index Register DDD = Destination Index Register B(001), C(010), D(011), E(100), H(101), L(110). Memory registers are addressed by the contents of registers H & L. (1) SSS = Source Index Register - (2) - Additional bytes of instruction are designated by BBBBBBBB. - X = "Don't Care" - (5) Flag flip-flops are defined by $C_4C_3$ carry (00)-overflow or underflowl, zero (01)-result is zero), sign (10)-MSB of result is "1"1, parity (11-parity is even). # **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> +0.5 to -20 V Power Dissipation 1.0 W @ 25° C \*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 ^{\circ}C \ to \ 70 ^{\circ}C, \ V_{CC} = +5V \ \pm 5\%, \ V_{DD} = -9V \ \pm 5\% \ unless otherwise specified. \ Logic "1" is defined as the more positive level (V_{IH}, V_{OH}). "0" is defined as the more negative level (V_{IL}, V_{OL}).$ | SYMBOL | | · · · · · · · · · · · · · · · · · · · | LIMITS | | UNIT | TEST | | | |-----------------|--------------------------------------------|---------------------------------------|--------|----------------------|------|-----------------------------------------------------|--|--| | | PARAMETER | MIN. | TYP. | MAX. | UNIT | CONDITIONS | | | | 1 <sub>DD</sub> | AVERAGE SUPPLY CURRENT-<br>OUTPUTS LOADED* | | 30 | 60 | mA | T <sub>A</sub> = 25°C | | | | 1, | INPUT LEAKAGE CURRENT | | | 10 | μА | VIN = OV | | | | V,L | INPUT LOW VOLTAGE (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 | | | | | Vor | OUTPUT LOW VOLTAGE | | | 0.4 | ٧ | 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 \pm 5\%$ , $V_{DD} = -9V \pm 5\%$ . All measurements are referenced to 1.5V levels. | | | 80 | 80 | 800 | 8-1 | | | | |--------------------------------|-----------------------------------------------------------------------|------|------|------|------|------|---------------------------------------|--| | SYMBOL | | LIN | MITS | LIN | IITS | UNIT | TEST CONDITIONS | | | | PARAMETER | MIN. | MAX. | MIN. | MAX. | ONT | | | | tcy | CLOCK PERIOD | 2 | 3 | 1.25 | 3 | μs | t <sub>R</sub> ,t <sub>F</sub> = 50ns | | | t <sub>B</sub> ,t <sub>F</sub> | CLOCK RISE AND FALL TIMES | | 50 | | 50 | ns | | | | t <sub>Ø1</sub> | PULSE WIDTH OF φ <sub>1</sub> | .70 | | .35 | | μs | | | | τ <sub>φ2</sub> | PULSE WIDTH OF φ <sub>2</sub> | .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 | μѕ | | | | 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> = 100pF | | | t <sub>OH</sub> | HOLD TIME FOR DATA BUS OUT | .10 | | .10 | | μς | | | | 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 | | | t <sub>S1</sub> | STATE OUT DELAY (ALL STATES EXCEPT T1 AND T11) [2] | | 1,1 | | 1.1 | μς | C <sub>L</sub> = 100 pF | | | t <sub>S2</sub> | STATE OUT DELAY (STATES | | 1.0 | | 1.0 | μς | C <sub>L</sub> = 100 pF | | | <sup>t</sup> RW | PULSE WIDTH OF READY DURING $\phi_{22}$ TO ENTER T3 STATE | .35 | | .35 | | μς | | | | t <sub>RD</sub> | READY DELAY TO ENTER WAIT | .20 | | .20 | | μs | | | $<sup>{1 \</sup>choose t_{1H}}$ MIN $\geq t_{SD}$ $<sup>^{12}</sup>$ If the INTERRUPT is not used, all states have the same output delay, $t_{S1}$ . ## **TIMING DIAGRAM** - Notes: 1. READY line must be at "0" prior to $\phi_{22}$ of $T_2$ to guarantee entry into the WAIT state. - 2. INTERRUPT line must not change levels within 200 ns (max.) of falling edge of $\phi_1$ . # TYPICAL D.C. CHARACTERISTICS MCS-80/85 # TYPICAL A.C. CHARACTERISTICS # **CAPACITANCE** f = 1MHz; $T_A = 25^{\circ}C$ ; Unmeasured Pins Grounded | SYMBOL | TEST | LIMIT (pF) | | | | | |------------------|--------------------------|------------|------|--|--|--| | | | 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 | | | |