MARCH 1977 Pub. No. 420305226-001 C 5-61 RES ORIG ## **INS8080A 8-Bit N-Channel Microprocessor** 003639 ## general description The INS8080A is an 8-bit microprocessor housed in a standard, 40-pin dual-in-line package. The chip, which is fabricated using N-channel silicon gate MOS technology, functions as the central processing unit (CPU) in National Semiconductor's N8080 microcomputer family. The INS8080A has a 16-bit address bus that is capable of addressing up to 65k bytes of memory and up to 256 input and 256 output devices. Data is routed to and from the INS8080A on a separate bidirectional 8-bit bus. This data bus is also TRI-STATE®, making direct memory addressing (DMA) and multiprocessing applications possible. The INS8080A directly provides signals to control the interface to memory and I/O ports. All buses, including control, are TTL compatible. An asynchronous interrupt capability is included in the INS8080A to allow external signals to change the instruction sequence. The interrupting device may vector the program to a particular service routine location (or some other direct function) by specifying an interrupt instruction to be executed. ## features T-3639 NSC - 2μs Instruction Cycle - Variable Length Instructions - General Purpose Registers Six plus an Accumulator - Direct Addressing up to 65k Bytes - Variable Length Stack Accessed by 16-bit Stack Pointer - Addresses 256 Input and 256 Output Ports - Provisions for Vectored Interrupts - TRI-STATE<sup>®</sup> Bus for DMA and Multiprocessing Capability - TRI-STATE TTL Drive Capabilities for Address and Data Buses - · Decimal Arithmetic Capability - Multiple Addressing Modes - Direct - Register - Register Indirect - Immediate - Direct Plug-in Replacement for Intel 8080A ## N8080A microcomputer family block diagram ## absolute maximum ratings | Temperature Under Bias 0°C to +70°C | |--------------------------------------------------------------------------| | Storage Temperature65°C to +150°C | | All Input or Output Voltages | | with Respect to V <sub>BB</sub> 0.3V to +20V | | $V_{CC},V_{DD}$ and $V_{SS}$ with Respect to $V_{BB}.$ . –0.3 V to +20 V | | Power Dissipation | Note: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under dc electrical characteristics. ## dc electrical characteristics $T_A = 0^{\circ}C$ to $+70^{\circ}C$ , $V_{DD} = +12V \pm 5\%$ , $V_{CC} = +5V \pm 5\%$ , $V_{BB} = -5V \pm 5\%$ , $V_{SS} = 0V$ , unless otherwise noted. | Symbol | Parameter | Min. | Тур. | Max. | Unit | Test Condition | |----------------------|----------------------------------------------|--------------------|------|----------------------|------|--------------------------------------------------------| | V <sub>ILC</sub> | Clock Input Low Voltage | V <sub>SS</sub> -1 | | V <sub>SS</sub> +0.8 | V | | | V <sub>IHC</sub> | Clock Input High Voltage | 9.0 | | V <sub>DD</sub> +1 | V | 1 | | V <sub>IL</sub> | Input Low Voltage | V <sub>SS</sub> -1 | | V <sub>SS</sub> +0.8 | V | 1 | | V <sub>IH</sub> | Input High Voltage | 3.3 | | V <sub>CC</sub> +1 | V | 1 | | V <sub>OL</sub> | Output Low Voltage | | | 0.45 | V | $\int_{OL} = 1.9 \text{ mA on all outputs,}$ | | V <sub>OH</sub> | Output High Voltage | 3.7 | | | V | $I_{OH} = 150 \mu A$ . | | I <sub>DD (AV)</sub> | Avg. Power Supply Current (V <sub>DD</sub> ) | | 40 | 70 | mA | 17 | | I <sub>CC</sub> (AV) | Avg. Power Supply Current (V <sub>CC</sub> ) | | 60 | 80 | mA | Operation $t_{CY} = 0.48 \mu s$ | | I <sub>BB</sub> (AV) | Avg. Power Supply Current (V <sub>BB</sub> ) | | 0.01 | 1 | mA | 13 τος - 0.40μο | | I <sub>IL</sub> | Input Leakage | | | ±10 | μΑ | $V_{SS} \leq V_{IN} \leq V_{CC}$ | | I <sub>CL</sub> | Clock Leakage | | | ±10 | μΑ | V <sub>SS</sub> ≤ V <sub>CLOCK</sub> ≤ V <sub>DD</sub> | | I <sub>CL</sub> | Data Bus Leakage in Input Mode | | | -100 | μΑ | $V_{SS} \leq V_{IN} \leq V_{SS} + 0.8V$ | | | | | | -2.0 | mA | $V_{SS} + 0.8V \leq V_{IN} \leq V_{CC}$ | | IFL | Address and Data Bus Leakage | 1 | | +10 | μΑ | V <sub>ADDR/DATA</sub> = V <sub>CC</sub> | | | During HOLD | <u> </u> | | -100 | μΑ | V <sub>ADDR/DATA</sub> = V <sub>SS</sub> + 0.45V | ## capacitance $T_A = 25^{\circ}C$ , $V_{CC} = V_{DD} = V_{SS} = 0V$ , $V_{BB} = -5V$ | Symbol | Parameter | Тур. | Max. | Unit | Test Condition | |------------------|--------------------|------|------|------|-----------------------------| | $C_\phi$ | Clock Capacitance | 17 | 25 | рF | f <sub>c</sub> = 1MHz | | C <sub>IN</sub> | Input Capacitance | 6 | 10 | pF | Unmeasured Pins | | C <sub>OUT</sub> | Output Capacitance | 10 | 20 | pF | Returned to V <sub>SS</sub> | - 1. The RESET signal must be active for a minimum of 3 clock - 2. When DBIN is high and $V_{\mbox{IN}} > V_{\mbox{IH}}$ an internal active pullup will be switched onto the Data Bus. - 3. $\Delta I \text{ supply } / \Delta T_A = -0.45\% / ^{\circ} C.$ DATA BUS CHARACTERISTIC DURING DBIN ## ac electrical characteristics | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |---------------------------------|----------------------------------------------------------------------------------------|------|------|------|---------------------| | t <sub>CY</sub> 3 | Clock Period | 0.48 | 2.0 | μs | | | t <sub>r</sub> , t <sub>f</sub> | Clock Rise and Fall Time | 0 | 50 | ns | | | $t_{\phi 1}$ | $\phi_1$ Pulse Width | 60 | | ns | | | $t_{\phi 2}$ | $\phi_2$ Pulse Width | 220 | | ns | | | t <sub>D1</sub> | Delay $\phi_1$ to $\phi_2$ | 0 | | ns | | | t <sub>D2</sub> | Delay $\phi_2$ to $\phi_1$ | 70 | | ns | | | t <sub>D3</sub> | Delay $\phi_1$ to $\phi_2$ Leading Edges | 80 | | ns | | | t <sub>DA</sub> <sup>2</sup> | Address Output Delay from $\phi_2$ | | 200 | ns | 7 | | t <sub>DD</sub> <sup>2</sup> | Data Output Delay from $\phi_2$ | | 220 | ns | $\int C_L = 100 pF$ | | t <sub>DC</sub> <sup>2</sup> | Signal Output Delay from $\phi_1$ or $\phi_2$ (SYNC, $\overline{\rm WR}$ , WAIT, HLDA) | | 120 | ns | ] | | t <sub>DF</sub> <sup>2</sup> | DBIN Delay from $\phi_2$ | 25 | 140 | ns | $C_L = 50 pF$ | | t <sub>DI</sub> 1 | Delay for Input Bus to Enter Input Mode | | tDF | ns | | | t <sub>DS1</sub> | Data Setup Time During $\phi_1$ and DBIN | 30 | | ns | | # timing waveforms [14] Note: Timing measurements are made at the following reference voltages: CLOCK '1' = $8.0\,\text{V}$ , '0' = $1.0\,\text{V}$ ; INPUTS '1' = $3.3\,\text{V}$ , '0' = $0.8\,\text{V}$ ; OUTPUTS '1' = $2.0\,\text{V}$ , '0' = $0.8\,\text{V}$ . ## ac electrical characteristics (cont'd.) | Symbol | Parameter | Min. | Max. | Unit | Test Condition | |------------------------------|---------------------------------------------------------------|------|------|------|------------------------------------------| | t <sub>DS2</sub> | Data Setup Time to $\phi_2$ During DBIN | 150 | | ns | | | t <sub>DH</sub> 1 | Data Hold Time from $\phi_2$ During DBIN | 1 | | ns | | | t <sub>IE</sub> 2 | INTE Output Delay from $\phi_2$ | | 200 | ns | C <sub>L</sub> = 50pF | | t <sub>RS</sub> | READY Setup Time During $\phi_2$ | 120 | | ns | <del>-</del> | | t <sub>HS</sub> | HOLD Setup Time to $\phi_2$ | 140 | | ns | | | t <sub>IS</sub> | INT Setup Time During $\phi_2$ (During $\phi_1$ in Halt Mode) | 120 | | ns | | | t <sub>H</sub> | Hold Time from $\phi_2$ (READY, INT, HOLD) | 0 | | ns | | | t <sub>FD</sub> | Delay to Float During Hold (Address and Data Bus) | | 120 | ns | | | t <sub>AW</sub> 2 | Address Stable Prior to WR | 5 | | ns | ٦ | | t <sub>DW</sub> <sup>2</sup> | Output Data Stable Prior to WR | 6 | | ns | | | t <sub>WD</sub> <sup>2</sup> | Output Data Stable from WR | 7 | | ns | 1 | | twa 2 | Address Stable from WR | 7 | | ns | $C_L = 100 \text{ pF}$ : Address, Data | | t <sub>HF</sub> 2 | HLDA to Float Delay | 8 | | ns | $C_L = 50 pF: \overline{WR}, HLDA, DBIN$ | | twF 2 | WR to Float Delay | 9 | | ns | | | t <sub>AH</sub> 2 | Address Hold Time After DBIN During HLDA | -20 | | ns | | - Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured. t<sub>DH</sub> = 50ns or t<sub>DF</sub>, whichever is less. - 2. Typical load circuit: 3. $t_{CY} = t_{D3} + t_{r\phi2} + t_{\phi2} + t_{D2} + t_{f\phi2} + t_{r\phi1} \geqslant 480 \, \text{ns}.$ - 4. The following are relevant when interfacing the INS8080A to devices having $V_{I\,H}$ = 3.3 V: - a) Maximum output rise time from $0.8\,V$ to $3.3\,V = 100\,ns$ @ $C_L = SPEC$ . - b) Output Delay when measured to 3.0 V = SPEC + 60 ns @ $C_L$ = SPEC. - c) If $C_L \neq SPEC$ , add 0.6ns/pF if $C_L > C_{SPEC}$ , subtract 0.3ns/pF (from modified delay) if $C_L < C_{SPEC}$ . - 5. $t_{AW} = 2t_{CY} t_{D3} t_{r\phi2} 140$ ns. - 6. $t_{DW} = t_{CY} t_{D3} t_{r\phi2} 170 \,\text{ns}.$ - 7. If not HLDA, $t_{WD}$ = $t_{WA}$ = $t_{D3}$ + $t_{r\phi2}$ + 10ns. If HLDA, $t_{WD}$ = $t_{WA}$ = $t_{WF}$ . - 8. $t_{HF} = t_{D3} + t_{r\phi2} 50 \text{ ns}.$ - 9. $t_{WF} = t_{D3} + t_{r\phi2} 10$ ns. - 10. Data in must be stable for this period during DBIN $\cdot$ T3. Both tDS1 and tDS2 must be satisfied. - 11. Ready signal must be stable for this period during $T_2$ or $T_W$ . (Must be externally synchronized.) - Hold signal must be stable for this period during T<sub>2</sub> or T<sub>W</sub> when entering hold mode, and during T<sub>3</sub>, T<sub>4</sub>, T<sub>5</sub>, and T<sub>WH</sub> when in hold mode. (External synchronization is not required.) - 13. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.) - This timing diagram shows timing relationships only; it does not represent any specific machine cycle. ## INS8080A functional pin definition The following describes the function of all of the INS8080A input/output pins. Some of these descriptions reference internal timing periods. #### **INPUT SIGNALS** Ready: When high (logic 1), indicates that valid memory or input data are available to the CPU on the INS8080A data bus. The READY signal is used to synchronize the CPU with slower memory or input/output devices. If the INS8080A does not receive a high READY input after sending out an address to memory or an input/output device, the INS8080A enters a WAIT mode for as long as the READY input remains low (logic 0). The CPU may also be single stepped by the use of the READY signal. Hold: When high, requests that the CPU enter the HOLD mode. When the CPU is in the HOLD mode, the CPU address and data buses both will be in the high-impedance state. The HOLD mode allows an external device to gain control of the INS8080A address and data buses immediately following the completion of the current machine cycle by the CPU. The CPU acknowledges the HOLD mode via the HOLD ACKNOWLEDGE (HLDA) output line. The HOLD request is recognized under the following conditions: - The CPU is in the HALT mode. - The READY signal is active and the CPU is in the t<sub>2</sub> or t<sub>W</sub> state. Interrupt (INT) Request: When high, the CPU recognizes an interrupt request on this line after completing the current instruction or while in the HALT mode. An interrupt request is not honored if the CPU is in the HOLD mode (HLDA = logic 1) or the Interrupt Enable Flip-flop is reset (INTE = logic 0). Reset: When activated (high) for a minimum of three clock periods, the content of the Program Counter is cleared and the Interrupt Enable and Hold Acknowledge Flip-flops are reset. Following a RESET, program execution starts at memory location 0. It should be noted that the status flags, accumulator, stack pointer, and registers are not cleared during the RESET sequence. $\phi_1$ and $\phi_2$ Clocks: Two non-TTL compatible clock phases which provide nonoverlapping timing references for internal storage elements and logic circuits of the CPU. +12 Volts: V<sub>DD</sub> Supply. +5 Volts: V<sub>CC</sub> Supply. -5 Volts: V<sub>BB</sub> Supply. Ground: V<sub>SS</sub> (0 volt) reference. #### **OUTPUT SIGNALS** **Synchronizing (SYNC) Signal:** When activated (high), the beginning of a new machine cycle is indicated and the status word is outputted on the Data Bus. Address ( $A_{15}$ – $A_0$ ) Bus: This bus comprises sixteen TRI-STATE output lines. The bus provides the address to memory (up to 65k bytes) or denotes the input/output device number for up to 256 input and 256 output peripherals. $\mbox{\bf Wait:}$ When high, acknowledges that the CPU is in the WAIT mode. Write ( $\overline{WR}$ ): When low, the data on the data bus are stable for WRITE memory or output operation. Hold Acknowledge (HLDA): Goes high in response to a logic 1 on the HOLD line and indicates that the data and address bus will go to the high-impedance state. The HLDA begins at one of the following times: - The t<sub>3</sub> state of a READ memory input operation. - The clock period following the t<sub>3</sub> state of a WRITE memory output operation. In both cases, the HLDA signal starts after the rising edge of the $\phi_1$ clock, and high impedance occurs after the rising edge of the $\phi_2$ clock. Interrupt Enable (INTE): Indicates the content of the internal Interrupt Enable Flip-flop. The Enable and Disable Interrupt (EI and DI) Instructions cause the Interrupt Enable Flip-flop to be set and reset, respectively. When the flip-flop is reset (INTE = logic 0), it inhibits interrupts from being accepted by the CPU. In addition, the Interrupt Enable Flip-flop is automatically reset (thereby disabling further interrupts) at the t<sub>1</sub> state of the instruction fetch cycle, when an interrupt is accepted; it is also reset by the RESET Signal. Data Bus In (DBIN): When high, indicates to external circuits that the data bus is in the input mode. The DBIN Signal should be used to gate data from memory or an I/O device onto the Data Bus. #### INPUT/OUTPUT SIGNALS Data ( $D_7 - D_0$ ) Bus: This bus comprises eight TRI-STATE input/output lines. The bus provides bidirectional communication between the CPU, memory, and input/output devices for instructions and data transfers. A status word (which describes the current machine cycle) is also outputted on the data bus during the first state of each machine cycle (SYNC = logic 1). ## pin configuration #### 8080A status Instructions for the 8080A require from one to five machine cycles for complete execution. The 8080A sends out 8 bits of status information on the data bus at the beginning of each machine cycle (during SYNC time). The following table defines the status information. #### Status Information Definition | Symbols | Data Bus<br>Bit | Definition | Symbols | Data Bus<br>Bit | Definition | |---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------| | INTA* | D <sub>0</sub> | Acknowledge signal for INTERRUPT request. Signal should be used to gate a restart instruction onto the data bus when DBIN is active. | OUT | D <sub>4</sub> | Indicates that the address bus contains the address of an output device and the data bus will contain the output data when WR is active. | | WO | D <sub>1</sub> | Indicates that the operation in the current machine cycle will be a WRITE memory or OUTPUT function (WO = | M <sub>1</sub> | D <sub>5</sub> | Provides a signal to indicate that the CPU is in the fetch cycle for the first byte of an instuction. | | | | 0). Otherwise, a READ memory or INPUT operation will be executed. | INP* | D <sub>6</sub> | Indicates that the address bus contains the address of an input device and the | | STACK | D <sub>2</sub> | Indicates that the address bus holds the pushdown stack address from the Stack Pointer. | | | input data should be placed on the data bus when DBIN is active. | | HLTA | D <sub>3</sub> | Acknowledge signal for HALT Instruction. | MEMR* | D <sub>7</sub> | Designates that the data bus will be used for memory read data. | <sup>\*</sup>These three status bits can be used to control the flow of data onto the INS8080A data bus. ### Status Word Chart | Marchine Coole | T | | | | Data | Bus Bit | - | | | |----------------------------------|------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Machine Cycle | Type | 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> | | Instruction Fetch | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | Memory Read | 2 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | Memory Write | 3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Stack Read | 4 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | Stack Write | 5 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | Input Read | 6 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | Output Write | 7 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Interrupt Acknowledge | 8 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | Halt Acknowledge | 9 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | Interrupt Acknowledge While Halt | 10 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | instruction | set | |--|-------------|-----| |--|-------------|-----| | Mnen | nonic | Description | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | No. of<br>Bytes | No. of<br>Machine<br>(M)<br>Cycles | No. of<br>States<br>(T) | S | | ion<br>AC | <del>-</del> | |------------|----------------|----------------------------------------------------------|---------------------------------------------------------------------------------|----------------|----------------|----------------|----------|----------------|----------------|----------------|----------------|-----------------|------------------------------------|-------------------------|-----------|----------|---------------|--------------| | | TRANSF | ER GROUP | | | | | | | _ | | | | | | | | _ | | | LDA | | Load Accumulator Direct | (A) ← ((byte 3) (byte 2)) | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 3 | 4 2 | 13<br>7 | | | | | | DAX. | | Load Accumulator Indirect | (A) ← ((B)(C)) | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 1 | 2 | 7 | 1 | | | | | DAX | D | Load Accumulator Indirect | (A) ← ((D)(E)) | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 3 | 5 | 16 | | | | | | HLD | | Load H and L Direct | (L) ← ((byte 3) (byte 2))<br>(H) ← ((byte 3) (byte 2) + 1) | 0 | 0 | 1 | 0 | 1 | 0 | 1 | U | 3 | 5 | 10 | | | | | | ΧI | В | Load Immediate, Registers B and C | (B) ← (byte 3) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 3 | 3 | 10 | | | | | | | | | (C) ← (byte 2)<br>(D) ← (byte 3) | | | | , | _ | 0 | 0 | 1 | 3 | 3 | 10 | | | | | | .XI | D | Load Immediate, Registers D and E | (E) ← (byte 2) | 0 | 0 | 0 | 1 | 0 | U | U | | 3 | 3 | 10 | | | | | | .XI | н | Load Immediate, Registers H and L | (H) ← (byte 3)<br>(L) ← (byte 2) | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 3 | 3 | 10 | | | | | | _XI | SP | Load Immediate, Stack Pointer | (SPH) ← (byte 3) | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 3 | 3 | 10 | | | | | | • | | | (SPL) ← (byte 2) | | | | | 0 | s | s | s | 1 | 2 | 7 | | | igs N<br>ecte | | | VOV | M, r | Move to Memory | $((H)(L)) \leftarrow (r)$ $(r) \leftarrow ((H)(L))$ | 0 | 1 | 1<br>D | 1<br>D | D | 1 | 1 | 0 | 1 | 2 | 7 | | | | | | MOV<br>MOV | r, M<br>r1, r2 | Move from Memory Move Registers | (r1) ← (r2) | 0 | 1 | D | D | D | s | s | S | li | 1 | 5 | | | | | | | 71, 12<br>M | Move to Memory Immediate | ((H)(L)) ← (byte 2) | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 2 | 3 | 10 | | | | | | MVI | | | | | | | D | D | | 1 | 0 | 2 | 2 | 7 | | | | | | MVI | r | Move Immediate | (r) ← (byte 2)<br>((byte 3) (byte 2)) ← (L) | 0 | 0 | D<br>1 | 0 | 0 | 1<br>0 | 1 | 0 | 3 | 5 | 16 | 1 | | | | | SHLD | | Store H and L Direct | ((byte 3) (byte 2)) ← (L)<br>((byte 3) (byte 2) + 1) ← (H) | ١ | U | 1 | U | ľ | U | 1 | J | | 5 | '` | | | | | | STA | | Store Accumulator Direct | ((byte 3) (byte 2)) ← (A) | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 3 | 4 | 13 | 1 | | | | | STAX | R | Store Accumulator Indirect | ((B)(C)) ← (A) | 0 | 0 | 0 | o | 0 | 0 | 1 | 0 | 1 | 2 | 7 | | | | | | STAX | D | Store Accumulator Indirect | ((D)(E)) ← (A) | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 2 | 7 | 1 | | | | | KCHG | ט | | ((D)(E)) ← (A)<br>(H) ↔ (D) | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | i | 1 | 4 | 1 | | | | | CUO | | Exchange H and L with D and E | (H) ↔ (E) | 1 ' | , | • | U | l ' | J | ' | | ' | ' | ' | 1 | | | | | RITH | IMETIC ( | GROUP | <u> </u> | | | | | | | | | 1 | | <b></b> | | - | | | | ACI | | Add Immediate with Carry | (A) ← (A) + (byte 2) + (CY) | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 2 | 2 | 7 | 1 | ‡ | ‡ | <b>‡</b> | | ADC | М | Add Memory with Carry | $(A) \leftarrow (A) + ((H)(L)) + (CY)$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 2 | 7 | 1 | <b>1</b> | ‡ | \$ | | ADC | f. | Add Register with Carry | $(A) \leftarrow (A) + (r) + (CY)$ | 1 | 0 | 0 | 0 | 1 | S | S | S | 1 | 1 | 4 | 1 | 1 | <b>‡</b> | \$ | | ADD | M | Add Memory | (A) - (A) + ((H) (L)) | 11 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 2 | 7 | 1 | 1 | <b>‡</b> | \$ | | ADD | r | Add Register | $(A) \leftarrow (A) + (r)$ | 11 | 0 | 0 | 0 | 0 | S | S | s | 1 | 1 | 4 | 1 | 1 | 1 | \$ | | ADI | | Add Immediate | (A) ← (A) + (byte 2) | 1 | 1 | 0 | 0 | ő | 1 | 1 | 0 | 1 | 2 | 7 | 1 | <b>‡</b> | <b>‡</b> | <b>t</b> | | DAA | | Decimal Adjust Accumulator | 8-bit number in Accumulator | 0 | Ó | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 | 1 | <b>1</b> | 1 | ‡ | | | | Desiring August Accumulator | is converted to two 4-bit BCD | ١ | - | | ~ | | · | - | • | | | | | | | | | DAD | В | Add B and C to H and L | digits<br>(H)(L) ← (H)(L) + (B)(C) | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 3 | 10 | . | | | | | DAD | D | Add D and E to H and L | (H)(L) ← (H)(L) + (D)(E) | 0 | 0 | 0 | 1 | ľ | 0 | 0 | 1 | 1 1 | 3 | 10 | . | | | | | DAD | Н | Add H and L to H and L | (H)(L) ← (H)(L) + (H)(L) | 0 | 0 | 1 | 0 | '1 | 0 | 0 | 1 | | 3 | 10 | ١. ا | | | | | DAD | SP | Add Stack Pointer to H and L | (H)(L) ← (H)(L) + (SP) | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 3 | 10 | . | | | | | DCR | M | Decrement Memory | ((H)(L)) ← ((H)(L)) – 1 | 0 | 0 | 1 | 1 | o | 1 | 0 | 1 | i | 3 | 10 | 1 | ţ | \$ | <b>1</b> | | OCR | r | Decrement Memory Decrement Register | $(r) \leftarrow (r) - 1$ | 0 | 0 | D | D | D | 1 | 0 | 1 | ; | 1 | 5 | 1 | <b>‡</b> | 1 | ‡ | | DCX | r<br>B | Decrement Register Decrement Registers B and C | $(B)(C) \leftarrow (B)(C) - 1$ | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 1 | 1 | 5 | [:] | | | · | | DCX | D | Decrement Registers B and C Decrement Registers D and E | $(D)(E) \leftarrow (D)(E) - 1$ | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 1 | 1 | 5 | . | . | | | | DCX | Н | Decrement Registers D and E Decrement Registers H and L | (H)(L) ← (H)(L) – 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | '1 | 1 | 5 | . | . | | | | DCX | SP | Decrement Stack Pointer | $(SP) \leftarrow (SP) - 1$ | 0 | 0 | 1 | 1 | 1 | 0 | i | 1 | i | 1 | 5 | . | . | | | | INR | M | Increment Memory | ((H)(L)) ← ((H)(L)) + 1 | 0 | n | 1 | 1 | o | 1 | 0 | 0 | 1 1 | 3 | 10 | 1 | <b>1</b> | 1 | <b>‡</b> | | INR | | , | (r) +- (r) + 1 | 0 | o | D | D | D | 1 | 0 | ō | 1 1 | 1 | 5 | l t | t | <b>‡</b> | <b>‡</b> | | INX | r<br>B | Increment Register | | 0 | 0 | 0 | 0 | 0 | Ö | 1 | 1 | 1 1 | 1 | 5 | : | . | | ÷ | | | D | Increment Registers B and C Increment Registers D and E | (B) (C) $\leftarrow$ (B) (C) + 1<br>(D) (E) $\leftarrow$ (D) (E) + 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 1 | 1 | 5 | . | . | | | | NX | | • | | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | | i | 5 | . | . | | | | INX | Н | Increment Registers H and L | (H)(L) ← (H)(L) + 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | i | 1 | 5 | ١. ١ | . | | | | INX | SP | Increment Stack Pointer | $(SP) \leftarrow (SP) + 1$<br>$(A) \leftarrow (A) \sim ((H)(L)) - (CY)$ | 1 | 0 | Ö | 1 | 1 | 1 | 1 | Ö | 1 1 | 2 | 7 | 1 | <b>‡</b> | \$ | <b>‡</b> | | SBB | M | Subtract Memory with Borrow | | l i | 0 | 0 | 1 | i | s | s | S | 1 1 | 1 | 4 | 1 | ţ. | 1 | ţ | | SBB | r | Subtract Register with Borrow | (A) ← (A) – (r) – (CY) | 1 | 1 | 0 | 1 | l i | 1 | 1 | 0 | 2 | 2 | 7 | l i l | 1 | 1 | \$ | | SBI | | Subtract Immediate with Borrow | (A) + (A) - (byte 2) - (CY) | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 2 | 7 | ‡ | 1 | <b>‡</b> | ‡ | | SUB | M | Subtract Memory | $(A) \leftarrow (A) = ((H)(L))$<br>$(A) \leftarrow (A) = (a)$ | ' | 0 | 0 | 1 | 0 | S | s | S | '1 | 1 | 4 | t | ÷ | ‡ | ‡ | | SUB<br>SUI | r | Subtract Register Subtract Immediate | $(A) \leftarrow (A) - (r)$<br>$(A) \leftarrow (A) - (byte 2)$ | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 2 | 2 | 7 | t l | 1 | <b>‡</b> | ‡ | | | AL GRO | | 114 44 - WATE 51 | | | | <u> </u> | | <u> </u> | - | | L | | | ш | 1 | | | | ANA | M | AND Memory | (A) ← (A) ∧ ((H) (L)) | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 2 | 7 | <b>‡</b> | ‡ | ‡d | ‡ | | ANA | r | AND Register | (A) ← (A) ∧ (r) | 1 | 0 | 1 | 0 | 0 | s | s | S | 1 | 1 | 4 | ‡ | Ť | ‡d | ‡ | | ANI | | AND Immediate | $(A) \leftarrow (A) \land (byte 2)$ | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 2 | 2 | 7 | <b>1</b> | t | ‡d | <b>‡</b> | | CMA | | Complement Accumulator | (A) ← (Ā) | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 | • | . | • | ٠ | | CMC | | Complement Carry | $(CY) \leftarrow (\overline{CY})$ | ő | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 4 | 1.1 | . | | • | | CMP | м | Compare Memory | (A) — ((H) (L)) | 1 | ō | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 2 | 7 | 1 1 | ‡ª | <b>‡</b> | \$ | | CMP | r | Compare Register | (A) — ((I) (L))<br>(A) — (r) | l i | 0 | 1 | 1 | 1 | s | s | S | 1 | 1 | 4 | 1 | ¢b | ţ | ‡ | | CPI | ۱ ا | Compare Immediate | (A) — (I)<br>(A) — (byte 2) | Ιì | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 2 | 2 | 7 | 1 | ţc | <b>‡</b> | ţ | | ORA | м | OR Memory | $(A) \leftarrow (A) \lor ((H)(L))$ | i | o | 1 | 1 | o | 1 | 1 | 0 | 1 | 2 | 7 | ‡ | į | 0 | 1 | | DRA | , | OR Register | $(A) \leftarrow (A) \lor (r)$ | 1 | Ö | 1 | 1 | 0 | s | s | s | 1 | 1 | 4 | ¢ | 1 | 0 | ‡ | | ORI | . | OR Immediate | (A) ← (A) V (byte 2) | 1 | 1 | 1 | 1 | | . 1 | 1 | 0 | 2 | 2 | 7 | Į į | \$ | 0 | ‡ | | RAL | | Rotate Left through Carry | $(A_{n+1}) \leftarrow (A_n); (CY) \leftarrow (A_7)$ | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 4 | • | - | | ٠ | | | | - ' | (A <sub>0</sub> ) ← (CY) | | c | C | | , | | | 1 | , | , | 4 | | | | _ | | RAR | | Rotate Right through Carry | $(A_n) \leftarrow (A_{n+1}); (CY) \leftarrow (A_0)$<br>$(A_7) \leftarrow (CY)$ | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 4 | | . | | • | | RLC | | Rotate Left | $(A_{n+1}) \leftarrow (A_n); (A_0) \leftarrow (A_7)$ | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 | $ \cdot $ | . | • | ٠ | | 200 | | Potato Picht | (CY) ← (A <sub>7</sub> ) | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 | . | . | | | | RRC | | Rotate Right | $(A_n) \leftarrow (A_{n-1}); (A_7) \leftarrow (A_0)$<br>$(CY) \leftarrow (A_0)$ | 1 | | | | 0 | | | 1 | , | 1 | 4 | | | | | | STC | | Set Carry | (CY) ← 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | 1 1 | | 7 | ; | ; | . | • | | XRA | м | Exclusive OR Memory | (A) ← (A) <del>V</del> ((H) (L)) | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 2 | | 1 | \$ | 0 | <b>‡</b> | | XRA | r | Exclusive OR Register | (A) ← (A) <del>V</del> (r) | 1 | 0 | 1 | 0 | 1 | S | S | S | 1 | 1 2 | 4 | ‡ | ‡<br>‡ | 0 | ‡<br>‡ | | XRI | | Exclusive OR Immediate | (A) ← (A) <del>V</del> (byte 2) | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 2 | 2 | 7 | Ţ | ¥ | ٥ | ţ | | | | | | | | | | | | | | | | | | | | | | | Notes: | <ol> <li>Z = 1 if (A) = (H)(L);</li> </ol> | b. Z = 1 if (A) = (r); | r | 7 | ≃ 1 | i+ / | <b>Δ</b> 1 - | : /h: | vte ' | 21. | | d Δ. : 4 | an arith | mo+ | ic c | nor | 2+:- | - # instruction set (cont'd.) | | | | Ор | Code | No. of | No. of<br>Machine | No. of<br>States | Condition Flags | | | | | |------------|----------------------------------------|---------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|--------|-------------------|------------------|-----------------|--|--|--|--| | Mnemonic | Description | Operation | 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> | Bytes | (M)<br>Cycles | (T) | S Z AC P CY | | | | | | BRANCH GR | ROUP | 1 | | | 4 | | | | | | | | | CALL | Call Unconditional | ((SP) - 1) ← (PCH) | 1 1 0 0 | 1 1 0 1 | 3 | 5 | 17 | <u> </u> | | | | | | | | ((SP) - 2) ← (PCL)<br>(SP) ← (SP) - 2 | | ' ' ' ' | | | '' | | | | | | | СС | Call an Cana | (PC) ← (byte 3) (byte 2) | | 1 | | | | | | | | | | CC | Call on Carry | If CY = 1,<br>((SP) - 1) ← (PCH) | 1 1 0 1 | 1 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 2) ← (PCL)<br>(SP) ← (SP) ~ 2 | | | | | | | | | | | | СМ | Call on Minus | (PC) ← (byte 3) (byte 2) If S = 1. | | | | | | | | | | | | • | Sun on minus | ((SP) - 1) ← (PCH) | 1 1 1 1 | 1 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 2) ← (PCL)<br>(SP) ← (SP) - 2 | | | | | | | | | | | | CNC | Call on No Carry | (PC) ← (byte 3) (byte 2)<br>If CY = 0, | 1 1 0 1 | 0 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | · | ((SP) - 1) ← (PCH)<br>((SP) - 2) ← (PCL) | | | " | 3/5 | 11/17 | | | | | | | | | (SP) ← (SP) – 2 | | | | | | | | | | | | CNZ | Call on Not Zero | (PC) ← (byte 3) (byte 2)<br>If Z = 0, | 1 1 0 0 | 0 1 0 0 | 3 | 3/5 | 11/17 | (Flags Not | | | | | | | | ((SP) - 1) ← (PCH)<br>((SP) - 2) ← (PCL) | 1 | | | | | Affected) | | | | | | | | (SP) ← (SP) – 2<br>(PC) ← (byte 3) (byte 2) | | | | | | | | | | | | СР | Call on Positive | If S = 0, | 1 1 1 1 | 0 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 1) ← (PCH)<br>((SP) - 2) ← (PCL) | | | | | | | | | | | | | | (SP) ← (SP) - 2<br>(PC) ← (byte 3) (byte 2) | | | | | | | | | | | | CPE | Call on Parity Even | If P = 1,<br>((SP) - 1) ← (PCH) | 1 1 1 0 | 1 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 2) ← (PCL) | | | | | | | | | | | | | | (SP) ← (SP) – 2<br>(PC) ← (byte 3) (byte 2) | | | | | | | | | | | | СРО | Call on Parity Odd | If P = 0,<br>((SP) - 1) ← (PCH) | 1 1 1 0 | 0 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 2) ← (PCL)<br>(SP) ← (SP) - 2 | | | | | | | | | | | | 0.7 | | (PC) ← (byte 3) (byte 2) | | | | | | | | | | | | CZ | Call on Zero | If Z = 1,<br>((SP) - 1) ← (PCH) | 1 1 0 0 | 1 1 0 0 | 3 | 3/5 | 11/17 | | | | | | | | | ((SP) - 2) ← (PCL)<br>(SP) ← (SP) - 2 | | | | | | | | | | | | JC | Jump on Carry | (PC) ← (byte 3) (byte 2) | 1 1 0 1 | 1 0 1 0 | 3 | 3 | 10 | | | | | | | | · | If CY = 1,<br>(PC) ← (byte 3) (byte 2) | | | | | 10 | | | | | | | JM | Jump on Minus | If S = 1,<br>(PC) ← (byte 3) (byte 2) | 1 1 1 1 | 1 0 1 0 | 3 | 3 | 10 | | | | | | | JMP<br>JNC | Jump Unconditional<br>Jump on No Carry | (PC) ← (byte 3) (byte 2) If CY = 0. | 1 1 0 0 | 0 0 1 1 | 3 | 3 | 10<br>10 | | | | | | | | | (PC) +- (byte 3) (byte 2) | | | | | | | | | | | | JNZ | Jump on Not Zero | If Z = 0,<br>(PC) ← (byte 3) (byte 2) | 1 1 0 0 | 0 0 1 0 | 3 | 3 | 10 | | | | | | | JP | Jump on Positive | If S = 0,<br>(PC) ← (byte 3) (byte 2) | 1 1 1 1 | 0 0 1 0 | 3 | 3 | 10 | | | | | | | JPE | Jump on Parity Even | If P = 1, | 1 1 1 0 | 1 0 1 0 | 3 | 3 | 10 | | | | | | | JPO | Jump on Parity Odd | (PC) ← (byte 3) (byte 2)<br>If P = 0, | 1 1 1 0 | 0 0 1 0 | 3 | 3 | 10 | | | | | | | JZ | Jump on Zero | (PC) ← (byte 3) (byte 2) If Z = 1, | 1 1 0 0 | 1 0 1 0 | 3 | 3 | 10 | | | | | | | | | (PC) ← (byte 3) (byte 2) | 1 1 1 0 | 1 0 0 1 | | | | | | | | | | PCHL | H and L to Program Counter | (PCH) ← (H)<br>(PCL) ← (L) | | | 1 | 1 | 5 | | | | | | | RC | Return on Carry | If CY = 1,<br>(PCL) ← ((SP)) | 1 1 0 1 | 1 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | | (PCH) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | | | | | | | | | | | | RET | Return | (PCL) ← ((SP)); | 1 1 0 0 | 1 0 0 1 | 1 | 3 | 10 | | | | | | | | _ | (PCH) ← ((SP) + 1);<br>(SP) ← (SP) + 2; | | | | | | | | | | | | RM : | Return on Minus | If S = 1,<br>(PCL) ← ((SP)) | 1 1 1 1 | 1 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | | (PCH) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | | | | 1 | | | | | | | | RNC | Return on No Carry | If CY = 0, | 1 1 0 1 | 0 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | | (PCL) ← ((SP))<br>(PCH) ← ((SP) + 1) | | | | | | | | | | | | RNZ | Return on Not Zero | (SP) ← (SP) + 2<br>If Z = 0, | 1 1 0 0 | 0 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | ·· <del>-</del> <del>-</del> | (PCL) ← ((SP))<br>(PCH) ← ((SP) + 1) | | . , | | | | | | | | | | DD. | D-1 D | (SP) ← (SP) + 2 | | 0 0 0 - | | , | | | | | | | | RP | Return on Positive | If S = 0,<br>(PCL) ← ((SP)) | 1 1 1 1 | 0 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | | (PCH) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | | | | | | | | | | | | RPE | Return on Parity Even | If P = 1, | 1 1 1 0 | 1 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | | (PCL) ← ((SP))<br>(PCH) ← ((SP) + 1) | | | | | | | | | | | | RPO | Return on Parity Odd | (SP) ← (SP) + 2<br>If P = 0, | 1 1 1 0 | 0 0 0 0 | 1 | 1/3 | 5/11 | | | | | | | | · | (PCL) ← ((SP))<br>(PCH) ← ((SP) + 1) | | | | 1 | | | | | | | | | | (SP) ← (SP) + 2 | 1 | | ı | 1 | | | | | | | | Mnemor | nic | Description | Operation | Op Code | | | No. of | | States | Condition Flags | | | | | | | | | | |--------------|--------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------|----|-------|---------------|----------|---|---|----------|----------|---| | | | · | , | 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> | Do | Bytes | (M)<br>Cycles | (T) | s | z | AC | P | c | | BRANCI | H GRO | OUP (continued) | | | | | | | | | | | | | | | | | | | RST | | Restart | $((SP) - 1) \leftarrow (PCH)$<br>$((SP) - 2) \leftarrow (PCL)$<br>$(SP) \leftarrow (SP) - 2$<br>$(PC) \leftarrow 8 * (NNN)$ | 1 | 1 | Ν | Ν | N | 1 | 1 | 1 | 1 | 3 | 11 | | | | | | | RZ | | Return on Zero | If Z = 1,<br>(PCL) ← ((SP))<br>(PCH) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1/3 | 5/11 | | | | | | | STACK, | I/O, A | ND MACHINE CONTROL GROUP | <b>P</b> | - | | | | _ | | | | | , | | _ | | | | _ | | DI | | Disable Interrupts | The Interrupt system is dis-<br>abled following the execution<br>of the DI instruction. | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 4 | | | | | | | EI | | Enable Interrupts | The interrupt system is en-<br>abled following the execution<br>of next instruction. | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 4 | • | • | | | | | HLT | | Halt | Processor is stopped; registers and flags are unaffected. | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 7 | | | | - | | | IN<br>NOP | | Input<br>No Operation | (A) ← (data) No operation is performed; registers and flags are unaffected. | 0 | 1<br>0 | 0 | 1<br>0 | 0 | 0 | 0 | 0 | 1 | 3<br>1 | 10 4 | | : | : | | | | OUT<br>POP | В | Output<br>Pop Registers B and C off Stack | (data) ← (A)<br>(C) ← ((SP))<br>(B) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | 1 | 1 | 0 | <b>1</b><br>0 | 0 | 0 | 0 | 1 | 1 | 3<br>3 | 10<br>10 | : | | : | : | | | POP | D | Pop Registers D and E off Stack | (E) ← ((SP))<br>(D) ← ((SP) + 1)<br>(SP) ← (SP) + 2 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 3 | 10 | | • | | ŀ | | | POP | Н | Pop Registers H and L off Stack | $(L) \leftarrow ((SP))$ $(H) \leftarrow ((SP) + 1)$ $(SP) \leftarrow (SP) + 2$ | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 3 | 10 | | | | • | | | POP | PSW | Pop Accumulator and Flags off Stack | $(CY) \leftarrow ((SP))_0$<br>$(P) \leftarrow ((SP))_2$<br>$(AC) \leftarrow ((SP))_4$<br>$(2) \leftarrow ((SP))_6$<br>$(S) \leftarrow ((SP))_7$<br>$(A) \leftarrow ((SP) + 1)$<br>$(SP) \leftarrow (SP) + 2$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 3 | 10 | ‡ | ţ | <b>‡</b> | <b>‡</b> | 1 | | PUSH | В | Push Registers B and C on Stack | $((SP) - 1) \leftarrow (B)$<br>$((SP) - 2) \leftarrow (C)$<br>$(SP) \leftarrow (SP) - 2$ | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 3 | 11 | • | | - | - | • | | PUSH | D | Push Registers D and E on Stack | $((SP) - 1) \leftarrow (D)$ $((SP) - 2) \leftarrow (E)$ $(SP) \leftarrow (SP) - 2$ | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 3 | 11 | | | | | - | | PUSH | Н | Push Registers H and L on Stack | $((SP) - 1) \leftarrow (H)$ $((SP) - 2) \leftarrow (L)$ $(SP) \leftarrow (SP) - 2$ | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 3 | 11 | | | | | - | | PUSH | PSW | Push Accumulator and Flags on Stack | ((SP) - 1) + (A)<br>((SP) - 2) <sub>0</sub> + (CY)<br>((SP) - 2) <sub>1</sub> + 1<br>((SP) - 2) <sub>2</sub> + (P)<br>((SP) - 2) <sub>3</sub> + 0<br>((SP) - 2) <sub>4</sub> + (AC)<br>((SP) - 2) <sub>6</sub> + (Z)<br>((SP) - 2) <sub>7</sub> + (S)<br>(SP) - (SP) - (S) | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 3 | 11 | | ٠ | | • | | | SPHL<br>XTHL | | Move H and L to Stack Pointer<br>Exchange Top of Stack with H and L | $(SP) \leftarrow (SP) - 2$ $(SP) \leftarrow (H)(L)$ $(L) \leftrightarrow ((SP))$ $(H) \leftrightarrow ((SP) + 1)$ | 1 1 | 1 | 1 | 1 | 1 | 0 | - | 1 | 1 1 | 1<br>5 | 5<br>18 | : | | - | | . | ## condition flags and standard rules There are five condition flags associated with the execution of instructions on the INS8080A. They are Zero, Sign, Parity, Carry, and Auxiliary Carry, and each flag is represented by a 1-bit register in the CPU. A flag is "set" by forcing the bit to 1, "reset" by forcing the bit to 0. The bit positions of the flags are indicated in the PUSH and POP PSW instructions. Unless indicated otherwise, when an instruction affects a flag, it affects it in the following manner: If the result of an instruction has the value 0, this flag is set; otherwise, it is SIGN (S): If the most significant bit of the result of the operation has the value 1, this flag is set; otherwise, it is reset. PARITY (P): If the modulo 2 sum of the bits of the result of the operation is 0 (that is, if the result has even parity), this flag is set; otherwise, it is reset (that is, if the result has odd parity). CARRY (CY): If the instruction resulted in a carry (from addition) or a borrow (from subtraction or a comparison) out of the high-order bit, this flag is set; otherwise, it is reset. **AUXILIARY** CARRY (AC): If the instruction caused a carry out of bit 3 and into bit 4 of the resulting value, the auxiliary carry is set; otherwise, it is reset. This flag is affected by singleprecision additions, subtractions, increments, decrements, comparisons, and logical operations; however, AC is used principally with additions and increments preceding a DAA (Decimal Adjust Accumulator) Instruction. ## symbols and abbreviations | The follo | wing symbols and abbreviati | ons are used in the | Symbols | Meaning | |-----------|--------------------------------|----------------------|-------------------|----------------------------------------------------------------------------------------------------------------------| | | at description of the INS | 3080A instructions: | PC | 16-bit program counter register (PCH and PCL are used to refer to the high-order and low-order 8 bits respectively.) | | Symbols | Meaning | | SP | 16-bit stack pointer register (SPH and SPL are | | Α | Register A (Accumulator) | | | used to refer to the high-order and low-order | | В | Register B | | | 8 bits respectively.) | | С | Register C | | · ( ) | The contents of the memory location or registers enclosed in the parentheses | | D | Register D | | <b>←</b> | "Is replaced by" | | Н | Register H | | ٨ | Logical AND | | Ļ | Register L | | <i>\</i> \ | Exclusive OR | | DDD, SSS | | one of the registers | V | | | | A, B, C, D, E, H, L (DDD = | = destination, SSS = | | Inclusive OR | | | source): | • | + | Addition | | | DDD or SSS | Register Name | <b>-</b><br>* | Twos complement subtraction | | | 111 | A | * | Multiplication | | | 000 | В | $\leftrightarrow$ | "Exchange" | | | 001 | С | | The ones complement (for example, $(\overline{A})$ ) | | | 010 | D | n | The restart number 0 through 7 | | | 011 | E | NNN | The binary representation 000 through 111 for | | | 100 | Н | | restart number 0 through 7 respectively | | | 101 | L | • | "Not affected" | | byte 2 | The second byte of the instru | | 0 | "Reset" | | byte 3 | The third byte of the instruc | tion | 1 | "Set" | | port | 8-bit address of an I/O device | е | x | Unknown | | r, r1, r2 | One of the registers A, B, C, | D, E, H, L | \$ | Flags affected according to Standard Rules, except as noted. | ## physical dimensions 40-Lead Ceramic Qual-in-Line Package (D) Order Number INS8080AD 40-Lead Plastic Dual-in-Line Package (N) Order Number INS8080N Manufactured under one or more of the following U.S. patents: 3083262, 3189758, 3231797, 3303356, 3317671, 3323071, 3381071, 3408542, 3421025, 3426423, 3440498, 3518750, 3519897, 3557431, 3560765, 356218, 3571630, 3575609, 3597059, 3593069, 3597640, 3607469, 3617859, 3631312, 363052, 3638131, 3648071, 3651565, 3693248. National Semiconductor Corporation 2900 Semiconductor Drive, Santa Clara, California 95051, (408) 737-5000/TWX (910) 339-9240 National Semiconductor GmbH 808 Fuerstenfeldbruck, Industriestrasse 10, West Germany, Tele. (08141) 1371/Telex 05-27649 National Semiconductor (UK) Ltd. Larkfield Industrial Estate, Greenock, Scotland, Tele. (0475) 33251/Telex 778-632