# NEC Electronics Inc. 98D 14942 \(\int\) ### µPD70108 (V20™) 8/16-BIT HIGH-PERFORMANCE CMOS MICROPROCESSOR T-49-17-07 #### **Description** The $\mu$ PD70108 (V20) is a CMOS 16-bit microprocessor with internal 16-bit architecture and an 8-bit external data bus. The $\mu$ PD70108 instruction set is a superset of the $\mu$ PD8086/8088; however, mnemonics and execution times are different. The $\mu$ PD70108 additionally has a powerful instruction set including bit processing, packed BCD operations, and high-speed multiplication/division operations. The $\mu$ PD70108 can also execute the entire 8080 instruction set and comes with a standby mode that significantly reduces power consumption. It is software-compatible with the $\mu$ PD70116 16-bit microprocessor. #### **Features** - ☐ Minimum instruction execution time: 250 ns (at 8 MHz) - ☐ Maximum addressable memory: 1 Mbyte - ☐ Abundant memory addressing modes - ☐ 14 x 16-bit register set - □ 101 instructions - Instruction set is a superset of μPD8086/8088 instruction set - ☐ Bit, byte, word, and block operations - ☐ Bit field operation instructions - ☐ Packed BCD instructions - $\square$ Multiplication/division instruction execution time: 4 $\mu$ s to 6 $\mu$ s (at 8 MHz) - ☐ High-speed block transfer instructions: - 1 Mbyte/s (at 8 MHz) - ☐ High-speed calculation of effective addresses: 2 clock cycles in any addressing mode - Maskable (INT) and nonmaskable (NMI) interrupt inputs - ☐ IEEE-796 bus compatible interface - ☐ 8080 emulation mode - ☐ CMOS technology - ☐ Low-power consumption - ☐ Low-power standby mode - ☐ Single power supply - ☐ 5 MHz, 8 MHz or 10 MHz clock #### **Ordering Information** | Part<br>Number | Package Type | Max Frequency of Operation | |----------------|--------------------|----------------------------| | μPD70108C-5 | 40-pin plastic DIP | 5 MHz | | μPD70108C-8 | 40-pin plastic DIP | 8 MHz | | μPD70108D-5 | 40-pin ceramic DIP | 5 MHz | | μPD70108D-8 | 40-pin ceramic DIP | 8 MHz | | μPD70108D-10 | 40-pin ceramic DIP | 10 MHz | | μPD70108G-5 | 52-pin miniflat | 5 MHz | | μPD70108G-8 | 52-pin miniflat | 8 MHz | | μPD70108L-5 | 44-pin PLCC | 5 MHz | | μPD70108L-8 | 44-pin PLCC | 8 MHz | #### **Pin Configurations** #### 40-Pin Plastic DIP/Cerdip 98D 14943 ## 1943 **NEC** T-49-17-01 ## μPD70108 (V20) ## Pin Configurations (cont) #### 44-Pin Plastic Leadless Chip Carrier (PLCC) #### 52-Pin Plastic Miniflat #### Pin Identification | Symbol | Direction | Function | |------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------| | IC* | | internally connected | | A <sub>14</sub> - A <sub>8</sub> | Out | Address bus, middle bits | | AD <sub>7</sub> - AD <sub>0</sub> | In/Out | Address/data bus | | NMI | In | Nonmaskable interrupt<br>input | | INT | Įn . | Maskable interrupt input | | CLK | In | Clock input | | GND | | Ground potential | | RESET . | In | Reset input | | READY | In | Ready input | | POLL | ln | Poll input | | INTAK (QS <sub>1</sub> ) | Out | Interrupt acknowledge<br>output (queue status bit 1<br>output) | | ASTB (QS <sub>0</sub> ) | Out | Address strobe output (queue status bit 0 output) | | BUFEN (BS <sub>0</sub> ) | Out | Buffer enable output (bus status bit 0 output) | | BUFR/W (BS <sub>1</sub> ) | Out | Buffer read/write output<br>(bus status bit 1 output) | | 10/M (BS <sub>2</sub> ) | Out | Access is I/O or memory<br>(bus status bit 2 output) | | WR (BUSLOCK) | Out | Write strobe output (bus lock output) | | HLDAK (RQ/AK <sub>1</sub> ) | Out<br>(in/Out) | Holdacknowledgeoutput,<br>(bus hold request<br>input/acknowledge<br>output 1) | | HLDRQ (RQ/AK <sub>0</sub> ) | in<br>(In/Out) | Hold request input (bus hold request input/acknowledge output 0) | | RD | Out | Read strobe output | | S/LG | In | Small-scale/large-scale system input | | LBS <sub>0</sub> (HIGH) | Out | Latched bus status output 0<br>(always high in large-scale<br>systems) | | A <sub>19</sub> /PS <sub>3</sub> -<br>A <sub>16</sub> /PS <sub>0</sub> | Out | Address bus, high bits or processor status output | | A <sub>15</sub> | Out | Address bus, bit 15 | | V <sub>DD</sub> | | Power supply | Notes: \* IC should be connected to ground. Where pins have different functions in small- and large-scale systems, the large-scale system pin symbol and function are in parentheses. Unused input pins should be tied to ground or $V_{DD}$ to minimize power dissipation and prevent the flow of potentially harmful currents. ## 98D 14944 ## μ**PD**70108 (**V**20) T.49-17-07 6427525 0014945 5 ### 6427525 N E C ELECTRONICS INC 98D 14945 #### μPD70108 (V20) #### Pin Functions Some pins of the $\mu PD70108$ have different functions according to whether the microprocessor is used in a small- or large-scale system. Other pins function the same way in either type of system. ## A<sub>15</sub> - A<sub>8</sub> [Address Bus] For small- and large-scale systems. The CPU uses these pins to output the middle 8 bits of the 20-bit address data. They are three-state outputs and become high impedance during hold acknowledge. #### AD7 - AD0 [Address/Data Bus] For small- and large-scale systems. The CPU uses these pins as the time-multiplexed address and data bus. When high, an AD bit is a one; when low, an AD bit is a zero. This bus contains the lower 8 bits of the 20-bit address during T1 of the bus cycle and is used as an 8-bit data bus during T2, T3, and T4 of the bus cycle. Sixteen-bit data I/O is performed in two steps. The low byte is sent first, followed by the high byte. The address/data bus is a three-state bus and can be at a high or low level during standby mode. The bus will be high impedance during hold and interrupt acknowledge. #### NMI [Nonmaskable Interrupt] For small- and large-scale systems. This pin is used to input nonmaskable interrupt requests. NMI cannot be masked by software. This input is positive edge triggered and must be held high for five clocks to guarantee recognition. Actual interrupt processing begins, however, after completion of the instruction in progress. The contents of interrupt vector 2 determine the starting address for the interrupt-servicing routine. Note that a hold request will be accepted even during NMI acknowledge. This interrupt will cause the $\mu PD70108$ to exit the standby mode. #### INT [Maskable Interrupt] For small- and large-scale systems. This pin is an interrupt request that can be masked by software. INT is active high level and is sensed during the last clock of the instruction. The interrupt will be accepted if the interrupt enable flag IE is set. The CPU outputs the INTAK signal to inform external devices that the interrupt request has been granted. INT must be asserted until the interrupt acknowledge is returned. If NMI and INT interrupts occur at the same time, NMI has higher priority than INT and INT cannot be accepted. A hold request will be accepted during INT acknowledge. This interrupt causes the $\mu$ PD70108 to exit the standby mode. #### CLK [Clock] For small- and large-scale systems. This pin is used for external clock input. #### RESET [Reset] For small- and large-scale systems. This pin is used for the CPU reset signal. It is an active high level. Input of this signal has priority over all other operations. After the reset signal input returns to a low level, the CPU begins execution of the program starting at address FFFF0H. In addition to causing normal CPU start, RESET input will cause the $\mu$ PD70108 to exit the standby mode. #### READY [Ready] For small- and large-scale systems. When the memory or I/O device being accessed cannot complete data read or write within the CPU basic access time, it can generate a CPU wait state (Tw) by setting this signal to inactive (low level) and requesting a read/write cycle delay. If the READY signal is active (high level) during either the T3 or Tw state, the CPU will not generate a wait #### POLL [Poll] For small- and large-scale systems. The CPU checks this input upon execution of the POLL instruction. If the input is low, then execution continues. If the input is high, the CPU will check the POLL input every five clock cycles until the input becomes low again. The POLL and READY functions are used to synchronize CPU program execution with the operation of external devices. #### RD [Read Strobe] For small- and large-scale systems. The CPU outputs this strobe signal during data read from an I/O device or memory. The IO/M signal is used to select between I/O and memory. The three-state output is held high during standby mode and enters the high-impedance state during hold acknowledge. #### S/LG [Small/Large] For small- and large-scale systems. This signal determines the operation mode of the CPU. This signal is fixed at either a high or low level. When 98D 14946 Ď μPD70108 (V20) T-49-17-07 this signal is a high level, the CPU will operate in smallscale system mode, and when low, in the large-scale system mode. A small-scale system will have at most one bus master such as a DMA controller device on the bus. A large-scale system can have more than one bus master accessing the bus as well as the CPU. #### **INTAK** [Interrupt Acknowledge] For small-scale systems. The CPU generates the INTAK signal low when it accepts an INT signal. The interrupting device synchronizes with this signal and outputs the interrupt vector to the CPU via the data bus $(AD_7 - AD_0)$ . #### **ASTB** [Address Strobe] For small-scale systems. The CPU outputs this strobe signal to latch address information at an external latch. ASTB is held at a low level during standby mode and hold acknowledge. #### **BUFEN** [Buffer Enable] For small-scale systems. This is used as the output enable signal for an external bidirectional buffer. The CPU generates this signal during data transfer operations with external memory or I/O devices or during input of an interrupt vector. This three-state output is held high during standby mode and enters the high-impedance state during hold acknowledge. #### **BUFR/W** [Buffer Read/Write] For small-scale systems. The output of this signal determines the direction of data transfer with an external bidirectional buffer. A high output causes transmission from the CPU to the external device; a low signal causes data transfer from the external device to the CPU. $BUF\overline{R}/W$ is a three-state output and becomes high impedance during hold acknowledge. #### IO/M [IO/Memory] For small-scale systems. The CPU generates this signal to specify either I/O access or memory access. A high-level output specifies I/O and a low-level signal specifies memory. IO/M's output is three state and becomes high impedance during hold acknowledge. #### WR [Write Strobe] For small-scale systems. The CPU generates this strobe signal during data write to an I/O device or memory. Selection of either I/O or memory is performed by the IO/M signal. This three-state output is held high during standby mode and enters the high-impedance state during hold acknowledge. #### **HLDAK** [Hold Acknowledge] For small-scale systems. The HLDAK signal is used to indicate that the CPU accepts the hold request signal (HLDRQ). When this signal is a high level, the address bus, address/data bus, and the control lines become high impedance. #### **HLDRQ** [Hold Request] For small-scale systems. This input signal is used by external devices to request the CPU to release the address bus, address/data bus, and the control bus. #### LBS<sub>0</sub> [Latched Bus Status 0] For small-scale systems. The CPU uses this signal along with the IO/M and BUFR/W signals to inform an external device what the current bus cycle is. | 10/M | BUFR/W | LBSO | Bus Cycle | |------|--------|------|-----------------------| | 0 | 0 | 0 | Program fetch | | 0 | 0 | . 1 | Memory read | | 0 | 1 | 0 | Memory write | | 0 | 1 | 1 | Passive state | | 1 | 0 | 0 | Interrupt acknowledge | | 1 | 0 | 1 | I/O read | | 1 | 1 | 0 | I/O write | | 1 | 1 | 1 | Halt | ## μ**PD**70108 (**V**20) # 98D 14947 **NEC** A<sub>19</sub>/PS<sub>3</sub> - A<sub>16</sub>/PS<sub>0</sub> [Address Bus/Processor Status] For small- and large-scale systems. These pins are time multiplexed to operate as an address bus and as processor status signals. When used as the address bus, these pins are the high 4 bits of the 20-bit memory address. During I/O access, all 4 bits output data 0. The processor status signals are provided for both memory and I/O use. PS $_3$ is always 0 in the native mode and 1 in 8080 emulation mode. The interrupt enable flag (IE) is pin on pin PS $_2$ . Pins PS $_1$ and PS $_0$ indicate which memory segment is being accessed. | A <sub>17</sub> /PS <sub>1</sub> | A <sub>16</sub> /PS <sub>0</sub> | Segment | |----------------------------------|----------------------------------|-----------------| | 0 | 0 | Data segment 1 | | 0 | 1 | Stack segment | | 1 | 0 | Program segment | | 1 | . 1 | Data segment 0 | The output of these pins is three state and becomes high impedance during hold acknowledge. #### QS<sub>1</sub>, QS<sub>0</sub> [Queue Status] For large-scale systems. The CPU uses these signals to allow external devices, such as the floating-point arithmetic processor chip, ( $\mu$ PD72091) to monitor the status of the internal CPU instruction queue. | QS <sub>1</sub> | QS <sub>0</sub> | Instruction Queue Status | |-----------------|-----------------|---------------------------------| | 0 | 0 | NOP (queue does not change) | | 0 | 1 | First byte of instruction | | 1 | . 0 | Flush queue | | 1 | 1 | Subsequent bytes of instruction | The instruction queue status indicated by these signals is the status when the execution unit (EXU) accesses the instruction queue. The data output from these pins is therefore valid only for one clock cycle immediately following queue access. These status signals are provided so that the floating-point processor chip can monitor the CPU's program execution status and synchronize its operation with the CPU when control is passed to it by the FPO (Floating Point Operation) instructions. #### BS2 - BS0 [Bus Status] For large-scale systems. The CPU uses these status signals to allow an external bus controller to monitor what the current bus cycle is. The external bus controller decodes these signals and generates the control signals required to perform access of the memory or I/O device. | | | | 1 7 / - | |-----------------|-----------------|-----------------|-----------------------| | BS <sub>2</sub> | BS <sub>1</sub> | BS <sub>0</sub> | Bus Cycle | | 0 | 0 | 0 | Interrupt acknowledge | | 0 | . 0 | 1 | I/O read | | 0 | 1 | - 0 | I/O write | | 0 | 1 | 1 | Halt | | 1 | 0 | 0 | Program fetch | | 1 | 0 | 1 | Memory read | | 1 | 1 | 0 | Memory write | | 1 | 1 | 1 | Passive state | | | | | | The output of these signals is three state and becomes high impedance during hold acknowledge. #### **BUSLOCK** [Bus Lock] For large-scale systems. The CPU uses this signal to secure the bus while executing the instruction immediately following the BUSLOCK prefix instruction, or during an interrupt acknowledge cycle. It is a status signal to the other bus masters in a multiprocessor system, inhibiting them from using the system bus during this time. The output of this signal is three state and becomes high impedance during hold acknowledge. BUSLOCK is high during standby mode except if the HALT instruction has a BUSLOCK prefix. #### RQ/AK<sub>1</sub>, RQ/AK<sub>0</sub> [Hold Request/Acknowledge] For large-scale systems. These pins function as bus hold request inputs $(\overline{RQ})$ and as bus hold acknowledge outputs $(\overline{AK})$ . $\overline{RQ}/\overline{AK}_0$ has a higher priority than $\overline{RQ}/\overline{AK}_1$ . These pins have three-state outputs with on-chip pullup resistors which keep the pin at a high level when the output is high impedance. #### **VDD** [Power Supply] For small- and large-scale systems. This pin is used for the +5 V power supply. #### GND [Ground] For small- and large-scale systems. This pin is used for ground. #### IC [Internally Connected] This pin is used for tests performed at the factory by NEC. The $\mu$ PD70108 is used with this pin at ground potential. 98D 14948 ## μ**PD7**0108 (**V2**0) T-49-17-07 #### **Absolute Maximum Ratings** | I <sub>A</sub> = +25°C | | |-----------------------------------------|-----------------------------------| | Power supply voltage, V <sub>DD</sub> | -0.5 V to +7.0 V | | Power dissipation, PD <sub>MAX</sub> | 0.5 W | | Input voltage, V <sub>I</sub> | -0.5 V to V <sub>DO</sub> + 0.3 V | | CLK input voltage, V <sub>K</sub> | -0.5 V to V <sub>DD</sub> + 1.0 V | | Output voltage, V <sub>0</sub> | -0.5 V to V <sub>DD</sub> + 0.3 V | | Operating temperature, T <sub>OPT</sub> | -40°C to +85°C | | Storage temperature, T <sub>STG</sub> | -65°C to +150°C | Comment: Exposing the device to stresses above those listed in Absolute Maximum Ratings could cause permanent damage. The device is not meant to be operated under conditions outside the limits described in the operational sections of this specification. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### Capacitance $T_A = +25 \,^{\circ}\text{C}, V_{DD} = 0 \,^{\circ}\text{V}$ | | | Lic | mits | | Test | |-------------------|--------|-----|------|------|-------------------------------| | Parameter | Symbol | Min | Max | Unit | Conditions | | Input capacitance | Cı | | 15 | pF | fc = 1 MHz<br>Unmeasured pins | | I/O capacitance | CIO | | 15 | | returned to 0 V | 3 #### **DC Characteristics** μPD70108-5, $T_A = -40$ °C to +85 °C, $V_{DD} = +5$ V $\pm$ 10% μPD70108-8, μPD70108-10, $T_A = -10$ °C to +70 °C, $V_{DD} = +5$ V $\pm$ 5% | | | | Limits | | | Test | |-----------------------------|--------------------|-----------------------|--------|-----------------------|------|---------------------------------------| | Parameter | Symbol | Min | Тур | Max | Unit | Conditions | | Input voltage high | VIH | 2.2 | | V <sub>DD</sub> + 0.3 | ٧. | · · · · · · · · · · · · · · · · · · · | | Input voltage low | V <sub>IL</sub> | 0.5 | | 0.8 | ٧ | ···· | | CLK input voltage high | . V <sub>KH</sub> | 3.9 | | V <sub>DD</sub> + 1.0 | ٧ | | | CLK input voltage low | V <sub>KL</sub> | -0.5 | | 0.6 | ٧ | | | Output voltage high | V <sub>OH</sub> | 0.7 x V <sub>DD</sub> | | | ٧ | $I_{OH} = -400 \mu\text{A}$ | | Output voltage low | V <sub>OL</sub> | - | | 0.4 | V | I <sub>OL</sub> = 2.5 mA | | Input leakage current high | ILIH | | | 10 | μΑ | $V_I = V_{DD}$ | | Input leakage current low | I <sub>LIL</sub> . | | | -10 | μΑ | V <sub>I</sub> = 0 V | | Output leakage current high | ILOH | | | 10 | μΑ | $V_0 = V_{DD}$ | | Output leakage current low | ILOL | | | -10 | μΑ | V <sub>0</sub> = 0 V . | | | | 70108-5 | 30 | 60 | mA | Normal operation | | | | 5 MHz | 5 | 10 | ·mA | Standby mode | | Supply current | I <sub>DD</sub> | 70108-8 | 45 | 80 | mA | Normal operation | | ••• | 50 | 8 MHz | 6 | 12 | mA | Standby mode | | | - | 70108-10 | 60 | 100 | mA | Normal operation | | • | - | 10 MHz | 7 · | 14 | mA | Standby mode | 98D 14949 ## **μPD70108 (V20)** #### **AC Characteristics** μPD70108-5, $T_A = -40$ °C to +85 °C, $V_{DD} = +5$ V ± 10% μPD70108-8, μPD70108-10, $T_A = -10$ °C to +70 °C, $V_{DD} = +5$ V ± 5% | en e | | <b>μ</b> Ρ <b>D</b> 701 | 08-5 | μPD701 | 08-8 | μ <b>PD7</b> 01 | 08-10 | | | |------------------------------------------|--------------------|-------------------------|------|-----------------------|------|-----------------------|-------|------|----------------------------------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Unit | Conditions | | Small/Large Scale | | | | • | | | | | | | Clock cycle | tcyk | 200 | 500 | 125 | 500 | 100 | 500 | ns | | | Clock pulse width high | tKKH | 69 | | 44 | | 41 | | ns | $V_{KH} = 3.0 V$ | | Clock pulse width low | tKKL | 90 | | 60 | | 49 | | ns | V <sub>KL</sub> = 1.5 V | | Clock rise time | t <sub>KR</sub> | • | 10 | | 8 | | 5 | ns | 1.5 V to 3.0 V | | Clock fall time | t <sub>KF</sub> | | 10 | | 7 | | 5 | ns | 3.0 V to 1.5 V | | READY inactive setup to CLK | tSRYLK | -8 | | -8 | 3 | -10 | | ns | | | READY inactive hold after CLK1 | thkryh | 30 | | 20 | | 20 | | ns | | | READY active setup to CLK1 | tsryhk | t <sub>KKL</sub> - 8 | | t <sub>KKL</sub> - 8 | | t <sub>KKL</sub> -10 | | ns | | | READY active hold after CLKT | tHKRYL | 30 | | 20 | | 20 | | ns | | | Data setup time to CLK ↓ | tsdk | 30 | | 20 | | 10 | | ns | | | Data hold time after CLK ↓ | thkd | 10 | | 10 | | 10 | | ns | • | | NMI, INT, POLL setup time<br>to CLK 1 | tsik | 30 | | 15 | | 15 | | ns | | | Input rise time (except CLK) | t <sub>IR</sub> | | 20 | | 20 | | 20 | ns | 0.8 V to 2.2 V | | Input fall time (except CLK) | tjF | | 12 | | 12 | | 12 | ns | 2.2 V to 0.8 V | | Output rise time | tor | | 20 | | 20 | | 20 | nş | 0.8 V to 2.2 V | | Output fall time | toF | | 12 | | 12 | | 12 | ns | 2.2 V to 0.8 V | | Small Scale | | · · · · · · | | | | | | | | | Address delay time from CLK | t <sub>DKA</sub> | 10 | 90 | 10 | 60 | 10 | 48 | ns | | | Address hold time from CLK | t <sub>HKA</sub> | 10 | | 10 | | 10 | | ns | | | PS delay time from CLK ↓ | tDKP | 10 | 90 | 10 | 60 | 10 | 50 | ns | - | | PS float delay time from CLK 1 | t <sub>FKP</sub> | 10 | 80 | 10 | 60 | 10 | 50 | ns | | | Address setup time to ASTB↓ | †SAST | t <sub>KKL</sub> 60 | | t <sub>KKL</sub> — 30 | | t <sub>KKL</sub> - 30 | | ns | | | Address float delay time from<br>CLK | t <sub>FKA</sub> | t <sub>HKA</sub> | 80 | t <sub>HKA</sub> | 60 | t <sub>HKA</sub> | 50 | ns | $\mathrm{C_L} = 100~\mathrm{pF}$ | | ASTB ↑ delay time from CLK ↓ | toksth | , | 80 | | 50 | | 40 | ns | | | ASTB ↓ delay time from CLK ↑ | t <sub>DKSTL</sub> | | 85 | | 55 | | 45 | ns | | | ASTB width high | tstst | t <sub>KKL</sub> - 20 | | t <sub>KKL</sub> — 10 | | t <sub>KKL</sub> - 10 | | ns | | | Address hold time from ASTB | tHSTA | t <sub>KKH</sub> 10 | | t <sub>KKH</sub> — 10 | | t <sub>KKH</sub> -10 | | ns | | 98D 14950 μ**PD7**0108 (**V2**0) T.49-17-07 AC Characteristics (cont) $\mu$ PD70108-5, $T_A = -40$ °C to +85°C, $V_{DD} = +5$ V $\pm$ 10% $\mu$ PD70108-8, $\mu$ PD70108-10, $T_A = -10$ °C to +70°C, $V_{DD} = +5$ V $\pm$ 5% | that I to I to | | | μ <b>PD7</b> 01 | 08-5 | μ <b>PD70</b> 1 | 08-8 | μ <b>P</b> 0701 | 08-10 | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------|-----------------------|------|-----------------------|------|-----------------------|-------|------|-------------------------| | Control delay time from CLK | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Unit | Conditions | | Address float to RDI | Small Scale (cont) | | | | ··· | | <del></del> | | | <del></del> | | Address float to RD↓ tafRL 0 0 0 0 ns RD↓ delay time from CLK ↓ tokRL 10 165 10 80 10 70 ns RD↓ delay time from CLK ↓ tokRH 10 150 10 80 10 60 ns Address delay time from RD↓ tokRH 10 150 10 80 10 60 ns Data output delay time from CLK ↓ tokRH 10 90 10 60 10 50 ns Data dload delay time from CLK ↓ tokNH 35 20 20 ns 10 80 10 60 10 50 ns Data dload delay time from CLK ↓ tokNH 35 20 20 ns 10 10 10 10 ns Data dload delay time from CLK ↓ tokNH 10 160 10 10 10 ns 10 ns 10 ns 10 ns 10 ns | Control delay time from CLK | tDKCT | 10 | 110 | 10 | 65 | 10 | 55 | ns | | | RD delay time from CLK | Address float to RD↓ | | 0 | | 0 | | 0 | | ns | | | Address delay time from RD 1 | RD ↓ delay time from CLK ↓ | t <sub>DKRL</sub> | 10 | 165 | 10 | 80 | 10 | 70 | ns | | | RD width low | RD ↑ delay time from CLK ↓ | t <sub>DKRH</sub> | 10 | 150 | 10 | 80 | 10 | 60 | ns | | | RD width low | Address delay time from RD 1 | torha | t <sub>CYK</sub> - 45 | | t <sub>CYK</sub> 40 | - | t <sub>CYK</sub> 35 | | ns | | | Date output delay time from CLK ↓ toko 10 90 10 60 10 50 ns Data float delay time from CLK ↓ text 10 80 10 60 10 50 ns HLDRD stup time to CLK ↑ text 2tcyk−60 2tcyk−40 2tcyk−35 ns HLDRD stup time to CLK ↑ text 15 Hb 35 20 20 ns HLDRD stup time from CLK ↓ text 10 Hb 160 10 100 10 60 ns HLDRD stup time from CLK ↓ text 10 Hb 160 10 100 10 60 ns HLDRD stup time from CLK ↓ text 10 Hk 10 10 10 60 ns Address delay time from CLK ↓ text 10 Mk 10 10 10 ns PS float delay time from CLK ↓ text text text 4tkA 80 text 50 ns PS float delay time from CLK ↓ text text text | RD width low | t <sub>RR</sub> | | | | | | | ns | C <sub>1</sub> = 100 pF | | Victor V | Data output delay time from CLK ↓ | t <sub>DKD</sub> | | 90 | | 60 | | 50 | ns | 2 | | HLDRO setup time to CLK | Data float delay time from CLK | t <sub>FKD</sub> | 10 | 80 | 10 | 60 | 10 | 50 | ns | | | HLDRQ setup time to CLK tokha 10 160 10 100 10 60 ns | WR width low | t <sub>WW</sub> | 2t <sub>CYK</sub> -60 | · | 2t <sub>CYK</sub> -40 | | 2t <sub>CYK</sub> -35 | | ns | | | Large Scale Address delay time from CLK total 10 90 10 60 10 48 ns Address hold time from CLK total total 10 10 10 ns PS delay time from CLK total total total 10 60 10 50 ns PS float delay time from CLK total total total 60 10 50 ns Address float delay time from CLK total total total 60 total 50 ns Address float delay time from RD total total total 60 total 50 ns Address delay time from BD total total total total 60 total 50 ns ASTB delay time from BD total total total 10 10 60 10 50 ns BB total delay time from CLK total total total total 10 65 10 50 ns BB total delay time from CLK total total total total 10 80 10 70 <td>HLDRQ setup time to CLK 1</td> <td>tshak</td> <td></td> <td>***</td> <td></td> <td></td> <td>·</td> <td></td> <td>ns</td> <td></td> | HLDRQ setup time to CLK 1 | tshak | | *** | | | · | | ns | | | Address delay time from CLK | HLDAK delay time from CLK ↓ | t <sub>DKHA</sub> | 10 | 160 | 10 | 100 | 10 | 60 | ns | | | Address hold time from CLK | Large Scale | | | | | | | | | | | PS delay time from CLK \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from CLK \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from CLK \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from CLK \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from \$\frac{1}{10000}\$ to \$0 10 50 ns PS float delay time from \$\frac{1}{100000}\$ to \$0 10 50 ns PS float delay time from \$\frac{1}{10000000000000000000000000000000000 | Address delay time from CLK | tDKA | 10 | 90 | 10 | 60 | 10 | 48 | ns | | | PS float delay time from CLK ↑ tFKP 10 80 10 60 10 50 ns Address float delay time from tFKA tHKA 80 tHKA 60 tHKA 50 ns Address float delay time from RD ↑ tDRHA tCYK - 45 tCYK - 40 tCYK - 35 ns ASTB delay time from BS ↓ tDBST 15 15 ns BS ↓ delay time from CLK ↑ tDKBL 10 110 10 60 10 50 ns BS ↑ delay time from CLK ↓ tDKBH 10 130 10 65 10 50 ns BS ↑ delay time from address tDAFRL 0 0 0 ns RD ↓ delay time from CLK ↓ tDKRL 10 165 10 80 10 70 ns RD ↓ delay time from CLK ↓ tDKRH 10 150 10 80 10 60 ns RD ↓ delay time from CLK ↓ tDKRH 10 150 10 80 10 60 ns RD ↓ delay time from CLK ↓ tDKRH 10 150 10 80 10 50 ns Date output delay time from tDKD 10 90 10 60 10 50 ns CLK ↓ AK delay time from CLK ↓ tDKAK 70 50 40 ns TO setup time from CLK ↓ tDKAK 70 50 40 ns TO setup time from CLK ↓ tDKAK 70 50 40 ns | Address hold time from CLK | thka | 10 | | 10 | | 10 | | ns | | | Address float delay time from that the term | PS delay time from CLK ↓ | toke | 10 | 90 | 10 | 60 | 10 | 50 | ns | | | Address delay time from $\overline{RD}$ $t_{DRHA}$ $t_{CYK} - 45$ $t_{CYK} - 40$ $t_{CYK} - 35$ $ | PS float delay time from CLK 1 | t <sub>FKP</sub> | 10 | 80 | 10 | 60 | 10 | 50 | ns | | | ASTB delay time from BS \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | t <sub>FKA</sub> | thka | 80 | thka | 60 | tHKA | 50 | ns | | | ASTB delay time from BS \ \ \ \text{tobst} \text{tobst} \ \text{tobst} \ \ \text{tobst} \ \ \text{tobst} \ \ \text{tobst} \ \text{tobst} \ \text{tobst} \ \text{tobst} \ \ \text{tobst} \t | Address delay time from RD 1 | †DRHA | t <sub>CYK</sub> 45 | | t <sub>CYK</sub> - 40 | | t <sub>CYK</sub> -35 | | ns | | | BS † delay time from CLK ↓ tDKBH 10 130 10 65 10 50 ns CL = 100 pF RD ↓ delay time from CLK ↓ tDKRL 10 165 10 80 10 70 ns RD ↓ delay time from CLK ↓ tDKRL 10 150 10 80 10 60 ns RD ↓ delay time from CLK ↓ tDKRH 10 150 10 80 10 60 ns RD width low tRR 2tcYK-75 2tcYK-50 2tcYK-40 ns Date output delay time from tDKD 10 90 10 60 10 50 ns CLK ↓ Data float delay time from CLK ↓ tDKAK 70 50 40 ns RD delay time from CLK ↓ tDKAK 70 50 40 ns RD delay time from CLK ↓ tDKAK 70 50 40 ns RD delay time from CLK ↓ tDKAK 70 50 40 ns RD delay time from CLK ↓ tDKAK 70 50 40 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK ↓ tDKAK 70 9 ns RD delay time from CLK 10 ps | ASTB delay time from BS \ | t <sub>DBST</sub> | | 15 | | 15 | | 15 | ns | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | BS ↓ delay time from CLK ↑ | †DKBL | 10 | 110 | 10 | 60 | 10 | 50 | ns | | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | BS † delay time from CLK ↓ | t <sub>DKBH</sub> | 10 | 130 | 10 | 65 | 10 | 50 | | | | RD | | †DAFRL | 0 | | 0 | | 0 | | | $C_L = 100 \ pF$ | | RD width low t_{RR} 2t_{CYK}-75 2t_{CYK}-50 2t_{CYK}-40 ns | RD ↓ delay time from CLK ↓ | tDKRL | 10 | 165 | 10 | 80 | 10 | 70 | ns | | | RD width low | RD † delay time from CLK ↓ | tDKRH | 10 | 150 | 10 | 80 | 10 | 60 | ns | | | Date output delay time from tDKD 10 90 10 60 10 50 ns CLK ↓ Data float delay time from tFKD 10 80 10 60 10 50 ns CLK ↑ AK delay time from CLK ↓ tDKAK 70 50 40 ns RQ setup time to CLK ↑ tSROK 20 10 9 ns | RD width low | | 2t <sub>CYK</sub> -75 | | 2t <sub>CYK</sub> -50 | | 2t <sub>CYK</sub> -40 | | ns | | | CLK ↑ AK delay time from CLK ↓ t <sub>DKAK</sub> 70 50 40 ns RO setup time to CLK ↑ t <sub>SROK</sub> 20 10 9 ns | | t <sub>DKD</sub> | | 90 | | 60 | | 50 | ns | | | RG setup time to CLK 1 t <sub>SROK</sub> 20 10 9 ns | CLK 1 | t <sub>FKD</sub> | 10 | 80 | 10 | 60 | 10 | 50 | ns | | | RO setup time to CLK 1 - t <sub>SROK</sub> 20 10 9 ns | AK delay time from CLK 4 | tDKAK | | 70 | - | 50 | | 40 | ns | | | RQ hold time after CLK 1 tHKRQ 40 30 20 ns | RQ setup time to CLK 1 | | 20 | | 10 | | 9 | | ns | | | | RQ hold time after CLK 1 | thkra | 40 | | 30 | | 20 | | ns | | 98D 14951 ## μ**PD7**0108 (**V20**) #### **Timing Waveforms** 98D 14952 5 NEC μ**PD**70108 (**V**20) T-49-17-07 ### **Timing Waveforms (cont)** 98D 14953 ## μ**PD70108 (V20)** #### Timing Waveforms (cont) 98D 14954 j D $\mu$ PD70108 (V20) T-49-17-07 ### **Timing Waveforms (cont)** 3 98D 14955 #### μPD70108 (V20) #### Register Configuration #### Program Counter [PC] The program counter is a 16-bit binary counter that contains the segment offset address of the next instruction which the EXU is to execute. The PC increments each time the microprogram fetches an instruction from the instruction queue. A new location value is loaded into the PC each time a branch, call, return, or break instruction is executed. At this time, the contents of the PC are the same as the Prefetch Pointer (PFP). #### Prefetch Pointer [PFP] The prefetch pointer (PFP) is a 16-bit binary counter which contains a segment offset which is used to calculate a program memory address that the bus control unit (BCU) uses to prefetch the next byte for the instruction queue. The contents of PFP are an offset from the PS (Program Segment) register. The PFP is incremented each time the BCU prefetches an instruction from the program memory. A new location will be loaded into the PFP whenever a branch, call, return, or break instruction is executed. At that time the contents of the PFP will be the same as those of the PC (Program Counter). #### Segment Registers [PS, SS, DS<sub>0</sub>, and DS<sub>1</sub>] The memory addresses accessed by the $\mu$ PD70108 are divided into 64K-byte logical segments. The starting (base) address of each segment is specified by a 16-bit segment register, and the offset from this starting address is specified by the contents of another register or by the effective address. These are the four types of segment registers used. | Segment Register | Default Offset | |----------------------------------|-----------------------| | PS (Program Segment) | PFP | | SS (Stack Segment) | SP, effective address | | DS <sub>0</sub> (Data Segment 0) | IX, effective address | | DS <sub>1</sub> (Data Segment 1) | ΙΥ | #### General-Purpose Registers [AW, BW, CW, and DW] There are four 16-bit general-purpose registers. Each one can be used as one 16-bit register or as two 8-bit registers by dividing them into their high and low bytes (AH, AL, BH, BL, CH, CL, DH, DL). Each register is also used as a default register for processing specific instructions. The default assignments are: AW: Word multiplication/division, word I/O, data conversion AL: Byte multiplication/division, byte I/O, BCD rotation, data conversion, translation AH: Byte multiplication/division BW: Translation CW: Loop control branch, repeat prefix CL: Shift instructions, rototation instructions, BCD operations DW: Word multiplication/division, indirect addressing I/O #### Pointers [SP, BP] and Index Registers [IX, IY] These registers serve as base pointers or index registers when accessing the memory using based addressing, indexed addressing, or based indexed addressing. These registers can also be used for data transfer and arithmetic and logical operations in the same manner as the general-purpose registers. They cannot be used as 8-bit registers. Also, each of these registers acts as a default register for specific operations. The default assignments are: SP: Stack operations IX: Block transfer (source), BCD string operations IY: Block transfer (destination), BCD string operations #### Program Status Word [PSW] The program status word consists of the following six status and four control flags. #### Status Flags - V (Overflow) - S (Sign) - Z (Zero) - AC (Auxiliary Carry) - P (Parity) - CY (Carry) #### **Control Flags** - MD (Mode) - DIR (Direction) • IE (Interrupt Enable) - BRK (Break) When the PSW is pushed on the stack, the word images of the various flags are as shown here. #### PSW 15 M D В S Z 0 Đ Ε R The status flags are set and reset depending upon the result of each type of instruction executed. Instructions are provided to set, reset, and complement the CY flag directly. Other instructions set and reset the control flags and control the operation of the CPU. 98D 14956 ## $\mu$ PD70108 (V20) T-49-17-07 #### High-Speed Execution of Instructions This section highlights the major architectural features that enhance the performance of the $\mu$ PD70108. - Dual data bus in EXU - Effective address generator - 16/32-bit temporary registers/shifters (TA, TB) - 16-bit loop counter - PC and PFP #### **Dual Data Bus Method** To reduce the number of processing steps for instruction execution, the dual data bus method has been adopted for the $\mu$ PD70108 (figure 1). The two data buses (the main data bus and the subdata bus) are both 16 bits wide. For addition/subtraction and logical and comparison operations, processing time has been speeded up some 30% over single-bus systems. Figure 1. Dual Data Buses #### Example ADD AW, BW ; AW ← AW + BW Single Bus **Dual Bus** Step 1 TA ← AW TA ← AW, TB ← BW Step 2 TB ← BW AW ← TA + TB Step 3 AW ← TA + TB #### **Effective Address Generator** This circuit (figure 2) performs high-speed processing to calculate effective addresses for accessing memory. Calculating an effective address by the microprogramming method normally requires 5 to 12 clock cycles. This circuit requires only two clock cycles for addresses to be generated for any addressing mode. Thus, processing is several times faster. Figure 2. Effective Address Generator #### 16/32-Bit Temporary Registers/Shifters [TA, TB] These 16-bit temporary registers/shifters (TA, TB) are provided for multiplication/division and shift/ rotation instructions. These circuits have decreased the execution time of multiplication/division instructions. In fact, these instructions can be executed about four times faster than with the microprogramming method. TA + TB: 32-bit temporary register/shifter for multiplication and division instructions. TB: 16-bit temporary register/shifter for shift/rotation instructions. ## μPD70108 (V20) #### Loop Counter [LC] This counter is used to count the number of loops for a primitive block transfer instruction controlled by a repeat prefix instruction and the number of shifts that will be performed for a multiple bit shift/rotation instruction. 6427525 N E C ELECTRONICS INC The processing performed for a multiple bit rotation of a register is shown below. The average speed is approximately doubled over the microprogram method. #### Example RORC AW, CL ; CL = 5 Microprogram method LC method $8 + (4 \times 5) = 28 \text{ clocks}$ 7 + 5 = 12 clocks #### Program Counter and Prefetch Pointer [PC and PFP] The µPD70108 microprocessor has a program counter, (PC) which addresses the program memory location of the instruction to be executed next, and a prefetch pointer(PFP), which addresses the program memory location to be accessed next. Both functions are provided in hardware. A time saving of several clocks is realized for branch, call, return, and break instruction execution, compared with microprocessors that have only one instruction pointer. #### **Enhanced Instructions** In addition to the $\mu$ PD8088/86 instructions, the $\mu$ PD70108 has the following enhanced instructions. | Instruction | Function | |-------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | PUSH imm | Pushes immediate data onto stack | | PUSH R | Pushes 8 general registers onto stack | | POP R | Pops 8 general registers from stack | | MUL imm | Executes 16-bit multiply of register or memory contents by immediate data | | SHL imm8<br>SHR imm8<br>SHRA imm8<br>ROL imm8<br>ROR imm8<br>ROLC imm8<br>RORC imm8 | Shifts/rotates register or memory by immediate value | | CHKIND | Checks array index against designated boundaries | | INM | Moves a string from an I/O port to memory | | OUTM | Moves a string from memory to an I/O port | | PREPARE | Allocates an area for a stack frame and copies previous frame pointers | | DISPOSE | Frees the current stack frame on a procedure exit | ## Enhanced Stack Operation Instructions PUSH imm This instruction allows immediate data to be pushed onto the stack. #### **PUSH R/POP R** These instructions allow the contents of the eight general registers to be pushed onto or popped from the stack with a single instruction. ## Enhanced Multiplication Instructions MUL reg16, imm16/MUL mem16, imm16 These instructions allow the contents of a register or memory location to be 16-bit multiplied by immediate data. ## Enhanced Shift and Rotate Instructions SHL reg, imm8/SHR reg, imm8/SHRA reg, imm8 These instructions allow the contents of a register to be shifted by the number of bits defined by the immediate data ## ROL reg, imm8/ROR reg, imm8/ROLC reg, imm8/RORC reg, imm8 These instructions allow the contents of a register to be rotated by the number of bits defined by the immediate data. ## Check Array Boundary Instruction CHKIND reg16, mem32 This instruction is used to verify that index values pointing to the elements of an array data structure are within the defined range. The lower limit of the array should be in memory location mem32, the upper limit in mem32 + 2. If the index value in reg16 is not between these limits when CHKIND is executed, a BRK 5 will occur. This causes a jump to the location in interrupt vector 5. #### **Block I/O Instructions** #### OUTM DW, src-block/INM dst-block, DW These instructions are used to output or input a string to or from memory, when preceded by a repeat prefix. #### **Stack Frame Instructions** #### PREPARE imm16, imm8 This instruction is used to generate the stack frames required by block-structured languages, such as PASCAL and Ada. The stack frame consists of two areas. One area has a pointer that points to another frame which has variables that the current frame can access. The other is a local variable area for the current procedure. ## NEC 98D 14958 **D** Τ· 49-17-07 μ**PD70108 (V20)** #### DISPOSE This instruction releases the last stack frame generated by the PREPARE instruction. It returns the stack and base pointers to the values they had before the PREPARE instruction was used to call a procedure. #### Unique Instructions In addition to the $\mu$ PD8088/86 instructions and the enhanced instructions, the $\mu$ PD70108 has the following unique instructions. | Instruction | Function | |-------------|-----------------------------------------------------| | INS | Insert bit field | | EXT | Extract bit field | | ADD4S | Adds packed decimal strings | | SUB4S | Subtracts one packed decimal string from another | | CMP4S | Compares two packed decimal strings | | ROL4 | Rotates one BCD digit left through AL lower 4 bits | | ROR4 | Rotates one BCD digit right through AL lower 4 bits | | TEST1 | Tests a specified bit and sets/resets Z flag | | NOT1 | Inverts a specified bit | | CLR1 | Clears a specified bit | | SET1 | Sets a specified bit | | REPC | Repeats next Instruction until CY flag is cleared | | REPNC | Repeats next instruction until CY flag is set | | FP02 | Additional floating point processor call | #### Variable Length Bit Field Operation Instructions This category has two instructions: INS (Insert Bit Field) and EXT (Extract Bit Field). These instructions are highly effective for computer graphics and highlevel languages. They can, for example, be used for data structures such as packed arrays and record type data used in PASCAL. #### INS reg8, reg8/INS reg8, imm4 This instruction (figure 3) transfers low bits from the 16-bit AW register (the number of bits is specified by the second operand) to the memory location specified by the segment base (DS<sub>1</sub> register) plus the byte offset (IY register). The starting bit position within this byte is specified as an offset by the lower 4-bits of the first operand. After each complete data transfer, the IY register and the register specified by the first operand are automatically updated to point to the next bit field. Either immediate data or a register may specify the number of bits transferred (second operand). Because the maximum transferable bit length is 16-bits, only the lower 4-bits of the specified register (00H to 0FH) will be valid. Bit field data may overlap the byte boundary of memory. 33 #### μPD70108 (V20) #### EXT reg8, reg8/EXT reg8, imm4 This instruction (figure 4) loads to the AW register the bit field data whose bit length is specified by the second operand of the instruction from the memory location that is specified by the DS0 segment register (segment base), the IX index register (byte offset), and the lower 4-bits of the first operand (bit offset). After the transfer is complete, the IX register and the lower 4-bits of the first operand are automatically updated to point to the next bit field. Either immediate data or a register may be specified for the second operand. Because the maximum transferrable bit length is 16 bits, however, only the lower 4-bits of the specified register (0H to 0FH) will be valid. Bit field data may overlap the byte boundary of memory. #### **Packed BCD Operation Instructions** The instructions described here process packed BCD data either as strings (ADD4S, SUB4S, CMP4S) or byte-format operands (ROR4, ROL4). Packed BCD strings may be from 1 to 254 digits in length. When the number of digits is even, the zero and carry flags will be set according to the result of the operation. When the number of digits is odd, the zero and carry flags may not be set correctly in this case, (CL = odd), the zero flag will not be set unless the upper 4 bits of the highest byte are all zero. The carry flag will not be set unless there is a carry out of the upper 4 bits of the highest byte. When CL is odd, the contents of the upper 4 bits of the highest byte of the result are undefined. #### ADD4S This instruction adds the packed BCD string addressed by the IX index register to the packed BCD string addressed by the IY index register, and stores the result in the string addressed by the IY register. The length of the string (number of BCD digits) is specified by the CL register, and the result of the operation will affect the overflow flag (V), the carry flag (CY), and zero flag (Z). BCD string (IY, CL) $\leftarrow$ BCD string (IY, CL) + BCD string (IX, CL) #### SUB4S This instruction subtracts the packed BCD string addressed by the IX index register from the packed BCD string addressed by the IY register, and stores the result in the string addressed by the IY register. The length of the string (number of BCD digits) is specified by the CL register, and the result of the operation will affect the overflow flag (V), the carry flag (CY), and zero flag (Z). BCD string (IY, CL) $\leftarrow$ BCD string (IY, CL) - BCD String (IX, CL) #### CMP4S This instruction performs the same operation as SUB4S except that the resulf is not stored and only the overflow (V), carry flags (CY) and zero flag (Z) are affected. BCD string (IY, CL) - BCD string (IX, CL) Figure 4. Bit Field Extraction ## NEC 98D 14960 D μ**PD7**0108 (V20) — Τ-49-/フ-*ο*7 #### ROL4 This instruction (figure 5) treats the byte data of the register or memory directly specified by the instruction byte as BCD data and uses the lower 4-bits of the AL register (AL<sub>L</sub>) to rotate that data one BCD digit to the Figure 5. BCD Rotate Left (ROL4) #### ROR4 This instruction (figure 6) treats the byte data of the register or memory directly specified by the instruction byte as BCD data and uses the lower 4-bits of the AL register (AL<sub>L</sub>) to rotate that data one BCD digit to the right. Figure 6. BCD Rotate Right (ROR4) #### **Bit Manipulation Instructions** #### TEST1 This instruction tests a specific bit in a register or memory location. If the bit is 1, the Z flag is reset to 0. If the bit is 0, the Z flag is set to 1. #### NOT1 This instruction inverts a specific bit in a register or memory location. #### CLR1 This instruction clears a specific bit in a register or memory location. #### SET<sub>1</sub> This instruction sets a specific bit in a register or memory location. #### Repeat Prefix Instructions #### REPC This instruction causes the $\mu$ PD70108 to repeat the following primitive block transfer instruction until the CY flag becomes cleared or the CW register becomes zero. #### REPNC This instruction causes the $\mu$ PD70108 to repeat the following primitive block transfer instruction until the CY flag becomes set or the CW register is decremented to zero. #### Floating Point Instruction #### FPO<sub>2</sub> This instruction is in addition to the $\mu$ PD8088/86 floating point instruction, FPO1. These instructions are covered in a later section. #### **Mode Operation Instructions** The $\mu$ PD70108 has two operating modes (figure 7). One is the native mode which executes $\mu$ PD8088/86, enhanced and unique instructions. The other is the 8080 emulation mode in which the instruction set of the $\mu$ PD8080AF is emulated. A mode flag (MD) is provided to select between these two modes. Native mode is selected when MD is 1 and emulation mode when MD is 0. MD is set and reset, directly and indirectly, by executing the mode manipulation instructions. Two instructions are provided to switch operation from the native mode to the emulation mode and back: BRKEM (Break for Emulation), and RETEM (Return from Emulation). Two instructions are used to switch from the emulation mode to the native mode and back: CALLN (Call Native Routine), and RETI (Return from Interrupt). The system will return from the 8080 emulation mode to the native mode when the RESET signal is present, or when an external interrupt (NMI or INT) is present. Figure 7. V20 Modes #### 98D 14961 # NEC ### μPD70108 (V20) #### **BRKEM imm8** This is the basic instruction used to start the 8080 emulation mode. This instruction operates exactly the same as the BRK instruction, except that BRKEM resets the mode flag (MD) to 0. PSW, PS, and PC are saved to the stack. MD is then reset and the interrupt vector specified by the operand imm8 of this command is loaded into PS and PC. The instruction codes of the interrupt processing routine jumped to are then fetched. Then the CPU executes these codes as $\mu$ PD8080AF instructions. In 8080 emulation mode, registers and flags of the $\mu$ PD8080AF are performed by the following registers and flags of the $\mu$ PD70108. | • | μ <b>PD8080AF</b> | μPD70108 | |------------|-------------------|----------| | Registers: | A | AL | | et e | В. | CH | | | · C | CL | | | D | DH | | | E | DL | | | Н | ВН | | | L | BL | | | SP | . ВР | | | PC | - PC | | Flags: | С | CY | | | Z | Z | | | S | S | | | P | Р | | | AC | AC | In the native mode, SP is used for the stack pointer. In the 8080 emulation mode this function is performed by BP. This use of independent stack pointers allows independent stack areas to be secured for each mode and keeps the stack of one of the modes from being destroyed by an erroneous stack operation in the other mode. The SP, IX, IY and AH registers and the four segment registers (PS, SS, DS<sub>0</sub>, and DS<sub>1</sub>) used in the native mode are not affected by operations in 8080 emulation mode. In the 8080 emulation mode, the segment register for instructions is determined by the PS register (set automatically by the interrupt vector) and the segment register for data is the $DS_0$ register (set by the programmer immediately before the 8080 emulation mode is entered). It is prohibited to nest BRKEM instructions. #### RETEM [no operand] When RETEM is executed in 8080 emulation mode (interpreted by the CPU as a $\mu$ PD8080AF instruction), the CPU restores PS, PC, and PSW (as it would when returning from an interrupt processing routine), and returns to the native mode. At the same time, the contents of the mode flag (MD) which was saved to the stack by the BRKEM instruction, is restored to MD = 1. The CPU is set to the native mode. #### **CALLN imm8** This instruction makes it possible to call the native mode subroutines from the 8080 emulation mode. To return from subroutine to the emulation mode, the RETI instruction is used. The processing performed when this instruction is executed in the 8080 emulation mode (it is interpreted by the CPU as $\mu$ PD8080AF instruction), is similar to that performed when a BRK instruction is executed in the native mode. The imm8 operand specifies an interrupt vector type. The contents of PS, PC, and PSW are pushed on the stack and an MD flag value of 0 is saved. The mode flag is set to 1 and the interrupt vector specified by the operand is loaded into PS and PC. #### RETI [no operand] This is a general-purpose instruction used to return from interrupt routines entered by the BRK instruction or by an external interrupt in the native mode. When this instruction is executed at the end of a subroutine entered by the execution of the CALLN instruction, the operation that restores PS, PC, and PSW is exactly the same as the native mode execution. When PSW is restored, however, the 8080 emulation mode value of the mode flag (MD) is restored, the CPU is set in emulation mode, and all subsequent instructions are interpreted and executed as $\mu$ PD8080AF instructions. RETI is also used to return from an interrupt procedure initiated by an NMI or INT interrupt in the emulation mode. ## Floating Point Operation Chip Instructions #### FPO1 fp-op, mem/FPO2 fp-op, mem These instructions are used for the external floating point processor. The floating point operation is passed to the floating point processor when the CPU fetches one of these instructions. From this point the CPU performs only the necessary auxiliary processing (effective address calculation, generation of physical addresses, and start-up of the memory read cycle). ## NEC ## 6427525 N E C ELECTRONICS INC 98D 14962 **D**T-49-17-07 μ**PD70108 (V20)** The floating point processor always monitors the instructions fetched by the CPU. When it interprets one as an instruction to itself, it performs the appropriate processing. At this time, the floating point processor chip uses either the address alone or both the address and read data of the memory read cycle executed by the CPU. This difference in the data used depends on which of these instructions is executed. Note: During the memory read cycle Initiated by the CPU for FPO1 or FPO2 execution, the CPU does not accept any read data on the data bus from memory. Although the CPU generates the memory address, the data is used by the floating point processor. #### **Interrupt Operation** The interrupts used in the $\mu$ PD70108 can be divided into two types: interrupts generated by external interrupt requests and interrupts generated by software processing. These are the classifications. #### **External Interrupts** - (a) NMI input (nonmaskable) - (b) INT input (maskable) #### **Software Processing** As the result of instruction execution - When a divide error occurs during execution of the DIV or DIVU instruction - When a memory-boundary-over error is detected by the CHKIND instruction #### Conditional break instruction When V = 1 during execution of the BRKV instruction #### Unconditional break instructions - 1-byte break instruction: BRK3 - 2-byte break instruction: BRK imm8 #### Flag processing When stack operations are used to set the BRK flag #### 8080 Emulation mode instructions - BRKEM imm8 - CALLN imm8 #### **Interrupt Vectors** Starting addresses for interrupt processing routines are either determined automatically by a single location of the interrupt vector table or selected each time interrupt processing is entered. The interrupt vector table is shown in figure 8. The table uses 1K bytes of memory addresses 000H to 3FFH and can store starting address data for a maximum of 256 vectors (4 bytes per vector). The corresponding interrupt sources for vectors 0 to 5 are predetermined and vectors 6 to 31 are reserved. These vectors consequently cannot be used for general applications. The BRKEM instruction and CALLN instruction (in the emulation mode) and the INT input are available for general applications for vectors 32 to 255. A single interrupt vector is made up of 4 bytes (figure 9). The 2 bytes in the low addresses of memory are loaded into PC as the offset, and the high 2 bytes are loaded into PS as the base address. The bytes are combined in reverse order. The lower-order bytes in the vector become the most significant bytes in the PC and PS, and the higher-order bytes become the least significant bytes. Figure 8. Interrupt Vector Table Figure 9. Interrupt Vector 0 98D 14963 ## NEC #### μ**PD7**0108 (V20) Based on this format, the contents of each vector should be initialized at the beginning of the program. The basic steps to jump to an interrupt processing routine are now shown. $(SP-1, SP-2) \leftarrow PSW$ $(SP-3, SP-4) \leftarrow PS$ $(SP-5, SP-6) \leftarrow PC$ $SP \leftarrow SP-6$ $IE \leftarrow 0, BRK \leftarrow 0, MD \leftarrow 1$ $PS \leftarrow vector high bytes$ $PC \leftarrow vector low bytes$ #### **Standby Function** The µPD70108 has a standby mode to reduce power consumption during program wait states. This mode is set by the HALT instruction in both the native and the emulation mode. In the standby mode, the internal clock is supplied only to those circuits related to functions required to release this mode and bus hold control functions. As a result, power consumption can be reduced to 1/10 the level of normal operation in either native or emulation mode. The standby mode is released by inputting a RESET signal or an external interrupt (NMI, INT). The bus hold function is effective during standby mode. The CPU returns to standby mode when the bus hold request is removed. During standby mode, all control outputs are disabled and the addres/data bus will be at either high or low levels. #### **Instruction Set** #### **Symbols** Preceding the instruction set, several tables explain symbols, abbreviations, and codes. #### Clocks In the Clocks column of the instruction set, the numbers cover these operations: instruction decoding, effective address calculation, operand fetch, and instruction execution. Clock timings assume the instruction has been prefetched and is present in the four-byte instruction queue. Otherwise, add four clocks for each byte not present For instructions that reference memory operands, the number on the left side of the slash (/) is for byte operands and the number on the right side is for word operands. For conditional control transfer or branch instructions, the number on the left side of the slash is applicable if the transfer or branch takes place. The number on the right side is applicable if it does not take place. If a range of numbers is given, the execution time depends on the operands involved. #### Symbols | Syllibols | | | | | |-------------|-----------------------------------------------------------------------------|--|--|--| | Symbol | Meaning | | | | | acc | Accumulator (AW or AL) | | | | | disp | Displacement (8 or 16 bits) | | | | | dmem | Direct memory address | | | | | dst | Destination operand or address | | | | | ext-disp8 | 16-bit displacement (sign-extension byte<br>+ 8-bit displacement) | | | | | far_label | Label within a different program segment | | | | | far_proc | Procedure within a different program segment | | | | | fp_op | Floating point instruction operation | | | | | imm | 8- or 16-bit immediate operand | | | | | imm3/4 | 3/4-bit immediate bit offset | | | | | imm8 | 8-bit immediate operand | | | | | imm16 | 16-bit immediate operand | | | | | mem | Memory field (000 to 111);<br>8- or 16-bit memory location | | | | | mem8 | 8-bit memory location | | | | | mem16 | 16-bit memory location | | | | | mem32 | 32-bit memory location | | | | | memptr16 | Word containing the destination address within the current segment | | | | | memptr32 | Double word containing a destination<br>address in another segment | | | | | mod | Mode field (00 to 10) | | | | | near_label | Label within the current segment | | | | | near_proc | Procedure within the current segment | | | | | offset | Immediate offset data (16 bits) | | | | | popvalue | Number of bytes to discard from the stack | | | | | reg | Register field (000 to 111); 8- or 16-bit general-purpose register | | | | | reg8 | 8-bit general-purpose register | | | | | reg16 | 16-bit general-purpose register | | | | | regptr | 16-bit register containing a destination address within the current segment | | | | | regptr16 | Register containing a destination address within the current segment | | | | | seg | (16 bits) | | | | | short_label | Label between —128 and +127 bytes from the end of the current instruction | | | | # 98D 14964 P Τ·49-17-07 μ**PD70108 (V20)** | Symbols (co | ont) | |-------------|-----------------------------------| | Symbol | Meaning | | sr | Segment register | | src | Source operand or address | | temp | Temporary register (8/16/32 bits) | | tmpcy | Temporary carry flag (1 bit) | | AC | Auxiliary carry flag | | AH | Accumulator (high byte) | | AL | Accumulator (low byte) | | AND | Logical product | | AW | Accumulator (16 bits) | | ВН | BW register (high byte) | | BL | BW register (low byte) | | BP | BP register | | BRK | Break flag | | BW | BW register (16 bits) | | CH | CW register (high byte) | | CL | CW register (low byte) | | CW | CW register (16 bits) | | CY | Carry flag | | )H | DW register (high byte) | | DIR | Direction flag | | )L | DW register (low byte) | | 80 | Data segment 0 register (16 bits) | | S1 | Data segment 1 register (16 bits) | | W | DW register (16 bits) | | | Interrupt enable flag | | , | <del></del> | Index register (source) (16 bits) | Symbols | | |------------------|--------------------------------------------------------------------------------------------| | Symbol | Meaning | | IY | Index register (destination) (16 bits) | | MD | Mode flag | | OR | Logical sum | | Р | Parity flag | | PC | Program counter (16 bits) | | PS | Program segment register (16 bits) | | PSW | Program status word (16 bits) | | R | Register set | | S | Sign extend operand field S = 0 No sign extension S = 1 Sign extend immediate byte operand | | S | Sign flag | | SP | Stack pointer (16 bits) | | SS | Stack segment register (16 bits) | | 1 | Overflow flag | | N | Word/byte field (0 to 1) | | K, XXX, YYY, ZZZ | Data to identify the instruction code of the external floating point arithmetic chip | | (OR | Exclusive logical sum | | (XH | Two-digit hexadecimal value | | XXXH | Four-digit hexadecimal value | | | Zero flag | | ) | Values in parentheses are memory contents | | | Transfer direction | | - | Addition | | - | Subtraction | | | Multiplication | | | Division | | 1 | Modulo | 98D 14965 ## $\mu$ PD70108 (V20) | NE | | |-------------------------------|---| | T-49-17-0 | 7 | | Register Selection (mod = 11) | | | Flag Operation | ons | |----------------|------------------------------------| | Symbol | Meaning | | (blank) | No change | | 0 | Cleared to 0 | | 1 | Set to 1 | | x | Set or cleared according to result | | u | Undefined | | R | Restored to previous state | | reg | W = 0 | W = 1 | |-----|-------|-------| | 000 | AL | WA | | 001 | CL | cw | | 010 | DL | DW | | 011 | BL | BW | | 100 | AH | SP | | 101 | СН | ВР | | 110 | DH | IX | | 111 | BH | ΙΥ | | mem mod = 00 mod = 0t mod = 10 | | | | | | |--------------------------------|-----------|-----------------|------------------|--|--| | mem | mod == 00 | mod = Ot | | | | | 000 | BW + IX | BW + IX + disp8 | BW + IX + disp16 | | | | 001 | BW + IY | BW + IY + disp8 | BW + IY + disp16 | | | | 010 | BP + IX | BP + IX + disp8 | BP + IX + disp16 | | | | 011 | BP + IY | BP + IY + disp8 | BP + IY + disp16 | | | | 100 | IX | IX + disp8 | IX + disp16 | | | | 101 | ΙΥ | IY + disp8 | IY + disp16 | | | | 110 | Direct | BP + disp8 | BP + disp16 | | | | 111 | BW | BW + disp8 | BW + disp16 | | | | sr | Segment Register | | |----|------------------|--| | 00 | DS1 | | | 01 | PS | | | 10 | SS | | | 11 | DSO | | 98D 14966 $\mu$ PD70108 (V20) T.49-17-07 #### Instruction Set | Mnemonic | Operand | 7 6 5 4 2 2 | ( | )pcode | | | | | lags | |--------------|--------------------|---------------|------------|----------------------------------------|----------------------------------------------|---------------|----------------|----------------|------| | | nsfer Instructions | 7 6 5 4 3 2 | | 7 6 5 4 | 3 2 1 0 | Ciocks | Bytes | AC CY V | PS | | MOV | reg, reg | 1 0 0 0 1 0 | 1 W | 4 4 | | | | · | | | | mem, reg | 100010 | | 1 1 reg | | 2 | 2 | | | | | reg, mem | 1 0 0 0 1 0 | | mod reg | <del></del> | 9/13 | 2-4 | | | | | mem, imm | | 1 W | mod reg | | 11/15 | 2-4 | | | | | reg, imm | 1 0 1 1 W | | mod reg | mem . | 11/15 | 3-6 | | | | | acc, dmem | 101000 | reg<br>0 W | | <del></del> | 4 | 2-3 | | | | | dmem, acc | 1 0 1 0 0 0 | 1 W | <del></del> | | 10/14 | 3 | | | | | sr, reg16 | 1 0 0 0 1 1 | 1 0 | 1 1 0 - | <u>. </u> | 9/13 | 3 | | | | | sr, mem16 | 1 0 0 0 1 1 | 1 0 | <del></del> | r reg | 2 | 2 | | | | | reg16, sr | 1 0 0 0 1 1 | 0 0 | <del></del> | r mem | 11/15 | 2-4 | | | | | mem16, sr | 1 0 0 0 1 1 | 0 0 | 1 1 0 s | <u>-</u> | 2 | 2 | | | | | DS0, reg16, mem32 | 1 1 0 0 0 1 | | mod 0 s | | 10/14 | 2-4 | | | | | DS1, reg16, mem32 | 1 1 0 0 0 1 | 0 1 | mod reg | | 18/26 | 2-4 | | | | | AH, PSW | | 0 0 | mod reg | mem | 18/26 | 2-4 | | | | | PSW, AH | | | | <del></del> _ | 2 | _1 | | | | DEA. | reg16, mem16 | <del></del> | 1 0 | | | 3 | | X_X | X X | | RANS | src_table | | 0 1 | mod re | g mem | 4 | 2-4 | | | | CH | reg, reg | | 1 1 | <del></del> | | 9 | _1 | | | | | mem, reg | | 1 W | 1 1 reg | reg | 3 | | | | | | AW, reg16 | | 1 W | mod reg | mem | 16/26 | 2-4 | | | | Repeat P | | 10010 | reg | | · | 3 | 1 | | | | REPC | | 0 1 1 0 0 1 | | | | | | | | | REPNC | <del></del> | | 0 1 | ······································ | | 2 | 1 | | | | IEP | | | 0 0 | | | 2 | _1 | | | | EPE<br>EPZ | | 1 1 1 1 0 0 | 1 1 | | | 2 | 1 | • | | | EPNE<br>EPNZ | | 1 1 1 1 0 0 | 1 0 | | · | 2 | 1 | <del>-</del> · | | | lock Tra | nsfer Instructions | | | | <del></del> | <del></del> | | | | | OVBK | dst, src | 1 0 1 0 0 1 | 0 W | | | 11 + 8n | 1 | | | | MPBK | dst, src | 1 0 1 0 0 1 | 1 W | | | 7 + 14n | <del></del> | | | | MPM | dst | | 1 W | | | 7 + 10n | <u> </u> | _ X X X | | | DM | src | | 0 W | | · | 7 + 9n | <u>'</u> | x x x | X X | | TM | dst | 101010 | 1 W | <del></del> | | 7 + 4n | <del>'</del> 1 | | | | | | | | n = number | of transfers | 7 1 411 | <del>-</del> | | | | O Instru | ctions | | | | | <del></del> - | | | | | | acc, imm8 | 1 1 1 0 0 1 ( | ) W | | | 9/13 | 2 | · | | | | acc, DW | 1 1 1 0 1 1 ( | | | <del></del> | 8/12 | 1 | | | | JT | imm8, acc | 1 1 1 0 0 1 | | | | 8/12 | 2 | | | | | DW, acc | 1 1 1 0 1 1 | | | <del>-</del> | 8/12 | | | | | М | dst, DW | 0 1 1 0 1 1 0 | | | | 9 + 8n | 1 | | | | JTM | DW, src | 0 1 1 0 1 1 1 | | | | | 1 | | | | | | | | n = number | | 9 + 8n | 1 | | | 98D 14967 🌶 ## μ**PD**70108 (**V**20) | | | | | | | | | | Opc | | | | | | | | _ | | | | | lags | | | _ | |----------|---------------------|--------|----------|-----|-----|--------|---|-----------------|-----|-------------|----|----------|-----|-----------|---|-----------|----------|---------|-------|-----|-----|------------|----------|-------------------------|----------| | Anemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC | CI | | ۲ | S | | | BÇD Inst | ructions | | | | | | | | | | | | | | | | | | | | | | | | _ | | ADJBA | | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | | | | | | | 3 | 1 | X | Х | | | | u | | ADJ4A | | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | | _ | | | | | | | 3 | 1 | | Х | _ | | | | | ADJBS | | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 3 | _ | | | | | | | 7 | 1 | X | Х | u | u | u | ι | | ADJ4S | · | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | | | | | | | 7 | 1 | X | X | | | | , | | ADD4S | dst, src | 0 | 0 | 0 | 0 | 1_ | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 7 + 19n | 2 | U | Х | u | u | | Х | | SUB4S | dst, src | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 7 + 19n | 2 | u | х | u | U | u | _ X | | CMP4S | dst, src | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1_ | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 + 19n | 2 | u | х | u | u | u | <u> </u> | | ROL4 | reg8 | 0 | 0 | 0 | 0 | 1<br>0 | 1 | 1<br>reg | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 25 | 3 | | | | | | | | | mem8 | 0<br>n | 0<br>nod | 0 | 0 | 1 | 1 | 1<br>men | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 28 | 3-5 | | | | | | | | ROR4 | гед8 | 0 | - | 0 | 0 | 1 | 1 | 1<br>reg | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 29 | 3 | | | | | | | | | mem8 | 0<br>n | 0<br>nod | 0 | 0 | 1 0 | | 1<br>men<br>= r | | 0<br>per of | | 1<br>D d | | 1<br>s di | | 1<br>ed b | 0<br>y 2 | 33 | 3-5 | | | | | | | | Data Typ | e Conversion Instru | ctions | | _ | | | | | | | | | | | | | | | | | | | | | | | CVTBD | | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 15 | 2 | u | u | u | х | X | | | CVTDB | | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 | 2 | U | U | u | х | X | . ; | | CVTBW | | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | | | | | | | | 2 | 1 | | | | | | | | CVTWL | | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | | | | | | | | | 4-5 | 1 | | | | | | | | Arithmet | ic Instructions | | | | | | | | | | | | | | | | | | | | | | | | | | ADD | reg, reg | 0 | 0 | 0 | 0 | 0 | 0 | 1 | W | 1 | 1 | | reg | | | reg | | 2 | 2 | Х | _x | . х | Х | X | : : | | | mem, reg | C | 0 | 0 | 0 | 0 | 0 | 0 | W | m | od | | reg | - | 1 | men | 1 | 16/24 | 2-4 | Х | × | Х | × | : x | ( | | | reg, mem | C | 0 | 0 | 0 | 0 | 0 | 1 | W | m | od | | reg | | Ī | men | n | 11/15 | 2-4 | Х | × | × | × | C X | : | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | 1 | 1 | 0 | 0 | 0 | | reg | | 4 | 3-4 | х | Х | Х | : х | X | ( | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | m | od | 0 | 0 | 0 | | men | n | 18/26 | 3-6 | Х | × | X | : × | ( ) | ( | | | acc, imm | ( | ) ( | 0 | 0 | 0 | 1 | 0 | W | | _ | | | | | | | 4 | 2-3 | х | , | Х | · > | <b>( )</b> | ( | | ADDC | reg, reg | | ) ( | 0 | 1 | 0 | 0 | 1 | W | 1 | 1 | | reç | <br>I | | reg | | 2 | 2 | х | X | . X | <b>X</b> | <b>(</b> ) | ι | | | mem, reg | ( | ) ( | 0 | 1 | 0 | 0 | 0 | W | m | od | | reç | ] | | mer | n | 16/24 | 2-4 | Х | · > | ( X | ` > | $\overline{}$ | < | | | reg, mem | | ) ( | 0 | 1 | 0 | 0 | 1 | W | m | od | | reç | ) | | mer | n | 11/15 | 2-4 | Х | • | ( X | ( ) | ( ) | ( | | | reg, imm | | 1 ( | ) ( | 0 | 0 | 0 | S | W | 1 | 1 | 0 | 1 | 0 | | reg | _ | 4 | 3-4 | X | , | <b>(</b> ) | ( ) | $\langle \cdot \rangle$ | ( | | | mem, imm | | 1 ( | ) ( | 0 | 0 | 0 | S | W | m | od | 0 | 1 | 0 | | mer | n | 18/26 | 3-6 | · × | ) | ( ) | ( ) | <b>K</b> > | < | | | acc, imm | ( | ) ( | ) ( | ) 1 | 0 | 1 | 0 | W | | | | | | | | | 4 | 2-3 | > | : ) | ( ) | ( ) | K ) | X | | SUB | reg, reg | ( | ) ( | ) 1 | ( | ) 1 | 0 | 1 | W | 1 | 1 | _ | reç | <br>} | | reç | } | 2 | 2 | > | ; | <b>( )</b> | ( ) | x ) | X | | | mem, reg | | 0 ( | ) 1 | ( | ) 1 | 0 | 0 | W | m | od | | re | <br>} | | mei | n | 16/24 | 2-4 | , | : ; | ( ) | ( ) | x ) | ĸ | | | reg, mem | ( | 0 ( | ) 1 | ( | ) 1 | 0 | 1 | W | П | od | | reg | ] | | mei | n | 11/15 | 2-4 | , | : 7 | x ) | ( ) | x x | x | | | reg, imm | | 1 ( | ) ( | ) ( | 0 | 0 | | W | 1 | | 1 | | 1 | | reg | | 4 | 3-4 | | | x ) | , , | | _ | 98D 14968 D μ**PD7**0108 (**V**20) T.49-17-01 #### Instruction Set (cont) | Mnemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | pcode<br>7 6 | 5 | 4 | 3 | 2 1 0 | Clocks | Bytes | Flags<br>AC CY V P S | z | |------------|------------------------|-----|----|---|---|---|----|-----|---|--------------|---|------------|----------|-------|--------|-------|----------------------|---| | Arithmeti | ic Instructions (cont) | | | | | | | | | | | | | | | | | | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | mod | 1 | 0 | 1 | mem | 18/26 | 3-6 | x x x x x | x | | | acc, imm | 0 | 0 | 1 | 0 | 1 | 1 | 0 | W | | | | | | 4 | 2-3 | x x x x x | х | | SUBC | reg, reg | 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | 1 1 | | reg | | reg | 2 | 2 | x x x x x | x | | | mem, reg | 0 | 0 | 0 | 1 | 1 | 0 | 0 | W | mod | | reg | _ | mem | 16/24 | 2-4 | · x x x x x | х | | | reg, mem | 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | mod | | reg | | mem | 11/15 | 2-4 | x x x x x | x | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | 1 1 | 0 | 1 | 1 | reg | 4 | 3-4 | x x x x x | х | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | mod | 0 | 1 | 1 | mem | 18/26 | 3-6 | x x x x x | х | | | acc, imm | 0 | 0 | 0 | 1 | 1 | 1 | 0 | W | | | | | | 4 | 2-3 | x x x x x | х | | INC | reg8 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 1 | 0 | 0 | 0 | reg | 2 | 2 | x x x x | х | | | mem | 1 | 1. | 1 | 1 | 1 | 1 | 1 | W | mod | 0 | 0 | 0 | mem | 16/24 | 2-4 | x | х | | | reg16 | 0 | 1 | 0 | 0 | 0 | | reç | ] | | • | | | | 2 | 1 | x | х | | DEC | reg8 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 1 | 0 | 0 | 1 | reg | 2 | 2 | x | х | | | mem | 1 | 1 | 1 | 1 | 1 | 1 | 1 | W | mod | 0 | 0 | 1 | mem | 16/24 | 2-4 | x | | | | reg16 | 0 | 1 | 0 | 0 | 1 | | reç | ] | | - | | _ | | 2 | 1 | x | | | MULU | reg | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 1 | 0 | 0 | reg | 21-30 | 2 | | u | | | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 1 | 0 | 0 | mem | 27-36 | 2-4 | | u | | MUL | reg | 1 · | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 1 | 0 | 1 | reg | 33-47 | 2 | | u | | | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 1 | 0 | 1 | mem | 39-57 | 2-4 | | U | | | reg16,reg16,imm8 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 1 | | reg | _ | reg | 28-34 | 3 | | u | | | reg16,mem16,imm8 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | mod | | reg | - | mem | 34-44 | 3-5 | | u | | | reg16,reg16,imm16 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 1 | | reg | | reg | 36-42 | 4 | иххии | u | | | reg16,mem16,imm16 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | mod | | reg | _ | mem | 46-52 | 4-6 | UXXUU | u | | DIVU | reg . | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 1 | 1 | 0 | reg | 19-25 | 2 | u u u u u | u | | | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 1 | 1 | 0 | mem | 25-35 | 2-4 | u u u u | u | | DIV | reg | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 1 | 1 | 1 | reg | 29-43 | 2 | u u u u u | u | | | mem | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | mod | 1 | 1 - | 1 | mem | 35-53 | 2-4 | u u u u u | u | | Comparis | on Instructions | | | | | | | | - | | | | | | | | | | | CMP | reg, reg | 0 | 0 | 1 | 1 | 1 | 0 | 1 | W | 1 1 | _ | reg | | reg | 2 | 2 | x x x x x | x | | | mem, reg | 0 | 0 | 1 | 1 | 1 | 0 | 0 | W | mod | | reg | | mem | 11/15 | 2-4 | x x x x x | | | | reg, mem | 0 | 0 | 1 | 1 | 1 | 0 | 1 | W | mod | | reg | | mem | 11/15 | 2-4 | x x x x x | | | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | s | W | 1 1 | 1 | 1 | 1 | reg | 4 | 3-4 | x x x x x | | | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | S | W | mod | 1 | 1 | 1 | mem | 13/17 | 3-6 | x x x x x | | | | acc, imm | 0 | 0 | 1 | 1 | 1 | 1 | 0 | W | | | | | | 4 | 2-3 | x x x x x | - | | Logical In | structions | | | _ | _ | | | | | | _ | | | | | | ···· | _ | | NOT | reg | 1 | 1 | 1 | 1 | 0 | 1 | 1 | W | 1 1 | 0 | 1 | 0 | reg | 2 | 2 | · | | | | mem | 1 | | | | | | 1 | | mod | | | | mem | 16/24 | 2-4 | | | | NEG | reg | 1 | 1 | 1 | 1 | 0 | ·1 | 1 | W | 1 1 | | | | reg | 2 | 2 | x x x x x | x | | | mem | 1 | | | | | _ | | | mod | | | <u> </u> | mem | 16/24 | 2-4 | x x x x x | | | TEST | reg, reg | 1 | | | | | | | | 1 1 | | reg | - | reg | 2 | 2 | u 0 0 x x | | | | mem, reg | 1 | | _ | | | | | | mod | | reg | | mem | 10/14 | 2-4 | u 0 0 x x | | | | reg, imm | 1 | | | | | _ | | | 1 1 | | <u>-</u> - | <u></u> | reg | 4 | 3-4 | u 0 0 x x | | 98D 14969 🍼 ## μ**PD70108 (V20)** | Minimanical Operand 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 0 Clocks Bytes AC CY V P S Z | | | | _ | _ | | _ | | | Opc | | _ | _ | | | | | ^ | Oleaka | D.4 | 40 | | | lag | | | , | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|-----|---|---|----------|---|---|---|-----|-----|---------|---|-----|---|---|--------------|---|--------|-------|----|---|-----|-----|----------|----------|---| | Mem, imm | Ynemonic | Operand | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | . 7 | ti<br>— | 5 | 4 | 3 | Z | | U | Clocks | Bytes | AL | Ü | 1 1 | _ | <u> </u> | 5 | | | Section 1 | Logical II | | | | _ | | | | | | | _ | _ | | | | | | | | | _ | _ | | | | | | NAND reg, reg | | | | | | | | _ | | | mo | d | 0 | 0 | 0 | | mem | | | | | | | | | | _ | | mem, reg | | acc, imm | | | | | | | | | | | | | | | | | | | | _ | _ | | | | _ | | Figs. mem | AND | reg, reg | | | | <u> </u> | _ | | | | | _ | | | | | _ <u>-</u> - | | | | | | | | | | _ | | Teg, Imm | | mem, reg | | | | | | | | | | | | _ | | | | | | | _ | | _ | | | | | | Mem, imm | | reg, mem | 0 | _ | | | | | | | | | | _ | | 1 | | | | | | | | | | | | | A | | reg, imm | 1 | | | | _ | | | | | | | | | | <u> </u> | | | | | | | | | | | | DR | | | | | | | | _ | | | mo | d | 1 | 0 | 0 | | mem | | | | | | _ | | | | | | Mem, reg | | acc, imm | | | | _ | | | | | | | | | | | | | | | u | | | _ | | | | | reg, mem | DR | reg, reg | | | _ | | | | | | | | | reg | | | Ť | | | | | | | | | | | | Feg, Imm | | mem, reg | 0 | Ø | | | 1 | _ | | | | | | reg | | | mem | | | | u | _ | | | | | | | Mem, Imm | | reg, mem | 0 | 0 | | 0 | | | | | | | | _ | | ı | mem | | | | u | | | | | | _ | | A | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | | | 1 | _ | - | | 1 | | reg | | | | U | | | | _ | <u>x</u> | X | | KOR reg, reg 0 0 1 1 0 1 W 1 reg reg 2 2 u 0 0 x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x | | mem, imm | . 1 | 0 | 0 | 0 | 0 | 0 | 0 | W | mo | d | 0 | 0 | 1 | | mem | | | | u | _ | _ | | Κ | <u>x</u> | X | | mem, reg | | acc, imm | 0 | 0 | 1 | 0 | 0 | 1 | 0 | W | | | | | | | | | | | u | | | | | | | | reg, mem | KOR | reg, reg | 0 | 0 | 1 | 1 | 0 | 0 | 1 | W | 1 | 1 | | гeg | | | reg | | 2 | 2 | u | 0 | _( | ) : | x | × | X | | reg, imm | | mem, reg | 0 | 0 | 1 | 1 | 0 | 0 | 0 | W | mo | d | | reg | | | mem | | 16/24 | 2-4 | ш | 0 | | ) : | X | X | X | | mem, imm | | reg, mem | 0 | 0 | 1 | 1 | 0 | 0 | 1 | W | mo | d | | reg | | | mem | | 11/15 | 2-4 | u | 0 | _ | | X | X | × | | Acc, imm | | reg, imm | 1 | 0 | 0 | 0 | 0 | 0 | 0 | W | 1 | 1 | 1 | 1 | 0 | | reg | | 4 | 3-4 | u | 0 | ( | ) : | x | X | X | | TEST1 reg, reg reg, imm3/4 reg, imm3/4 reg, imm3/4 reg, imm3/4 reg, imm3/4 reg, reg | | mem, imm | 1 | 0 | 0 | 0 | 0 | 0 | 0 | W | mo | d | 1 | 1 | 0 | | mem | | 18/26 | 3-6 | u | 0 | | ) : | X. | <u>x</u> | Х | | Teg8, reg8 | | acc, imm | . 0 | 0 | 1 | 0 | 0 | 1 | 0 | W | | | | | | | | | 4 | 2-3 - | u | 0 | ) ( | ) : | x | x | × | | TEST1 reg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 13/21 4-6 U 0 0 U U 1 1 1 0 0 0 0 reg mem, imm3/4 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 13/21 3-5 Teg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 13/21 3-5 Teg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 13/21 3-5 | Bit Məni <sub>l</sub> | oulation instructions | | | | | | | | | | | | | | | | | | | | _ | | | | | | | EXT reg8, reg8 | INS | reg8, reg8 | | | 0 | | 1 | 1 | | | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 35-133 | 3 | | | | | | | | | TEST1 reg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 3 3 U 0 0 U U 2 1 1 1 0 0 0 reg mem, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 12/16 3-5 U 0 0 U U 2 mod 0 0 0 mem reg, imm3/4 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 4 4 U 0 0 U U 2 1 1 0 0 0 reg mem, imm3/4 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 13/21 4-6 U 0 0 U U 2 mod 0 0 0 mem SET1 reg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 13/21 3-5 | | reg8, imm8 | _ | _ | | | | 1 | | | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 35-133 | 4 | | | | | | | | | TEST1 reg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 3 3 U 0 0 U U 2 1 1 1 0 0 0 reg mem, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 W 12/16 3-5 U 0 0 U U 2 mod 0 0 0 mem reg, imm3/4 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 4 4 U 0 0 U U 2 1 1 1 0 0 0 0 reg mem, imm3/4 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 W 13/21 4-6 U 0 0 U U 2 mod 0 0 0 mem SET1 reg, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 1 0 W 4 3 1 1 0 0 0 0 reg mem, CL 0 0 0 0 1 1 1 1 1 0 0 0 1 0 1 0 W 13/21 3-5 | EXT | reg8, reg8 | | _ | 0 | | 1 | 1 | | | . 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 34-59 | 3 | | | | | | | | | 1 1 0 0 0 reg | | reg8, imm8 | | | | | | 1 | | | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 34-59 | 4 | | | | | | | | | mod 0 0 0 mem | TEST1 | reg, CL | | | | | | 1 | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | W | 3 | 3 | u | ( | ) | 0 | u<br>— | u | , | | 1 1 0 0 0 reg | | mem, CL | - | | | | | | | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | W | 12/16 | 3-5 | u | _ | ) | 0 | u | u | ; | | mod 0 0 0 mem SET1 reg, CL 0 0 0 0 1 1 1 1 0 0 0 1 0 1 0 W 4 3 1 1 0 0 0 reg mem, CL 0 0 0 0 1 1 1 1 0 0 0 1 0 1 0 W 13/21 3-5 | | reg, imm3/4 | | - | | | | 1 | | | 0 | 0 | 0 | 1 | 1 | 0 | 0 | W | 4 | 4 | u | ( | ) | 0 | u | u | | | 1 1 0 0 0 reg mem, CL 0 0 0 0 1 1 1 1 0 0 0 1 0 1 0 W 13/21 3-5 | | mem, imm3/4 | - | | - | - | | | | | 0 | 0 | 0 | 1 | 1 | 0 | 0 | W | 13/21 | 4-6 | и | ( | ) | 0 | u | u | | | | SET1 | | _ | - | - | | | 1 | | | 0 | 0 | 0 | 1 | 0 | 1 | 0 | W | 4 | 3 | | | | | | | | | | | mem, CL | - | - | - | - | | | | | 0 | 0 | 0 | 1 | 0 | 1 | 0 | W | 13/21 | 3-5 | | | | | | | | 98D 14970 **D** T-49-17-07 μPD70108 (V20) | Mnemonic<br>Bit Manip | Operands Oulation Instruction | 7 | _ | _ | | | | | | | | | | | | | | | ags | | | |-----------------------|--------------------------------|--------|---------|---|----|--------|--------------|--------------|----|-----|----|-----|-------|-----|------|-----------|-------|---------|-----|------------|------------| | Bit Manip | oulation Instruction | | 6 | 5 | 4 | 3 | 2 1 0 | pcode<br>. 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Clocks | Bytes | AC CY V | | 8 | <b>Z</b> . | | | | ns (co | nt) | | | | | | | | | | | | | | | | | • | - | | | reg, imm3/4 | 0<br>1 | 0<br>1 | 0 | 0 | 1<br>0 | 1 1 1<br>reg | 0 | 0 | 0 | 1 | 1 | 1 | 0 | W | . 5 | 4 | | | | | | | mem, imm3/4 | 0<br>m | 0<br>od | 0 | 0 | 1 | 1 1 1<br>mem | 0 | Q | 0 | 1 | 1 | 1 | 0 | W | 14/22 | 4-6 | | | | | | | CY | 1 | 1 | 1 | 1 | 1 | 0 0 1 | | | | | • | | | | 2 | 1 | 1 | | | | | | DIR | 1 | 1 | 1 | 1 | 1 | 1 0 1 | | | | | | | | | 2 | 1 | · | | | | | CLR1 | reg, CL | 0<br>1 | 0 | 0 | 0 | 1 | 1 1 1<br>reg | 0 | 0 | 0 | 1 | 0 | 0 | 1 | W | 5 | 3 | | | | | | | mem, CL | 0 | 0<br>od | 0 | 0 | 1 | 1 1 1<br>mem | 0 | 0 | 0 | 1 | 0 | 0 | 1 | W | 14/22 | 3-5 | | | | | | | reg, imm3/4 | 0 | 0 | 0 | 0 | 1 | 1 1 1<br>reg | Ó | 0 | 0 | 1 | 1 | 0 | .1 | W | 6 | 4 | | | | | | | mem, imm3/4 | 0<br>m | 0<br>od | 0 | 0 | 1 | 1 1 1<br>mem | . 0 | 0 | 0 | 1 | 1 | 0 | 1 | W | 15/27 | 4-6 | | | | | | | CY | 1 | 1 | 1 | 1 | 1 | 0 0 0 | | | | | | | | | 2 | 1 | 0 | | | | | | DIR | 1 | 1 | 1 | 1 | 1 | 1 0 0 | | | | | | | | | 2 | 1 | | | | | | NOT1 | reg, CL | 0<br>1 | 0<br>1 | | 0 | 1 | 1 1 1<br>reg | 0 | 0 | 0 | 1 | 0 | 1 | 1 | W | 4 | 3 | | | | | | | mem, CL | 0<br>m | 0<br>od | 0 | 0 | 1<br>0 | 1 1 1<br>mem | 0 | 0 | 0 | 1 | 0 | 1 | 1 | W | 18/26 | 3-5 | | | | | | | reg, imm3/4 | 0<br>1 | 0 | | 0 | 1 | 1 1 1<br>reg | 0 | 0 | 0 | 1 | 1 | 1 | 1 | W | 5 | 4 | | | | | | | mem, imm3/4 | 0<br>m | 0<br>od | - | 0 | 1<br>0 | 1 1 1<br>mem | 0 | 0 | 0 | 1 | 1 | 1 | 1 | W | 19/27 | 4-6 | | | | | | | CY | 1 | 1 | 1 | 1 | 0. | 1 0 1 | | | | | | | | | 2 | 1 | х | | | | | Shift/Rota | ate instructions | | | | | | | | | | | | | | | | | | | | | | SHL | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 0 W | 1 | 1 | 1 | 0 | 0 | • | reg | | 2 | 2 | u x x | x | X | х | | | mem, 1 | 1 | 1 | 0 | 1. | 0 | 0 0 W | m | od | 1 | 0 | 0 | Г | nen | Π, | 16/24 | 2-4 | u x x | х | х | х | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 1 W | 1 | 1 | 1 | 0 | 0 | | reg | | 7 + n | 2 | u x u | х | х | х | | | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 1 W | m | od | 1 | 0 | 0 | r | nen | 1 | 19/27 + n | 2-4 | ихи | х | х | X | | | reg, imm8 | 1 | 1 | 0 | 0 | 0 | 0 0 W | 1 | 1 | 1 | 0 | 0 | | reg | | 7 + n | 3 | u x u | х | х | х | | | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 0 W | m | od | 1 | 0 | 0 | Г | nen | 1 | 19/27 + n | 3-5 | u x u | х | x | x | | SHR | reg, 1 | 1 | 1 | 0 | 1 | 0 | 0 0 W | 1 | 1 | 1 | 0 | 1 | | reg | | 2 | 2 | U X X | х | х | х | | | mem, 1 | 1 | 1 | 0 | 1 | 0 | 0 0 W | m | od | 1 | 0 | 1 | Г | nen | 1 | 16/24 | 2-4 | u x x | х | x | x | | | reg, CL | 1 | 1 | 0 | 1 | 0 | 0 1 W | 1 | 1 | 1 | 0 | 1 | | reg | | 7 + n | 2 | u x u | х | <b>x</b> , | х | | • | mem, CL | 1 | 1 | 0 | 1 | 0 | 0 1 W | m | od | 1 | .0 | 1 | n | nem | 1 | 19/27 + n | 2-4 | ихи | х | X | X | | | reg, imm8 | 1 | 1 | 0 | 0 | 0 | 0 0 W | 1 | 1 | 1 | 0 | 1 | | reg | | 7 + n | 3 | u x u | Х | x | x | | | mem, imm8 | 1 | 1 | 0 | 0 | 0 | 0 0 W | m | od | 1 | 0 | 1 | П | nen | 1 | 19/27 + n | 3-5 | u x u | х | x | x | | | | | | | | | | | ı | n = | nu | mbe | er of | fsh | ifts | | | | | _ | - | 98D 14971 D ## μ**PD**70108 (**V**20) | Anemonic | Operands | 7 | · | <br>B | 5 | 4 | 3 | 2 | 1 | Opcor<br>O | de<br>7 6 | 5 | 4 | 3 | 2 | 1 0 | Clacks | Bytes | AC | CY | Fla<br>V | igs<br>P | s | Z | |----------|---------------------|--------|-----------------|-----------------|---|----------|----------|-----|---|------------|-----------|-----|----------|----------|---------------|----------|-----------|-------|----|-----|----------|----------|---|---| | | ate Instructions (d | | _ | _ | | | _ | | | | | | | | | | | | | | _ | | | | | HRA | reg, 1 | 1 | <u> </u> | 1 | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 1 | 1 | 1 | _ | reg | 2 | 2 | u | X | 0 | X | X | X | | HINA | mem, 1 | | | 1 | | 1 | 0 | 0 | 0 | W | mod | 1 | 1 | 1 | ı | mem | 16/24 | 2-4 | u | Х | 0 | X | X | Х | | | reg, CL | | _ | 1 | 0 | 1 | 0 | 0 | 1 | W | 1 1 | 1 | 1 | 1 | | reg | 7 + n | 2 | u | X | U | Х | X | X | | | mem, CL | | | 1 | 0 | 1 | 0 | 0 | 1 | W | mod | 1 | 1 | 1 | . 1 | mem | 19/27 + n | 2-4 | u | X | u | Х | X | Х | | | reg, imm8 | | _ | <u>.</u><br>1 | 0 | 0 | 0 | 0 | 0 | w | 1 1 | 1 | 1 | 1 | _ | reg | 7 + n | 3 | U | X | u | Х | Х | X | | | mem, imm8 | | | <u>.</u><br>1 | 0 | 0 | 0 | 0 | 0 | W | mod | 1 | 1 | 1 | | mem | 19/27 + n | 3-5 | u | X | u | _x | Х | X | | | | | _ | <u>.</u> | 0 | 1 | 0 | 0 | 0 | W | 1 1 | 0 | 0 | 0 | | reg | 2 | 2 | | X | X | | | | | ROL | reg, 1 | | | 1 | 0 | <u> </u> | <u> </u> | 0 | 0 | | mod | 0 | 0 | 0 | _ | mem | 16/24 | 2-4 | | Х | х | | | | | | mem, 1 | | | 1 | 0 | 1 | 0 | 0 | 1 | | 1 1 | 0 | 0 | 0 | | reg | 7 + n | 2 | | Х | u | ! | | | | | reg, CL | | <u>.</u> | 1 | 0 | 1 | 0 | 0 | 1 | | mod | 0 | 0 | 0 | | mem | 19/27 + n | 2-4 | | X | U | _ | | | | | mem, CL | | 1 | <u> </u> | 0 | <u>.</u> | 0 | | 0 | | 1. 1 | | 0 | 0 | | reg | 7 + n | 3 | | Х | U | | | | | | reg, imm | | <del>;</del> | <u>.</u> | 0 | _ | 0 | | 0 | | mod | 0 | 0 | 0 | _ | mem | 19/27 + n | 3-5 | | X | ι | 1 | | | | | mem, imm | | <u>-</u> | <u>'</u> | 0 | 1 | | | | | 1 1 | 0 | 0 | 1 | _ | reg | 2 | 2 | | Х | ι | J _ | | | | ROR | reg, 1 | | 1 | 1 | | | | _ | | | mod | 0 | Ö | 1 | _ | mem | 16/24 | 2-4 | | Х | | ( | | | | | mem, 1 | | _ | 1 | | | _ | | _ | | 1 1 | 0 | -0 | 1 | _ | reg | 7 + n | 2 | | Х | : 1 | J | | | | | reg, CL | | <u> </u> | 1 | | | _ | | | | mod | 0 | 0 | 1 | | mem | 19/27 + n | 2-4 | | X | ٠ ١ | u | | | | | mem, CL | | <u> </u> | <u> </u> | | | | | _ | ) W | 1 1 | 0 | | ) 1 | _ | reg | 7 + n | 3 | | Х | ( | u | | | | | reg, imm8 | | <u>.</u> | _ <u>.</u><br>1 | _ | | | | | ) W | mod | | _ | ) 1 | _ | mem | 19/27 + n | 3-5 | | | ( | u | | | | | mem, imm8 | | <u>'</u> | 1 | | | | | | W | 1 1 | | 1 | 1 0 | ) | reg | 2 | 2 | | `` | K | X | | | | ROLC | reg, 1 | | 1 | 1 | | | | | | ) W | mod | | _ | 1 0 | ) | mem | 16/28 | 2-4 | | , | x | Х | | | | | mem, 1 | | 1 | _ <u>'</u> | | | | | | 1 W | 1 1 | | | 1 0 | _ | reg | 7 + n | 2 | | | X | u | | | | | reg, CL | | 1 | _ | | | | ) ( | | 1 W | mod | | | 1 0 | ) | mem | 19/27 + n | 2-4 | | 2 | X. | u | | | | • | mem, CL | | 1 | | | ) ( | | ) ( | | 0 W | 1 | | | 1 0 | _ | reg | 7 + n | 3 | | - : | X | u | | | | | reg, imm8 | | 1 | | | | _ | 0 ( | | 0 W | mod | | _ | 1 ( | | mem | 19/27 + n | 3-5 | | | x | u | | | | | mem, imm8 | | <u>'</u> | | _ | | | 0 ( | | 0 W | 1 | | _ | 1 1 | _ | reg | 2 | 2 | | | x | х | | | | RORC | reg, 1 | | <u>'</u> | | _ | | _ | | | 0 W | mo | | _ | 1 1 | | mem | 16/24 | 2-4 | | | X | Х | | | | | mem, 1 | | _ <u>'</u><br>1 | | | _ | | | _ | 1 W | | 1 ( | _ | 1 ' | _ | reg | 7 + n | 2 | | | х | U | | | | | reg, CL | | _ | | _ | _ | _ | | | 1 W | mo | | | 1 | _ | mem | 19/27 + n | 2-4 | • | | х | u | | | | | mem, CL | | _1 | _ | | _ | | | | 0 W | 1 | | | | 1 | reg | 7 + n | 3 | | | х | u | | | | | reg, imm8 | | _1 | | | | _ | | | 0 W | mo | | _ | | <u>.</u><br>1 | mem | 19/27 + n | 3-5 | | | х | U | | | | | mem, imm8 | | | _ | 1 | 0 | | | | - | | | _ | | _ | r of shi | | | | | | | | | | | | | | | | | | | | | | | - | .,,,,,,, | | | | | | | _ | | | | | | Manipulation Instr | ructio | | | - | _ | _ | _ | 1 | 1 1 | | ıd: | 1 | 1 | n | mem | 26 | 2-4 | | | | _ | | | | PUSH | mem16 | | | 1_ | | | | | _ | 1 1 | | - | <u>.</u> | <u>.</u> | _ | | 12 | 1 | | | _ | _ | | | | | reg16 | | | _ | | | 1 | | _ | reg<br>1 0 | | | _ | | _ | | 12 | 1 | | | _ | _ | | | | | sr | | | _ | | 0 | S | | 1 | | | | _ | _ | | | 12 | | | _ | _ | | | | | | PSW | | | | 0 | 0 | 1 | 1 | 1 | 0 0 | · | | | | _ | | 67 | 1 | | | | | _ | _ | | | _R | | _ | | 1 | 1 | 0 | 0 | 0 | 0 0 | | | | | | | 11/12 | 2-3 | | | | | | | | | imm | | | 0 | 1 | 1 | 0 | 1_ | 0 | S 0 | | | | | | | 117.12 | | | | | | | | ## 98D 14972 ## 6427525 N E C ELECTRONICS INC ## $\mu$ PD70108 (V20) T.49-17-07 | | on Set (cont) | | | _ | | | | | | | | | | | | | | | | - | | | |----------|-------------------------|------------------|----------|---------------|----------|----------|----------|----------------|-------------|-----|----|-----|----|--------|----------|--------|-------------|---------------|------|------|---|---| | Mnemonic | Operands | 7 6 | 5 | | 13 | 2 | 1 | | code<br>7 6 | 5 | 4 | . 3 | | 2 1 | n | Clocks | Bytes | AC | CV I | lags | | - | | Stack Ma | anipulation Instruction | s (cont) | _ | | | | | | | | | | | | <u> </u> | DIVERS | Dyles | AU | CY 1 | | 8 | | | POP | mem16 | 1 0 | 0 | _ | ) 1 | 1 | 1 | 1 | mod | 0 | 0 | | _ | men | - | 25 | 2-4 | | | · | | | | | reg16 | 0 1 | | _ | | | rec | | | Ť | | _ | | 7.1011 | <u> </u> | 12 | 1 | | | | | - | | | sr | 0 0 | | | sr | 1 | | 1 | | | | _ | _ | | | 12 | _ <u>'</u> | | | | | | | | PSW | 1 0 | 0 | 1 | | | | 1 | | | | | _ | | | 12 | 1 | | D [ | | _ | | | • | R | 0 1 | | 0 | | 0 | | 1 | | | | | | | | 75 | _ <u>-</u> | <u> </u> | R F | - H | H | R | | PREPARE | imm16, imm8 | | 0 | 0 | | | 0 | 0 | | | | _ | | | | * | 4 | | | | | | | | | | • • | | | | | | imm8 = | | | | | _ | | | 7 | | | | | | | DISPOSE | | 1 1 | | | 1 | | | | nm8 > 1 | : 1 | 9+ | 8 ( | im | m8 | 1) | | | | | | | | | | ransfer Instructions | <u></u> | | | - | | - | | | | | | _ | | | 10 | 1 | | | | | | | CALL | near_proc | 1 1 | 1 | 0 | 1 | 0 | 0 | 0 | | | | | - | | | | <del></del> | | | | | | | | regptr | 1 1 | 1 | 1 | | 1 | 1 | 1 | 1 1 | _ | - | | _ | | | 20 | 3 | | | | _ | | | | memptr16 | | <u> </u> | 1 | | <u>'</u> | 1 | 1 | mod | 0 | 1 | | _ | reg | | 18 | 1 | | | | | | | | far_proc | 1 0 | <u>.</u> | 1 | | 0 | <u> </u> | 0 | 11100 | | _1 | 0 | - | mem | _ | 31 • | 2-4 | | | | | | | | memptr32 | 1 1 | 1 | 1 | <u> </u> | 1 | <u>'</u> | 1 | mod | 0 | _ | 1 | | | _ | 29 | 5 | <del></del> - | | | _ | | | RET | | 1 1 | 0 | 0 | | 0 | 1 | <u>'</u> | IIIOU | _ | | | | mem | _ | 47 | | | | | | | | | pop_value | 1 1 | 0 | 0 | | 0 | 1 | 0 | | — | | | | | | 19 | 1 | | | | | | | | | 11 | 0 | 0 | | 0 | | 1 | | | | | | | | 24 | 3 | | | | _ | | | | pop_value | <del>- i i</del> | ÷ | 0 | <u> </u> | 0 | <u>'</u> | 0 | | | | | _ | | | 29 | 1 | | | | | | | BR | near_label | 1 1 | 1 | 0 | 1 | 0 | 0 | 1 | | | | _ | | | | 32 | 3 | | | | | | | | short_label | | 1 | 0 | <u>'</u> | 0 | | 1 | | | _ | | _ | | | 13 | 3 | | | | | | | | reg | 1 1 | 1 | 1 | 1 | 1 | 1 | <del>'</del> - | 1 1 | 1 | 0 | · | | | | 12 | 2 | · . | | | | | | - | memptr16 | 1 1 | <u>'</u> | 1 | <u>'</u> | 1 | | 1 | mod | | 0. | | | reg | _ | 11 | 2 | | | | | | | | far_label | 1 1 | | 0 | 1 | 0 | | 0 | IIIUU | - | | | | mem | _ | 24 | 2-4 | | | | | | | | memptr32 | 1 1 | | 1 | <u>'</u> | 1 | | 1 | mod | 1 | _ | 1 | | | | 15 | 5 | | | | | | | 3V | near_label | 0 1 | | 1 | | 0 | | 0. | | | _ | | | mem | | 35 | 2-4 | | | | | | | BNV | near_label | 0 1 | | 1 | | | _ | 1 | | _ | | | | | | 14/4 | 2 | - | | | _ | | | BC, BL | near_label | 0 1 | | 1 | _ | 0 | | 0 | | | | | | | | 14/4 | 2 | | | | _ | | | INC, BNL | near_label | 0 1 | | <u>,</u> | | | 1 | <u> </u> | | | | | _ | | | 14/4 | 2 | | | | _ | _ | | BE, BZ | near_label | 0 1 | _ | 1 | | | | 0 | | | | | | | | 14/4 | 2 | | | | _ | | | SNE, BNZ | near_label | 0 1 | | 1 | | | 0 | | | | | | _ | | | 14/4 | 2 | | | | | | | NH | near_label | 0 1 | | <u>'</u><br>1 | | | | 0 | | | | | | | | 14/4 | 2 | | | | | | | IH . | near_label · | | | <u>.</u><br>1 | | | | 1 | | | | | | | | 14/4 | 2 | | | | | | | N | near_label | | | 1 | | | | <u>'</u> | | | | | | | | 14/4 | 2 | | | | | | | P | near_label | | | <u>'</u><br>1 | | | 0 | | | | _ | | _ | | | 14/4 | 2 | | | | | | | PE | near_label | | | _ | | | 1 1 | | | | | _ | | | | 14/4 | 2 | | | | | | | PO | near_label | | | 1 | | | 1 | | | | | | _ | | | 14/4 | 2 | | | | | | | LT | near_label | <u> </u> | | <u>-</u><br>1 | | | 0 1 | | | | | | | | | 14/4 | 2 | | | | | | | GE | near_label | | | _ | _ | · | _ | | | | | | | | | 14/4 | 2 | | | | | | | | 11001210001 | U I | - | _ | 1 | 1 | 0 | | | | | | | | | 14/4 | 2 | | | | | | # 98D 14973 D ## μ**PD70108 (V20)** | | | _ | _ | _ | _ | | | | Opcod | e<br>7 | e | _ | A | 2 | , | 1 | 0 | Clocks | Bytes | AC | | Fla<br>V | gs<br>P | S | z | |-----------|---------------------------|-----|-----|-----|---|-----|-----|----------|----------|------------|-----|----|----------|------------|----|-----|------|----------|-------|----|---|----------|---------|----------|------------| | Inemonic | Operand | | b | b | 4 | 3 | 2 | <u>.</u> | U | <u>'</u> _ | U | 0 | <u>-</u> | - | | - | | | | | | _ | ÷ | Ť | _ | | Control T | ransfer Instructions (con | | | | | _ | | | | | | | | | | _ | | 14/4 | 2 | | | | | _ | | | ILE | near_label | 0 | 1 | 1_ | 1 | 1 | | 1 | | | | _ | | | _ | | | | 2 | | — | | | _ | _ | | BGT | near_label | 0 | 1 | 1 | 1 | 1 | 1 | 1 | <u> </u> | | | | | | | | | 14/4 | 2 | — | | | | | _ | | BNZNE | near_label | 1 | 1 | 1 | 0 | 0 | 0 | | 0 | | | | _ | | | | | 14/5 | | | | | _ | | | | BNZE | near_label | 1 | 1 | 1 | 0 | 0 | | 0 | 1 | | | | | | _ | | | 14/5 | 2 | | | | | _ | | | BNZ | near_label | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | | | | , | - | | | | 13/5 | 2 | | | | | _ | | | BCWZ | near_label | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | | | | _ | | _ | | | 13/5 | 2 | | | _ | | _ | | | nterrupt | Instructions | | | | | | | | | | | | | | | | | | | | | | | | | | BRK | 3. | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | | | | | | | | 50 | 1 | | | | | | | | | imm8 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | | | | | | | | | 50 | 2 | | | _ | | | | | BRKV | imm8 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | | | | | | | 52/3 | 1 | | | | | | _ | | RETI | | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | | | | | | | | | 39 | 1 | R. | R | R | R | R | _ <u>R</u> | | CHKIND | reg16, mem32 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | m | od | | re | g | | m | em | 73-76/26 | 2-4 | | | | | | | | BRKEM | imm8 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 | 1 1 | 50 | 3 | | _ | | | _ | | | | trol instructions | _ | | | | | | | | | | | | | | | | | | | | | | | | | HALT | | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | | | | | | | | | 2 | 1 | | _ | | | | | | BUSLOCK | | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | 2 | 1 | | | | | | | | FP01 | fp_op | 1 | 1 | 0 | 1 | 1 | Х | Х | Х | 1 | 1 | Υ | ١ | ′ ነ | 7 | Z | ΖZ | 2 | 2 | | | | _ | | _ | | | fp_op, mem | 1 | 1 | 0 | 1 | | | X | X | m | od | Υ | ١ | 1 | 7 | m | em : | 15 | 2-4 | | | | | | _ | | FP02 | fp_op | 0 | 1 | 1 | 0 | 0 | 1 | 1 | Х | 1 | 1 | Υ | ١ | ( ) | 7 | Z | ZZ | 2 | 2 | | | | | | | | 1102 | fp_op, mem | 0 | 1 | 1 | 0 | 0 | 1 | 1 | Х | m | od | Y | ١ | <i>(</i> ) | ′ | m | em | 15 | 2-4 | | | | | | | | POLL | TP=OF1 IIIOIII | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | | | _ | | _ | | | | 2 + 5n | 1 | | | | | | | | . PULL | | • | | _ | | r | = | nun | nber of | tin | ies | PO | LL | pin | is | saı | nple | | | | | | _ | | | | NOP | | 1 | 0 | C | 1 | . ( | 0 | 0 | 0 | | | | | | | | | 3 | | | | | | | _ | | DI | | 1 | 1 | 1 | 1 | 1 | 0 | ) 1 | 0 | | | | | | ٠ | | | 2 | _1 | | _ | _ | | | _ | | El | | 1 | 1 | . 1 | 1 | 1 | 0 | 1 | 1 | | | | | | | | | 2 | 1 | | | | | | _ | | | truction Set Enhancemen | its | | | | | | | | | | | | - | | | | <u> </u> | | | | | | | | | RETEM | <u> </u> | 1 | . 1 | - | 0 | ) . | 1 1 | <u> </u> | 1 | 1 | 1 | 1 | | 1 | 1 | 1 | 0 1 | 39 | 2 | R | R | F | R | <u> </u> | ₹ F | | CALLN | imm8 | | _ | | | , . | i 1 | 1 | ) 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 - | 58 | 3 | | | | | | |