# HD64180R/Z 8-BIT CMOS (Micro Processing Unit) Based on a microcoded execution unit and advanced CMOS manufacturing technology, the HD64180 is an 8-bit MPU which provides the benefits of high performance, reduced system cost and low power operation while maintaining compatibility with the large base of industry standard 8-bit software. Performance is improved by virtue of high operating frequency, pipelining, enhanced instruction set and an integrated Memory Management Unit (MMU) with 1M or 512k bytes memory physical address space. System cost is reduced by incorporating key system functions on-chip including the MMU, two channel refresh, two channel Asynchronous Serial Communication Interface (ASCI), Clocked Serial I/O Port (CSI/O), two channel I6-bit Programmable Reload Timer (PRT), Versatile 12 source interrupt controller and a 'dual' $(68\times\times,80\times\times)$ bus interface. Low power consumption during normal CPU operation is supplemented by two specific software controlled low power operation modes. The HD64180, when combined with CMOS VLSI memories and peripherals, is useful in system applications requiring high performance, battery power operation and standard software compatibility. The HD64180Z is fully compatible with Z80180 (Z180) which is marketed by Zilog Inc. #### Software Features Enhanced standard 8-bit software architecture: Upward compatible with CP/M-80® #### ■ Hardware Features - On-chip MMU supporting 1M byte memory (Provided 512K byte for DP-64S. - Two channel DMAC with memory-memory, memory-I/O and memory-memory mapped I/O transfer capabilities - Two channel, full duplex asynchronous serial communication interface (ASC) with programmable baud rate generator and modem control handshake signals - One channel clocked serial I/O port with serial/parallel shift register - Two channel 16-bit programmable reload timer for output waveform generation - · Four external and eight internal interrupts - Dual bus interface compatible with Motorola 68 family and with Intel 80 family - · On-chip clock generator - Operating Frequency up to 10 MHz - Low power dissipation: 50 mW at 4 MHz Operation (typ.) - R = Interface with 63/68, 80xx peripherals - Z = Interface with Z80 peripherals ## Pin Function Differences in the HD64180 Series | Package *<br>Type | Pin<br>No. | HD64180R1 | HD64180Z | |-------------------|------------|-----------------|-----------------| | | 18 | V <sub>ss</sub> | V <sub>SS</sub> | | CP-68 | 35 | A <sub>19</sub> | A <sub>19</sub> | | | 52 | NC | TESŤ | | | 12 | V <sub>SS</sub> | V <sub>SS</sub> | | FP-80B | 33 | A <sub>19</sub> | A <sub>19</sub> | | | 53 | NC | TEST | <sup>\*&</sup>quot;J" after package designation indicates industrial temperature parts. ## HD64180R | Part No. | Clock Frequency<br>(MHz) | Package<br>Type | Address<br>Space | |----------------|--------------------------|-----------------|------------------| | HD64180RP-6 | 6 | | | | HD64180RP-8 | 8 | DP-64S | 512 K Byte | | HD64180RP-10 | 10 | | | | HD64180RF-6X | 6 | | | | HD64180RF-8X | 8 | FP-80 | 1 M Byte | | HD64180RF-10X | 10 | | | | HD64180RCP-6X | 6 | | | | HD64180RCP-8X | 8 | CP-68 | 1 M Byte | | HD64180RCP-10X | 10 | C1 -00 | 1 W Byte | ## HD64180Z | Part No. | Clock Frequency<br>(MHz) | Package<br>Type | Address<br>Space | |----------------|--------------------------|-----------------|------------------| | HD64180ZP-6 | 6 | | | | HD64180ZP-8 | 8 | DP-64S | 512 K Byte | | HD64180ZP-10 | 10 | | | | HD64180ZF-6X | 6 | | | | HD64180ZF-8X | 8 | FP-80 | 1 M Byte | | HD64180ZF-10X | 10 | | | | HD64180ZCP-6X | 6 | | | | HD64180ZCP-8X | 8 | CP-68 | l M Byte | | HD64180ZCP-10X | 10 | | | #### ■ PIN ASSIGNMENT #### **■ PIN ASSIGNMENT** ### ■ HD64180 BLOCK DIAGRAM (A<sub>0</sub> ~ A<sub>19</sub>: HD64180R1, HD64180Z; FP-80, CP-68) ## ■ ABSOLUTE MAXIMUM RATINGS | Item | Symbol | Value | Unit | |-----------------------|------------------|---------------------------|------| | Supply Voltage | V <sub>cc</sub> | -0.3~ + 7.0 | V | | Input Voltage | V <sub>in</sub> | $-0.3 \sim V_{cc} + 0.3$ | V | | Operating Temperature | T <sub>opr</sub> | -20 ~ +75*<br>-40 ~ +85** | °C | | Storage Temperature | T <sub>stg</sub> | <b>−55</b> ~ <b>+ 150</b> | °C | <sup>(</sup>NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI. ## ■ ELECTRICAL CHARACTERISTICS • DC CHARACTERISTICS ( $V_{cc}=5V\pm10\%$ , $V_{ss}=0V$ , ta=-20 ~ +75°C, Industrial Temp Ta=-40 ~ +85°C, unless otherwise noted.) | Item | Symbol | Condition | min. | typ. | max. | Unit | |-----------------------------------------------------------|------------------|---------------------------------------------|----------------------|------|-----------------------|------| | Input "H" Voltage<br>RESET, EXTAL, NMI | V <sub>IH1</sub> | | V <sub>CC</sub> -0.6 | | V <sub>CC</sub> + 0.3 | ٧ | | Input "H" Voltage<br>Except RESET, EXTAL, NMI | V <sub>IH2</sub> | | 2.0 | _ | V <sub>CC</sub> + 0.3 | ٧ | | Input "L" Voltage<br>RESET, EXTAL, NMI | $V_{IL1}$ | | -0.3 | _ | 0.6 | ٧ | | Input "L" Voltage<br>Except RESET, EXTAL, NMI | V <sub>IL2</sub> | | -0.3 | _ | 0.8 | ٧ | | Output "H" Voltage | V <sub>OH</sub> | $I_{OH} = -200 \mu A$ | 2.4 | _ | _ | V | | All Outputs | <b>V</b> ОН | $I_{OH} = -20\mu A$ | V <sub>CC</sub> -1.2 | | | V | | Output "L" Voltage<br>All Outputs | $V_{OL}$ | I <sub>OL</sub> = 2.2mA | _ | | 0.45 | ٧ | | Input Leakage<br>Current All Inputs<br>Except XTAL, EXTAL | I <sub>IL</sub> | $V_{in} = 0.5 \sim V_{CC} - 0.5$ | - | _ | 1.0 | μΑ | | Three State Leakage<br>Current | I <sub>TL</sub> | $V_{in} = 0.5 \sim V_{CC} - 0.5$ | | | 1.0 | μΑ | | Power Dissipation | Icc* | f = 4MHz | _ | 10 | 20 | | | (Normal Operation) | | f = 6MHz | _ | 15 | 30 | | | | | f = 8HMz | _ | 20 | 40 | | | | | f = 10MHz | _ | 25 | 50 | mA | | Power Dissipation | | f = 4HMz | | 2.5 | 5.0 | 1117 | | (SYSTEM STOP mode) | | f = 6MHz | _ | 3.3 | 7.5 | | | | | f = 8HMz | _ | 5.0 | 10.0 | | | | | f = 10MHz | <del>-</del> | 6.3 | 12.5 | | | Pin Capacitance | Ср | V <sub>in</sub> = 0V, f = 1HMz<br>Ta = 25°C | _ | _ | 12 | pF | <sup>\*</sup>VIH min. = V<sub>CC</sub>-1.0V, V<sub>IL</sub> max. = 0.8V (all output terminal are at no load) <sup>\*</sup>Standard Temp. <sup>\*\*</sup>Industrial Temp. # • DC CHARACTERISTICS ( $V_{cc}=5V\pm10\%$ , $V_{ss}=0V$ , ta=-20 ~ +75°C, Industrial Temp Ta=-40 ~ +85°C, unless otherwise noted.) | | | HD64180R/Z-4 | | HD64180R/Z-6 | | HD64180R/Z-8 | | HD64180R/Z-10 | | | |---------------------------------------------|--------------------|--------------|------|--------------|----------------------------------------------|--------------|------|---------------|------|---------------| | Item | Symbol | min. | max. | min. | max. | min. | max. | min. | max. | unit | | Clock Cycle Time | t <sub>cyc</sub> | 250 | 2000 | 162 | 2000 | 125 | 2000 | 100 | 2000 | ns | | Clock "H" Pulse Width | tchw | 110 | | 65 | | 50 | | 40 | | ns | | Clock "L" Pulse Width | t <sub>CLW</sub> | 110 | | 65 | | 50 | | 40 | | ns | | Clock Fall Time | t <sub>cf</sub> | | 15 | | 15 | | 15 | | 10 | ns | | Clock Rise Time | t <sub>cr</sub> | | 15 | | 15 | | 15 | | 10 | ns | | Address Delay Time | t <sub>AD</sub> | | 110 | | 90 | | 80 | | 70 | ns | | Address Set-up Time<br>(ME or IQE ↓) | tas | 50 | | 30 | | 20 | | | 70 | ns | | ME Delay Time 1 | t <sub>MED1</sub> | | 85 | | 60 | | 45 | 10 | | ns | | IO C = 1 | | | 85 | | 60 | | 45 | | 50 | ns | | RD Delay Time 1 | <sup>†</sup> RDD1 | | 85 | | 65 | | 60 | | 55 | 113 | | LIR Delay Time 1 | t <sub>LD1</sub> | | 100 | | 80 | | 70* | | 60 | ns | | Address Hold Time 1<br>(ME, IQE, RD or WR↑) | t <sub>AH</sub> | 80 | | 35 | | 20 | | 10 | | ns | | ME Delay Time 2 | t <sub>MED</sub> 2 | | 85 | | 60 | | 45 | | 50 | ns | | RD Delay Time 2 | t <sub>RDD2</sub> | | 85 | | 60 | | 45 | | 50 | ns | | LIR Delay Time 2 | t <sub>LD2</sub> | | 100 | | 80 | | 70* | | 60 | ns | | Data Read Set-up Time | t <sub>DRS</sub> | 50 | | 40 | | 30 | | 25 | | ns | | Data Read Hold Time | t <sub>DRH</sub> | 0 | | 0 | | 0 | | 0 | | ns | | ST Delay Time 1 | t <sub>STD1</sub> | | 110 | | 90 | | 70 | | 60 | ns | | ST Delay Time 2 | t <sub>STD2</sub> | | 110 | | 90 | | 70 | | 60 | ns | | WAIT Set-up Time | tws | 80 | | 40 | | 40 | | 30 | | ns | | WAIT Hold Time | t <sub>WH</sub> | 70 | | 40 | | 40 | | 30 | | ns | | Write Data Floating Delay Time | t <sub>WDZ</sub> | , | 100 | | 95 | | 70 | | 60 | ns | | WR Delay Time 1 | twRD1 | | 90 | | 65 | | 60 | | 50 | ns | | Write Data Delay Time | t <sub>WDD</sub> | | 110 | | 90 | | 80 | | 60 | ns | | Write Data Set-up Time (WR ↓) | twos | 60 | | 40 | | 20 | | 15 | | ns | | WR Delay Time 2 | twRD2 | | 90 | | 80 | | 60 | | 50 | ns | | Wil Dolay Timo E | 111102 | 1 | l | | <u>i </u> | | | | | $\rightarrow$ | <sup>\*</sup>For a loading capacitance of less than or equal to 40 picofarads and operating temperature from 0 to 50 degrees, subtract 10 nanoseconds from the value given in the maximum columns. ## **@HITACHI** | | | HD64180R/Z-4 | | HD64180R/Z-6 | | HD64180R/Z-8 | | HD64180R/Z-10 | | | |-----------------------------------------------------------|-------------------|--------------|------|--------------|------|--------------|------|---------------|------|------| | Item | Symbol | min. | max. | min. | max. | min. | max. | min. | max. | unit | | Write Data Hold Time<br>(WR ↑) | twDH | 60 | | 40 | | 15 | | 10 | | ns | | IOE Delay Time 1 | t <sub>IOD1</sub> | | 85 | | 60 | | 45 | | 50 | ns | | | | | 85 | | 65 | | 60 | | 55 | ns | | IOE Delay Time 2 | t <sub>IOD2</sub> | | 85 | | 60 | | 45 | | 50 | ns | | IOE Delay Time 2<br>(LIR ↓ ) | t <sub>IOD3</sub> | 540 | | 340 | | 250 | | 200 | | ns | | INT Set-up Time<br>(φ↓) | tints | 80 | | 40 | | 40 | | 30 | | ns | | $ \overline{\text{INT Hold Time}} \\ (\phi \downarrow ) $ | tINTH | 70 | | 40 | | 40 | | 30 | | ns | | NMI Pulse Width | t <sub>NMIW</sub> | 120 | | 120 | | 100 | | 80 | | ns | | BUSREQ Set-up Time (φ ↓ ) | t <sub>BRS</sub> | 80 | | 40 | | 40 | | 30 | | ns | | BUSREQ Hold Time | t <sub>BRH</sub> | 70 | | 40 | | 40 | | 30 | | ns | | BUSACK Delay Time 1 | t <sub>BAD1</sub> | | 100 | | 95 | | 70 | | 60 | ns | | BUSACK Delay Time 2 | t <sub>BAD2</sub> | | 100 | _ | 95 | | 70 | | 60 | ns | | Bus Floating Delay Time | t <sub>BZD</sub> | | 130 | | 125 | | 90 | | 70 | ns | | ME Pulse Width (HIGH) | t <sub>MEWH</sub> | 200 | | 110 | | 90 | | 70 | | ns | | ME Pulse Width (LOW) | tMEWL | 210 | | 125 | | 100 | | 80 | | ns | | REF Delay Time 1 | t <sub>RFD1</sub> | - | 110 | | 90 | | 80 | | 60 | ns | | REF Delay Time 2 | t <sub>RFD2</sub> | | 110 | · | 90 | | 80 | | 60 | ns | | HALT Delay Time 1 | t <sub>HAD1</sub> | | 110 | | 90 | | 80 | | 50 | ns | | HALT Delay Time 2 | t <sub>HAD2</sub> | | 110 | | 90 | | 80 | | 50 | ns | | DREQ i Set-up Time | tDRQS | 80 | | 40 | | 40 | | 30 | | ns | | DREQ i Hold Time | tDRQH | 70 | | 40 | | 40 | | 30 | | ns | | TEND i Delay Time 1 | t <sub>TED1</sub> | | 85 | | 70 | | 60 | | 50 | ns | | TEND i Delay Time 2 | t <sub>TED2</sub> | | 85 | | 70 | | 60 | | 50 | ns | | Enable Delay Time 1 | t <sub>ED1</sub> | | 100 | | 95 | | 70 | | 60 | ns | | Enable Delay Time 2 | t <sub>ED2</sub> | | 100 | | 95 | _ | 70 | | 60 | ns | | E Pulse Width (HIGH) | P <sub>WEH</sub> | 150 | | 75 | | 65 | | 55 | | ns | | E Pulse Width (LOW) | P <sub>WEL</sub> | 300 | | 180 | | 130 | | 110 | | ns | | | HD64180R/Z-4 | | HD64180R/Z-6 | | HD64180R/Z-8 | | HD64180R/Z-10 | | | | |--------------------------------------------------------------------|-------------------|------|------------------|------|------------------|------|------------------|------|------------------|------| | Item | Symbol | min. | max. | min. | max. | min. | max. | min. | max. | unit | | Enable Rise Time | t <sub>Er</sub> | | 25 | | 20 | | 20 | | 20 | ns | | Enable Fall Time | t <sub>Ef</sub> | | 25 | | 20 | | 20 | | 20 | ns | | Timer Output Delay<br>Time | t <sub>TOD</sub> | | 300 | | 300 | | 200 | | 150 | ns | | CSI/O Transmit Data Delay Time (Internal Clock Operation) | t <sub>STDI</sub> | | 200 | | 200 | | 200 | | 150 | ns | | CSI/O Transmit Data<br>Delay Time<br>(External Clock<br>Operation) | <sup>t</sup> STDE | | 7.5tcyc<br>+ 300 | | 7.5tcyc<br>+ 300 | | 7.5tcyc<br>+ 200 | | 7.5tcyc<br>+ 150 | ns | | CSI/O Receive Data<br>Set-up Time<br>(Internal Clock<br>Operation) | t <sub>SRSI</sub> | 1 | | 1 | | 1 | | 1 | | tcyc | | CSI/O Receive Data<br>Hold Time<br>(Internal Clock<br>Operation) | tsrhi | 1 | | 1 | | 1 | | 1 | | tcyc | | CSI/O Receive Data<br>Set-up Time<br>(External Clock<br>Operation) | tSRSE | 1 | | 1 | | 1 | | 1 | | tcyc | | CSI/O Receive Data | tSRHE | 1 | | 1 | | 1 | | 1 | | tcyc | | RESET Set-up Time | t <sub>RES</sub> | 120 | | 120 | | 100 | | 80 | | ns | | RESET Hold Time | t <sub>REH</sub> | 80 | | 80 | | 70 | <u> </u> | 60 | | ns | | Oscillator Stabilization<br>Time | tosc | | 20 | | 20 | | 20 | | 40 | ms | | External Clock Rise<br>Time<br>(EXTAL) | t <sub>EXr</sub> | | 25 | | 25 | | 25 | | 25 | ns | | External Clock Fall Time (EXTAL) | tEXf | | 25 | | 25 | | 25 | | 25 | ns | | RESET Rise Time | t <sub>Rr</sub> | | 50 | | 50 | | 50 | | 50 | ms | | RESET Fall Time | t <sub>Rf</sub> | | 50 | | 50 | | 50 | | 50 | ms | | Input Rise Time (except EXTAL, RESET) | t <sub>ir</sub> | | 10 | | 100 | | 100 | | 100 | ns | | Input Fall Time<br>(except EXTAL, RESET) | t <sub>lf</sub> | | 100 | | 100 | | 100 | | 100 | ns | ## **OHITACHI** \*1 Output buffer is off at this point. Figure 1 CPU Timing (1) Figure 1 CPU Timing (2) Figure 2 DMA Control Signals Figure 3 E Clock Timing (2) Figure 4 Timer Output Timing Figure 5 SLP Execution Cycle Figure 6 CSI/O Receive/Transmit Timing EXTAL Rise time and Fall time Inputs, other than EXTAL, Rise time and Fall time Figure 7 Bus Timing Test Load (TTL Load) #### 1 PIN DESCRIPTION ## XTAL (IN) Crystal oscillator connection. Should be left open if an external TTL clock is used. It is noted this input is not a TTL level input. See Table D.C. characteristics. #### EXTAL (IN) Crystal oscillator connection. An external TTL clock can be input on this line. This input is schmitt triggered. System Clock. The frequency is equal to one-half of crystal oscillator. #### RESET - CPU Reset (IN) When LOW, initializes the HD64180 CPU. All output signals are held inactive during RESET. ## A<sub>0</sub>-A<sub>17</sub> — Address Bus (OUT, 3-STATE) A<sub>18</sub>/TOUT 19-bit address bus provides physical memory addresses of up to 512k bytes. The address bus enters the high impedance state during RESET and when another device acquires the bus as indicated by BUSREQ and BUSACK LOW. A18 is multiplexed with the TOUT output from PRT channel 1. During RESET, the address bus function is selected. TOUT function can be selected under software control. ## D<sub>0</sub>-D<sub>7</sub> — Data Bus (IN/OUT, 3-STATE) Bidirectional 8-bit data bus. The data bus enters the high impedance state during RESET and when another device acquires the bus as indicated by BUSREQ and BUSACK LOW. ## RD - Read (OUT, 3-STATE) Used during a CPU read cycle to enable transfer from the external memory or I/O device to the CPU data bus. ### WR - Write (OUT, 3-STATE) Used during a CPU write cycle to enable transfer from the CPU data bus to the external memory or I/O device. ## ME - Memory Enable (OUT, 3-STATE) Indicates memory read or write operation. The HD64180 asserts ME LOW in the following cases. - (a) When fetching instructions and operands. - (b) When reading or writing memory data. - (c) During memory access cycles of DMA. - (d) During dynamic RAM refresh cycles. ## IOE - I/O Enable (OUT, 3-STATE) Indicates I/O read or write operation. The HD64180 asserts IOE LOW in the following cases. - (a) When reading or writing I/O data - (b) During I/O access cycles of DMA. - (c) During INT acknowledge cycle ## WAIT - Bus Cycle Wait (IN) Introduces wait states to extend memory and I/O cycles. If LOW at the falling edge of $T_2$ , a wait state $(\underline{Tw})$ is inserted. Wait states will continue to be inserted until the $\underline{WAIT}$ input is sampled HIGH at the falling edge of Tw, at which time the bus cycle will proceed to completion. ## E - Enable (OUT) Synchronous clock for connection to HD63×× series and other 6800/6500 series compatible peripheral LSIs. ## BUSREQ - Bus Request (IN) Another device may request use of the bus by asserting BUSREQ LOW. The CPU will stop executing instructions and places the address bus, data bus, $\overline{RD}$ , $\overline{WR}$ , $\overline{ME}$ and $\overline{IOE}$ in the high impedance state. ## BUSACK - Bus Acknowledge (OUT) When the CPU completes bus release (in response to BUSREQ LOW), it will assert BUSACK LOW. This acknowledges that the bus is free for use by the requesting device. ## HALT - Halt/Sleep Status (OUT) Asserted LOW after execution of the HALT or SLP instructions. Used with LIR and ST output pins to encode CPU status. ## LIR - Load Instruction Register (OUT) Asserted LOW when the current cycle is an op-code fetch cycle. Used with HALT and ST output pins to encode CPU status. ### ST - Status (OUT) Used with the HALT and LIR output pins to encode CPU Table 1 Status Summary | ST | HALT | LIR | Operation | |----|------|-----|---------------------------------------------------------| | 0 | 1 | 0 | CPU operation<br>(1st op-code fetch) | | 1 | 1 | 0 | CPU operation<br>(2nd op-code and<br>3rd op-code fetch) | | 1 | 1 | 1 | CPU operation<br>(MC except for op-code fetch) | | 0 | X | 1 | DMA operation | | 0 | 0 | 0 | HALT mode | | 1 | 0 | 1 | SLEEP mode (including SYSTEM STOP mode) | NOTE) X: Don't care MC: Machine cycle ## REF - Refresh (OUT) When LOW, indicates the CPU is in the dynamic RAM refresh cycle and the low-order 8 bits $(A_0 - A_7)$ of the address bus contain the refresh address. ## NMI - Non-Maskable Interrupt (IN) When edge transition from HIGH to LOW is detected, forces the CPU to save certain state information and vector to an interrupt service routine at address 0066H. The saved state information is restored by executing the RETN (Return from Non-Maskable Interrupt) instruction. ## INT<sub>0</sub> - Maskable Interrupt Level 0 (IN) When LOW, requests a CPU interrupt (unless masked) and saves certain state information unless masked by software. $\overline{ ext{INT}}_{\scriptscriptstyle{0}}$ requests service using one of three software programmable interrupt modes. | Mode | Operation | |------|------------------------------------------------------------------------------| | 0 | Instruction fetched and executed from data bus | | 1 | Instruction fetched and executed from address 0038H. | | 2 | Vector System — Low-order 8 bits vector table address fetched from data bus. | In all modes, the saved state information is restored by executing RETI (Return from Interrupt) instruction. ## INT<sub>1</sub>, INT<sub>2</sub> - Maskable Interrupt Level 1, 2 (IN) When LOW, requests a CPU interrupt (unless masked) and saves certain state information unless masked by software. $\overline{INT_1}$ and $\overline{INT_2}$ (and internally generated interrupts) request interrupt service using a vector system similar to Mode 2 of $\overline{INT_0}$ . #### DREQ - DMA Request - Channel 0 (IN) When LOW (programmable edge or level sensitive), requests DMA transfer service from channel 0 of the HD64180 DMAC. $\overline{DREQ_0}$ is used for Channel 0 memory $\longleftrightarrow$ 1/O and memory $\longleftrightarrow$ memory mapped 1/O transfers. $\overline{DREQ_0}$ is not used for memory $\longleftrightarrow$ memory transfers. This pin is multiplexed with CKA. #### TEND<sub>0</sub> - Transfer End - Channel 0 (OUT) Asserted LOW synchronous with the last write cycle of channel 0 DMA transfer to indicate DMA completion to an external device. This pin is multiplexed with CKA<sub>1</sub>. #### DREQ<sub>1</sub> - DMA Request - Channel 1 (IN) When LOW (programmable edge or level sense), requests DMA transfer service from channel 1 of the HD64180 DMAC. Channel 1 supports Memory ←→ 1/O transfers. #### TEND<sub>1</sub> - Transfer End - Channel 1 (OUT) Asserted LOW synchronous with the last write cycle of channel 1 DMA transfer to indicate DMA completion to an external device. #### TXA<sub>0</sub> - Asynchronous Transmit Data - Channel 0 (QUT) Asynchronous transmit data from channel 0 of the Asynchronous Serial Communication Interface (ASCI). ## RXA<sub>0</sub> — Asynchronous Receive Data — Channel 0 (IN) Asynchronous receive data to channel 0 of the ASCI. #### CKA<sub>0</sub> - Asynchronous Clock - Channel 0 (IN/OUT) Clock input/output for channel 0 of the ASC1. This pin is multiplexed (software selectable) with $\overline{DREQ}_0$ . #### RTS<sub>0</sub> - Request to Send - Channel 0 (OUT) Programmable modem control output signal for channel 0 of the ASCI #### CTS<sub>0</sub> - Clear to Send - Channel 0 (IN) Modem control input signal for channel 0 of the ASCI. #### DCD<sub>0</sub> - Data Carrier Detect - Channel 0 (IN) Modem control input signal for channel 0 of the ASCI. ## TXA<sub>1</sub> — Asynchronous Transmit Data — Channel 1 (OUT) Asynchronous transmit data from channel 1 of the ASCI. #### RXA<sub>1</sub> — Asynchronous Receive Data — Channel 1 (IN) Asynchronous receive data to channel 1 of the ASCI. ## CKA<sub>1</sub> - Asynchronous Clock - Channel 1 (IN/OUT) Clock input/output for channel 1 of the ASCI. This pin is multiplexed (software selectable) with $\overline{\text{TEND}}_0$ . ## CTS<sub>1</sub> - Clear to Send - Channel 1 (IN) Modem control input signal for channel 1 of the ASCI. This pin is multiplexed (software selectable) with RXS. #### TXS - Clocked Serial Transmit Data (OUT) Clocked serial transmit data from the Clocked Serial I/O Port (CSI/O). #### RXS - Clocked Serial Receive Data (IN) Clocked serial receive data to the CSI/O. This pin is multiplexed (software selectable) with ASCI channel 1 $\overline{CTS_1}$ modem control input. #### CKS - Serial Clock (IN/OUT) Input or output clock for the CSI/O. #### TOUT - Timer Output (OUT) Pulse output from Programmable Reload Timer channel 1. This pin is multiplexed (software selectable) with $A_{18}$ (Address 18). V<sub>CC</sub> - Power Supply V<sub>SS</sub> - Ground #### Multiplexed pin descriptions ## A<sub>18</sub>/TOUT During RESET, this pin is initialized as A<sub>18</sub> pin. If either TOC1 or TOC0 bit in Timer Control Register (TCR) is set to 1, TOUT function is selected. If TOC1 and TOC0 bits are cleared to 0, A<sub>18</sub> function is selected. #### CKA0/DREQ During RESET, this pin is initialized as CKA<sub>0</sub> pin. If either <u>DM1</u> or SM1 in DMA Mode Register (DMODE) is set to 1, <u>DREQ</u><sub>0</sub> function is always selected. #### CKA1/TENDO During RESET, this pin is initialized as CKA<sub>1</sub> pin. If CKA1D bit in ASCI control register ch 1 (CNTLA1) is set to 1, TEND<sub>0</sub> function is selected. If CKA1D bit is set to 0, CKA<sub>1</sub> function is selected. #### RXS/CTS. During RESET, this pin is initialized as RXS pin. If CTS1E bit in ASCI status register chl (STAT1) is set to 1, $\overline{\text{CTS}}_1$ function is selected If CTS1E bit is set to 0, RXS function is selected. #### 2 CPU REGISTERS The HD64180 CPU registers consist of Register Set GR, Register Set GR' and Special Registers. The Register Set GR consists of 8-bit Accumulator (A), 8-bit Flag Register (F), and three General Purpose Registers (BC, DE, and HL) which may be treated as 16-bit registers (BC, DE, and HL) or as individual 8-bit registers (B, C, D, E, H, and L) depending on the instruction to be executed. The Register Set GR' is alternate register set of Register Set GR and also contains Accumulator (A'), Flag Register (F') and three General Purpose Registers (BC', DE', and HL'). While the alternate Register Set GR' contents are not directly accessible, the contents can be programmably exchanged at high speed with those of Register Set GR. The Special Registers consist of 8-bit Interrupt Vector Register (I), 8-bit R Counter (R), two 16-bit Index Registers (IX and IY), 16-bit Stack Pointer (SP), and 16-bit Program Counter (PC). Fig. 8 shows CPU registers configuration. ## Register Set GR | Accumulator<br>A | Flag Register<br>F | | |------------------|--------------------|----------------------| | B Register | C Register | General | | D Register | E Register | Purpose<br>Registers | | H Register | L Register | | ## Special Registers | R Counter | |-----------| | R | | IX | | IY | | SP | | ter PC | | | ## Register Set GR' | Accumulator<br>A' | Flag Register<br>F' | | |-------------------|---------------------|---------| | B' Register | C' Register | General | | D' Register | E' Register | Purpose | | H' Register | L' Register | | Figure 8 CPU Register Configuration #### 2.1 Register Description #### (1) Accumulator (A, A') The Accumulator (A) serves as the primary register used for many arithmetic, logical and I/O instructions. ## (2) Flag Registers (F, F') The flag register stores various status bits (described in the next section) which reflect the results of instruction execution. ## (3) General Purpose Registers (BC, BC', DE, DE', HL, HL') The General Purpose Registers are used for both address and data operation. Depending on instruction, each half (8 bits) of these registers (B, C, D, E, H, and L) may also be used. ## (4) Interrupt Vector Register (I) For interrupts which require a vector table address to be calculated (INT<sub>0</sub> Mode 2, INT<sub>1</sub>, INT<sub>2</sub> and internal interrupts), the Interrupt Vector Register (I) provides the most significant byte of the vector table address. #### (5) R Counter (R) The least significant seven bits of the R Counter (R) serve to count the number of instructions executed by the HD64180. R is incremented for each CPU op-code fetch cycles (each LIR cycles). ## (6) Index Registers (IX, and IY) The Index Registers are used for both address and data operations. For addressing, the contents of a displacement specified in the instruction are added to or subtracted from the Index Register to determine an effective operand address. #### (7) Stack Pointer (SP) The Stack Pointer (SP) contains the memory address based LIFO stack. #### (8) Program Counter (PC) The Program Counter (PC) contains the address of the instruction to be executed and is automatically updated after each instruction fetch. #### (9) Flag Register (F) The Flag Register stores the logical state reflecting the results of instruction execution. The contents of the Flag Register are used to control program flow and instruction operation. bit 7 6 5 4 3 2 1 0 S Z - H - P/V N C Flag Register (F) #### S: Sign (bit 7) S stores the state of the most significant bit (bit 7) of the result. This is useful for operations with signed numbers in which values with bit 7 = 1 are interpreted as negative. #### Z: Zero (bit 6) Z is set to 1 when instruction execution results containing 0. Otherwise, Z is reset to 0. #### H: Half Carry (bit 4) H is used by the DAA (Decimal Adjust Accumulator) instruction to reflect borrow or carry from the least significant 4 bits and thereby adjust the results of BCD addition and subtraction. #### P/V: Parity/Overflow (bit 2) P/V serves a dual purpose. For logical operations P/V is set to 1 if the number of 1 bit in the result is even and P/V is reset to 0 if the number of 1 bit in the result is odd. For two complement arithmetic, P/V is set to 1 if the operation produces a result which is outside the allowable range (+127 to -128 for 8-bit operations, +32767 to -32768 for 16-bit operations). #### N: Negative (bit 1) N is set to 1 if the last arithmetic instruction was a subtract operation (SUB, DEC, CP, etc.) and N is reset to 0 if the last arithmetic ## 8-bit Register | g or g' field | Register | |---------------|----------| | 0 0 0 | В | | 0 0 1 | С | | 0 1 0 | D | | 0 1 1 | E | | 1 0 0 | Н | | 1 0 1 | L | | 1 1 0 | _ | | 1 1 1 | Α | ## 16-bit Register | zz field | Register | |----------|----------| | 0 0 | ВС | | 0 1 | D E | | 1 0 | HL | | 1 1 | AF | instruction was an addition operation (ADD, INC, etc.). #### C: Carry (bit 0) C is set to 1 when a carry (addition) or borrow (subtraction) from the most significant bit of the result occurs. C is also affected by Accumulator logic operations such as shifts and rotates. #### 3 ADDRESSING MODES The HD64180 instruction set includes eight addressing modes. Implied Register Register Direct Register Indirect Indexed Extended Immediate Relative OI #### (1) Implied Register (IMP) Certain op-codes automatically imply register usage, such as the arithmetic operations which inherently reference the Accumulator, Index Registers, Stack Pointer and General Purpose Registers. ### (2) Register Direct (REG) Many op-codes contain bit fields specifying registers to be used for the operation. The exact bit field definition vary depending on instruction as follows. | ww field | Register | |----------|----------| | 0 0 | BC | | 0 1 | DE | | 1 0 | HL | | 1 1 | SP | | xx field | Register | |----------|----------| | 0 0 | ВС | | 0 1 | DE | | 1 0 | ΙX | | 1 1 | SP | | yy field | Register | |----------|----------| | 0 0 | ВС | | 0 1 | DE | | 1 0 | IY | | 1 1 | S P | Suffixed H and L to ww,xx,yy,zz (ex. wwH,IXL) indicate upper and lower 8-bit of the 16-bit register respectively. #### (3) Register Indirect (REG) The memory operand address is contained in one of the 16-bit General Purpose Registers (BC, DE and HL). ## (4) Indexed (INDX) The memory operand address is calculated using the contents of an Index Register (IX or IY) and an 8-bit signed displacement specified in the instruction. #### (5) Extended (EXT) The memory operand address is specified by two bytes contained in the instruction. #### (6) Immediate (IMMED) The memory operands are contained within one or two bytes of the instruction. #### (7) Relative (REL) Relative addressing mode is only used by the conditional and unconditional branch instructions. The branch displacement (relative to the contents of the program counter) is contained in the instruction. #### (8) 10 (10) IO addressing mode is used only by I/O instructions. This mode specifies I/O address ( $\overline{IOE} = 0$ ) and outputs them as follows. - An operand is output to A<sub>0</sub>-A<sub>7</sub>. The Contents of Accumulator is output to A<sub>8</sub>-A<sub>16</sub>. - The Contents of Register B is output to A<sub>0</sub>-A<sub>7</sub>. The Contents of Register C is output to A<sub>8</sub>-A<sub>15</sub>. - (3) An operand is output to A<sub>0</sub>-A<sub>7</sub>. 00H is output to A<sub>8</sub>-A<sub>18</sub>. (useful for internal I/O register access) - (4) The Contents of Register C is output to A<sub>0</sub>-A<sub>7</sub>. 00H is output to A<sub>-</sub>-A<sub>1</sub>. to A<sub>8</sub>-A<sub>15</sub>. (useful for internal I/O register access) #### **■ CPU BUS TIMING** This section explains the HD64180 CPU timing for the following operations. - (1) Instruction (op-code) fetch timing. - (2) Operand and data read/write timing. - (3) I/O read/write timing. - (4) Basic instruction (fetch and execute) timing. - (5) RESET timing. - (6) BUSREQ/BUSACK bus exchange timing. The basic CPU operation consists of one or more "machine cycles" (MC). A machine cycle consists of three system clocks, $T_1$ , $T_2$ and $T_3$ while accessing memory or I/O, or it consists of one system clock, Ti while the CPU internal operation. The system clock ( $\phi$ ) is half frequency of crystal oscillation (Ex. 8 MHz crystal $\rightarrow \phi$ of 4 MHz, 250 nsec). For interfacing to slow memory or peripherals, optional wait states (Tw) may be inserted between $T_2$ and $T_3$ . #### Instruction (op-code) Fetch Timing Fig. 9 shows the instruction (op-code) fetch timing with no wait states. An op-code fetch cycle is externally indicated when the LIR (Load Instruction Register) output pin is LOW. In the first half of $T_1$ , the address bus $(A_0 - A_{18})$ is driven with the contents of the Program Counter (PC). Note that this is the translated address output of the HD64180 on-chip MMU. In the second half of T<sub>1</sub>, the ME (Memory Enable) and RD (Read) signals are asserted LOW, enabling the memory. The op-code on the data bus is latched at the rising edge of $T_3$ and the bus cycle terminates at the end of $T_3$ . Figure 9 Op-Code Fetch Timing Fig. 10 illustrates the insertion of wait states (Tw) into the opcode fetch cycle. Wait states (Tw) are controlled by the external WAIT input combined with an on-chip programmable wait state generator. At the falling edge of T<sub>2</sub> the combined WAIT input is sampled. If $\overline{WAIT}$ input is asserted LOW, a wait state (Tw) is inserted. The address bus, $\overline{ME}$ , $\overline{RD}$ and $\overline{LIR}$ are held stable during wait states. When the $\overline{WAIT}$ is sampled inactive HIGH at the falling edge of Tw, the bus cycle enters $T_3$ and completes at the end of $T_3$ . Figure 10 Op-Code Fetch Timing (with wait state) ## Operand and Data Read/Write Timing The instruction operand and data read/write timing differs from op-code fetch timing in two ways. First, the LIR output is held inactive. Second, the read cycle timing is relaxed by one-half clock cycle since data is latched at the falling edge of T<sub>3</sub>. Instruction operands include immediate data, displacement and extended addresses and have the same timing as memory data reads. During memory write cycles the ME signal goes active in the second half of T1. At the end of T1, the data bus is driven with the write data. At the start of $\underline{T_2}$ , the $\overline{WR}$ signal is asserted LOW enabling the memory. $\overline{ME}$ and $\overline{WR}$ go inactive in the second half of $T_3$ followed by deactivation of the write data on the data bus. Wait states (Tw) are inserted as previously described for op-code fetch cycles. Fig. 11 illustrates the read/write timing without wait states (Tw), while Fig. 12 illustrates read/write timing with wait states (Tw). Figure 11 Memory Read/Write Timing (without wait state) Figure 12 Memory Read/Write Timing (with wait state) #### 4.3 I/O Read/Write Timing I/O instructions cause data read/write transfer which differs from memory data transfer in the following three ways. The $\overline{IOE}$ (I/O Enable) signal is asserted LOW instead of the $\overline{ME}$ signal. The 16-bit I/O address is not translated by the MMU and $A_{16}$ - $A_{18}$ are held LOW. At least one wait state (Tw) is always inserted for I/O read and write cycles (except internal I/O cycles). Fig. 13 shows I/O read/write timing with the automatically inserted wait state (Tw). Figure 13 I/O Read/Write Timing #### 4.4 Basic Instruction Timing An instruction may consist of a number of machine cycles including op-code fetch, operand fetch and data read/write cycles. An instruction may also include cycles for internal processing in which case the bus is idle. The example in Fig. 14 illustrates the bus timing for the data transfer instruction LD (IX+d),g. This instruction moves the contents of a CPU register (g) to the memory location with address computed by adding an signed 8-bit displacement (d) to the contents of an index register (IX). The instruction cycle starts with the two machine cycles to read the two bytes instruction op-code as indicated by $\overline{LIR}$ LOW. Next, the instruction operand (d) is fetched. The external bus is idle while the CPU computes the effective address. Finally, the computed memory location is written with the contents of the CPU register (g). Figure 14 LD (IX+d), g Instruction Timing #### 4.5 RESET Timing Fig. 15 shows the HD64180 hardware RESET timing. If the RE-SET pin is LOW for at least six clock cycles, processing is terminated and the HD64180 restarts execution from (logical and physical) address 00000H. Figure 15 RESET Timing ## 4.6 BUSREQ/BUSACK Bus Exchange Timing The HD64180 can coordinate the exchange of control, address and data bus ownership with another bus master. The alternate bus master can request the bus release by asserting the BUSREQ (Bus Request) input LOW. After the HD64180 releases the bus, it relinquishes control to the alternate bus master by asserting the BUSACK (Bus Acknowledge) output LOW. The bus may be released by the HD64180 at the end of each machine cycle. In this context a machine cycle consists of a minimum of 3 clock cycles (more if wait states are inserted) for op-code fetch, memory read/write and I/O read/write cycles. Except for these cases, a machine cycle corresponds to one clock cycle. When the bus is released, the address $(A_0-A_{18})$ , data $(D_0-D_7)$ and control $(\overline{ME}, \overline{IOE}, \overline{RD}, \text{ and } \overline{WR})$ signals are placed in the high impedance state. Note that dynamic RAM refresh is not performed when the HD64180 has released the bus. The alternate bus master must provide dynamic memory refreshing if the bus is released for long periods of time. Fig. 16 illustrates BUSREQ/BUSACK bus exchange during a memory read cycle. Fig. 17 illustrates bus exchange when the bus release is requested during an HD64180 CPU internal operation. BUSREQ is sampled at the falling edge of the system clock prior to T<sub>3</sub>, Ti and Tx (BUS RELEASE state). If BUSREQ is asserted LOW at the falling edge of the clock state prior to Tx, another Tx is executed. Figure 16 Bus Exchange Timing (1) Figure 17 Bus Exchange Timing (2) #### **B HALT AND LOW POWER OPERATION MODES** The HD64180 can operate in 4 different modes. HALT mode, IOSTOP mode and two low power operation modes — SLEEP and SYSTEM STCP. Note that in all operating modes, the basic CPU clock (XTAL, EXTAL) must remain active. #### 5.1 HALT Mode HALT mode is entered by execution of the HALT instruction (op-code = 76H) and has the following characteristics. - (1) The internal CPU clock remains active. - (2) All internal and external interrupts can be received. - (3) Bus exchange (BUSREQ and BUSACK) can occur. - (4) Dynamic RAM refresh cycle (REF) insertion continues at the programmed interval. - (5) I/O operations (ASCI, CSI/O and PRT) continue. - (6) The DMAC can operate. - (7) The HALT output pin is asserted LOW. - (8) The external bus activity consists of repeated 'dummy' fetches of the op-code following the HALT instruction. Essentially, the HD64180 operates normally in HALT mode, except that instruction execution is stopped. HALT mode can be exited in the following two ways. #### RESET Exit from HALT Mode If the RESET input is asserted LOW for at least six clock cycles, HALT mode is exited and the normal RESET sequence (restart at address 00000H) is initiated. #### Interrupt Exit from HALT Mode When an internal or external interrupt is generated, HALT mode is exited and the normal interrupt response sequence is initiated. If the interrupt source is masked (individually by enable bit, or globally by IEF, state), the HD64180 remains in HALT mode. However, NMI interrupt will initiate the normal NMI interrupt response sequence independent of the state of IEF<sub>1</sub>. HALT timing is shown in Fig. 18. Figure 18 HALT Timing #### 5.2 SLEEP Mode SLEEP mode is entered by execution of the 2 byte SLP instruction. SLEEP mode has the following characteristics. - (1) The internal CPU clock stops, reducing power consumption. - (2) The internal crystal oscillator does not stop. - (3) Internal and external interrupt inputs can be received. - (4) DRAM refresh cycles stop. - (5) I/O operations using on-chip peripherals continue. - (6) The internal DMAC stop. - (7) BUSREQ can be received and acknowledged. - (8) Address outputs go HIGH and all other control signal output become inactive HIGH. - (9) Data Bus, 3-state. SLEEP mode is exited in one of two ways as shown below. #### RESET Exit from SLEEP Mode If the RESET input is held LOW for at least six clock cycles, the HD64180 will exit SLEEP mode and begin the normal RESET sequence with execution starting at address (logical and physical) 00000H. #### Interrupt Exit from SLEEP Mode The SLEEP mode is exited by detection of an external (NMI, INT, INT,) or internal (ASCI, CSI/O, PRT) interrupt. In the case of NMI, SLEEP Mode is exited and the CPU begins the normal NMI interrupt response sequence. In the case of all other interrupts, the interrupt response depends on the state of the global interrupt enable flag (IEF<sub>1</sub>) and the individual interrupt source enable bit. If the individual interrupt condition is disabled by the corresponding enable bit, occurrence of that interrupt is ignored and the CPU remains in the SLEEP state. Assuming the individual interrupt condition is enabled, the response to that interrupt depends on the global interrupt enable flag ( $\mathrm{IEF}_1$ ). If interrupts are globally enabled ( $\mathrm{IEF}_1=1$ ) and an individually enabled interrupt occurs, SLEEP mode is exited and the appropriate normal interrupt response sequence is executed. If interrupts are globally disabled (IEF<sub>1</sub>=0) and an individually enabled interrupt occurs, SLEEP mode is exited and instruction execution begins with the instruction following the SLP instruction. Note that this provides a technique for synchronization with high speed external events without incurring the latency imposed by an interrupt response sequence. Fig. 19 shows SLEEP timing. #### 5.3 IOSTOP Mode IOSTOP mode is entered by setting the IOSTP bit of the I/O Control Register (ICR) to 1. In this case, on-chip I/O (ASCI, CSI/O, PRT) stops operating. However, the CPU continues to operate. Recovery from IOSTOP mode is by clearing the IOSTP bit in ICR to 0. #### 5.4 SYSTEM STOP Mode SYSTEM STOP mode is the combination of SLEEP and IOSTOP modes. SYSTEM STOP mode is entered by setting the IOSTP bit in ICR to 1 followed by execution of the SLP instruction. In this mode, on-chip I/O and CPU stop operating, reducing power consumption. Recovery from SYSTEM STOP mode is the same as recovery from SLEEP mode, noting that internal I/O sources (disabled by IOSTOP) cannot generate a recovery interrupt. Figure 19 SLEEP Timing #### 6 INTERRUPTS The HD64180 CPU has twelve interrupt sources, four external and eight internal, with fixed priority. This section explains the CPU registers associated with interrupt processing, the TRAP interrupt, interrupt response modes and the external interrupts. The detailed discussion of internal interrupt generation (except TRAP) is presented in the appropriate hardware section (i.e. PRT, DMAC, ASCI and CSI/O). | Priori | ty | Interrupt | | |----------|----|-----------------------------------------------|--------------------| | Higher | 1 | TRAP (Undefined Op-code Trap) | Internal Interrupt | | Priority | 2 | NMI (Non Maskable Interrupt) | | | <b>†</b> | 3 | INT <sub>0</sub> (Maskable Interrupt Level 0) | External Interrupt | | | 4 | INT <sub>1</sub> (Maskable Interrupt Level 1) | · | | | 5 | INT 2 (Maskable Interrupt Level 2) | | | | 6 | Timer 0 | | | 1 | 7 | Timer 1 | | | | 8 | DMA channel 0 | | | | 9 | DMA channel 1 | Internal Interrupt | | . ↓ | 10 | Clocked Serial I/O Port | | | Lower | 11 | Asynchronous SCI channel 0 | | | Priority | 12 | Asynchronous SCI channel 1 | | Figure 20 Interrupt Sources #### 6.1 Interrupt Control Registers and Flags The HD64180 contains three registers and two flags which are associated with interrupt processing. | Register and<br>Flag Name | Function | Access Method | | | | |-------------------------------------|------------------------------------------|-------------------------------------------------|--|--|--| | ı | Contains upper 8-bit of interrupt vector | LD A, I and<br>LD I, A instructions | | | | | IL. | Contains lower 8-bit of interrupt vector | I/O instruction (addr = 33H) | | | | | ITC Interrupt/Trap cont | | 1/O instruction<br>(addr = 34H) | | | | | IEF <sub>1</sub> , IEF <sub>2</sub> | Enable/disable interrupt | EI, DI,<br>LD A, I, and<br>LD A, R instructions | | | | #### (1) Interrupt Vector Register (I) Mode 2 for $\overline{\text{INT}}_0$ external interrupt, $\overline{\text{INT}}_1$ and $\overline{\text{INT}}_2$ external interrupts and all internal interrupts (except TRAP) use a programmable vectored technique to determine the address at which interrupt processing starts. In response to the interrupt a 16-bit address is generated. This address accesses a vector table in memory to obtain the address at which execution restarts. While the method for generation of the least significant byte of the table address differs, all vectored interrupts use the contents of I as the most significant byte of the table address. By programming the contents of I, vector tables can be relocated on 256 bytes boundaries throughout the 64k bytes logical address space. Note that I is read/written with the LD A, I and LD I, A instructions rather than I/O (IN, OUT) instructions. I is initialized to 00H during RESET. #### (2) Interrupt Vector Low Register (IL) This register determines the most significant three bits of the low-order byte of the interrupt vector table address for external interrupts $\overline{INT}_1$ and $\overline{INT}_2$ and all internal interrupts (except TRAP). The five least significant bits are fixed for each specific interrupt source. By programming IL the vector table can be relocated on 32 bytes boundaries. IL is initialized to 00H during RESET. #### (3) INT/TRAP Control Register (ITC) INT/TRAP Control Register (ITC : I/O Address = 34H) | bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------|-----|---|---|---|------|------|------| | | TRAP | UFO | _ | - | - | ITE2 | ITE1 | ITEO | | | 0.444 | | | | | D/M/ | B/W | R/W | ITC is used to handle TRAP interrupts and to enable or disable the external maskable interrupt inputs $\overline{INT_0}$ , $\overline{INT_1}$ , and $\overline{INT_2}$ . #### TRAP (bit 7) This bit is set to 1 when an undefined op-code is fetched. TRAP can be reset under program control by writing it with 0, however it cannot be written with 1 under program control. TRAP is cleared to 0 during RESET. #### UFO: Undefined Fetch Object (bit 6) When a TRAP interrupt occurs (TRAP bit is set to 1), the contents of UFO allow determination of the starting address of the undefined instruction. This is necessary since the TRAP may occur on either the second or third byte of the op-code. UFO allows the stacked PC value (stacked in response to TRAP) to be correctly adjusted. If UFO = 0, the first op-code should be interpreted as the stacked PC-1. If UFO = 1, the first op-code address is stacked PC-2. UFO is read-only. ## ITE2,1,0: Interrupt Enable 2,1,0 (bits 2-0) ITE2, ITE1 and ITE0 enable and disable the external interrupt inputs INT<sub>2</sub>, INT<sub>1</sub>, and INT<sub>0</sub> respectively. If cleared to 0, the interrupt is masked. During RESET, ITE0 is initialized to 1 while ITE1 and ITE2 are initialized to 0. #### · Interrupt Enable Flag 1,2 (IEF1, IEF2) IEF, controls the overall enabling and disabling of all internal and external maskable interrupts (i.e. all interrupts except $\overline{NM1}$ and TRAP) If $IEF_1 = 0$ , all maskable interrupts are disabled. $IEF_1$ can be reset to 0 by the DI (Disable Interrupts) instruction and set to 1 by the EI (Enable Interrupts) instruction. The purpose of $IEF_z$ is to correctly manage the occurrence of $\overline{NMI}$ . During $\overline{NMI}$ , the prior interrupt reception state is saved and all maskable interrupts are automatically disabled ( $IEF_1$ copied to IEF<sub>2</sub> and then IEF<sub>1</sub> cleared to 0). At the end of the NMI interrupt service routine, execution of the RETN (Return from Non-maskable Interrupt) will automatically restore the interrupt receiving state (by copying IEF<sub>2</sub> to IEF<sub>1</sub>) prior to the occurrence of NMI. IEF<sub>2</sub> state can be reflected in the P/V bit of the CPU Status register by executing LD A, I or LD A, R instructions. Table 2 shows the state of IEF, and IEF2. Table 2 State of IEF, and IEF, | CPU Operation | IEF, | IEF <sub>2</sub> | REMARKS | |------------------|------------------|------------------|---------------------------------------------------| | RESET | 0 | 0 | Inhibits the interrupt except NMI and TRAP | | NMI | 0 | IEF, | Copies the contents of IEF, to IEF <sub>2</sub> . | | RETN | IEF <sub>2</sub> | not affected | Returns from the NMI service routine. | | Interrupt except | 0 | 0 | Inhibits the interrupt except NMI and TRAP | | RETI | not affected | not affected | | | TRAP | not affected | not affected | | | EI | 1 | 1 | | | DI | 0 | 0 | | | LD A, I | not affected | not affected | Transfers the contents of IEF2 to P/V flag. | | LD A, R | not affected | not affected | Transfers the contents of IEF, to P/V flag. | #### 6.2 TRAP Interrupt The HD64180 generates a non-maskable (not affected by the state of IEF<sub>1</sub>) TRAP interrupt when an undefined op-code fetch occurs. This feature can be used to increase software reliability, implement an 'extended' instruction set, or both. TRAP may occur during op-code fetch cycles and also if an undefined op-code is fetched during the interrupt acknowledge cycle for $\overline{\text{INT}}_0$ when Mode 0 is used. When a TRAP interrupt occurs the HD64180 operates as follows. - The TRAP bit in the Interrupt TRAP/Control (ITC) register is set to 1. - (2) The current PC (Program Counter) value, reflecting the location of the undefined op-code, is saved on the stack. - (3) The HD64180 vectors to logical address 0. Note that if logical address 0000H is mapped to physical address 00000H, the vector is the same as for RESET. In this case, testing the TRAP bit in ITC will reveal whether the restart at physical address 00000H was caused by RESET or TRAP. The state of the UFO (Undefined Fetch Object) bit in ITC allows TRAP manipulation software to correctly 'adjust' the stacked PC depending on whether the second or third byte of the op-code generated the TRAP. If UFO = 0, the starting address of the invalid instruction is equal to the stacked PC-1. If UFO = 1, the starting address of the invalid instruction is equal to the stacked PC-2. Fig. 21 shows TRAP Timing. Note that Bus Release cycle, Refresh cycle, DMA cycle and WAIT cycle can't be inserted just after T<sub>TP</sub> state which is inserted for TRAP interrupt sequence. Figure 21 (a) TRAP Timing - 2nd Op-code Undefined Figure 21 (b) TRAP Timing - 2nd Op-code Undefined #### 6.3 External Interrupts The HD64180 has four external hardware interrupt inputs. - NMI Non-maskable Interrupt INT<sub>0</sub> Maskable Interrupt Level 0 - (3) INT Maskable Interrupt Level 1 - (4) INT<sub>2</sub> Maskable Interrupt Level 2 NMI, INT, and INT, have fixed interrupt response modes. INT, has three different software programmable interrupt response modes - Mode 0, Mode 1 and Mode 2. #### 6.4 NMI - Non-Maskable Interrupt The NMI interrupt input is edge sensitive and cannot be masked by software. When NMI is detected, the HD64180 operates as follows. - (1) DMAC operation is suspended by clearing the DME (DMA Main Enable) bit in DCNTL. - (2) The PC is pushed onto the stack. - (3) The contents of IEF, are copied to IEF2. This saves the interrupt reception state that existed prior to NMI. - (4) IEF<sub>1</sub> is cleared to 0. This disables all external and internal maskable interrupts (i.e. all interrupts except NMI and TRAP). (5) Execution commences at logical address 0066H. The last instruction of an NMI service routine should be RETN (Return from Non-maskable Interrupt). This restores the stacked PC, allowing the interrupted program to continue. Furthermore, RETN causes IEF, to be copied to IEF, restoring the interrupt reception state that existed prior to the NMI. Note that NMI, since it can be accepted during HD64180 onchip DMAC operation, can be used to externally interrupt DMA transfer. The NMI service routine can reactivate or abort the DMAC operation as required by the application. For NMI, special care must be taken to insure that interrupt inputs do not 'overrun' the NMI service routine. Unlimited NMI inputs without a corresponding number of RETN instructions will eventually cause stack overflow Fig. 22 shows the use of NMI and RETN while Fig. 23 details NMI response timing. NMI is edge sensitive and the internally latched NMI falling edge is held until it is sampled. If the falling edge of NMI is latched before the falling edge of clock state prior to T<sub>3</sub> or Ti in the last machine cycle, the internally latched NMI is sampled at the falling edge of the clock state prior to T3 or Ti in the last machine cycle and NMI acknowledge cycle begins at the end of the current machine cycle. Figure 22 NMI Sequence (2) HITACHI 6.5 INTo - Maskable Interrupt Level 0 The next highest priority external interrupt after NMI is INT. $\overline{INT_0}$ is sampled at the falling edge of the clock state prior to $T_3$ or $T_1$ in the last machine cycle. If $\overline{INT_0}$ is asserted LOW at the falling edge of the clock state prior to T<sub>3</sub> or Ti in the last machine cycle, INT<sub>0</sub> is accepted. The interrupt is masked if either the IEF, flag or the ITE0 (Interrupt Enable 0) bit in ITC are cleared to 0. Note that after RE-SET the state is as follows. (1) IEF, is 0, so $\overline{\text{INT}_0}$ is masked. (2) ITEO is 1, so $\overline{\text{INT}_0}$ is enabled by execution of the EI (Enable Interrupts) instruction. The INT, interrupt is unique in that three programmable interrupt response modes are available - Mode 0, Mode 1, and Mode 2. The specific mode is selected with the IM 0, IM 1 and IM 2 (Set Interrupt Mode) instructions. During RESET, the HD64180 is initialized to use Mode 0 for INT<sub>0</sub>. The three interrupt response modes for INT<sub>0</sub> are... (1) Mode 0 - Instruction fetch from data bus. (2) Mode 1 - Restart at logical address 0038H. (3) Mode 2 - Low byte vector table address fetch from data bus. #### INT<sub>0</sub> Mode 0 During the interrupt acknowledge cycle, an instruction is fetched from the data bus (D<sub>0</sub>-D<sub>7</sub>) at the rising edge of T<sub>3</sub>. Often, this instruction is one of the eight single byte RST (RESTART) instructions which stack the PC and restart execution at a fixed logical address. However, multibyte instructions can be processed if the interrupt acknowledging device can provide a multibyte response. Unlike all other interrupts, the PC is not automatically stacked. Note that TRAP interrupt will occur if an invalid instruction is fetched during INT<sub>0</sub> Mode 0 interrupt acknowledge. Fig. 24 shows INT<sub>0</sub> Mode 0 Timing. Figure 24 INT Mode 0 Timing (RST Instruction on the Data Bus) INT<sub>0</sub> Mode 1 When INT<sub>0</sub> is received, the PC is stacked and instruction execution restarts at logical address 0038H. Both IEF, and IEF, flags are reset to 0, disabling all maskable interrupts. The interrupt service routine should normally terminate with the EI (Enable Interrupts) instruction followed by the RETI (Return from Interrupt) instruction, so that the interrupts are reenabled. Fig. 25 shows the use of INT<sub>0</sub> (Mode 1) and RETI. Fig. 26 shows INT<sub>0</sub> Mode 1 timing. Figure 25 INT Mode 1 Interrupt Sequence Figure 26 INT Mode 1 Timing INT<sub>0</sub> Mode 2 This method determines the restart address by reading the contents of a table residing in memory. The vector table consists of up to 128 two-byte restart addresses stored in low byte, high byte The vector table address is located on 256 bytes boundaries in the 64k bytes logical address space as programmed in the 8-bit Interrupt Vector Register (I). Fig. 27 shows the INT, Mode 2 Vector During INT, Mode 2 acknowledge cycle, first, the low-order 8 bits of vector is fetched from the data bus at the rising edge of T<sub>3</sub> and CPU acquires the 16-bit vector. Next, the PC is stacked. Finally, the 16-bit restart address is fetched from the vector table and execution commences at that address. Note that external vector acquisition is indicated by LIR and IOE both LOW. Two wait states (Tw) are automatically inserted for external vector fetch cycles. During RESET the Interrupt Vector Register (I) is initialized to 00H and, if necessary, should be set to a different value prior to the occurrence of a INT<sub>0</sub> Mode 2 interrupt. Fig. 28 shows INT<sub>0</sub> Mode 2 interrupt Timing. Figure 27 INT Mode 2 Vector Acquisition Two wait states are automatically inserted. Figure 28 INTo Mode 2 Timing ## 6.6 INT, INT2 The operation of external interrupts $\overline{INT_1}$ and $\overline{INT_2}$ is a vector mode similar to $\overline{INT_0}$ Mode 2. The difference is that $\overline{INT_1}$ and $\overline{INT_2}$ generate the low-order byte of vector table address using the IL (Interrupt Vector Low) register rather than fetching it from the data bus. This is also the interrupt response sequence used for all internal interrupts (except TRAP). As shown in Fig. 29 the low-order byte of vector table address is comprised of the most significant three bits of the software programmable IL register and the least significant five bits which are a unique fixed value for each interrupt $(\overline{INT_1}, \overline{INT_2})$ and internal source. $\overline{INT_1}$ and $\overline{INT_2}$ are globally masked by $IEF_1=0$ . Each is also individually maskable by respectively clearing the ITE1 and ITE2 (bits 1, 2) of the INT/TRAP control register to 0. During RESET, IEF1, ITE1 and ITE2 bits are initialized to 0. #### 6.7 Internal Interrupts Internal interrupts (except TRAP) use the same vectored response mode as $\overline{INT_1}$ and $\overline{INT_2}$ (Fig. 29). Internal interrupts are globally masked by $IEF_1=0$ . Individual internal interrupts are enabled/disabled by programming each individual I/O (PRT, DMAC, CSI/O, ASCI) control register. The lower vector of $\overline{INT_1}$ , $\overline{INT_2}$ , and internal interrupt are summarized in Table 3. Figure 29 INT, INT2 and Internal Interrupts Vector Acquisition Table 3 Interrupt Source and Lower Vector | Interrupt Source | Bai a ait. | IL. | | | | Fixed Code | | | | | |------------------|-------------------|-----|----------------|----------------|----|----------------|----------------|----|---|--| | | Priority | b, | b <sub>e</sub> | b <sub>5</sub> | b. | b <sub>3</sub> | b <sub>2</sub> | b, | b | | | INT, | Highest | • | • | • | 0 | 0 | 0 | 0 | 0 | | | INT <sub>2</sub> | | • | | | 0 | 0 | 0 | 1 | 0 | | | PRT channel 0 | | • | | | 0 | 0 | 1 | 0 | 0 | | | PRT channel 1 | | • | • | • | 0 | 0 | 1 | 1 | 0 | | | DMA channel 0 | | • | • | • | 0 | 1 | 0 | 0 | 0 | | | DMA channel 1 | $\neg$ | • | • | • | 0 | 1 | 0 | 1 | 0 | | | CSI/O | 7 | • | • | • | 0 | 1 | 1 | 0 | 0 | | | ASCI channel 0 | $\neg \downarrow$ | • | • | • | 0 | 1 | 1 | 1 | 0 | | | ASCI channel 1 | Lowest | • | • | • | 1 | 0 | 0 | 0 | 0 | | <sup>\*</sup> Programmable #### Interrupt Acknowledge Cycle Timing Fig. 30 shows interrupt acknowledge cycle timing for internal interrupts, $\overline{INT_1}$ , and $\overline{INT_2}$ . $\overline{INT_1}$ and $\overline{INT_2}$ are sampled at the falling edge of clock state prior to $T_3$ or Ti in the last machine cycle. If $\overline{INT_1}$ or $\overline{INT_2}$ is asserted LOW at the falling edge of clock state prior to $T_3$ or Ti in the last machine cycle, the interrupt request is accepted. Figure 30 INT, INT, and Internal Interrupts Timing #### 6.8 Interrupt Sources and Reset #### (1) Interrupt Vector Register (I) All bits are reset to 0. Since I=0 locates the vector tables starting at logical address 0000H, vectored interrupts ( $\overline{INT}_0$ Mode 2, $\overline{INT}_1$ , $\overline{INT}_2$ and internal interrupts) will overlap with fixed restart interrupts like RESET (0), $\overline{NMI}$ (0066H), $\overline{INT}_0$ Mode 1 (0038H) and RST (0000H - 0038H). The vector table(s) can be built elsewhere in memory and located on 256 bytes boundaries by reprogramming I with the LD I, A instruction. #### (2) IL Register Bits 7 - 5 are reset to 0. The LL Register can be programmed to locate the vector table for $\overline{INT}_1$ , $\overline{INT}_2$ and internal interrupts on 32 bytes sub-boundaries within the 256 bytes area specified by I. ### (3) IEF<sub>1</sub>, IEF<sub>2</sub> Flags Reset to 0. Interrupts other than NMI and TRAP are disabled. ## (4) ITC Register ITE0 are set to 1. ITE1 and ITE2 are reset to 0. $\overline{\text{INT}_0}$ can be enabled by the EI instruction, which sets IEF<sub>1</sub> = 1. To enable $\overline{\text{INT}_1}$ and $\overline{\text{INT}_2}$ also requires that the ITE1 and ITE2 bits be respectively set = 1 by writing to ITC. #### (5) I/O Control Registers Interrupt enable bits reset to 0. All HD64180 on-chip I/O (PRT, DMAC, CSI/O, ASCI) interrupts are disabled and can be individually enabled by writing to each I/O control register interrupt enable bit. # 6.9 Difference between INT<sub>0</sub> interrupt and the other interrupts (INT<sub>1</sub>, INT<sub>2</sub> and internal interrupts) in the interrupt acknowledge cycles As shown in Fig. 24, Fig. 26, Fig. 28 and Fig. 30, the interrupt acknowledge cycle of INT<sub>0</sub> is different from those of the other interrupts, that is, INT<sub>1</sub>, INT<sub>2</sub> and internal interrupts concerning the state of control signals. The state of the control signals in each interrupt acknowledge cycle are shown below. $\overline{\text{INT}}_0$ interrupt acknowledge cycle: $\overline{\text{LIR}} = 0$ , $\overline{\text{IOE}} = 0$ , $\overline{\text{ST}} = 0$ $\overline{\text{INT}}_1$ , $\overline{\text{INT}}_2$ , and internal interrupt acknowledge cycle: $\overline{\text{LIR}} = 1$ , $\overline{\text{IOE}} = 1$ , $\overline{\text{ST}} = 0$ #### 7 MEMORY MANAGEMENT UNIT (MMU) The HD64180 contains an on-chip MMU which performs the translation of the CPU 64k bytes (16-bit addresses- 0000H to FFFFH) logical memory address space into a 512k bytes (19-bit addresses- 00000H to 7FFFFH) physical memory address space. Address translation occurs internally in parallel with other CPU operation #### 7.1 Logical Address Spaces The 64k bytes CPU logical address space is interpreted by the MMU as consisting of up to three separate logical address areas, Common Area 0, Bank Area and Common Area 1. As shown in Fig. 31 a variety of logical memory configurations are possible. The boundaries between the Common and Bank Areas can be programmed with 4k bytes resolution. Figure 31 Logical Address Mapping Examples ## 7.2 Logical to Physical Address Translation Fig. 32 shows an example in which the three logical address space portions are mapped into a 512k bytes physical address space. The important points to note are that Common and Bank Areas can overlap and that Common Area 1 and Bank Area can be freely relocated (on 4k bytes physical address boundaries). Common Area 0 (if it exists) is always based at physical address 00000H. Figure 32 Logical → Physical Memory Mapping Example ## 7.3 MMU Block Diagram The MMU block diagram is shown in Fig. 33. The MMU translates internal 16-bit logical addresses to external 19-bit physical addresses. Figure 33 MMU Block Diagram Whether address translation takes place depends on the type of CPU cycle as follows. #### (1) Memory Cycles Address Translation occurs for all memory access cycles including instruction and operand fetches, memory data reads and writes, hardware interrupt vector fetch and software interrupt restarts. #### (2) I/O Cycles The MMU is logically bypassed for I/O cycles. The 16-bit logical I/O address space corresponds directly with the 16-bit physical I/O address space. The upper three bits $(A_{16}-A_{18})$ of the physical address are always 0 during I/O cycles. Figure 34 I/O Address Translation ## (3) DMA Cycles When the HD64180 on-chip DMAC is using the external bus, the MMU is physically bypassed. The 19-bit source and destination registers in the DMAC are directly output on the physical address bus $(A_0-A_{1n})$ . #### 7.4 MMU Registers Three MMU registers are used to program a specific configuration of logical and physical memory. - (1) MMU Common/Bank Area Register (CBAR) - (2) MMU Common Base Register (CBR) - (3) MMU Bank Base Register (BBR) CBAR is used to define the logical memory organization, while CBR and BBR are used to relocate logical areas within the 512k bytes physical address space. The resolution for both setting boundaries within the logical space and relocation within the physical space is 4k bytes. The CAR field of CBAR determines the start address of Common Area 1 (Upper Common) and by default, the end address of the Bank Area. The BAR field determines the start address of the Bank Area and by default, the end address of Common Area 0 (Lower Common). The CA and BA fields of CBAR may be freely programmed subject only to the restriction that CA may never be less than BA. Fig. 35 and Fig. 36 shows example of logical memory organizations associated with different values of CA and BA. Figure 35 Logical Memory Organization Figure 36 Logical Space Configuration (Example) #### 7.5 MMU Register Description ## (1) MMU Common/Bank Area Register (CBAR) CBAR specifies boundaries within the HD64180 64k bytes logical address space for up to three areas, Common Area 0, Bank Area, and Common Area 1. MMU Common/Bank Area Register (CBAR : I/O Address = 3AH) 2 BAO CA2 CA1 CAO BA3 BA2 RA 1 R/W R/W R/M R/W B/W R/W R/W R/W #### CA3-CA0: CA (bits 7-4) CA specifies the start (low) address (on 4k bytes boundaries) for the Common Area 1. This also determines the last address of the Bank Area. All bits of CA are initialized to 1 during RESET. #### BA3-BA0: BA (bits 3-0) BA specifies the start (low) address (on 4k bytes boundaries) for the Bank Area. This also determines the last address of the Common Area 0. All bits of BA are initialized to 0 during RESET. ## (2) MMU Common Base Register (CBR) CBR specifies the base address (on 4k bytes boundaries) used to generate a 19-bit physical address for Common Area 1 accesses. All bits of CBR are initialized to 0 during RESET. #### (3) MMU Bank Base Register (BBR) BBR specifies the base address (on 4k bytes boundaries) used to generate a 19-bit physical address for Bank Area accesses. All bits of BBR are initialized to 0 during RESET. #### 7.6 Physical Address Translation Fig. 37 shows the way in which physical addresses are generated based on the contents of CBAR, CBR and BBR. MMU comparators classify an access by logical area as defined by CBAR. Depending on which of the three potential logical areas (Common Area 1, Bank Area or Common Area 0) is being accessed, the appropriate 7-bit base address is added to the upper 4 bits of the logical address, yielding a 19-bit physical address. CBR is associated with Common Area 1 accesses. Common Area 0 accesses use a (non-accessible, internal) base register which contains 0. Thus, Common Area 0, if defined, is always based at physical address 00000H. Figure 37 Physical Address Generation #### 7.7 MMU and RESET During RESET, all bits of the CA field of CBAR are set to 1 while all bits of the BA field of CBAR, CBR, and BBR are cleared to 0. The logical 64k bytes address space corresponds directly with the first 64k bytes (0000H to FFFFH) of the 512k bytes (00000H to 7FFFFH) physical address space. Thus, after RESET, the HD64180 will begin execution at logical and physical address 0. #### 7.8 MMU Register Access Timing When data is written into CBAR, CBR, or BBR, the value will be effective from the cycle immediately following the I/O write cycle which updates these registers. Care must be taken during MMU programming to insure that CPU program execution is not disrupted. Observe that the next cycle following MMU register programming will normally be an opcode fetch from the newly translated address. One simple technique is to localize all MMU programming routines in a Common Area that is always enabled. #### 8 DYNAMIC RAM REFRESH CONTROL The HD64180 incorporates a dynamic RAM refresh control circuit including 8-bit refresh address generation and programmable refresh timing. This circuit generates asynchronous refresh cycles inserted at the programmable interval independent of CPU program execution. For systems which don't use dynamic RAM, the refresh function can be disabled. When the internal refresh controller determines that a refresh cycle should occur, the current instruction is interrupted at the first breakpoint between machine cycles. The refresh cycle is inserted by placing the refresh address on $A_0$ - $A_7$ and the REF output is driven LOW. Refresh cycles may be programmed to be either two or three clock cycles in duration by programming the REFW (Refresh Wait) bit in Refresh Control Register (RCR). Note that the external WAIT input and the internal wait state generator are not effective during refresh. Fig. 38 shows the timing of a refresh cycle with a refresh wait $(T_{RW})$ cycle. NOTE: \* If three refresh cycles are specified, T<sub>RW</sub>, is inserted. Otherwise, T<sub>RW</sub> is not inserted. MC: Machine Cycle Figure 38 Refresh Timing #### 8.1 Refresh Control Register (RCR) RCR specifies the interval and length of refresh cycles, as well as enabling or disabling the refresh function. #### REFE: Refresh Enable (bit 7) REFE = 0 disables the refresh controller while REFE = 1 enables refresh cycle insertion. REFE is set to 1 during RESET. #### REFW: Refresh Wait (bit 6) REFW = 0 causes the refresh cycle to be two clocks in duration. REFW = 1 causes the refresh cycle to be three clocks in duration by adding a refresh wait cycle $(T_{RW})$ . REFW is set to 1 during RESET. ## CYC1, 0: Cycle Interval (bits 1-0) CYC1 and CYC0 specify the interval (in clock cycles) between refresh cycles. In the case of dynamic RAMs requiring 128 refresh cycles every 2 ms (or 256 cycles every 4 ms), the required refresh interval is less than or equal to $15.625~\mu s$ . Thus, the underlined values indicate the best refresh interval depending on CPU clock frequency. CYC0 and CYC1 are cleared to 0 during RESET. Table 4 Refresh Interval | CYC1 | CYCO | Insertion | Time interval | | | | | | | |------|------|-----------|--------------------|------------|---------|---------|---------|--|--| | | CTCO | interval | φ: 10 MHz | 8 MHz | 6 MHz | 4 MHz | 2.5 MHz | | | | 0 | 0 | 10 states | (1.0 μs)* | (1.25 μs)* | 1.66 µs | 2.5 μs | 4.0 μs | | | | 0 | 1 1 | 20 states | (2.0 μs)* | (2.5 μs)* | 3.3 μs | 5.0 μs | 8.0 μs | | | | 1 | ] o | 40 states | (4.0 μs)* | (5.0 μs)* | 6.6 µs | 10.0 μs | 16.0 μs | | | | 1 | 1 1 | 80 states | ( <u>8.0 μs</u> )* | (10.0 μs)* | 13.3 μs | 20.0 μs | 32.0 μs | | | <sup>\*</sup> calculated interval #### 8.2 Refresh control and reset After RESET, based on the initialized value of RCR, refresh cycles will occur with an interval of 10 clock cycles and be 3 clock cycles in duration. #### 8.3 Dynamic RAM refresh operation notes - Refresh cycle insertion is stopped when the CPU is in the following states. - (a) During RESET - (b) When the bus is released in response to BUSREQ - (c) During SLEEP mode - (d) During WAIT states - (2) Refresh cycles are suppressed when the bus is released in response to BUSREQ. However, the refresh timer continues to operate. Thus, the time at which the first refresh cycle occurs after the HD64180 re-acquires the bus depends on the refresh timer, and has no timing relationship with the bus exchange. - (3) Refresh cycles are suppressed during SLEEP mode. If a refresh cycle is requested during SLEEP mode, the refresh cycle request is internally 'latched' (until replaced with the next refresh request). The 'latched' refresh cycle is inserted at the end of the first machine cycle after SLEEP mode is exited. After this initial cycle, the time at which the next refresh cycle will occur depending on the refresh time, and has no timing relationship with the exit from SLEEP mode. - (4) Regarding (2) and (3), the refresh address is incremented by 1 for each successful refresh cycle, not for each refresh request. Thus, independent of the number of 'missed' refresh requests, each refresh bus cycle will use a refresh address incremented by 1 from that of the previous refresh bus cycles. #### 9 WAIT STATE GENERATOR #### 9.1 Wait State Timing To ease interfacing with slow memory and I/O devices, the HD64180 uses wait states (Tw) to extend bus cycle timing. A wait state(s) is inserted based on the combined (logical OR) state of the external $\overline{WAIT}$ input and an internal programmable wait state (Tw) generator. Wait states (Tw) can be inserted in both CPU execution and DMA transfer cycles. #### 9.2 WAIT Input When the external $\overline{\text{WAIT}}$ input is asserted LOW, wait state (Tw) are inserted between T<sub>2</sub> and T<sub>3</sub> to extend the bus cycle duration. The $\overline{\text{WAIT}}$ input is sampled at the falling edge of the system clock in T<sub>2</sub> or Tw. If the $\overline{\text{WAIT}}$ input is asserted LOW at the falling edge of the system clock in Tw, another Tw is inserted into the bus cycle. Note that $\overline{\text{WAIT}}$ input transitions must meet specified set-up and hold times. This can easily be accomplished by externally synchronizing $\overline{\text{WAIT}}$ input transitions with the rising edge of the system clock. Dynamic RAM refresh is not performed during wait states (Tw) and thus systems designs which uses the automatic refresh function must consider the affects of the occurrence and duration of wait states (Tw). Fig. 39 shows WAIT timing. Figure 39 WAIT Timing ## 9.3 Programmable Wait State Insertion In addition to the WAIT input, wait states (Tw) can also be programmably inserted using the HD64180 on-chip wait state generator. Wait state (Tw) timing applies for both CPU execution and on-chip DMAC cycles. By programming the 4 significant bits of the DMA/WAIT Control Register (DCNTL), the number of wait states (Tw) automatically inserted in memory and I/O cycles can be separately specified. Bits 4-5 specify the number of wait states (Tw) inserted for I/O access and bits 6-7 specify the number of wait states (Tw) inserted for memory access. #### DMA/WAIT Control Register (DCNTL: I/O Address = 32H) The number of wait states (Tw) inserted in a specific cycle is the maximum of the number requested by the $\overline{WAIT}$ input, and the number automatically generated by the on-chip wait state generator. #### MWI1, MWI0: Memory Wait Insertion (bits 7-6) For CPU and DMAC cycles which access memory (including memory mapped I/O), 0 to 3 wait states may be automatically inserted depending on the programmed value in MWI1 and MWI0. | MWI1 | MWIO | The number of wait states | |------|------|---------------------------| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 2 | | 1 | 1 | 3 | #### IWI1, IWI0: I/O Wait Insertion (bits 5-4) For CPU and DMA cycles which access external I/O (and interrupt acknowledge cycles), 1 to 6 wait states (Tw) may be automatically inserted depending on the programmed value in IWI1 and IWI0. | | | The number of wait states | | | | | | | | | |------|------|-------------------------------------|-------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------|--|--|--|--| | IWI1 | iwio | For external I/O registers accesses | For internal I/O registers accesses | For INT o interrupt<br>acknowledge cy-<br>cles when LIR is<br>LOW | For INT ,, INT 2 and internal interrupts acknowledge cycles (Note (2)) | For NMI interrupt<br>acknowledge cy-<br>cles when LIR is<br>LOW<br>(Note (2)) | | | | | | 0 | 0 | 1 | | 2 | | | | | | | | 0 | 1 | 2 | 7 0 | 4 | ┐ , | 0 | | | | | | 1 | 0 | 3 | (Note (1)) | 5 | 7 * | | | | | | | 1 | 1 | 4 | 7 | 6 | | | | | | | NOTE: (1) For HD64180 internal I/O register access (I/O addresses 0000H-003FH), IWI1 and IWI0 do not determine wait state (Tw) timing. For ASCI, CSI/O and PRT Data Register accesses, 0 to 4 wait states (Tw) will be generated. Wait states inserted during access to these registers is a function of internal synchronization requirements and CPU state. All other on-chip I/O register accesses (i.e. MMU, DMAC, ASCI Control Registers, etc.) have 0 wait states inserted and thus require only three clock cycles. clock cyteries. (2) For interrupt acknowledge cycles in which LIR is HIGH, such as interrupt vector table read and PC stacking cycle, memory access timing applies. ## 9.4 WAIT Input and RESET During RESET, MWI1, MWI0, IWI1 and IWI0 are all set to 1, selecting the maximum number of wait states (Tw) (3 for memory accesses, 4 for external I/O accesses). Also, note that the WAIT input is ignored during RESET. For example, if RESET is detected while the HD64180 is in a wait state (Tw), the wait stated cycle in progress will be aborted, and the RESET sequence initiated. Thus, RESET has higher priority than WAIT. ## HD64180R/Z #### 10 DMA CONTROLLER (DMAC) The HD64180 contains a two channel DMA (Direct Memory Access) controller which supports high speed data transfer. Both channels (channel 0 and channel 1) have the following capabilities. #### Memory Address Space Memory source and destination addresses can be directly specified anywhere within the 512k bytes physical address space using 19-bit source and destination memory addresses. In addition, memory transfers can arbitrarily cross 64k bytes physical address boundaries without CPU intervention. #### I/O Address Space I/O source and destination addresses can be directly specified anywhere within the 64k bytes I/O address space (16-bit source and destination I/O addresses). #### Transfer Length Up to 64k bytes can be transferred based on a 16-bit byte count register. ## **DREQ** Input Level and edge sense DREQ input detection are selectable. #### **TEND** Output Used to indicate DMA completion to external devices. #### Transfer Rate Each byte transfer can occur every six clock cycles. Wait states can be inserted in DMA cycles for slow memory or I/O devices. At the system clock $(\phi) = 6$ MHz, the DMA transfer rate is as high as 1.0 megabytes/second (no wait states). Additional feature disk for DMA interrupt request by DMA END. Each channel has the following additional specific capabilities. #### Channel 0 - Memory memory, memory I/O, memory memory mapped I/O transfers - Memory address increment, decrement, no-change - · Burst or cycle steal memory <--> memory transfers - · DMA to and from both ASCI channels - · Higher priority than DMAC channel 1 #### Channel 1 - · Memory ← → I/O transfer - · Memory address increment, decrement #### **DMAC Registers** Each channel of the DMAC (channel 0, 1) has three registers specifically associated with that channel. #### Channel 0 SAR0 - Source Address Register DAR0 - Destination Address Register BCR0 - Byte Count Register ### Channel J MARI – Memory Address Register IARI – I/O Address Register BCRI – Byte Count Register The two channels share the following three additional registers in common. DSTAT - DMA Status Register DMODE - DMA Mode Register DCNTL - DMA Control Register #### 10.1 DMAC Block Diagram Fig. 40 shows the HD64180 DMAC Block Diagram. Figure 40 DMAC Block Diagram #### 10.2 DMAC Register Description # (1) DMA Source Address Register Channel 0 (SAR0: I/O Address = 20H to 22H) Specifies the physical source address for channel 0 transfers. The register contains 19 bits and may specify up to 512k bytes memory addresses or up to 64k bytes I/O addresses. Channel 0 source can be memory, I/O or memory mapped I/O. # (2) DMA Destination Address Register Channel 0 (DARO: I/O Address = 23H to 25H) Specifies the physical destination address for channel 0 transfers. The register contains 19 bits and may specify up to 512k bytes memory addresses or up to 64k bytes I/O addresses. Channel 0 destination can be memory, I/O or memory mapped I/O. # (3) DMA Byte Count Register Channel 0 (BCR0: I/O Address = 26H to 27H) Specifies the number of bytes to be transferred. This register contains 16 bits and may specify up to 64k bytes transfers. When one byte is transferred, the register is decremented by one. If "n" bytes should be transferred, "n" must be stored before the DMA operation. ### (4) DMA Memory Address Register Channel 1 (MAR1: 1/O Address = 28H to 2AH) Specifies the physical memory address for channel 1 transfers. This may be destination or source memory address. This register contains 19 bits and may specify up to 512k bytes memory addresses. # (5) DMA I/O Address Register Channel 1 (IAR1: I/O Address = 28H to 2CH) Specifies the I/O address for channel 1 transfers. This may be destination or source I/O address. This register contains 16 bits and may specify up to 64k bytes I/O addresses. # (6) DMA Byte Count Register Channel 1 (BCR1: I/O Address = 2EH to 2FH) Specifies the number of bytes to be transferred. This register contains 16 bits and may specify up to 64k bytes transfers. When one byte is transferred, the register is decremented by one. #### (7) DMA Status Register (DSTAT) DSTAT is used to enable and disable DMA transfer and DMA termination interrupts. DSTAT also allows determining the status of a DMA transfer i.e. completed or in progress. | | DMA Status Register (DSTAT : I/O Address = 30H) | | | | | | | | | | |-----|-------------------------------------------------|------|------|------|------|------|---|-----|--|--| | bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | DE1 | DEO | DWET | DWEO | DIE1 | DNEO | | DME | | | | | 2244 | 2044 | 14/ | 14/ | D/A/ | B/M/ | | | | | #### DE1: DMA Enable Channel 1 (bit 7) When DE1 = 1 and DME = 1, channel 1 DMA is enabled. When a DMA transfer terminates (BCR1 = 0), DE1 is reset to 0 by the DMAC. When DE1 = 0 and the DMA interrupt is enabled (DIE1 = 1), a DMA interrupt request is made to the CPU. To perform a software write to DE1, DWE1 should be written with 0 during the same register write access. Writing DE1 to 0 disables channel 1 DMA, but DMA is restartable. Writing DE1 to 1 enables channel 1 DMA and automatically sets DME (DMA Main Enable) to 1. DE1 is cleared to 0 during RESET. ## DEO: DMA Enable Channel 0 (bit 6) When DE0 = 1 and DME = 1, channel 0 DMA is enabled. When a DMA transfer terminates (BCR0 = 0), DE0 is cleared to 0 by the DMAC. When DE0 = 0 and the DMA interrupt is enabled (DIE0 = 1), a DMA interrupt request is made to the CPU. To perform a software write to DE0, $\overline{DWE0}$ should be written with 0 during the same register write access. Writing DE0 to 0 disables channel 0 DMA. Writing DE0 to 1 enables channel 0 DMA and automatically sets DME (DMA Main Enable) to 1. DE0 is cleared to 0 during RESET. #### DWE1: DE1 Bit Write Enable (bit 5) When performing any software write to DE1, $\overrightarrow{DWE1}$ should be written with 0 during the same access. $\overrightarrow{DWE1}$ write value of 0 is not held and $\overrightarrow{DWE1}$ is always read as 1. #### DWEO: DEO Bit Write Enable (bit 4) When performing any software write to DE0, $\overline{DWE0}$ should be written with 0 during the same access. $\overline{DWE0}$ write value of 0 is not held and $\overline{DWE0}$ is always read as 1. #### DIE1: DMA Interrupt Enable Channel 1 (bit 3) When DIE1 is set to 1, the termination of channel 1 DMA transfer (indicated when DE1 = 0) causes a CPU interrupt request to be generated. When DIE1 = 0, the channel 1 DMA termination interrupt is disabled. DIE1 is cleared to 0 during RESET. #### DIEO: DMA Interrupt Enable Channel 0 (bit 2) When DIE0 is set to 1, the termination channel 0 of DMA transfer (indicated when DE0 = 0) causes a CPU interrupt request to be generated. When DIE0 = 0, the channel 0 DMA termination interrupt is disabled. DIE0 is cleared to 0 during RESET. #### DME: DMA Main Enable (bit 0) A DMA operation is only enabled when its DE bit (DE0 for channel 0, DE1 for channel 1) and the DME bit are set to 1. When NMI occurs, DME is reset to 0, thus disabling DMA activity during the NMI interrupt service routine. To restart DMA, DE0 and/or DE1 should be written with 1 (even if the contents are already 1). This automatically sets DME to 1, allowing DMA operations to continue. Note that DME cannot be directly written. It is cleared to 0 by NMI or indirectly set to 1 by setting DE0 and/or DE1 to 1. DME is cleared to 0 during RESET. ## (8) DMA Mode Register (DMODE) DMODE is used to set the addressing and transfer mode for channel 0. #### DM1, DM0: Destination Mode Channel 0 (bits 5, 4) Specifies whether the destination for channel 0 transfers is memory, I/O or memory mapped I/O and the corresponding address modifier. DM1 and DM0 are cleared to 0 during RESET. Table 5 Destination | DM1 | DMO | Memory/I/O | Address<br>Increment/Decrement | |-----|-----|------------|--------------------------------| | 0 | 0 | Memory | +1 | | 0 | 1 | Memory | <u> </u> | | 1 | 0 | Memory | fixed | | 1 | 1 | 1/0 | fixed | #### SM1, SM0: Source Mode Channel 0 (bits 3, 2) Specifies whether the source for channel 0 transfers is memory, I/O or memory mapped I/O and the corresponding address modifier. SM1 and SM0 are cleared to 0 during RESET. Table 7 shows all DMA transfer mode combinations of DM0, DM1, SM0, SM1. Since I/O > I/O transfers are not implemented, twelve combinations are available. Table 6 Source | SM1 | ѕмо | Memory/I/O | Address<br>Increment/Decrement | |-----|-----|------------|--------------------------------| | 0 | 0 | Memory | +1 | | 0 | 1 | Memory | -1 | | 1 | 0 | Memory | fixed | | 1 | 1 | I/O | fixed | Table 7 Combination of Transfer Mode | DM1 | DMO | SM1 | SMO | Transfer Mode | Address<br>Increment/Decrement | |-----|-----|-----|-----|---------------------|--------------------------------| | 0 | 0 | 0 | 0 | Memory→Memory | SAR0+1, DAR0+1 | | 0 | 0 | 0 | 1 | Memory→Memory | SARO-1, DARO+1 | | 0 | 0 | 1 | 0 | Memory*→Memory | SAR0 fixed, DAR0+1 | | 0 | 0 | 1 | 1 | l/ <b>O→M</b> emory | SAR0 fixed, DAR0+1 | | 0 | 1 | 0 | 0 | Memory→Memory | SARO+1, DARO-1 | | 0 | 1 | 0 | 1 | Memory→Memory | SARO-1, DARO-1 | | 0 | 1 | 1 | 0 | Memory*→Memory | SAR0 fixed, DAR0-1 | | 0 | 1 | 1 | 1 | I/O→Memory | SAR0 fixed, DARO - 1 | | 1 | 0 | 0 | 0 | Memory→Memory* | SAR0+1, DAR0 fixed | | 1 | 0 | 0 | 1 | Memory→Memory* | SARO- 1, DARO fixed | | 1 | 0 | 1 | 0 | reserved | | | 1 | 0 | 1 | 1 | reserved | | | 1 | 1 | 0 | 0 | Memory→I/O | SARO+ 1, DARO fixed | | 1 | 1 | 0 | 1 | Memory→I/O | SARO-1, DARO fixed | | 1 | 1 | 1 | 0 | reserved | | | 1 | 1 | 1 | 1 | reserved | | <sup>.:</sup> includes memory mapped I/O #### MMOD: Memory Mode Channel 0 (bit 1) When channel 0 is configured for memory $\iff$ memory transfers, the external $\overline{DREQ}_0$ input is not used to control the transfer timing. Instead, two automatic transfer timing modes are selectable — burst (MMOD = 1) and cycle steal (MMOD = 0). For burst memory $\iff$ memory transfers, the DMAC will sieze control of the bus continuously until the DMA transfer completes (as shown by the byte count register = 0). In cycle steal mode, the CPU is given a cycle for each DMA byte transfer cycle until the transfer is completed. For channel 0 DMA with I/O source or destination, the $\overline{DREQ_0}$ input times the transfer and thus MMOD is ignored. MMOD is cleared to 0 during RESET. #### **DMA/WAIT Control Register (DCNTL)** DCNTL controls the insertion of wait states into DMAC (and CPU) accesses of memory or I/O. Also, the DMA request mode for each DREQ (DREQ<sub>0</sub> and DREQ<sub>1</sub>) input is defined as level or edge sense. DCNTL also sets the DMA transfer mode for channel 1, which is limited to memory $\longleftrightarrow$ I/O transfers. DMA/WAIT Control Register (DCNTL: I/O Address = 32H) #### MWI1, MWI0: Memory Wait Insertion (bits 7-6) Specifies the number of wait states introduced into CPU or DMAC memory access cycles. MWII and MWI0 are set to 1 during RESET. See section of Wait State Control for details. #### IWI1, IWI0: I/O Wait Insertion (bits 5-4) Specifies the number of wait states introduced into CPU or DMAC I/O access cycles. IWI1 and IWI0 are set to 1 during RE-SET. See section of Wait State Control for details. #### DMS1, DMS0: DMA Request Sense (bits 3-2) DMS1 and DMS0 specify the DMA request sense for channel 0 $(\overline{DREQ_0})$ and channel 1 $(\overline{DREQ_1})$ respectively. When reset to 0, the input is level sense. When set to 1, the input is edge sense. DMS1 and DMS0 are cleared to 0 during RESET. ### DIM1, DIM0: DMA Channel 1 I/O and Memory Mode (bits 1-0) Specifies the source/destination and address modifier for channel 1 memory $\longleftrightarrow$ 1/O transfer modes. 1M1 and 1M0 are cleared to 0 during RESET. Table 8 Channel 1 Transfer Mode | DIM1 | DIMO | Transfer Mode | Address<br>Increment/Decrement | |------|------|---------------|--------------------------------| | 0 | 0 | Memory→I/O | MAR1 + 1, IAR1 fixed | | 0 | 1 | Memory→I/O | MAR1 - 1, IAR1 fixed | | 1 | 0 | I/O→Memory | IAR1 fixed, MAR1+1 | | 1 | 1 | I/O→Memory | IAR1 fixed, MAR1 - 1 | #### 10.3 DMA Operation This section discusses the three DMA operation modes for channel 0, memory $\longleftrightarrow$ memory, memory $\longleftrightarrow$ I/O and memory $\longleftrightarrow$ memory mapped I/O. In addition, the operation of channel 0 DMA with the on-chip ASCI (Asynchronous Serial Communication Interface) as well as Channel 1 DMA are described. ## (1) Memory ← → Memory - Channel 0 For memory $\iff$ memory transfers, the external $\overline{DREQ_0}$ input is not used for DMA transfer timing. Rather, the DMA operation is timed in one of two programmable modes — burst or cycle steal. In both modes, the DMA operation will automatically proceed until termination as shown by byte count (BCR0) = 0. In burst mode, the DMA operation will proceed until termination. In this case, the CPU cannot perform any program execution until the DMA operation is completed. In cycle steal mode, the DMA and CPU operation are alternated after each DMA byte transfer until the DMA is completed. The sequence (1 CPU Machine Cycle) DMA Byte Transfer ... is repeated until DMA is completed. Fig. 41 shows cycle steal mode DMA timing. Figure 41 Cycle Steal Mode DMA Timing To initiate memory $\iff$ memory DMA transfer for channel 0, perform the following operations. - ① Load the memory source and destination addresses into SAR0 and DAR0. - 3 Load the number of bytes to transfer in BCR0. - Specify burst or cycle steal mode in the MMOD bit of DCNTL. - ⑤ Program DE0 = 1 (with DWE0 = 0 in the same access) in DSTAT and the DMA operation will start 1 machine cycle later. If interrupt occurs at the same time, the DIE0 bit should be set to 1. (2) Memory $\longleftrightarrow$ I/O (Memory Mapped I/O) — Channel O For memory $\iff$ 1/O (and memory $\iff$ memory mapped 1/O) the $\overline{DREQ}_0$ input is used to time the DMA transfers. In addition, the $\overline{TEND}_0$ (Transfer End) output is used to indicate the last (byte count register BCR0 = 00H) transfer. The $\overline{DREQ_0}$ input can be programmed as level or edge sensitive. When level sense is programmed, the DMA operation begins when $\overline{DREQ_0}$ is sampled LOW. If $\overline{DREQ_0}$ is sampled HIGH, after the next DMA byte transfer, control is relinquished to the HD64180 CPU. As shown in Fig. 42. $\overline{DREQ_0}$ is sampled at the rising edge of the clock cycle prior to $T_3$ i.e. either $T_2$ or $T_w$ . Figure 42 CPU Operation and DMA Operation (DREQ is programmed for level sense) ## HD64180R/Z When edge sense is programmed, DMA operation begins at the falling edge of $DREQ_0$ . If another falling edge is detected before the rising edge of the clock prior to $T_3$ during DMA write cycle (i.e. $T_2$ or Tw), the DMAC continues operating. If an edge is not detected, the CPU is given control after the current byte DMA transfer com- pletes. The CPU will continue operating until a $\overline{DREQ}_0$ falling edge is detected before the rising edge of the clock prior to $T_3$ at which time the DMA operation will (re)start. Fig. 43 shows the edge sense DMA timing. Figure 43 CPU Operation and DMA Operation (DREQ is programmed for edge sense) During the transfers for channel 0, the $\overline{\text{TEND}}_0$ output will go LOW synchronous with the write cycle of the last (BCR0 = 00H) DMA transfer as shown in Fig. 44. Figure 44 TEND Output Timing The $\overline{DREQ}_0$ and $\overline{TEND}_0$ pins are programmably multiplexed with the CKA0 and CKA1 ASCI clock input/outputs. However, when DMA channel 0 is programmed for memory $\longleftrightarrow$ I/O (and memory $\longleftrightarrow$ memory mapped I/O) transfers, the CKA0/ $\overline{DREQ}_0$ pin automatically functions as input pin even if it has been programmed as output pin for CKA0. And the CKA1/ $\overline{TEND}_0$ pin functions as output pin for $\overline{TEND}_0$ by setting CKA1D to 1 in CNTLA1. To initiate memory $\longleftrightarrow$ N/O (and memory $\longleftrightarrow$ memory mapped I/O) DMA transfer for channel 0, perform the following operations. - ① Load the memory and I/O or memory mapped I/O source and destination addresses into SARO and DARO. Note that I/O addresses (not memory mapped I/O) are limited to 16 bits (A<sub>0</sub>-A<sub>13</sub>). Make sure that bits A<sub>16</sub> and A<sub>17</sub> are 0 (A<sub>18</sub> is a don't care) to correctly enable the external DREQ<sub>0</sub> input. - 3 Load the number of bytes to transfer in BCR0. - Specify whether DREQ<sub>0</sub> is edge or level sense by programming the DMS0 bit of DCNTL. - S Enable or disable DMA termination interrupt with the DIE0 bit in DSTAT. - 6 Program DE0 = 1 (with $\overline{DWE0} = 0$ in the same access) in DSTAT and the DMA operation will begin under the control of the $\overline{DREQ}_{o}$ input. #### (3) Memory $\iff$ ASCI - Channel 0 Channel 0 has extra capability to support DMA transfer to and from the on-chip two channel ASCI. In this case the external $\overline{DREQ}_0$ input is not used for DMA timing. Rather, the ASCI status bits are used to generate an internal $\overline{DREQ}_0$ . The TDRE (Transmit Data Register Empty) bit and the RDRF (Receive Data Register Full) bit are used to generate an internal $\overline{DREQ}_0$ for ASCI transmission and reception respectively. To initiate memory $\longleftrightarrow$ ASCI DMA transfer, perform the following operations. ① Load the source and destination addresses into SAR0 and DAR0. Specify the I/O (ASCI) address as follows. Bits A<sub>0</sub>-A<sub>7</sub> should be contain the address of the ASCI channel transmitter or receiver (I/O addresses 06H-09H). Bits A<sub>8</sub>-A<sub>15</sub> should equal 0. Bits $A_{17}$ - $A_{16}$ should be set according to the following table to enable use of the appropriate ASCI status bit as an internal DMA request. Table 9 DMA Request | SAR18 | SAR17 | SAR16 | DMA Transfer Request | |-------|-------|-------|-----------------------| | × | 0 | 0 | DREQ | | × | 0 | 1 | RDRF (ASCI channel 0) | | × | 1 | 0 | RDRF (ASCI channel 1) | | X | 1 | 1 | reserved | #### X: Don't care | DAR18 | DAR17 | DAR16 | DMA Transfer Request | |-------|-------|-------|-----------------------| | Х | 0 | 0 | DREQ | | х | 0 | 1 | TDRE (ASCI channel 0) | | X | 1 | 0 | TDRE (ASCI channel 1) | | × | 1 | 1 | reserved | #### X: Don't care - ② Specify memory ← → I/O transfer mode and address increment/decrement in the SM0, SM1, DM0 and DM1 bits of DMODE. - 3 Load the number of bytes to transfer in BCR0. - The DMA request sense mode (DMS0 bit in DCNTL) MUST be specified as 'edge sense'. - Enable or disable DMA termination interrupt with the DIE0 bit in DSTAT. - 6 Program DE0 = 1 (with DWE0 = 0 in the same access) in DSTAT and the DMA operation with the ASCI will begin under control of the ASCI generated internal DMA request. The ASCI receiver or transmitter being used for DMA must be initialized to allow the first DMA transfer to begin. The ASCI receiver must be 'empty' as shown by RDRF = 0. The ASCI transmitter must be 'full' as shown by TDRE = 0. Thus, the first byte should be written to the ASCI Transmit Data Register under program control. The remaining bytes will be transferred using DMA. #### (4) Channel 1 DMA DMAC Channel I can perform memory $\longleftrightarrow$ I/O transfers. Except for different registers and status/control bits, operation is exactly the same as described for channel 0 memory $\longleftrightarrow$ I/O DMA. To initiate DMA channel 1 memory $\iff$ 1/0 transfer perform the following operations. - ① Load the memory address (19 bits) into MAR1. - ② Load the I/O address (16 bits) into IAR1. - Trogram the source/destination and address increment/decrement mode using the DIM1 and DIM0 bits in DCNTL. - Specify whether DREQ<sub>1</sub> is level or edge sense in the DMS1 bit - in DCNTL. - Enable or disable DMA termination interrupt with the DIE1 bit in DSTAT. - (6) Program DE1 = 1 (with DWE1 = 0 in the same access) in DSTAT and the DMA operation with the external I/O device will begin using the external DREQ<sub>i</sub> input and TEND<sub>i</sub> output. #### 10.4 DMA Bus Timing When memory (and memory mapped I/O) is specified as a source or destination, ME goes LOW during the memory access. When I/O is specified as a source or destination, IOE goes LOW during the I/O access. When I/O (and memory mapped I/O) is specified as a source or destination, the DMA timing is controlled by the external DREQ input and the TEND output indicates DMA termination. Note that external I/O devices may not overlap addresses with internal I/O and control registers, even using DMA. For I/O accesses, 1 wait state is automatically inserted. Additional wait states can be inserted by programming the on-chip wait state generator or using the external WAIT input. Note that for memory mapped I/O accesses, this automatic I/O wait state is not inserted. For memory to memory transfers (channel 0 only), the external $\overline{DREQ}_0$ input is ignored. Automatic DMA timing is programmed as either burst or cycle steal. When a DMA memory address carry/borrow between bits $A_{15}$ and $A_{16}$ of the address bus occurs (when crossing 64k bytes boundaries), the minimum bus cycle is extended to four clocks by automatic insertion of one internal Ti state. ## 10.5 DMAC Channel Priority For simultaneous $\overline{DREQ_0}$ and $\overline{DREQ_1}$ requests, channel 0 has priority over channel 1. When channel 0 is performing a memory $\longleftrightarrow$ memory transfer, channel 1 cannot operate until the channel 0 operation has terminated. If channel 1 is operating, channel 0 cannot operate until channel 1 releases control of the bus. ## 10.6 DMAC and BUSREQ, BUSACK The BUSREQ and BUSACK inputs allow another bus master to take control of the HD64180 bus. BUSREQ and BUSACK have priority over the on-chip DMAC and will suspend DMAC operation. The DMAC releases the bus to the external bus master at the breakpoint of the DMAC memory or I/O access. Since a single byte DMAC transfer requires a read and a write cycle, it is possible for the DMAC to be suspended after the DMAC read, but before the DMAC write. Even in this case, when the external master releases the HD64180 bus (BUSREQ HIGH), the on-chip DMAC will correctly continue the suspended DMA operation. #### 10.7 DMAC Internal Interrupts Fig. 45 illustrates the internal DMA interrupt request generation circuit. Figure 45 DMAC Interrupt Request Circuit Diagram ## HD64180R/Z DE0 and DE1 are automatically cleared to 0 by the HD64180 at the completion (byte count = 0) of a DMA operation for channel 0 and channel 1 respectively. They remain 0 until a 1 is written. Since DE0 and DE1 use level sense, an interrupt will occur if the CPU IEF<sub>1</sub> flag is set to 1. Therefore, the DMA termination interrupt service routine should disable further DMA interrupts (by programming the channel DIE bit = 0) before enabling CPU interrupts (i.e. IEF<sub>1</sub> is set to 1). After reloading the DMAC address and count registers, the DIE bit can be set to 1 to reenable the channel interrupt, and at the same time DMA can resume by programming the channel DE bit = 1. #### 10.8 DMAC and NMI $\overline{NMI},$ unlike all other interrupts, automatically disables DMAC operation by clearing the DME bit of DSTAT. Thus, the $\overline{NMI}$ interrupt service routine may respond to time critical events without delay due to DMAC bus usage. Also, $\overline{NMI}$ can be effectively used as an external DMA abort input, recognizing that both channels are suspended by the clearing of DME. If the falling edge of $\overline{NMI}$ occurs before the falling clock of the state prior to $T_3$ ( $T_2$ or Tw) of the DMA write cycle, the DMAC will be suspended and the CPU will start the $\overline{NMI}$ response at the end of the current cycle. By setting a channels DE bit to 1, that channels operation can be restarted, and DMA will correctly resume from the point at which it was suspended by $\overline{NMI}$ . See Fig. 46 for details. Figure 46 NMI and DMA Operation #### 10.9 DMAC and RESET During RESET the bits in DSTAT, DMODE, and DCNTL are initialized as stated in their individual register descriptions. Any DMA operation in progress is stopped allowing the CPU to use the bus to perform the RESET sequence. However, the address register (SAR0, DAR0, MAR1, IAR1) and byte count register (BCR0, BCR1) contents are not changed during RESET. ## 11 ASYNCHRONOUS SERIAL COMMUNICATION INTER-FACE (ASCI) The HD64180 on-chip ASCI has two independent full duplex channels. Based on full programmability of the following functions, the ASCI can directly communicate with a wide variety of standard UARTs (Universal Asynchronous Receiver/Transmitter) including the HD6350 CMOS ACIA and the Serial Communication Interface (SCI) contained on the HD6301 series CMOS single chip controllers. The key functions for ASCI are shown below. Each channel is independently programmable. - · Full duplex communication - · 7- or 8-bit data length - · Program controlled 9th data bit for multiprocessor communica- - tion - · 1 or 2 stop bits - Odd, even, no parity - · Parity, overrun, framing error detection - Programmable baud rate generator, /16 and /64 modes Speed to 38.4k bits per second (CPU f<sub>C</sub> = 6.144 MHz) - Modern control signals Channel 0 has DCD<sub>0</sub>, CTS<sub>0</sub> and RTS<sub>0</sub> Channel 1 has CTS<sub>1</sub> - · Programmable interrupt condition enable and disable - · Operation with on-chip DMAC #### 11.1 ASCI Block Diagram Fig. 47 shows the ASCI Block Diagram. Figure 47 ASCI Block Diagram ### 11.2 ASCI Register Description ## (1) ASCI Transmit Shift Register 0, 1 (TSR0, 1) When the ASCI Transmit Shift Register receives data from the ASCI Transmit Data Register (TDR), the data is shifted out to the TXA pin. When transmission is completed, the next byte (if available) is automatically loaded from TDR into TSR and the next transmission starts. If no data is available for transmission, TSR idles by outputting a continuous HIGH level. This register is not program accessible. # (2) ASCI Transmit Data Register 0, 1 (TDR0, 1: I/O Address = 06H, 07H) Data written to the ASCI Transmit Data Register is transferred to the TSR as soon as TSR is empty. Data can be written to while TSR is shifting out the previous byte of data. Thus, the ASCI transmitter is double bufferred. Data can be written into and read from the ASCI Transmit Data Register. If data is read from the ASCI Transmit Data Register, the ASCI data transmit operation won't be affected by this read operation. ## (3) ASCI Receive Shift Register 0, 1 (RSR0, 1) This register receives data shifted in on the RXA pin. When full, data is automatically transferred to the ASCI Receive Data Register (RDR) if it is empty. If RSR is not empty when the next incoming data byte is shifted in, an overrun error occurs. This register is not program accessible. # (4) ASCI Receive Data Register 0, 1 (RDR0, 1: I/O Address = 08H, 09H) When a complete incoming data byte is assembled in RSR, it is automatically transferred to the RDR if RDR is empty. The next incoming data byte can be shifted into RSR while RDR contains the previous received data byte. Thus, the ASCI receiver is double buffered. The ASCI Receive Data Register is read-only-register. However, if RDRF = 0, data can be written into the ASCI Receive Data Register, and the data can be read. ## (5) ASCI Status Register 0, 1 (STATO, 1) Each channel status register allows interrogation of ASCI communication, error and modem control signal status as well as enabling and disabling of ASCI interrupts. ASC! Status Register 0 (STAT0 : I/O Address = 04H) ASCI Status Register 1 (STAT1 : I/O Address = 05H) #### RDRF: Receive Data Register Full (bit 7) RDRF is set to 1 when an incoming data byte is loaded into RDR. Note that if a framing or parity error occurs, RDRF is still set and the receive data (which generated the error) is still loaded into RDR. RDRF is cleared to 0 by reading RDR, when the $\overline{DCD_0}$ input is HIGH, in IOSTOP mode and during RESET. #### OVRN: Overrun Error (bit 6) OVRN is set to 1 when RDR is full and RSR becomes full. OVRN is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0, when $\overline{DCD_0}$ is HIGH, in IOSTOP mode and during RESET. #### PE: Parity Error (bit 5) PE is set to 1 when a parity error is detected on an incoming data byte and ASC1 parity detection is enabled (the MOD1 bit of CNTLA is set to 1). PE is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0, when $\overline{DCD_0}$ is HIGH, in IOSTOP mode and during RESET. #### FE: Framing Error (bit 4) If a receive data byte frame is delimited by an invalid stop bit (i.e. 0, should be 1), FE is set to 1. FE is cleared to 0 when the EFR bit (Error Flag Reset) of CNTLA is written to 0, when $\overline{DCD_0}$ is HIGH, in IOSTOP mode and during RESET. ## RIE: Receive Interrupt Enable (bit 3) RIE should be set to 1 to enable ASCI receive interrupt requests. When RIE to 1, if any of the flags RDRF, OVRN, PE, FE become set to 1 an interrupt request is generated. For channel 0, an interrupt will also be generated by the transition of the external $\overline{DCD_0}$ input from LOW to HIGH. RIE is cleared to 0 during RESET. ## DCD<sub>0</sub>: Data Carrier Detect (bit 2 STAT0) Channel 0 has an external $\overline{DCD_0}$ input pin. The $\overline{DCD_0}$ bit is set to 1 when the $\overline{DCD_0}$ input is HIGH. It is cleared to 0 on the first read of STAT0 following the HIGH to LOW transition of $\overline{DCD_0}$ input and during RESET. When $\overline{DCD_0} = 1$ , receiver unit is reset and receiver operation is inhibited. #### CTS1E: Channel 1 CTS Enable (bit 2 STAT1) Channel 1 has an external $\overline{\text{CTS}}_1$ input which is multiplexed with the receive data pin (RXS) for the CSI/O (Clocked Serial I/O Port). Setting CTS1E to 1 selects the $\overline{\text{CTS}}_1$ function and clearing CTS1E to 0 selects the RXS function. ## TDRE: Transmit Data Register Empty (bit 1) TDRE = 1 indicates that the TDR is empty and the next transmit data byte can be written to TDR. After the byte is written to TDR, TDRE is cleared to 0 until the ASCI transfers the byte from the TDR to the TSR, at which time TDRE is again set to 1. TDRE is set to 1 in IOSTOP mode and during RESET. When the external $\overline{CTS}$ input is HIGH, TDRE is reset to 0. #### TIE: Transmit Interrupt Enable (bit 0) TIE should be set to 1 to enable ASCI transmit interrupt requests. If TIE = 1, an interrupt will be requested when TDRE = 1. TIE is cleared to 0 during RESET. #### · ASCI Control Register AO, 1 (CNTLAO, 1) Each ASCI channel Control Register A configures the major operating modes such as receiver/transmitter enable and disable, data format, and multiprocessor communication mode. ASCI Control Register A 1 (CNTLA1: I/O Address = 01H) ## MPE: Multi Processor Mode Enable (bit 7) The ASCI has a multiprocessor communication mode which utilizes an extra data bit for selective communication when a number of processors share a common serial bus. Multiprocessor data format is selected when the MP bit in CNTLB is set to 1. If multiprocessor mode is not selected (MP bit in CNTLB = 0), MPE has no effect. If multiprocessor mode is selected, MPE enables or disables the 'wake-up' feature as follows. If MPE is set to 1, only received bytes in which the MPB (multiprocessor bit) = 1 can affect the RDRF and error flags. Effectively, other bytes (with MPB = 0) are 'ignored' by the ASCI. If MPE is reset to 0, all bytes, regardless of the state of the MPB data bit, affect the RDRF and error flags. MPE is cleared to 0 during RESET. #### RE: Receiver Enable (bit 6) When RE is set to 1, the ASCI receiver is enabled. When RE is cleared to 0, the receiver is disabled and any receive operation in progress is interrupted. However, the RDRF and error flags are not reset and the previous contents of RDRF and error flags are held. RE is cleared to 0 in IOSTOP mode and during RESET. ## TE: Transmitter Enable (bit 5) When TE is set to 1, the ASCI transmitter is enabled. When TE is cleared to 0, the transmitter is disabled and any transmit operation in progress is interrupted. However, the TDRE flag is not reset and the previous contents of TDRE are held. TE is cleared to 0 in IOSTOP mode and during RESET. ## RTS<sub>0</sub> - Request to Send Channel 0 (bit 4 in CNTLA0) When $\overline{RTS_0}$ is cleared to 0, the $\overline{RTS_0}$ output pin will go LOW. When $\overline{RTS_0}$ is set to 1, the $\overline{RTS_0}$ output immediately goes HIGH. $\overline{RTS_0}$ is set to 1 during RESET. ## CKA1D: CKA1 Clock Disable (bit 4 in CNTLA1) When CKA1D is set to 1, the multiplexed CKA1/ $\overline{\text{TEND}}_0$ pin is used for the $\overline{\text{TEND}}_0$ function. When CKA1D = 0, the pin is used as CKA1, an external data clock input/output for channel 1. CKA1D is cleared to 0 during RESET. ## MPBR/EFR: Multiprocessor Bit Receive/Error Flag Reset (bit 3) When multiprocessor mode is enabled (MP in CNTLB = 1), MPBR, when read, contains the value of the MPB bit for the last re- ceive operation. When written to 0, the EFR function is selected to reset all error flags (OVRN, FE and PE) to 0. MPBR/EFR is undefined during RESET. #### MOD2, 1, 0: ASCI Data Format Mode 2, 1, 0 (bits 2-0) These bits program the ASCI data format as follows. MOD2 $= 0 \rightarrow 7$ bit data $= 1 \rightarrow 8$ bit data MOD1 = 0 → No parity = 1 → Parity enabled MOD0 $= 0 \rightarrow 1$ stop bit $= 1 \rightarrow 2$ stop bits The data formats available based on all combinations of MOD2, MOD1 and MOD0 are shown in Table 10. Table 10 Combination of Data Format | MOD2 | MOD1 | MODO | Data Format | |------|------|------|--------------------------------------| | 0 | 0 | 0 | Start + 7 bit data + 1 stop | | ٥ | 0 | 1 | Start + 7 bit data + 2 stop | | 0 | 1 | 0 | Start + 7 bit data + parity + 1 stop | | ٥ | 1 | 1 | Start + 7 bit data + parity + 2 stop | | 1 | 0 | 0 | Start + 8 bit data + 1 stop | | 1 | 0 | 1 | Start + 8 bit data + 2 stop | | 1 | 1 | 0 | Start + 8 bit data + parity + 1 stop | | 1 | 1 | 1 | Start + 8 bit data + parity + 2 stop | ## (6) ASCI Control Register B0, 1 (CNTLB0, 1) Each ASCI channel control register B configures multiprocessor mode, parity and baud rate selection. ASCI Control Register B 0 (CNTLB0 : I/O Address = 02H) ASCI Control Register B 1 (CNTLB1 : I/O Address = 03H) | bit | 7 | 6 | 5 | 4 | 3 | 2 | . 1 | 0 | |-----|------|-----|------------|-----|-----|-----|-----|-----| | | MPBT | MP | ĈŦŚ/<br>PS | PEO | DR | SS2 | SS1 | SSO | | | R/W ## MPBT: Multiprocessor Bit Transmit (bit 7) When multiprocessor communication format is selected (MP bit = 1), MPBT is used to specify the MPB data bit for transmission. If MPBT = 1, then MPB = 1 is transmitted. If MPBT = 0, then MPB = 0 is transmitted. MPBT state is undefined during and after RESET. ## MP: Multiprocessor Mode (bit 6) When MP is set to 1, the data format is configured for multiprocessor mode based on the MOD2 (number of data bits) and MOD0 (number of stop bits) bits in CNTLA. The format is as follows. Start bit + 7 or 8 data bits + MPB bit + 1 or 2 stop bits Note that multiprocessor (MP = 1) format has no provision for parity. If MP = 0, the data format is based on MOD0, MOD1 and MOD2 and may include parity. The MP bit is cleared to 0 during RESET. CTS/PS: Clear to Send/Prescale (bit 5) When read, CTS/PS reflects the state of the external CTS input. If the CTS input pin is HIGH, CTS/PS will be read as 1. Note that when the CTS input pin is HIGH, the TDRE bit is inhibited (i.e. held at 0). For channel 1, the CTS, input is multiplexed with RXS pin (Clocked Serial Receive Data). Thus, CTS/PS is only valid when read if the channel 1 CTS1E bit = 1 and the CTS, input pin function is selected. The read data of CTS/PS is not affected by RESET. When written, CTS/PS specifies the baud rate generator prescale factor. If CTS/PS is set to 1, the system clock (φ) is prescaled by 30 while if CTS/PS is cleared to 0, the system clock is prescaled by 10. CTS/PS is cleared to 0 during RESET. #### PEO: Parity Even Odd (bit 4) PEO selects even or odd parity. PEO does not affect the enabling/disabling of parity (MOD1 bit of CNTLA). If PEO is cleared to 0, even parity is selected. If PEO is set to 1, odd parity is selected. PEO is cleared to 0 during RESET. #### DR: Divide Ratio (bit 3) DR specifies the divider used to obtain baud rate from the data sampling clock. If DR is cleared to 0, divide by 16 is used while if DR is set to 1, divide by 64 is used. DR is cleared to 0 during RE-SFT ## SS2, 1, 0: Source/Speed Select 2, 1, 0 (bits 2-0) Specify the data clock source (internal or external) and baud rate prescale factor. SS2, SS1, and SS0 are all set to 1 during RESET. Table 11 shows the divide ratio corresponding to SS2, SS1, and SS0. Table 11 Divide Ratio | SS2 | SS1 | SSO | Divide Ratio | |-----|-----|-----|----------------| | 0 | 0 | 0 | ÷ 1 | | 0 | 0 | 1 | ÷2 | | 0 | 1 | 0 | ÷ 4 | | 0 | 1 | 1 | ÷ 8 | | 1 | 0 | 0 | ÷16 | | 1 | 0 | 1 | ÷ 32 | | 1 | 1 | 0 | +64 | | 1 | 1 | 1 | external clock | The external ASCI channel $\frac{0}{0}$ data clock pins are multiplexed with DMA control lines $(CKA_o/\overline{DREQ}_o)$ and $CKA_i/\overline{TEND}_o)$ . During RESET, these pins are initialized as ASCI data clock inputs. If SS2, SS1, and SS0 are reprogrammed (any other value than SS2, SS1, SS0 = 1) these pins become ASCI data clock outputs. However, if DMAC channel 0 is configured to perform memory $\iff$ 1/0 (and memory mapped 1/0) transfers the $CKA_o/\overline{DREQ}_o$ pin revert to DMA control signals regardless of SS2, SS1, and SS0 programming. Also, if the $CKA_i/\overline{DRD}_o$ reverts to the DMA Control output function regardless of SS2, SS1, and SS0 programming. Final data clock rates are based on CTS/PS (prescale), DR, SS2, SS1, SS0, and the HD64180 system clock (\$\phi\$) frequency as shown in Table 12. Table 12 Baud Rate List | Pre | scaler | | npling<br>ate | | Bau | ıd Rate | <del></del> | General<br>Divide | Bau | d Rate (Exam<br>(BPS) | nple) | | CKA | |-----|-----------------|----|---------------|-----|-----|---------|-----------------|-------------------|----------------|-----------------------|----------------|-----|--------------------| | PS | Divide<br>Ratio | DR | Rate | SS2 | SS1 | sso | Divide<br>Ratio | Ratio | φ=6.144<br>MHz | φ=4.608<br>MHz | φ=3.072<br>MHz | 1/0 | Clock<br>Frequency | | | | | 1 | 0 | 0 | 0 | ÷1 | φ÷160 | 38400 | | 19200 | | φ÷10 | | | | ŀ | | 0 | 0 | 1 | 2 | 320 | 19200 | | 9600 | | 20 | | | ļ | | 1 | 0 | 1 | 0 | 4 | 640 | 9600 | | 4800 | | 40 | | | | 0 | 16 | 0 | 1 | 1 | 8 | 1280 | 4800 | | 2400 | 0 | 80 | | | | | l | 1 | 0 | 0 | 16 | 2560 | 2400 | , | 1200 | | 160 | | | | | İ | 1 | 0 | 1 | 32 | 5120 | 1200 | | 600 | | 320 | | | | | ļ. | 1 | 1 | 0 | 64 | 10240 | 600 | | 300 | | 640 | | 0 | φ÷10 | | | 1 | 1 | 1 | | fc÷16 | - | _ | - | _ | fc | | | | | | 0 | 0 | 0 | ÷1 | φ÷640 | 9600 | | 4800 | | φ÷10 | | | | | | 0 | 0 | 1 | 2 | 1280 | 4800 | | 2400 | | 20 | | | | | | 0 | 1 | 0 | 4 | 2560 | 2400 | | 1200 | | 40 | | | | 1 | 64 | 0 | 1 | 1 | 8 | 5120 | 1200 | | 600 | 0 | 80 | | | l i | | | 1 | 0 | 0 | 16 | 10240 | 600 | | 300 | | 160 | | | | | | 1 | 0 | 1 | 32 | 20480 | 300 | | 150 | | 320 | | | | | | 1 | 1 | 0 | 64 | 40960 | 150 | | 75 | | 640 | | | | | | 1 | 1 | 1 | | fc ÷ 64 | _ | - | _ | ı | fc | | | | | | 0 | 0 | 0 | ÷ 1 | φ÷480 | | 9600 | | | φ÷ 30 | | | | | | 0 | 0 | 1 | 2 | 960 | | 4800 | | | 60 | | | | | | 0 | 1 | 0 | 4 | 1920 | | 2400 | | | 120 | | | | 0 | 16 | 0 | 1 | 1 - | 8 | 3840 | | 1200 | | 0 | 240 | | | | | | 1 | 0 | 0 | 16 | 7680 | | 600 | | | 480 | | | | | | 1 | 0 | 1 | 32 | 15360 | 1 | 300 | | | 960 | | | | | | 1 | 1 | 0 | 64 | 30720 | | 150 | | | 1920 | | 1 | φ÷30 | | | 1 | 1 | 1 | _ | fc ÷ 16 | _ | | ~ | I | fc | | | | | | 0 | 0 | 0 | ÷ 1 | φ÷1920 | | 2400 | | | φ÷30 | | | | Ī | | 0 | 0 | 1 | 2 | 3840 | İ | 1200 | i | | 60 | | | ĺ | | | 0 | 1 | 0 | 4 | 7680 | | 600 | | | 120 | | | | 1 | 64 | 0 | 1 | 1 | 8 | 15360 | | 300 | | 0 | 240 | | | | | | 1 | 0 | 0 | 16 | 30720 | } | 150 | | | 480 | | | 1 | 1 | | 1 | 0 | 1 | 32 | 61440 | } | 75 | | | 960 | | i | | | 1 | 1 | 1 | 0 | 64 | 122880 | | 37.5 | | | 1920 | | | | | | 1 | 1 | 1 | | fc÷64 | - ] | - | _ | ī | fc | ## 11.3 MODEM Control Signals ASCI channel 0 has CTS<sub>0</sub>, DCD<sub>0</sub>, and RTS<sub>0</sub> external modem control signals. ASCI channel 1 has a CTS<sub>1</sub> modem control signal which is multiplexed with RXS pin (Clocked Serial Receive Data). ## (1) CTS<sub>0</sub>: Clear to Send 0 (input) The $CTS_0$ input allows external control (start/stop) of ASCI channel 0 transmit operations. When $\overline{CTS_0}$ is HIGH, channel 0 TDRE bit is held at 0 regardless of whether the TDR0 (Transmit Data Register) is full or empty. When $\overline{CTS_0}$ is LOW, TDRE will reflect the state of $\overline{TDR0}$ . Note that the actual transmit operation is not disabled by $\overline{CTS_0}$ HIGH, only TDRE is inhibited. ## (2) DCD<sub>0</sub>: Data Carrier Detect 0 (input) The $\overline{DCD_0}$ input allows external control (start/stop) of ASCI channel 0 receive operations. When $\overline{DCD_0}$ is HIGH, channel 0 RDRF bit is held at 0 regardless of whether the RDR0 (Receive Data Register) is full or empty. The error flags (PE, FE and OVRN bits) are also held at 0. Even after the $\overline{DCD_0}$ input goes LOW, these bits will not resume normal operation until the status register (STAT0) is read. Note that this first read of STAT0, while enabling normal operation, will still indicate the $\overline{DCD_0}$ input is HIGH ( $\overline{DCD0}$ bit = 1) even though it has gone LOW. Thus, the STAT0 register should be read twice to insure the $\overline{DCD0}$ bit is cleared to 0. ## (3) RTS<sub>0</sub>: Request to Send 0 (output) $\overline{RTS}_0$ allows the ASCI to control (start/stop) another communication devices transmission (for example, by connection to that devices $\overline{CTS}$ input). $\overline{RTS}_0$ is essentially a 1 bit output port, having no side effects on other ASCI registers or flags. ### (4) CTS<sub>1</sub>: Clear to Send 1 (input) Channel 1 CTS<sub>1</sub> input is multiplexed with the RXS pin (Clocked Serial Receive Data). The $\overline{CTS_1}$ function is selected when the CTS1E bit in STAT1 is set to 1. When enabled, the $\overline{CTS_1}$ operation is equivalent to $\overline{CTS_0}$ . Modem control signal timing is shown in Fig. 48(a) and Fig. 48(b). Figure 48 (a) DCD Timing Figure 48 (b) RTS Timing ## 11.4 ASCI interrupts Fig. 49 shows the ASCI interrupt request generation circuit. Figure 49 ASCI Interrupt Request Circuit Diagram ## **@HITACHI** #### 11.5 ASCI ←→ DMAC operation Operation of the ASCI with the on-chip DMAC channel 0 requires the DMAC be correctly configured to utilize the ASCI flags as DMA request signals. #### 11.6 ASCI and RESET During RESET, the ASCI status and control registers are initialized as defined in the individual register descriptions. Receive and Transmit operations are stopped during RESET. However, the contents of the transmit and receive data registers (TDR and RDR) are not changed by RESET. #### 11.7 ASCI Clock In external clock input mode, the external clock is directly input to the sampling rate (+16/+64) as shown in Fig. 50. Figure 50 ASCI Clock Block Diagram #### 12 CLOCKED SERIAL I/O PORT (CSI/O) The HD64180 includes a simple, high speed clock synchronous serial I/O port. The CSI/O includes transmit/receive (half duplex), fixed 8-bit data and internal or external data clock selection. High speed operation (baud rate as high as 200k bits/second at f<sub>C</sub> = 4 MHz) is provided. The CSI/O is ideal for implementing a multiprocessor communication link between the HD64180 and the HMCS400 series (4-bit) and the HD6301 series (8-bit) single chip controllers as well as additional HD64180s. These secondary devices may typically perform a portion of the system I/O processing such as keyboard scan/decode, LDC interface etc. ### 12.1 CSI/O Block Diagram The CSI/O block diagram is shown in Fig. 51. The CSI/O consists of two registers — the Transmit/Receive Data Register (TRDR) and Control Register (CNTR). Figure 51 CSI/O Block Diagram #### 12.2 CSI/O Register Description # CSI/O Transmit/Receive Data Register (TRDR: I/O Address = OBH) TRDR is used for both CSI/O transmission and reception. Thus, the system design must insure that the constraints of half-duplex operation are met (Transmit and receive operation can't occur simultaneously). For example, if a CSI/O transmission is attempted at the same time that the CSI/O is receiving data, a CSI/O will not work. Also note that TRDR is not buffered. Therefore, attempting to perform a CSI/O transmit while the previous transmit data is still being shifted out causes the shift data to be immediately updated, thereby corrupting the transmit operation in progress. Similarly, reading TRDR while a transmit or receive is in progress should be avoided. # (2) CSI/O Control/Status Register (CNTR: I/O Address = OAH) CNTR is used to monitor CSI/O status, enable and disable the CSI/O, enable and disable interrupt generation and select the data clock speed and source. #### EF: End Flag (bit 7) EF is set to 1 by the CSI/O to indicate completion of an 8-bit data transmit or receive operation. If EIE (End Interrupt Enable) bit =1 during the time EF =1, a CPU interrupt request will be generated. Program access of TRDR should only occur if EF =1. The CSI/O clears EF to 0 when TRDR is read or written. EF is cleared to 0 du ing RESET and IOSTOP mode. #### EIE: End Interrupt Enable (bit 6) EIE should be set to 1 to enable EF = 1 to generate a CPU interrupt request. The interrupt request is inhibited if EIE is cleared to 0. EIE is cleared to 0 during RESET. #### RE: Receive Enable (bit 5) A CSI/O receive operation is started by setting RE to 1. When RE is set to 1, the data clock is enabled. In internal clock mode, the data clock is output from the CKS pin. In external clock mode, the clock is input on the CKS pin. In either case, data is shifted in on the RXS pin in synchronization with the (internal or external) data clock. After receiving 8 bits of data, the CSI/O automatically clears RE to 0, EF is set to 1 and an interrupt (if enabled by EIE = 1) will be generated. Note that RE and TE should never both be set to 1 at the same time. RE is cleared to 0 during RESET and IOSTOP mode. Note that the RXS pin (pin 52) is multiplexed with CTS<sub>1</sub> modem control input of ASCI channel 1. In order to enable the RXS function, the CTSIE bit in CNTA1 should be reset to 0. #### TE: Transmit Enable (bit 4) A CSI/O transmit operation is started by setting TE to 1. When TE is set to 1, the data clock is enabled. In internal clock mode, the data clock is output from the CKS pin. In external clock mode, the clock is input on the CKS pin. In either case, data is shifted out on the TXS pin synchronous with the (internal or external) data clock. After transmitting 8 bits of data, the CSI/O automatically clears TE to 0, EF is set to 1 and an interrupt (if enabled by ${\sf EIE}=1$ ) will be generated. Note that TE and RE should never both be set to 1 at the same time. TE is cleared to 0 during RESET and IOSTOP mode. #### SS2, 1, 0: Speed Select 2, 1, 0 (bits 2-0) SS2, SS1 and SS0 select the CSI/O transmit/receive clock source and speed. SS2, SS1 and SS0 are all set to 1 during RESET. Table 13 shows CSI/O Baud Rate Selection. Table 13 CSI/O Baud Rate Selection | SS2 | SS1 | SSO | Divide<br>Ratio | Baud<br>Rate | | |-----|-----|-----|------------------------------------------|--------------|--| | 0 | 0 | 0 | ÷ 20 | (200000) | | | 0 | 0 | 1 | ÷40 | (100000) | | | 0 | 1 | 0 | ÷80 | (50000) | | | 0 | 1 | 1 | ÷ 160 | (25000) | | | 1 | 0 | 0 | ÷ 320 | (12500) | | | 1 | 0 | 1 | ÷ 640 | (6250) | | | 1 | 1 | 0 | ÷ 1280 | (3125) | | | 1 | 1 | 1 | external Clock input<br>(less than ÷ 20) | | | #### ( ) shows the baud rate (BPS) at $\phi = 4$ MHz. After RESET, the CKS pin is configured as an external clock input (SS2, SS1, SS0 = 1). Changing these values causes CKS to become an output pin and the selected clock will be output when transmit or receive operations are enabled. ### 12.3 CSI/O Interrupts The CSI/O interrupt request circuit is shown in Fig. 52. Figure 52 CSI/O Interrupt Circuit Diagram #### 12.4 CSI/O Operation The CSI/O can be operated using status polling or interrupt driven algorithms. #### (1) Transmit - Polling - ① Poll the TE bit in CNTR until TE = 0. - (2) Write the transmit data into TRDR. - 3 Set the TE bit in CNTR to 1. - (4) Repeat 1 to 3 for each transmit data byte. #### (2) Transmit - Interrupts - (1) Poll the TE bit in CNTR until TE = 0. - Write the first transmit data byte into TRDR. - 3 Set the TE and EIE bits in CNTR to 1. - When the transmit interrupt occurs, write the next transmit data byte into TRDR. - (5) Set the TE bit in CNTR to 1. - 6 Repeat 4 to 5 for each transmit data byte. ### (3) Receive - Polling - ① Poll the RE bit in CNTR until RE = 0. - 2 Set the RE bit in CNTR to 1. - 3 Poll the RE bit in CNTR until RE = 0. - 4 Read the receive data from TRDR. - S Repeat 2 to 4 for each receive data byte. #### (4) Receive - Interrupts - ① Poll the RE bit in CNTR until RE = 0. - ② Set the RE and EIE bits in CNTR to 1. - 3 When the receive interrupt occurs read the receive data from TRDR. - 4 Set the RE bit in CNTR to 1. - ⑤ Repeat 3 to 4 for each receive data byte. #### 12.5 CSI/O Operation Timing Notes - Note that transmitter clocking and receiver sampling timings are different from internal and external clocking modes. Fig. 53 to Fig. 54 shows CSI/O Transmit/Receive Timing. - (2) The transmitter and receiver should be disabled (TE and RE = 0) when initializing or changing the baud rate. #### 12.6 CSI/O Operation Notes (1) Disable the transmitter and receiver (TE and RE = 0) before initializing or changing the baud rate. When changing the baud rate after completion of transmission or reception, a delay of at least one bit time is required before baud rate modification. ## HD64180R/Z - (2) When RE or TE is cleared to 0 by software, a corresponding receive or transmit operation is immediately terminated. Normally, TE or RE should only be cleared to 0 when EF = 1. - (3) Simultaneous transmission and reception is not possible. Thus, TE and RE should not both be 1 at the same time. Figure 53 Transmit Timing - Internal Clock Figure 54 Transmit Timing — External Clock Figure 55 Receive Timing - Internal Clock Figure 56 Receive Timing - External Clock ## 12.7 CSI/O and RESET CSI/O transmit and receive operations in progress are aborted During RESET each bit in the CNTR is initialized as defined in during RESET. However, the contents of TRDR are not changed. the CNTR register description. ## HD64180R/Z ## 13 PROGRAMMABLE RELOAD TIMER (PRT) The HD64180 contains a two channel 16-bit Programmable Reload Timer. Each FRT channel contains a 16-bit down counter and a 16-bit reload register. The down counter can be directly read and written and a down counter overflow interrupt can be programmably enabled or disabled. In addition, PRT channel 1 has a TOUT output pin (multiplexed with A<sub>12</sub>) which can be set HIGH, LOW, or toggled. Thus PRT1 can perform programmable output waveform #### generation. ## 13.1 PRT Block Diagram The PRT block diagram is shown in Fig. 57. The two channel parate timer data and reload registers and a common status/ control register. The PRT input clock for both channels is equal to the system clock (4) divided by 20. Figure 57 PRT Block Disgram ## **13.2 PRT Register Description** (1) Timer Data Register (TMDR: I/O Address = CHO: ODH, OCH CH1: 15H, 14H) PRTO and PRTI each have 16-bit Timer Data Registers (TMDR), TMDR0 and TMDR1 are each accessed as low and high byte registers (TMDR0H, TMDR0L and TMDR1H, TMDR1L). During RESET, TMDR0 and TMDR1 are set to FFFFH. TMDR is decremented once every twenty & clocks. When TMDR counts down to 0, it is automatically reloaded with the value contained in the Reload Register (RLDR). TMDR can be read and written by software using the following procedures. The read procedure uses a PRT internal temporary storage register to return accurate data without requiring the timer to be stopped. The write procedure requires the PRT to be stopped. For reading (without stopping the timer), TMDR must be read in the order of lower byte — higher byte (TMDRnL, TMDRnH). The lower byte read (TMDRnL) will store the higher byte value in an internal register. The following higher byte read (TMDRnH) will access this internal register. This procedure insures timer data validity by eliminating the problem of potential 16-bit timer updating between each 8-bit read. Specifically, reading TMDR in higher byte - lower byte order may result in invalid data. Note the implications of TMDR higher byte internal storage for applications which may read only the lower and/or higher bytes. In normal operation all TMDR read routines should access both the lower and higher bytes, in that order. For writing, the TMDR down counting must be inhibited using the TDE (Timer Down Count Enable) bits in the TCR (Timer Control Register), following which any or both higher and lower bytes of TMDR can be freely written (and read) in any order. ## (2) Timer Reload Register (RLDR: I/O Address = CHO: OEH, OFH CH1: 16H, 17H) PRTO and PRT1 each have 16-bit Timer Reload Registers (RLDR), RLDR0 and RLDR1 are each accessed as low and hig byte registers (RLDROH, RLDROL and RLDRIH, RLDRIL). During RESET RLDR0 and RLDR1 are set to FFFFH. When the TMDR counts down to 0, it is automatically reloaded with the contents of RLDR. ## (3) Timer Central Register (TCR) TCR monitors both channels (PRT0, PRT1) TMDR status and controls enabling and disabling of down counting and interrupts as well as controlling the output pin (A10/TOUT) for PRT 1. ## TIF1: Timer Interrupt Flag 1 (bit 7) When TMDR1 decrements to 0, TIF1 is set to 1. This can generate an interrupt request if enabled by TIE1 = 1. TIF1 is reset to 0 when TCR is read and the higher or lower byte of TMDR1 are read. During RESET, TIF1 is cleared to 0. ## TIFO: Timer Interrupt Flag 0 (bit 6) When TMDR0 decrements to 0, TIF0 is set to 1. This can generate an interrupt request if enabled by TIEO = 1. TIFO is reset to 0 when TCR is read and the higher or lower byte of TMDR0 are read. During RESET, TIFO is cleared to 0. ## M HITACHI Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 494 #### TIE1: Timer Interrupt Enable 1 (bit 5) When TIE1 is set to 1, TIF1 = 1 will generate a CPU interrupt request. When TIE1 is reset to 0, the interrupt request is inhibited. During RESET, TIE1 is cleared to 0. #### TIEO: Timer Interrupt Enable 0 (bit 4) When TIE0 is set to 1, TIF0 = 1 will generate a CPU interrupt request. When TIE0 is reset to 0, the interrupt request is inhibited. During RESET, TIE0 is cleared to 0. ## TOC1, 0: Timer Output Control (bits 3, 2) TOC1 and TOC0 control the output of PRT1 using the multiplexed A<sub>1.</sub>/TOUT pin as shown below. During RESET, TOC1 and TOC0 are cleared to 0. This selects the address function for A<sub>1.</sub>/ TOUT. By programming TOC1 and TOC0, the A<sub>1.</sub>/TOUT pin can be forced HIGH, LOW or toggled when TMDR1 decrements to 0. | TOC1 | тосо | | OUTPUT | |------|------|-----------|------------------------------------------------------------| | 0 | 0 | Inhibited | (A 18/TOUT pin is selected as an address output function.) | | 0 | 1 | toggled*¬ | /A /TOLIT air is saturated | | 1 | 0 | o - | (A 18/TOUT pin is selected as a PRT1 output function.) | | 1 | 1 | ا 1 | as a first output tarretter, | When TMDR1 decrements to 0, TOUT level is reversed. This can provide square wave with 50% duty to external devices without any software support. ## TDE1, 0: Timer Down Count Enable (bits 1, 0) TDE1 and TDE0 enable and disable down counting for TMDR1 and TMDR0 respectively. When TDEn (n=0,1) is set to 1, down counting is executed for TMDRn. When TDEn is reset to 0, down counting is stopped and TMDRn can be freely read or written. TDE1 and TDE0 are cleared to 0 during RESET and TMDRn will not decrement until TDEn is set to 1. Fig. 58 shows timer initialization, count down and reload timing. Fig. 59 shows timer output (A<sub>18</sub>/TOUT) timing. Figure 58 PRT Operation Timing Figure 59 PRT Output Timing Figure 60 PRT Interrupt Request Circuit Diagram #### 13.3 PRT Interrupts The PRT interrupt request circuit is shown in Fig. 60. #### 13.4 PRT and RESET During RESET the bits in TCR are initialized as defined in the TCR register description. Down counting is stopped and the TMDR and RLDR registers are initialized to FFFFH. The A<sub>18</sub>/TOUT pin reverts to the address output function. #### 13.5 PRT Operation Notes - TMDR data can be accurately read without stopping down counting by reading the lower (TMDRnL\*) and higher (TMDRnH\*) bytes in that order. Or, TMDR can be freely read or written by stopping the down counting. - (2) Care should be taken to insure that a timer reload does not occur during or between lower (RLDRnL\*) and higher (RLDRnH\*) byte writes. This may be guaranteed by system design/timing or by stopping down counting (with TMDR containing a non-zero value) during the RLDR updating. Similarly, in applications in which TMDR is written at each TMDR overflow, the system/software design should guarantee that RLDR can be updated before the next overflow occurs. Otherwise, time base inaccuracy will occur. NOTE: \* n = 0, 1 - During RESET, the multiplexed A<sub>19</sub>/TOUT pin reverts to the address output. - By reprogramming the TOC1 and TOC0 bits, the timer output function for PRT channel 1 can be selected. The following shows the initial state of the TOUT pin after TOC1 and TOC0 are programmed to select the PRT channel 1 timer output function. (i) PRT (channel 1) has not counted down to 0. If the PRT has not counted down to 0 (timed out), the initial state of TOUT depends on the programmed value in TOC1 and TOC0. | TOC1 | тосо | TOUT State After<br>Programming<br>TOC1/TOC0 | TOUT State After<br>Next Timeout | |------|------|----------------------------------------------|----------------------------------| | 0 | 1 | HIGH (1) | LOW (0) | | . 1 | 0 | HIGH (1) | LOW (0) | | 1 | 1 | HIGH (1) | HIGH (1) | (ii)PRT (channel 1) has counted down to 0 at least once. If the PRT has counted down to 0 (timed out) at least once, the initial state of TOUT depends on the number of time outs (even or odd) that have occurred. | Numbers of Timeouts<br>(even or odd) | TOUT State After Programming TOC1/TOC0 | |--------------------------------------|----------------------------------------| | Even (2, 4, 6) | HIGH (1) | | Odd (1, 3, 5) | Low (o) | ## 14 INTERNAL I/O REGISTERS The HD64180 internal I/O Registers occupy 64 I/O addresses (including reserved addresses). These registers access the internal I/O modules (ASCI, CSI/O, PRT) and control functions (DMAC, DRAM refresh, interrupts, wait state generator, MMU and I/O relocation). To avoid address conflicts with external I/O, the HD64180 internal I/O addresses can be relocated on 64 bytes boundaries within the bottom 256 bytes of the 64k bytes I/O address space. ## 14.1 I/O Control Register (ICR) ICR allows relocating of the internal I/O addresses. ICR also controls enabling/disabling of the IOSTOP mode. #### IOA7.6: I/O Address Relocation (bits 7-6) 1OA7 and IOA6 relocate internal I/O as shown in Fig. 61. Note that the high-order 8 bits of 16-bit internal I/O addresses are always 0. IOA7 and IOA6 are cleared to 0 during RESET. Figure 61 Internal I/O Address Relocation ### IOSTP: IOSTOP Mode (bit 5) IOSTOP mode is enabled when IOSTP is set to 1. Normal I/O operation resumes when IOSTP is reset to 0. IOSTP is cleared to 0 during RESET. #### 14.2 Internal I/O Registers Address Map The internal I/O register addresses are shown in Table 14. These addresses are relative to the 64 bytes boundary base address specified in ICR. Table 14 Internal I/O Register Address Map (1) | | Basistas | Mnemonic | Add | ress | |----------|--------------------------------------|-----------|----------|------------| | | Register | Minemonic | Binary | Hexadecima | | | ASCI Control Register A Ch 0 | CNTLAO | XX000000 | ООН | | | ASCI Control Register A Ch 1 | CNTLA1 | XX000001 | 01H | | | ASCI Control Register B Ch 0 | CNTLBO | XX000010 | 02H | | | ASCI Control Register B Ch 1 | CNTLB1 | XX000011 | озн | | 4001 | ASCI Status Register Ch 0 | STAT0 | XX000100 | 04H | | ASCI | ASCI Status Register Ch 1 | STAT1 | XX000101 | 05H | | | ASCI Transmit Data Register Ch 0 | TDRO | XX000110 | 06Н | | | ASCI Transmit Data Register Ch 1 | TDR1 | XX000111 | 07H | | | ASCI Receive Data Register Ch 0 | RDRO | XX001000 | 08Н | | | ASCI Receive Data Register Ch 1 | RDR1 | XX001001 | 09Н | | 001/0 | CSI/O Control Register | CNTR | XX001010 | OAH | | CSI/O | CSI/O Transmit/Receive Data Register | TRDR | XX001011 | ОВН | | | Timer Data Register Ch OL | TMDROL | XX001100 | осн | | | Timer Data Register Ch OH | TMDROH | XX001101 | ODH | | | Reload Register Ch OL | RLDROL | XX001110 | OEH | | | Reload Register Ch OH | RLDROH | XX001111 | OFH | | | Timer Control Register | TCR | XX010000 | 10H | | <b>-</b> | Reserved | | XX010001 | 11H | | Timer | | | | | | | | | XX010011 | 13H | | | Timer Data Register Ch 1L | TMDR1L | XX010100 | 14H | | | Timer Data Register Ch 1H | TMDR1H | XX010101 | 15H | | | Reload Register Ch 1L | RLDR1L | XX010110 | 16H | | | Reload Register Ch 1H | RLDR1H | XX010111 | 17H | | | Free Running Counter | FRC | XX011000 | 18H | | Othom | Reserved | | XX011001 | 19H | | Others | | | 1 5 | 1 5 | | | | | XX011111 | 1FH | Table 14 Internal I/O Register Address Map (2) | | | Mnemonic | Address | | | |---------|---------------------------------------------|----------|-----------|------------|--| | | Register | Mnemonic | Binary | Hexadecima | | | | DMA Source Address Register Ch OL | SAROL | XX100000 | 20H | | | | DMA Source Address Register Ch OH | SAROH | XX100001 | 21H | | | | DMA Source Address Register Ch 0B | SAROB | XX100010 | 22H | | | | DMA Destination Address Register Ch OL | DAROL | XX100011 | 23H | | | | DMA Destination Address Register Ch OH | DAROH | XX100100 | 24H | | | | DMA Destination Address Register Ch 0B | DAROB | XX100101 | 25H | | | | DMA Byte Count Register Ch OL | BCROL | XX100110 | 26H | | | | DMA Byte Count Register Ch 0H | BCROH | XX100111 | 27H | | | | DMA Memory Address Register Ch 1L | MAR1L | XX101000 | 28H | | | DMA | DMA Memory Address Register Ch 1H | MAR1H | XX101001 | 29H | | | DIVIA | DMA Memory Address Register Ch 1B | MAR1B | XX101010 | 2AH | | | | DMA I/O Address Register Ch 1L | IAR1L | XX101011 | 2BH | | | | DMA I/O Address Register Ch 1H | IAR1H | XX101100 | 2CH | | | | Reserved | | XX101101 | 2DH | | | | DMA Byte Count Register Ch 1L | BCR1L | XX101110 | 2EH | | | | DMA Byte Count Register Ch 1H | BCR1H | XX101111 | 2FH | | | | DMA Status Register | DSTAT | XX110000 | 30H | | | | DMA Mode Register | DMODE | XX110001 | 31H | | | | DMA/WAIT Control Register | DCNTL | XX110010 | 32H | | | | IL Register (Interrupt Vector Low Register) | IL | XX110011 | 33H | | | INT | INT/TRAP Control Register | ITC | XX110100 | 34H | | | | Reserved | | XX110101 | 35H | | | | Refresh Control Register | RCR | XX110110 | 36H | | | Refresh | Reserved | | XX110111 | 37H | | | | MMU Common Base Register | CBR | XX111000 | 38H | | | MMU | MMU Bank Base Register | BBR | XX111001 | 39H | | | | MMU Common/Bank Area Register | CBAR | XX111010 | ЗАН | | | | Reserved | | XX11,1011 | 3BH | | | I/O | | | ) | ) | | | I/U | | | XX111110 | 3EH | | | | I/O Control Register | ICR | XX111111 | 3FH | | 14.3 I/O Addressing Notes The internal I/O register addresses are located in the I/O address space from 0000H to 00FFH (16-bit I/O addresses). Thus, to access the internal I/O registers (using I/O instructions), the high-order 8 bits of the 16-bit I/O address must be 0. The conventional I/O instructions (OUT (m), A/ IN A, (m) / OUTI / INI/ etc.) place the contents of a CPU register on the high-order 8 bits of the address bus, and thus may be difficult to use for accessing internal I/O registers. For efficient internal I/O register access, a number of new instructions have been added, which force the high-order 8 bits of the 16-bit I/O address to 0. These instructions are INO, OUTO, OTIM, OTIMR, OTDM, OTDMR and TSTIO (See section 19 Instruction Set). Note that when writing to an internal I/O register, the same I/O write occurs on the external bus. However, the duplicate external I/O write cycle will exhibit internal I/O write cycle timing. For example, the WAIT input and programmable wait state generator are ignored. Similarly, internal I/O read cycles also cause a duplicate external I/O read cycle — however, the external read data is ignored by the HD64180. Normally, external I/O addresses should be chosen to avoid overlap with internal I/O addresses to avoid duplicate I/O accesses. #### 15 E CLOCK OUTPUT TIMING - 6800 TYPE BUS INTER-**FACE** A large selection of 6800 type peripheral devices can be connected to the HD64180, including the Hitachi 6300 CMOS series (6321 PIA, 6350 ACIA, etc.) as well as 6500 family devices. These devices require connection with the HD64180 synchronous E clock output. The speed (access time) required for the peripheral device are determined by the HD64180 clock rate. Table 15, Fig. 62 and Fig. 63 define E clock output timing. Table 15 E Clock Timing in Each Condition | Condition | Duration of E Clock Output "High" | | | |----------------------------------------------------|-----------------------------------|------------------------------|--| | Op-code Fetch Cycle<br>Memory Read/Write Cycle | Tz† - Taţ | $(1.5\phi + n_w \cdot \phi)$ | | | I/O read Cycle | 1st Tw† - Tal | $(0.5\phi + n_w \cdot \phi)$ | | | I/O Write Cycle | 1st Tw† - T3† | (n <sub>w</sub> · φ) | | | NMI Acknowledge 1st MC | T21 - T31 | (1.5φ) | | | INT₀ Acknowledge 1 st MC | 1st Tw1 - T3 | $(0.5\phi + n_w \cdot \phi)$ | | | BUS RELEASE mode<br>SLEEP mode<br>SYSTEM STOP mode | φ - φ | (2φ or 1φ) | | NOTE) n<sub>w</sub> : the number of wait states MC : Machine Cycle Two wait states are automatically inserted. NOTE) MC: Machine Cycle Figure 62 E Clock Timing (During Read/Write Cycle and Interrupt Acknowledge Cycle) (a) E Clock Timing in BUS RELEASE Mode ## (b) E Clock Timing in SLEEP Mode and SYSTEM STOP Mode Figure 63 E Clock Timing (in BUS RELEASE mode, SLEEP mode, SYSTEM STOP mode) Wait states inserted in op-code fetch, memory read/write and I/O read/write cycles extend the duration of E clock output HIGH. Note that during I/O read/write cycles with no wait states (only occurs during on-chip I/O register accesses), E will not go HIGH. The correspondence between the duration of E clock output HIGH and standard peripheral device speed selections is as follows. | Device Speed Selection | Required duration of<br>E clock output HIGH | |------------------------|---------------------------------------------| | 1.0 MHz (ex: HD6321P) | 500 ns min. | | 1.5 MHz (ex: HD63A21P) | 333 ns min. | | 2.0 MHz (ex: HD63821P) | 230 ns min. | ## 15.1 6800 Type Bus Interfacing Note When the HD64180 is connected to 6800 type peripheral LSIs with E clock, the 6800 type peripheral LSIs should be located in I/O address space. If the 6800 type peripheral LSIs are located in memory address space, WR set-up time and WR hold time for E clock won't be guaranteed during memory read/write cycles and 6800 type peripheral LSIs can't be connected correctly. ## 16 ON-CHIP CLOCK GENERATOR The HD64180 contains a crystal oscillator and system clock $(\phi)$ generator. A crystal can be directly connected or an external clock input can be provided. In either case, the system clock $(\phi)$ is equal to one-half the input clock. For example, a crystal or external clock input of 8 MHz corresponds with a system clock rate of $\phi = 4$ MHz. The following table shows the AT cut crystal characteristics (Co, Rs) and the load capacitance (CL1, CL2) required for various frequencies of HD64180 operation. | Table 16 Crys | tal C | haract | eristics | |---------------|-------|--------|----------| |---------------|-------|--------|----------| | Clock Frequency | 4MHz | 4MHz < f ≦ 12MHz | 12MHz < f ≤ 16MHz | |-----------------------------------|-------------------|-------------------|-------------------| | Со | < 7 pF | < 7 pF | < 7 pF | | Rs | <60Ω | <60Ω | <60Ω | | CL <sub>1</sub> , CL <sub>2</sub> | 10 to 22 pF ± 10% | 10 to 22 pF ± 10% | 10 to 22 pF ± 10% | If an external clock input is used instead of a crystal, the waveform (twice the $\phi$ clock rate) should exhibit a 50% $\pm$ 5% duty cycle. Note that the minimum clock input HIGH voltage level is $V_{CC}\!-\!0.6V$ . The external clock input is connected to the EXTAL pin, while the XTAL pin is left open. Fig. 64 shows external clock interface. Figure 64 External Clock Interface Fig. 65 shows the HD64180 clock generator circuit while Fig. 66 and Fig. 67 specify circuit board design rules. Figure 65 Crystal Interface Figure 66 Note for Board Design of the Oscillation Circuit Figure 67 Example of Board Design - Circuit Board design should observe the followings. - To prevent induced noise, the crystal and load capacitors should be physically located as close to the LSI as possible. - (2) Signal lines should not run parallel to the clock oscillator inputs. In particular, the clock input circuitry and the system clock φ output should be separated as much as possible. - (3) Similar to (2), $V_{CC}$ power lines should be separated from the clock oscillator input circuitry. - (4) Resistivity between XTAL or EXTAL and the other pins should be greater than 10M ohms. Signal line layout should avoid areas marked with /////. ## HD64180R/Z #### 17 MISCELLANEOUS Free Running Counter (I/O Address = 18H) Read only 8-bit free running counter without control registers and status registers. The contents of the 8-bit free running counter is counted down by 1 with an interval of $10~\phi$ clock cycles. The free running counter continues counting down without being affected by the read operation. If data is written into the free running counter, we can't guarantee the interval of DRAM refresh cycle and baud rates of ASCI and CSI/O. In IOSTOP mode, the free running counter continues counting down. It is initialized to FFH during RESET. ## **18 OPERATION NOTES** # 18.1 Precaution on Interfacing the Z80° Family Peripheral LSIs to the HD64180 ## (1) Problem In daisy chain, the Z80\* family peripheral LSI (PIO, DMA, CTC, SIO, or DART) resets interrupt circuit (i.e. IEO changes from LOW to HIGH) by fetching the RETI op-code on the data bus concurrently during the CPU fetches the RETI. Therefore, the followings should be noted for the RETI op-code (EDH, 4DH) fetch timing in the Z80\* peripheral LSI. When the peripheral LSI fetches the first op-code of RETI (EDH), $\overline{LIR}$ should be negated HIGH at the rising edge of system clock $\phi$ as shown in Fig. 71, A. (This isn't referred in the manuals for the Z80\* peripheral LSI.) So, $\overline{LIR}$ hold time ( $\overline{LIR}$ = HIGH) should be required as shown in Fig. 71. Figure 71 LIR Hold Time Because $\overline{LIR}$ changes synchronously with the rising edge of system clock $\phi$ , $\overline{LIR}$ delay time is equal to $\overline{LIR}$ hold time of the Z80\* peripheral LSI. However, this $\overline{LIR}$ hold time may not be sufficient for the Z80\* peripheral LSI in some case and IEO line may not be reset. #### (2) An example of countermeasure Fig. 72 shows an example of circuit, while Fig. 73 shows the LIR and LIR timing in the circuit. Figure 72 Circuit Example \* Z80 is a registered trademark of Zilog, Inc. Figure 73 LIR and LIR' Timing in the Circuit $\overline{LIR}$ ', which is synchronized with the falling edge of system clock $\phi$ , is provided to the peripheral LSI. In this case, one-half clock cycle duration is confirmed as the hold time. Please carefully examine the circuit before you use it on your application. # 18.5 Precaution on Interfacing HD64180 with Z80° CTC (1) Problem The following problem may happen when interfacing HD64180 with Z80° CTC (Z8430). Therefore, countermeasure shown in section 2 should be taken. Fig. 81 illustrates Z80° CTC write timing specified in Z80° CTC Data Sheet. Fig. 82 and Fig. 83 show Z80° I/O write timing and HD64180 I/O write timing respectively. As shown above, $\overline{\rm OE}$ in HD64180 goes LOW by a half $\phi$ clock cycle faster than $\overline{\rm IORO}$ in Z80. When interfacing Z80 with Z80° CTC, data is written into Z80° CTC at the rising edge of Tw. By contrast, when interfacing HD64180 with Z80° CTC, data is written into Z80° CTC at the rising edge of T<sub>2</sub>. In the latter case, data may not be written into Z80° CTC if $\overline{\rm IOE}$ set-up time for the rising edge of T<sub>2</sub> is less than the set-up time specified in Z80° CTC. Figure 81 Z80° CTC Write Timing\*\* Figure 82 Z80° I/O Write Timing Figure 83 HD64180 I/O Write Timing #### (2) Countermeasure To Avoid the problem, $\overline{IOE}$ in HD64180 should be asserted LOW at the rising edge of $T_2$ to assure the set-up time specified in 280° CTC. Fig. 84 (a) shows a circuit for delaying $\overline{IOE}$ by a half $\phi$ clock cycle. If this circuit is externally connected between HD64180 and Z80° CTC, $\overline{\text{IOE}}$ ' will be pulled LOW at the rising edge of $T_2$ only in I/O read/write cycle as shown in Fig. 84 (b). While in $\overline{\text{INT}}_0$ acknowledge cycle, $\overline{\text{IOE}}$ and $\overline{\text{IOE}}$ ' are asserted LOW at the timing shown in Fig. 84 (c). In $\overline{\text{INT}}_0$ acknowledge cycle, $\overline{\text{IOE}}$ ' delays because of propagation time of TTL gates of the countermeasure circuit and the vector access time is shortened. If vector access time for HD64180 is not assured during $\overline{\text{INT}}_0$ acknowledge cycle, wait states should be inserted by programming IWI0 and IWI1 bits of DMA/WAIT Control Register. However, note that wait states insertion by software should be inhibited during Z80° CTC read/write cycles, because more than one wait state can not be allowed in the case of Z80° CTC. (Please see Z80° CTC Data Sheet. One wait state is automatically inserted during the cycles.) Refer to "Fig. 85 Z80° CTC Access Flow" for details. (c) INT o Acknowledge Cycle Timing Figure 84 Countermeasure Circuit and Timings in the Circuit Z80 is a registered trademark of Zilog, Inc. <sup>\*\*</sup> Copied from Z80\* CTC Data Sheet (April, 1985) Figure 85 Z80° CTC Access Flow # 18.6 Notes on HD64180 INT<sub>0</sub> Mode 0 (1) Problem In INT<sub>0</sub> Mode 0, the CPU executes an instruction which is placed on the data bus during the interrupt acknowledge cycle. Usually, RST (1-byte instruction) or CALL (3-byte instruction) is placed on the data bus. Then, the CPU pushes the Program Counter (PC) onto the stack and jumps to the interrupt service routine. In the case of RST instruction, the correct return address is pushed onto the stack. However, in the case of CALL instruction, the pushed return address is equal to the correct return address + 2. #### (2) Explanation of operation During the 1st op-code fetch cycle in the interrupt acknowledge cycle, the CPU stops incrementing the PC. At this time, the PC contains the return address. After the 1st op-code is fetched, the CPU restarts incrementing the PC. Therefore, is RST (1-byte instruction) is executed in the interrupt acknowledge cycle, the correct return address is pushed onto the stack and the CPU can return from the interrupt service routine correctly. While, if CALL (3-byte instruction) is executed in the interrupt acknowledge cycle, the PC is incremented twice during the operand read cycle of the 2 bytes after the 1st op-code is fetched. Therefore, the return address + 2 in the PC is pushed onto the stack. So, when RETI is executed at the end of the interrupt service routine, the CPU can not return from the interrupt correctly. Fig. 86 shows the CALL execution timing in $\overline{INT_0}$ Mode 0. Figure 86 The CALL Execution Timing in INT Mode 0 #### (3) Countermeasure The following explains the countermeasure of the problem in $\overline{INT_n}$ Mode 0. (I) RST When RST is executed, the correct return address in the PC is pushed onto the stack. D CALL When CALL is executed, the stack contents must be decremented by two in the interrupt service routine to return from the interrupt correctly. Table 18 summarizes how to adjust the stack contents depending on the instruction to be executed. Table 18 Stack Contents Adjustment | Instruction | Stack Contents Adjustment | |--------------------|-------------------------------------| | RST | No | | CALL | Decrement the stack contents by two | | Other instructions | No<br>(The PC is not stacked.) | The INT<sub>0</sub> Mode 0 sequences when executing RST and CALL are shown in Fig. 87. (a) INTo Mode 0 Sequence when executing RST (b) INTo Mode O Sequence when executing CALL NOTE) PC: PC indicates the return address Figure 87 INT Mode 0 Sequence ### 19 INSTRUCTION SET ### 19.1 Instruction set overview The HD64180 is object code compatible with standard 8-bit operating system and application software. The instruction set also contains a number of new instructions to improve system and software performance, reliability and efficiency. | New Instructions | Operation | |------------------|-------------------------------------------------------| | SLP | Enter SLEEP mode | | MLT | 8-bit multiply with 16-bit result | | IN0 g, (m) | Input contents of immediate I/O address into register | | OUTO (m), g | Output register contents to immediate I/O address | | OTIM | Block output - increment | | OTIMR | Block output - increment and repeat | | OTDM | Block output - decrement | | OTDMR | Block output - decrement and repeat | | TSTIO m | Non-destructive AND, I/O port and accumula-<br>tor | | TST g | Non-destructive AND, register and accumula-<br>tor | | TST m | Non-destructive AND, immediate data and accumulator | | TST (HL) | Non-destructive AND, memory data and ac-<br>cumulator | #### (1) SLP - Sleep The SLP instruction causes the HD64180 to enter SLEEP low power consumption mode. See section 5 for a complete description of the SLEEP state. #### (2) MLT - Multiply The MLT performs unsigned multiplication on two 8 bit numbers yielding a 16 bit result. MLT may specify BC, DE, HL or SP registers. In all cases, the 8-bit operands are loaded into each half of the 16-bit register and the 16-bit result is returned in that register. # (3) INO g, (m) - Input, Immediate I/O address The contents of immediately specified 8-bit I/O address are input into the specified register. When I/O is accessed, 00H is output in high-order bits of address automatically. #### (4) OUTO (m), g - Output, immediate I/O address The contents of the specified register are output to the immediately specified 8-bit I/O address. When I/O is accessed, 00H is output in high-order bits of address automatically. ### (5) OTIM, OTIMR, OTDM, OTDMR - Block I/O The contents of memory pointed to by HL is output to the I/O address in (C). The memory address (HL) and I/O address (C) are incremented in OTIM and OTIMR and decremented in OTDM and OTDMR respectively. B register is decremented. The OTIMR and OTDMR variants repeat the above sequence until register B is decremented to 0. Since the I/O address (C) is automatically incremented or decremented, these instructions are useful for block I/O (such as HD64180 on-chip I/O) initialization. When I/O is accessed, 00H is output in high-order bits of address automatically. ### (6) TSTIO m - Test I/O Port The contents of the I/O port addressed by C are ANDed with 8-bit immediate data and the status flags are updated. The I/O port contents are not written (non-destructive AND). When I/O is accessed, 00H is output in higher bits of address automatically. #### (7) TST g - Test Register The contents of the specified register are ANDed with the accumulator (A) and the status flags are updated. The accumulator and specified register are not changed (non-destructive AND). # HD64180R/Z #### (8) TST m - Test Immediate The 8-bit immediate data is ANDed with the accumulator (A) and the status flags are updated. The accumulator is not changed (non-destructive AND). #### (9) TST (HL) - Test Memory The contents of memory pointed to by HL are ANDed with the accumulator (A) and the status flags are updated. The memory contents and accumulator are not changed (non-destructive AND). #### 19.2 Instruction set summary The followings explain the symbols in instruction set, and the following tables summarize the operation of each instruction. #### (1) Register g, g', ww, xx, yy, and zz specify a register to be used. g and g' specify an 8-bit register. ww, xx, yy, and zz specify a pair of 16-bit registers. The following tables show the correspondence between symbols and registers. | g,g' | Reg. | ww | Reg. | хx | Reg. | уу | Reg. | ZZ | Reg. | |------|------|----|------|----|------|----|------|----|------| | 000 | В | 00 | BC | 00 | BC | 00 | BC | 00 | BC | | 001 | С | 01 | DE | 01 | DE | 01 | DE | 01 | DE | | 010 | D | 10 | HL | 10 | IX | 10 | IY | 10 | HL | | 011 | E | 11 | SP | 11 | SP | 11 | SP | 11 | AF | | 100 | Н | | | - | | | | •— | • | | 101 | L | | | | | | | | | | 111 | Α | | | | | | | | | NOTE: Suffixed H and L to ww,xx,yy,zz (ex.wwH,IXL) indicate upper and lower 8-bit of the 16-bit register respectively. #### (2) Bit b specifies a bit to be manipulated in the bit manipulation instruction. The following table shows the correspondence between b and bits. | ь | Bit | |-----|-----| | 000 | 0 | | 001 | 1 | | 010 | 2 | | 011 | 3 | | 100 | 4 | | 101 | 5 | | 110 | 6 | | 111 | 7 | #### (3) Condition f specifies the condition in program control instructions. The following shows the correspondence between f and conditions. | f | Condition | |-----|----------------| | 000 | NZ non zero | | 001 | Z zero | | 010 | NC non carry | | 011 | C carry | | 100 | PO parity odd | | 101 | PE parity even | | 110 | P sign plus | | 111 | M sign minus | | | | ### (4) Restart Address v specifies a restart address. The following table shows the correspondence between v and restart addresses. | v | Address | |-----|---------| | 000 | 00H | | 001 | 08H | | 010 | 10H | | 011 | 18H | | 100 | 20H | | 101 | 28H | | 110 | 30H | | 111 | 38H | #### (5) Flag The following symbols show the flag conditions. not affected affected undefined set to 1 reset to 0 parity v overflow #### (6) Miscellaneous ( )<sub>M</sub> : data in the memory address ( )<sub>1</sub> : data in the I/O address m or n : 8-bit data mn : 16-bit data r : 8-bit register R : 16-bit register b·( )<sub>M</sub> : a content of bit b in the memory address b·gr : a content of bit b in the register gr d or j : 8-bit signed displacement d or j : 8-bit signed displacement S : source addressing mode D : destination addressing mode · : AND operation + : OR operation ⊕ : EXCLUSIVE OR operation # **Data Manipulation Instructions** Arithmetic and Logical Instructions (8-bit) | Operation MNEMONICS OP-code Addressing | | | | | | | | | | | L | _ | | leg | | | | | |----------------------------------------|---------------|---------------------|--------------|----------|--------------|--------------|--------------------------------------------------|----------|--------------|----------|--------------------------------------------------|----------------------------------------------------------------------------------------------------|-----|-----|---|-----|----------|---| | | MNEMONICS | OP-code | i | | | | • | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | 1 | | / Marine | | | IMMED | EXT | IND | REG | REGI | MP | REL | | | | s | z | н | PΛ | / N | 4 | | ωο | ADD Ag | 10 000 g | | | | s | | ۵ | | 1 | 4 | Ar+gr:→Ar | 1 | ī | 1 | ٧ | P | R | | | ADD A, MU | 10 000 110 | | | ļ | | s | D | | 1 | 6 | Ar+ HUM-Ar | 1 | 1 | ı | ٧ | F | R | | | ADD A,m | 11 000 110 | s | 1 | 1 | | | D | | 2 | 6 | Ar+ m→Ar | 1 | 1 | ı | ٧ | P | R | | | 1 | < m > | | | ĺ | | | | | | | | ļ | | | | | | | | ADD A, (IX+d) | 11 011 101 | 1 | ļ | s | | | D | | 3 | 14 | Ar+ 8x+ dh₁→Ar | 1 | 1 | 1 | ٧ | F | R | | | | 10 000 110 | Ì | İ | | | | | | | | | | | | | | | | | | < ø > | | | | | | | | 1 | | | | | | | | | | | ADD A, BY+di | 11 111 101 | 1 | | s | | | О | | 3 | 14 | Ar+ fY+dh,→Ar | 1 | 1 | 1 | ٧ | F | я | | | | 10 000 110 | | 1 | | | | | | | | | | | | | | | | | | < 0 > | | 1 | | | | | | | | | | | | | | | | | | | + | ┼— | <del>-</del> | - | | В | | 1 | 4 | Ar+ gr+ c→Ar | 1 | 1 | 1 | | F | _ | | <b>v</b> oc | ADC A.g | 10 001 g | | | | S | s | D | | | 6 | Ar+ HUM+ c-Ar | 1 ' | | | v | | | | | ADC A, IHU | 10 001 110 | s | 1 | | ļ | " | D . | | 2 | 6 | Ar+m+c-Ar | | i | | v | | | | | ADC A,m | 11 001 110 | , | | ļ | | | " | | 1 | | A . III . C . A | 1' | ٠ | • | • | • | | | | | < m > | | | s | 1 | | D | | 3 | 14 | Ar+ 8X+dlm+cAr | 1. | | , | ٧ | | R | | | ADC A (IX+d) | 10 001 110 | | | 3 | ł | | " | | * | '~ | ATT BAT CAMP TO COM | 1. | ٠ | ٠ | ٠ | | | | | i | | | | 1 | | | ĺ | į | i | | ì | | | | | | | | | | < d > | | | s | | | Ь | | 3 | 14 | Ar+ 8Y+dhu+cAr | 1. | , | , | v | , 1 | A | | | ADC A (Y+d) | 11 111 101 | 1 | İ | , | 1 | | " | | 1 3 | ' <del>-</del> | AIT ST TONG TO A | ' | • | ٠ | ٠ | • | " | | | | 10 001 110<br>< d > | | 1 | 1 | | ] | | | | | | ľ | | | | | | | | | | <del> </del> | <u> </u> | <u> </u> | ↓ | <b>.</b> | Ь. | ļ | ļ | | <b>_</b> | + | | _ | _ | | _ | | AND | AND g | 10 100 g | 1 | | | s | | P | | 1 | 4 | Ar · gr→Ar | 1 ' | 1 | | | | R | | | AND HL | 10 100 110 | | | | 1 | s | D | | 1 | 6 | Ar · HLI <sub>M</sub> —Ar | 1 | 1 | | P | | A | | | AND m | 11 100 110 | s | 1 | | | | P | | 2 | 6 | Ar · m⊶Ar | 1 | I | 5 | P | | н | | | | < m > | | | 1 | | ì | 1 | | 1 | | | | | | | | _ | | | AND (IX+d) | 11 011 101 | Ì | | S | | ł | D | | 3 | 14 | Ar - BX + dlm Ar | 1 | 1 | S | P | | R | | | | 10 100 110 | ľ | | | | 1 | | | 1 | · | i | | | | | | | | | 1 | < d > | | 1 | | | İ | | | | | | | | | | | | | | AND (IY+d) | 11 111 101 | | ł | s | | | ь | 1 | 3 | 14 | Ar · BY + d) <sub>M</sub> → Ar | 11 | 1 | 9 | P | . , | R | | | 7 | 10 100 110 | | | • | 1 | ł | İ | | ' | | 1 | 1 | | | | | | | | İ | < d > | | | | | | 1 | | | | | | | | | | | | | | <del></del> | +- | + | † | s | <del> </del> | Ь | <del> </del> | 1 | 4 | Ar-gr | 1 | - | _ | | , | 5 | | Compare | CP g | 10 111 g | | | | | s | | | ] ; | 6 | Ar- Ofthe | 1, | 1 | | | | s | | | CP (HL) | 10 111 110 | s | | 1 | | " | | | 2 | | Ar-m | ; | 1 | | | | | | | CP m | 11 111 110 | , | 1 | | | | ١٠ | | 1 | | ~ " | Ι, | • | • | | | • | | | | 1 | 1 | | s | | İ | 0 | | 3 | 14 | Ar- EX+d)u | ١, | | , | | , | | | | CP (DX + di) | 10 111 110 | 1 | | " | | İ | " | | " | '- | AL BY CHA | Ι, | • | ٠ | | | • | | | | 1 | | | 1 | | | 1 | 1 | 1 | | | | | | | | | | | CP (ry+d) | < d > | 1 | | s | 1 | 1 | <b>D</b> | Ì | 3 | 14 | Ar 07+dh | ١, | | 1 | | , | s | | | CP (IV+a) | 10 111 110 | | ł | " | | İ | " | | 1 | '- | ~ *, · · · · · · · · · · · · · · · · · · | Ι, | ٠ | • | , | | • | | | | < a > | ļ | 1 | | | İ | ĺ | | ŀ | 1 | | | | | | | | | | <del> </del> | | | - | + | <del> </del> | - | S/D | <del></del> | ╁╌ | <del> </del> | Ā~A | + | - | _ | ; . | _ | s | | COMPLEMENT | CPL | 00 101 111 | | - | | - | - | 5/0 | <u> </u> | ١ | 3 | <del></del> | + | | | | | _ | | DEC | DEC g | 00 g 101 | İ | | | S/D | ١. | | İ | 1 | 4 | gr-1gr | 1 | | | ١ | | 5 | | | DEC (HL) | 00 110 101 | 1 | 1 | 1 | | S/D | | | 1 | 10 | OHLIM 1 OHLIM | | 1 | | | | | | | DEC (X+d) | 11 011 101 | | | S/0 | 1 | | | 1 | 3 | 18 | (X+d) <sub>M</sub> -1→ | 1 | 1 | 1 | • | <i>'</i> | 5 | | | | 00 110 101 | | | | | | | 1 | | | (DX + d) <sub>M</sub> | | | | | | | | | | < d > | | | | | | | 1 | ۱. | ١ | | Ι. | | | | | | | | DEC (TY+d) | 11 111 101 | ĺ | 1 | \$/D | 1 | 1 | | 1 | 3 | 18 | (IY + d) <sub>M</sub> - 1 | 1' | Į | 1 | ١, | , : | 5 | | | 1 | 00 110 101 | | | | 1 | | | ! | 1 | | ITY + dh <sub>e</sub> | 1 | | | | | | | | 1 | < d > | | $\bot$ | ↓ | - | <u> </u> | 1 | <b>—</b> | <u> </u> | ļ | | + | | | | | | | | + | | 1 | 1 | 1 | S/D | 1 | 1 | 1 | 1 | 4 | gr+1 →gr | 1 | 1 | 1 | • | | R | | INC | INC g | 00 g 100 | 1 | i | ı | | | | | | | | | | | | | | | INC | NC (HL) | 00 110 100 | | | | | S/D | 1 | ł | 1 | 10 | (HL)M+1→94L)M | 1 | | | | | | | INC | | - | | | \$/0 | | S/D | | | 3 | 10<br>18 | (HL) <sub>M</sub> + 1 → 9 HL) <sub>M</sub><br>(IX + d) <sub>M</sub> + 1 →<br>(IX + d) <sub>M</sub> | | | | , | | | | INC | NC (HL) | 00 110 100 | | | | | S/D | | | ł | 1 | | | | | | | ٧ | | | | T | | | | | | | | | | | | | P | beg. | | | |-----------|-------------------|------------------------|----------|--------------|----------|----------|--------------|----------------|-------------|----------|----------------|----------------------------------------------------|--------------|---|---|------|--------|---| | Operation | MNEMONICS | OP-code | | | • | ddressir | • | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | ٥ | | neme | | L | MMED | EXT | NO | REG | REGI | IMP | REL. | | | | s | Z | н | P/V | N | С | | INC | | < d > | | | | | | ļ | | | | | | | | | | | | | INC IY+di | 11 111 101 | | ļ | S/D | | | | | 3 | 18 | 8Y + db <sub>M</sub> + 1 →<br>8Y + db <sub>M</sub> | 1 | 1 | ı | ٧ | R | • | | | | 00 110 100<br>< d > | | | | | | | | | | V + 0-0 | | | | | | | | MULT | MLT ww | 11 101 101 | $\vdash$ | <del> </del> | $\vdash$ | S/D | 1 | $\vdash$ | <del></del> | 2 | 17 | water× water-was | ŀ | | | | | _ | | , | "" | 01 ww1 100 | | | | | | | | | | | | | | | | | | NEGATE | NEG | 11 101 101 | | | | | | S/D | | 2 | 6 | 0-AAr | 1 | 1 | 1 | ٧ | s | 1 | | | | 01 000 100 | <u> </u> | | ļ | | | L | L | ļ | | ļ | L | | | | _ | _ | | OR | OR g | 10 110 9 | | | | s | | 0 | | 1 | 4 | Ar+gr—Ar | 1 | | R | | | R | | | OR HL)<br>OR m | 10 110 110 | s | | | | s | D | | 1 2 | 6 | Ar+MU <sub>M</sub> Ar<br>Ar+mAr | 1 | ı | | P | R | | | | On III | < m > | " | | | | | - | | | - | | ľ | · | | | | | | | OR EX+df | 11 011 101 | Ì | | s | | | D | | 3 | 14 | Ar + EX + dlm—Ar | ı | ı | R | P | R | R | | | | 10 110 110 | | | | | | l | | | | | | | | | | | | | | < d > | | | | | | D | | 3 | 14 | Ar+8Y+di <sub>M</sub> →Ar | 1 | ı | A | P | R | R | | | OR IY+d | 11 111 101 | 1 | | s | | | , | | , | ' <del>'</del> | | | | | | | | | | | < d > | | | | | | | ł | | 1 | _ | | | | | | | | SUB | SUB g | 10 010 g | | | | s | | В | | 1 | 4 | Ar-grAr | | | | | s | | | | SUB (HL) | 10 010 110 | | | 1 | | s | 0 | | 1 | 6 | Ar− #L) <sub>M</sub> Ar<br>Ar− mAr | | | | | 5<br>5 | | | | SUB m | 11 010 110<br>< m > | S | | | | | D | | 2 | 6 | Ar-m→Ar | ' | 1 | · | ٠ | ٠ | ٠ | | ŀ | SUB EX+d | 11 011 101 | | | s | | | ь | | 3 | 14 | Ar- (X+d) <sub>M</sub> -Ar | 1 | 1 | 1 | ٧ | s | ı | | | | 10 010 110 | | | l | | | | Ì | | | | l | | | | | | | | | < d > | | | | Ì | 1 | | | ١. | | | L | | | | _ | | | | SUB (Y+d) | 11 111 101 | | 1 | s | | | D | 1 | 3 | 14 | Ar- 6Y+dlm-Ar | 1 | 1 | ı | ٧ | 5 | ı | | | | < d > | 1 | ĺ | ļ | 1 | | | ļ | | ļ | | l | | | | | | | SUBC | SBC Ag | 10 011 9 | <b>1</b> | | | s | | 0 | Ì | 1 | 4 | Ar-gr-cAr | 1 | 1 | 1 | ٧ | s | 1 | | | SBC A, HU | 10 011 110 | | | İ | | s | D | | 1 | 6 | Ar- HLM-c-Ar | | | | | S | | | | SBC Am | 11 011 110<br>< m > | s | | | | | D | | 2 | 6 | Ar~ m~ c→Ar | 1 | 1 | 1 | ٧ | S | 1 | | 1 | SBC A, EX+d | 11 011 101 | | | s | | | D | | 3 | 14 | Ar- 6X+dl <sub>M</sub> -c-Ar | ı | ı | 1 | ٧ | s | ı | | | | 10 011 110 | | | | į | 1 | | | | | | | | | | | | | | SBC A #Y+di | < d > | | | s | | | , | | 3 | 14 | Ar- (IY+d) <sub>M</sub> -c-Ar | ١. | | | | s | | | | SBC A ST + O | 10 011 110 | | | " | | | ١ | | , | '- | Ar-III + OM - C-Ar | 1 | ١ | ٠ | ۰ | 3 | ١ | | | | < d > | | 1 | | | | | | | | | | | | | | | | TEST | TST g | 11 101 101 | | | | s | | | | 2 | 7 | Ar · gr | ı | 1 | s | P | R | R | | | TST (HL) | 00 g 100 | | | | | s | | | 2 | 10 | Ar · BHLhu | ١. | | _ | _ | _ | | | | ISI HU | 00 110 100 | | | | | | | ĺ | 1 | " | Ar · HUM | 1 | 1 | 5 | ۲ | A | H | | | TST m | 11 101 101 | s | | | | | | | 3 | 9 | Ar · m | ı | 1 | 5 | P | R | R | | | | 01 100 100 | | | | ļ | | | ļ | | | | ļ | | | | | | | <u> </u> | <del> </del> | < m > | + | - | $\vdash$ | - | <del> </del> | <del> _</del> | | + | <del> </del> | | <del> </del> | _ | _ | _ | _ | ᆜ | | XOR | XOR g<br>XOR BILL | 10 101 g<br>10 101 110 | | | | S | s | D | | 1 | 6 | Ar⊕ #U <sub>M</sub> —Ar | ľ | | R | | | A | | | XOR m | 11 101 110 | s | | | | | D | | 2 | 6 | Ar d m—Ar | i | | | | R | | | | | < m > | 1 | | | | | | | | | | | | | | | | | | XOR (X+d) | 11 011 101 | Ī | | S | | | P | | 3 | 14 | Ar⊕ bX+dbyAr | 1 | ı | R | P | R | R | | | | < d > | | | | 1 | | | | | | | | | | | | | | | XOR (Y+d) | 11 111 101 | | | s | | | D | | 3 | 14 | Ar @ 8Y + dlmAr | ı | 1 | R | P | A | A | | | 1 | 10 101 110<br>< d > | | | | | | | | ] | [ | | | | | | | | | | 1 | 1 | 1 | L | | L | 1 | | | <u> </u> | l | 1 | 1 | | | | | ! | Rotate and Shift Instructions | | | | OP-code Addressing Bytes Bytes | | | | | | | | | [ | _ | | P | <b>*</b> 9 | | _ | |-----------|-------------|------------------|-----------------------------------|-----|-----|----------|------|------|-----|-------|----------|-------------|-----|---|-----|------------|-----|---| | Operation | MNEMONICS | OP-code | | | | ddressin | 9 | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | - | | neme | | | MMED | EXT | IND | REG | REGI | IMP | REL | | | | s | Z | н | P/V | N | • | | otate | RLA | 00 010 111 | | | | | | \$/0 | | 1 | 3 | فتستث | | - | R | | Ħ | | | nd | RL g | 11 001 011 | İ | 1 | | S/D | | | | 2 | 7 | . ,, | 1 | 1 | R | P | R | | | hift | | 00 010 9 | | | | | | | | | | | | | | | | | | eta | RL HU | 11 001 011 | | | | l | S/D | | | 2 | 13 | | 1 | ı | Ħ | P | R | | | | | 00 010 110 | İ | | į ! | | | | | | | | l | | | _ | _ | | | | RL (IX+d) | 11 011 101 | 1 | | S/D | | | | | 4 | 19 | | 1 | 1 | R | P | R | | | | | 11 001 011 | | | 1 | | | ŀ | İ | | | | i | | | | | | | | | < d > | | | | İ | | | | | | | i | | | | | | | | | 00 010 110 | | 1 | | 1 | 1 | | | | | | ١. | 1 | | | | | | | RL (1Y + d) | 11 111 101 | 1 | İ | S/D | | | | ļ | 4 | 19 | ļ | 1 | i | H | ۲ | _ | | | | | 11 001 011 | | | Ì | 1 | ļ | | | | | | 1 | | | | | | | | | < d > | | | 1 | | ł | | | | | | | | | | | | | | 1 | 00 010 110 | | 1 | l | ł | İ | | | ١. | | | ١. | | | | | | | | RLCA | 00 000 111 | İ | | | | | S/D | Ì | 1 2 | 3 | ) o'dimini, | Ι, | 1 | | | | | | | ALC 9 | 11 001 011 | 1 | | | S/D | | | 1 | 1 2 | <b>'</b> | | ١, | • | | • | | | | | | 00 000 g | | | | | 5/0 | | | 2 | 13 | | i | 1 | R | P | R | | | | RLC (HL) | 11 001 011 | | | | 1 | 5/0 | 1 | | 1 | , ,, | | ١. | ٠ | | | | | | | | 00 000 110 | | İ | S/D | İ | | i | 1 | 4 | 19 | | ١, | t | A | P | A | | | | RLC 0X + d) | 11 011 101 | | | 5/0 | | | 1 | 1 | - | '* | | Ι. | • | | | | | | | | 11 001 011 | 1 | | | | | i i | | | | | 1 | | | | | | | | 1 | 1 . | | | | | | | 1 | 1 | 1 | | | | | | | | | | 1 | 00 000 110 | | İ | S/D | | 1 | | 1 | ۱. | 19 | | ١. | 1 | R | P | A | 1 | | | RLC (IY+d) | 11 111 101 | 1 | | 3/0 | | | | | 1 | | | Ι' | · | | | | | | | | 1 | ı | 1 | | 1 | | | | | | | | | | | | | | | | < d > 00 000 110 | - | 1 | 1 | | | | | | | <u></u> | 1 | | | | | | | | 1 | l l | | 1 | | | | S/D | | 2 | 16 | | ١. | 1 | R | - | P | 4 | | | RLD | 11 101 101 | | | | | | 3.0 | | • | | ÜİIII Ü | 1 | | | | | | | | | 01 101 111 | - | | | İ | } | | 1 | | | | | | | | | | | | RRA | 00 011 111 | | | | - | 1 | S/D | | 1 | 3 | (immin-ò | | | R | | | 4 | | | RR g | 11 001 011 | 1 | | | S/D | | | | 2 | 7 | »,——» « | ı | 1 | A | P | F | 4 | | | | 00 011 g | | | 1 | | | 1 | | | 1 | | | | | | | | | | RR IHU | 11 001 011 | | | İ | | S/D | ı | 1 | 2 | 13 | | 1 | 1 | F | l P | F | A | | | İ | 00 011 110 | | | | | | 1 | İ | 1 | | | ì | | | | | | | | RR (UX+d) | 11 011 101 | 1 | | S/D | | ļ | | 1 | 4 | 19 | | 1 | 1 | F | t P | , | 4 | | | | 11 001 011 | ĺ | i | 1 | 1 | 1 | | 1 | | 1 | | | | | | | | | | ĺ | < d > | | | | | | | | | ļ | | | | | | | | | | 1 | 00 011 110 | | | | | ì | 1 | 1 | 1 | İ | | | | | | | _ | | | RR (IY+d) | 11 111 101 | | | S/D | | | | 1 | 4 | 19 | | 1 | 1 | F | 1 6 | ' | R | | | | 11 001 011 | | | 1 | | 1 | | | İ | | | | | | | | | | | | < d > | | | 1 | | 1 | 1 | | | | | | | | | | | | | | 00 011 110 | 1 | 1 | | | 1 | | | | 1 . | | | | | _ | | _ | | | RRCA | 00 001 111 | | 1 | İ | | | S/D | | 1 | 3 | ن شسش ه | | | | | | R | | | RAC g | 11 001 011 | ļ | | 1 | S/D | i | | | 2 | , | , | 1 | 1 | | 3 1 | , | R | | | | 00 001 g | | ŀ | | | | | 1 | | 1 | ĺ | ١. | | | | | | | | RRC (HL) | 11 001 011 | | , · | | 1 | 5/0 | 1 | ļ | 2 | 13 | 1 | 1 | 1 | ' | 4 1 | • | R | | | ì | 00 001 110 | | | | | İ | | ľ | 1. | 1 | | ١. | | | | | | | | RRC (IX+d) | 11 011 101 | | 1 | S/D | | | | 1 | 4 | 19 | 1 | 1, | 1 | , , | , , | . ' | 7 | | | 1 | 11 001 011 | 1 | | 1 | - | | | | | | | | | | | | | | | 1 | < d > | | 1 | | | | | | 1 | | | | | | | | | | | | 00 001 110 | | | | | | | | ١. | 1 | i | 1. | 1 | | | | | | | RRC (TY+d) | 11 111 101 | | | S/D | 1 | | | 1 | 4 | 19 | | 1, | | , 1 | n 1 | | ~ | | | 1 | 11 001 011 | | | | | 1 | | | 1 | | 1 | | | | | | | | | 1 | < d > | - 1 | 1 | | | | 1 | | | 1 | 1 | 1 | | | | | | | | 1 | 00 001 110 | ł. | 1 | 1 | 1 | | 1 | 1 | 1 | | i . | - 4 | | | | | | | 0 | | | 1 | | | Addressi | · | | | | | | | | F | leg | | | |-------------------|-------------|--------------|---------|-----|----------------|----------|------|---------|-----|-------|--------|---------------|----|---|---|-----|---|---| | Operation<br>name | MINEMONICS | OP-code | <u></u> | ı | <del>,</del> - | , . | · | · · · · | т — | Bytes | States | Operation | 7 | _ | _ | | 1 | _ | | | | <del> </del> | IMMED | EXT | NO | REG | REGI | MP | REL | ļ | | <u></u> | s | Z | | | N | C | | Rotate | RRD | 11 101 101 | | | | | | \$/0 | | 2 | 16 | ^~~~ | 1 | 1 | R | P | R | | | and | | 01 100 111 | | | | | | | ĺ | | | CTTTT WW | ŀ | | | | | | | Shift | SLA g | 11 001 011 | 1 | | | S/D | | | | 2 | 7 | | 1 | 1 | A | P | A | ţ | | Data | | 00 100 g | İ | | | 1 | | 1 | ĺ | | ł | Ď-ŮIIIII | | | | | | | | | SLA OHL) | 11 001 011 | ŀ | | | | S/D | | ŀ | 2 | 13 | | 1 | 1 | R | P | R | 1 | | | SLA (IX+d) | 11 011 101 | l | | S/D | | | | | | | ] | i | | | | | | | | SLA BX+0) | 11 001 011 | | | 5/0 | | | | | 4 | 19 | 1 | 1 | I | A | Р | R | ŧ | | | 1 | < d > | } | ĺ | | | | | | | | | | | | | | | | | | 00 100 110 | 1 | | | | | | | | | | l | | | | | | | | SLA (IV+d) | 11 111 101 | | | S/D | İ | - | | | 4 | 19 | | ١. | | _ | _ | _ | | | | 35.4 | 11 001 011 | 1 | | 3/5 | | | | | • | 19 | | 1 | 1 | н | P | A | 1 | | | | < d > | | | | i | | 1 | | | | | | | | | | | | | | 00 100 110 | | | | l | | | | | | | | | | | | | | | SRA g | 11 001 011 | | | | S/D | | | | 2 | , | | ١. | | _ | _ | _ | | | | J | 00 101 g | | | | 3/0 | | | | 1 | ′ | diminiño | 1 | ١ | н | ۲ | R | 1 | | | SRA HLI | 11 001 011 | 1 | | | | S/D | | | 2 | 13 | | | | | | я | | | | | 00 101 110 | | | | ŀ | 5,5 | | | 1 1 | ,, | | i | | _ | • | - | , | | | SRA (X+d) | 11 011 101 | | | S.∕D | | | | | 4 | 19 | | ١. | , | | ۰ | R | | | | | 11 001 011 | | | | | | | | , | ,,, | | ٠, | , | n | r | _ | 1 | | | ļ | < 0 > | | | | | | | ' | l i | | | | | | | | | | | | 00 101 110 | | | | [ | | | | | | | | | | | | | | | SRA (IV+d) | 11 111 101 | ] | | S/D | | | | | 4 | 19 | | | 1 | | ٥ | R | , | | | | 11 001 011 | l | | 1 | | | | | | | | • | • | | | - | • | | | | < ø > | | | | | | | | | | | | | | | | | | | | 00 101 110 | | | | | 1 | | | | | | | | | | | | | | SRL g | 11 001 011 | | | | S/O | | | | 2 | 7 | •-fillillið-ó | ī | 1 | R | ٩ | R | ; | | | | l | | | | | | | | | | | | | | | | | | | | 00 111 g | | | | | i | | | | | •-û1111115-0 | | | | | | | | | SAL OHU | 11 001 011 | | | | | \$/0 | 1 | | 2 | 13 | * * * | 1 | 1 | R | P | R | 1 | | | | 00 111 110 | | | | | | 1 | | ı | | | | | | | | | | | SRL (IX+d) | 11 011 101 | | l | S/D | | | ľ | i | 4 | 19 | | 1 | 1 | R | P | R | 1 | | | | 11 001 011 | | | | | | | İ | | | | | | | | | | | | | < d > | | | ļ | ĺ | | İ | | | } | | | | | | | | | ļ | SRL (TY+d) | 11 111 101 | | | | | - 1 | | ļ | . 1 | | | | | | | | | | | OFFE WITTON | 11 001 011 | | | S/D | | İ | - 1 | 1 | 4 | 19 | i | 1 | 1 | R | P | R | 1 | | | | < d > | | | | | | - 1 | | | | | | | | | | ļ | | - | | 00 111 110 | | 1 | | | | 1 | | | | | | | | | | | | | | S 111 110 | | | 1 | - 1 | | J | | - 1 | | | | | | | | ļ | # Bit Manipulation Instructions | | | T | | | | | | | | | | | | | F | - | | | |-----------|---------------|------------|----------|-----|----------|--------------|-------------|----|--------------|-------|--------------|-----------------------------------------|-----|---|---|-----|-----|-----| | Operation | MNEMONICS | OP-code | | | ^ | ddressin | 9 | | | Dytes | States | Operation | 7 | 6 | 4 | 2 | 1 | 0 | | namé | | | IMMED | EXT | ND. | REG | REGI | MP | REL | | | | +- | _ | - | - | _ | c | | Bit Set | SET b,g | 11 001 011 | | | | S/D | | | | 2 | 7 | t→b · gr | - | • | • | ٠ | ٠ | • | | | 1 | 11 b g | 1 | 1 | | | | | | ١ | | | | | | | | | | | SET b. HL) | 11 001 011 | | | | | S/D | | | 2 | 13 | 1 b · BHL) <sub>M</sub> | Ι' | • | · | | | | | | 1 | 11 6 110 | | | | | | | | ١. | | | 1 | | | | | | | | SET b. (IX+d) | 11 011 101 | 1 | | \$/D | | | 1 | | 4 | 19 | 1—b·(IX+di <sub>M</sub> | 1. | • | • | • | | | | | | 11 001 011 | | | ļ | ļ | 1 | | | } | 1 | | | | | | | | | | | < d > | | | 1 | | | 1 | ļ | 1 | Í | } | ļ | | | | | | | | | 11 6 110 | | 1 | | | 1 | | 1 | | ļ | | 1 | | | | | | | | SET b, (1Y+d) | 11 111 101 | 1 | 1 | S/D | | | | | 4 | 19 | 1b · BY+dM | | • | • | | | • | | | İ | 11 001 011 | | İ | ļ | | | | | İ | | | ŀ | | | | | | | | | < d > | | 1 | 1 | 1 | | 1 | Ì | 1 | | | 1 | | | | | | | | | 11 Б 110 | | | | İ | | | l | i | | | 1 | _ | | _ | | | | Bit Reset | RES b.g | 11 001 011 | <b>†</b> | | | S/D | | | | 2 | , | Ob · gr | | ٠ | | | | | | | | 10 ь о | 1 | | | j | | | ļ | 1 | | | | | | | | | | | RES b. HL) | 11 001 011 | | | 1 | | S/D | | Ì | 2 | 13 | 0-b · Milm | 1. | | | ٠ | ٠ | | | | /200,712 | 10 6 110 | 1 | 1 | ì | 1 | | ĺ | | Į | | 1 | | | | | | | | | RES b. (CX+d) | 11 011 101 | 1 | | S/D | | | | ļ | 4 | 19 | 0-b • 8X+dh | · | | | | | | | | nes u, w w | 11 001 011 | | | | ļ | | 1 | 1 | | | | 1 | | | | | | | | 1 | < d > | | | ì | 1 | ĺ | Ì | İ | | | i | | | | | | | | | Ĭ | 10 ь 110 | | | | 1 | | | 1 | 1 | İ | | 1 | | | | | | | | | 11 111 101 | 1 | 1 | S/D | 1 | 1 | } | ì | 4 | 19 | 0b - IY+dbu | ١. | | | | | | | Į. | RES b. (Y+d) | | 1 | 1 | 1 | | | | | 1 | 1 | [ · · · · · · · · · · · · · · · · · · · | ł | | | | | | | 1 | | 11 001 011 | | | 1 | | 1 | 1 | 1 | 1 | | | 1 | | | | | | | | | < d > | i | | 1 | ļ | 1 | | | 1 | l | 1 | | | | | | | | | | 10 6 110 | ļ — | | <u> </u> | <del> </del> | <del></del> | + | <del>}</del> | 1 | <del> </del> | <del> </del> | +: | | | | | R | | Bit Teet | BIT b.g | 11 001 011 | | | 1 | s | | | | 2 | 6 | p. a | ^ | , | • | • • | | • | | | | 01 Б 9 | 1 | | ł | 1 | - | 1 | | 1 . | l . | | ١ | | | | | | | 1 | BIT b, #HL) | 11 001 011 | Ì | | ł | | 5 | | | 2 | 9 | b · HUM-z | × | 1 | • | , | | R | | | | 01 b 110 | | | | ĺ | 1 | 1 | İ | 1 | ļ | | 1. | | | | | _ | | | BIT b, (IX+d) | 11 011 101 | | 1 | 5 | 1 | Ì | | 1 | 4 | 15 | p · (DX + olivi → z | × | ı | • | , | | R · | | | | 11 001 011 | | | 1 | | | 1 | i | | 1 | | | | | | | | | 1 | | < d > | 1 | 1 | | | 1 | | 1 | 1 | 1 | | | | | | | | | Į | Ì | 01 в 110 | | 1 | | 1 | 1 | 1 | | | | | | | | | | | | | BIT b, BY+dI | 11 111 101 | | 1 | s | l | 1 | 1 | | 4 | 15 | b·lV+dbu-z | × | I | • | 5 2 | ۱ ، | A . | | | | 11 001 011 | | 1 | 1 | - | 1 | 1 | | 1 | 1 | | | | | | | | | 1 | | < d > | | | | - | | | | | 1 | | - 1 | | | | | | | 1 | 1 | 01 в 110 | | | 1 | | 1 | 1 | 1 | | 1 | 1 | - | | | | | | | | _1 | | | _1 | _L | | ᆚ | | ٠ | Ц | | | ┷- | _ | | _ | _ | _ | # Arithmetic Instructions (16-bit) | | | | | | | | | | | | | | | | FI | -0 | | | |-----------|------------|------------|-------|----------|----------|-----------|------|----------|-----|----------|--------|---------------------------------------------------|-------------------|---|----|-----|---|---| | Operation | MINEMONICS | OP-code | | | • | Addressir | •9 | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | 0 | | патте | | | IMMED | EXT | IND | REG | REGI | MP | REL | 1 | | | 5 | z | н | P/V | N | С | | ADD | ADD HLww | 00 ww1 001 | | | | s | | .0 | | 1 | 7 | HLR+ WWR-HLR | · | | x | | R | 1 | | | ADD IX,xx | 11 011 101 | | | | s | | D | | 2 | 10 | IX <sub>R</sub> +x <sub>RR</sub> →IX <sub>R</sub> | | • | X | ٠ | R | 1 | | | | 00 xx1 001 | | ļ ' | | | | Ì | | | | | | | | | | | | | ADD IY.yy | 11 111 101 | 1 | | | s | | Đ | | 2 | 10 | IY <sub>R</sub> +yy <sub>R</sub> IY <sub>R</sub> | • | • | X | ٠ | R | ı | | | | 00 yy1 001 | | | | | | | | | | | $ldsymbol{f eta}$ | | | | | _ | | ADC | ADC HLww | 11 101 101 | | | | s | | ٥ | | 2 | 10 | HLA+wwa+c-HLA | t | 1 | X | ٧ | R | I | | | | 01 ww1 010 | | | | | | Ĭ | | | | | L | | | | | | | DEC | DEC www | 00 ww1 011 | | | | S/D | Ī | | | 1 | 4 | wwn-1→wwn | | | ٠ | ٠ | | | | | DEC IX | 11 011 101 | | ĺ | | İ | | S/D | | 2 | 7 | IX <sub>R</sub> - 1 → IX <sub>R</sub> | | ٠ | ٠ | | ٠ | • | | | | 00 101 011 | | | | | | 1 | | | | | Ì | | | | | | | | DEC IY | 11 111 101 | | 1 | | | | S/D | | 2 | 7 | IVR1-IVR | | | • | ٠ | | • | | | | 00 101 011 | | L | <u> </u> | | | <u> </u> | | | | | _ | | | | | _ | | INC | INC ww | 00 ww0 011 | | | | S/D | 1 | | | 1 | 4 | wwn+1wwn | · | ٠ | • | • | - | • | | | INC IX | 11 011 101 | | | l | | | S/D | | 2 | 7 | IXn+1→IXn | | ٠ | ٠ | ٠ | | ٠ | | | | 00 100 011 | | | | | | | | Ì | | 1 | | | | | | | | | INCIY | 11 111 101 | | | | | | S/D | | 2 | 7 | IYR+1→IYR | | | • | • | • | • | | | L | 00 100 011 | | <u> </u> | L | L | L | <u> </u> | | <u> </u> | | | L | | | | | | | SBC | SBC HL,ww | 11 101 101 | | | | s | l | D | Į | 2 | 10 | HLR-WWR-C-HLR | 1 | i | X | ٧ | s | 1 | | | | 01 ww0 010 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | 1 | | | | | | # **Data Transfer Instructions** R-Bit Load | | | | | | | | | | | | | | L | | F | •• | | _ | |-----------|----------------|------------|------|-----|-----|----------|------|-----|-----|----------|--------|--------------------------|-------|---|---|-----|---|---| | Operation | MNEMONICS | OP-code | | | | ddressin | • | | | Bytes | States | Operation | 1 | | | 2 | _ | _ | | neme | | | MMED | EXT | ND | REG | REGI | MP | REL | <u> </u> | | | s | _ | | PΛ | _ | _ | | ped | LD AJ | 11 101 101 | | | | | ĺ | S/D | | 2 | • | r-a- | 1 | 1 | R | EF: | R | • | | -bit | | 01 010 111 | | | | l | Ì | 1 | ł | 1 | | | Ι. | ı | | æe | | | | eta | LD A.R | 11 101 101 | } | | 1 | l | | S/D | ļ | 2 | 6 | Rr—Ar | 1' | 1 | - | · | | | | | Į | 01 011 111 | l | | | Ì | | 1 | 1 | 1 | | l | 1 | | | | | | | | LD A, EPC) | 00 001 010 | | l | | | S | P | 1 | 1 | 6 | BC) <sub>M</sub> —Ar | 1 | • | · | | Ċ | | | | LD A (DE) | 00 011 010 | Į | Į | ì | 1 | S | P | ļ | 1 | 6 | (DE) <sub>M</sub> Ar | T. | Ċ | Ċ | | | | | | LD A fmn) | 00 111 010 | | s | | | | 0 | | 3 | 12 | imni <sub>M</sub> —Ar | 1 | | · | | | | | | 1 | < n > | 1 | 1 | 1 | i | 1 | | | 1 | ł | * | 1 | | | | | | | | 1 | < m > | | ł | | 1 | | ì | İ | | _ | ł | | | | | | | | | 1D LA | 11 101 101 | 1 | 1 | | l | 1 | S/D | 1 | 2 | 6 | Artr | Ι. | • | • | | | | | | | 01 000 111 | 1 | | 1 | 1 | | | | | Į. | 1 | | | | | | | | | LD RA | 11 101 101 | | İ | 1 | İ | ì | S/D | 1 | 2 | 6 | AR | Ι. | • | ٠ | | | | | | | 01 001 111 | 1 | 1 | 1 | 1 | 1 | | | l | | | | | | | | | | | LD (BC),A | 00 000 010 | | | 1 | | 0 | s | 1 | 1 | 7 | Ar—(BC) <sub>M</sub> | - 1 | • | • | | | | | | LD (DE).A | 00 010 010 | 1 | | ì | 1 | D | 5 | 1 | 1 | 7 | A(DE) <sub>M</sub> | 1. | • | • | • | | | | | LD (mn).A | 00 110 010 | | 0 | ļ | 1 | | 5 | | 3 | 13 | Ar- trois | Ι. | | • | | ٠ | | | | Ì | < n > | 1 | | 1 | 1 | 1 | | | ŀ | | ì | - | | | | | | | | Į. | < m > | | } | [ | | | | 1 | 1 | | | 1 | | | | | | | | ம் ஓஓ் | 01 g g' | 1 | | i | S/D | 1 | İ | | ١, | • | gr-gr | - [ . | • | | | | | | | LD g. HLJ | 01 g 110 | | | 1 | D | S | | Ì | 1 | 6 | HLl <sub>M</sub> gr | - [ . | | | | | | | | LDgum | 00 g 110 | S | ı | | P | 1 | | | 2 | 6 | m-gr | 1. | • | | | | | | | | < m > | 1 | i | 1 | 1 | 1 | | | Į | 1 | Į. | - 1 | | | | | | | | 1.0 g. 8X+d4 | 11 011 101 | | 1 | s | D | 1 | ì | 1 | 3 | 14 | £X+dh <sub>M</sub> gr | ١. | • | | | | | | | | 01 g 110 | Ì | 1 | 1 | | | | 1 | 1 | | 1 | - 1 | | | | | | | | } | < d > | 1 | 1 | | 1 | | 1 | | ì | | | | | | | | | | | LD g. BY+dl | 11 111 101 | 1 | i | s | D | 1 | | | 3 | 14 | 8Y + dh <sub>M</sub> —gr | - 1 | | | | | | | | 1-5 | 01 9 110 | | 1 | 1 | Į. | L | 1 | | - | | ł | | | | | | | | | | < 0 > | | | 1 | | 1 | 1 | 1 | | ļ | ł | 1 | | | | | | | | LD HUM | 00 110 110 | s | | ļ | | D | - | | 2 | 9 | m-#Ll <sub>M</sub> | - [ | | • | | • | • | | | | < m > | ì | 1 | ł | 1 | | Ì | Ţ | - | 1 | | - 1 | | | | | | | | LD 8X+d8,m | 11 011 101 | s | | l D | 1 | | ļ | ļ | 4 | 15 | m(DX+dh <sub>M</sub> | - 1 | • | • | | | • | | | | 00 110 110 | | 1 | ĺ | 1 | | i | ł | 1 | | | - | | | | | | | | | < d > | | | - | | | | ļ | - | | Į. | | | | | | | | | | < m > | | | l | 1 | 1 | ı | İ | - 1 | 1 | | | | | | | | | | LD (IY+d),m | 11 111 101 | s | | 0 | | | | - | 4 | 15 | mfry+di <sub>M</sub> | i | | | | • | • | | | 1 | 00 110 110 | | -1 | - | | | - | - | 1 | | | | | | | | | | | - | < d > | | 1 | | | | | | | 1 | | | | | | | | | | ì | < m > | | | | | - | | | | | | | | | | | | | | LD HUA | 01 110 g | | | | s | D | 1 | | 1 | 7 | gr B4L) <sub>kt</sub> | | | | • | • | ٠ | | | LD (DX + of).g | 11 011 101 | - | 1 | D | s | 1 | - | 1 | 3 | 15 | gr→tX+di <sub>M</sub> | İ | | | ٠ | • | ٠ | | l | 1 | 01 110 g | | - | | | | 1 | | - | 1 | | - 1 | | | | | | | | | < d > | . | | | | | | Ì | | | | | | | | | | | ĺ | LD #Y+di.g | 11 111 101 | | 1 | ٥ | s | İ | ì | | 3 | 15 | gr→6Y+dbu | | | | • | • | • | | | | 01 110 g | - | | | | | - [ | 1 | | | 1 | ļ | | | | | | | 1 | 1 | < d > | j | | 1 | ı | 1 | 1 | | | ı | | i | | | | | | 16-Bit Load | Operation | | | | | | ddressir | <b>.</b> | | | | 1 | | L | | | Fleg | _ | | _ | |-----------|--------------|---------------------|----------|-----|-----|----------|----------|-----|-----|-------|--------|-----------------------------------------|-----|---|---|------|-----|---|---| | neme | MNEMONICS | OP-code | <u> </u> | | | , | _ | , | , | Bytes | States | Operation | 7 | 6 | 4 | . 2 | ! | 1 | 0 | | | ļ | | IMMED | EXT | IND | REG | REGI | IMP | RÉL | ļ | | | s | Z | _ | ( P/ | V 1 | N | c | | Load | LD www, mm | 00 ww0 001 | s | | l | D | l | 1 | | 3 | 9 | mnwwk | 1. | • | | | | | • | | 16-bit | 1 | < n > | | | | | | | 1 | i | | | | | | | | | | | Data | | < m > | | | | | | 1 | 1 | | | | | | | | | | | | | LD IX. mn | 11 011 101 | s | | İ | Ì | 1 | D | | 4 | 12 | mnXA | | • | | | • | | • | | | | 00 100 001<br>< n > | 1 . | | | | | | | | ] | | | | | | | | | | | | < n > < m > | | | | ĺ | | | | | i | | | | | | | | | | | LD IY, mn | 11 111 101 | s | | | | | 0 | | 4 | | | 1 | | | | | | | | | LD IV, IV | 00 100 001 | , | | | i | | ١ | | 1 | 12 | mn—lY <sub>R</sub> | 1. | | • | • | | | • | | | | < n > | | | | | | | | | | | | | | | | | | | | | < m > | | | | | | | l . | | | | - | | | | | | | | | LD SP, HL | 11 111 001 | | | | | | S/D | | ١, | 4 | | 1 | | | | | | | | | LD SP. IX | 11 011 101 | | | | | | S/D | | 2 | 7 | HLa-SPR | ١. | • | | | | | • | | | | 11 111 001 | | | | | | 3.0 | | 1 | , | IX <sub>R</sub> →SP <sub>R</sub> | Ι. | • | • | ٠ | • | | • | | | LO SP, IY | 11 111 101 | | | | | | S/D | | 2 | 7 | IYa-SPa | ١. | | | | | | | | | | 11 111 001 | | | | | | | | • | , | TIR-SFR | ľ | • | · | | | | | | | LD www. (mm) | 11 101 101 | | s | | ь | | | | 4 | 18 | fmn+1) <sub>M</sub> wwttr | ١. | | | | | | | | | | 01 ww1 011 | | - | | | | | | , | | (mn) <sub>M</sub> wwt.r | Ι΄. | | · | · | • | | • | | | ļ | < n > | | | | | | | | | | 111111111111111111111111111111111111111 | | | | | | | | | | | < m > | | | | | | | | | | | | | | | | | | | | LD HL (mn) | 00 101 010 | | s | | | | ь | | 3 | 15 | (mn+1) <sub>M</sub> →Hr | ١. | | | | | | | | | l | < n > | | | | | | | | | | (mn)M→Ft | 1 | | | | | | | | | i | < m > | | | | | i | | | | | | 1 | | | | | | | | | LD IX, (mn) | 11 011 101 | | s | | | | D | | 4 | 18 | (mn+1) <sub>M</sub> →DXHr | ١. | | | | | | | | | | 00 101 010 | | | | | | | | | | (mni <sub>M</sub> →tXLr | | | | | | | | | | | < n > | | | | | | | | | | | | | | | | | | | | | < m > | | | | | | li | | | | | l | | | | | | | | | LD IY, (mm) | | | _ | | | | | | | | ļ | l | | | | | | | | | LD IT, SMM | 00 101 010 | | s | | | | D | | 4 | 18 | (mn+1) <sub>M</sub> →!YHr | | • | | ٠ | | | | | | } | < n > | | | | | | | | | | imni <sub>M</sub> →!YLr | | | | | | | | | | | \ m > | | | | | | | | i | | | | | | | | | | | | LD (mn).ww | 11 101 101 | | D | | s | | ľ | | 4 | | | İ | | | | | | | | | | 01 ww0 011 | | • | | • | - 1 | | | • | 19 | wwtr(mn+1) <sub>M</sub> | | • | • | | • | | | | | | < n > | l | | | | | | | | | wwl (mn) <sub>M</sub> | | | | | | | | | | | < m > | | | | | | | ı | | | | | | | | | | | | | LD (mm),HL | 00 100 010 | | ь | | | | s | | 3 | 16 | Hr⊶(mn+1) <sub>M</sub> | | | | | | | | | | | < n > | ŀ | - | - | - 1 | - 1 | 1 | | • [ | 16 | Lr-imniu | | • | | • | | | | | | | < m > | | | - 1 | | | - 1 | ļ | i | | Cr BANNA | | | | | | | | | | LD (mn), IX | 11 011 101 | - 1 | ь | - [ | | | s | | 4 | 19 | IXHr→(mn+1) <sub>M</sub> | | | | | | | | | | | 00 100 010 | | ļ | | | | ł | - 1 | . | | DKL/ (mri) <sub>M</sub> | | | • | · | • | | | | | | < n > | | | | | | ł | | - 1 | | | | | | | | | | | | | < m > | - 1 | j | - 1 | | | 1 | - 1 | | | | | | | | | | | | | LD (mm), IY | 11 111 101 | | D | | | i | s | | 4 | 19 | IYHr⊶(mn+1) <sub>M</sub> | | | | | | | 1 | | | | 00 100 010 | ļ | | | İ | | - 1 | | | | IYLr (mn) <sub>M</sub> | | | | | | | 1 | | | | < n > | | ı | - 1 | - | | | | | | | | | | | | | ļ | | | | < m > | | i | - | - 1 | - 1 | - 1 | | - 1 | | i | | | | | | | | ### **Block Transfer** | | | Į. | ļ | | | | | | | | | | L | | F | leg | | | |-------------------|------------|------------|------|-----|----|----------|------|----|------|-------|------------------------|--------------------------------------------|----|---|-----|-----|---|----| | Operation<br>name | MINEMONICS | OP-code | | | | ddressir | • | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | | 1 | | | | l | MMED | EXT | ND | REG | REGI | MP | REL. | | | | s | z | | | _ | N | | lock | | | | | | | | | | | | | | 2 | | 0 | | _ | | ransfer | CPD | 11 101 101 | | | | Ì | S | s | | 2 | 12 | Ar ML) <sub>M</sub> | [1 | ı | 1 | 1 | | 5 | | iesrch | | 10 101 001 | | ĺ | | l | | i | l | , , | | BC <sub>R</sub> —1→BC <sub>R</sub> | ĺ | _ | | _ | | | | eta . | | 1 | | | | | | | } | 1 . 1 | | HLR-1-HLR | Ι. | 2 | | Œ | | _ | | | CPOR | 11 101 101 | 1 | | | 1 | 5 | s | | 2 | 14 | BCR#O Ar# HUM | 1 | 1 | ı | ı | | 5 | | | i | 10 111 001 | | 1 | ļ | | | | | | 12 | BCn=0 or Ar= HLh | 1 | | | | | | | | 1 | | | 1 | | | 1 | 1 | | | | Ar- HLh | 1 | | | | | | | | | | | | 1 | 1 | | ĺ | | | | Q BC <sub>R</sub> −1→BC <sub>R</sub> | | | | | | | | | | | | ł | ĺ | | ļ | | | | | LHLg-1→HLg | | | | | | | | | 1 | | | | 1 | 1 | 1 | 1 | | | | Repeat Q until | 1 | _ | | G | | | | | | | | | | i | | l | ĺ | | | Ar= HL) <sub>M</sub> or BC <sub>R</sub> =0 | ١. | 2 | | _ | | _ | | | CPI | 11 101 101 | | 1 | | ļ | s | s | | 2 | 12 | Ar- HL)M | 1 | I | ı | | | 5 | | | | 10 100 001 | | i . | | 1 | | | İ | | | BC <sub>R</sub> -1-BC <sub>R</sub> | 1 | • | | G | | | | | | | | | İ | | | | 1 | 1 | | HLa+1→HLa | 1 | P | ' 1 | ١ | 7 | \$ | | | CPIR | 11 101 101 | | | | | S | s | | 2 | 14 | BCR≠Q Ar≠#UM | 1 | | | | | | | | İ | 10 110 001 | | 1 | | | 1 | | 1 | | 12 | BCR=0 or Ar≠ HLhu<br>□ Ar- HLhu | 1 | | | | | | | | | 1 | | | 1 | | Ì | | ! | ] | 1 | Q 8Cg-1-8Cg | 1 | | | | | | | | 1 | | 1 | | | | | | | 1 | | Higt 1Hig | 1 | | | | | | | | | | | | | - | | | | | } | Repeat Q until | 1 | | | | | | | | | 1 | 1 | 1 | 1 | 1 | 1 | , | i | i | | Ar= OLIM or BCn=0 | | | | 0 | D | | | | LDO | 11 101 101 | | | 1 | | S/D | | | 2 | 12 | HUM-DEM | 1. | | F | 1 | t | A | | | 1000 | 10 101 000 | | ĺ | ĺ | i i | | | | 1 | ļ | 9C <sub>R</sub> -1-8C <sub>R</sub> | 1 | | | | | | | | | 10.00 | 1 | | | | 1 | 1 | | | | DER-1-DER | 1 | | | | | | | | ì | | | ì | Ì | 1 | | | | 1 | | HLa-1-HLa | | | | | | | | | LDOR | 11 101 101 | | | | | \$/0 | i | | 1 2 | 14BCe≠0 | FHU DE | ١. | | , | | R | R | | | LDOR | 10 111 000 | 1 | | | | 1 | | | - | 12@Ce=0 | Q 8Cn-1-8Cn | ŀ | | | | | | | | | 10 111 000 | ı | | | 1 | 1 | 1 | | 1 | | DEn1DEn | | | | | | | | | Į. | | | | | 1 | 1 | | 1 | | | LHA-1→HA | | | | | | | | | ï | ] | | 1 | 1 | | | 1 | 1 | | | Repeat Q until | | | | | | | | | | | | | 1 | ì | ĺ | | Ì | | | BC <sub>R</sub> =0 | | | | ( | D | | | | LDH | 11 101 101 | | | | 1 | S/D | į | | 2 | 12 | HLM-DEM | ١. | | | A . | | R | | | 5 | 10 100 000 | | 1 | 1 | 1 | | | | - | i - | BCn-1-BCn | | | | | | | | | | 10 100 000 | | İ | 1 | | | 1 | | | | DEn+1-DEn | | | | | | | | | | Ì | 1 | | 1 | | 1 | 1 | 1 | 1 | ļ. | Ha+1-Ha | 1 | | | | | | | | LDIR | 11 101 101 | 1 | | 1 | | S/0 | | | 1 2 | 14(BC <sub>R</sub> ≠0) | F HLIM - DEM | . | | - | A | R | R | | | "" | 10 110 000 | 1 | | | 1 | | | ļ | | 1209Cn=0 | 1 1 " " | | | | | | | | | | 100 300 | 1 | 1 | 1 | - | ] | 1 | 1 | | " " | DEn+1DEn | | | | | | | | | | | 1 | | 1 | | | | | | | HRR+1-HLR | | | | | | | | | | | 1 | | 1 | | | | | | 1 | Repeat Q until | 1 | | | | | | | | | | 1 | | 1 | 1 | | | 1 | | | BC <sub>R</sub> =0 | | | | | | | <sup>1)</sup> P/V=0 : BC+-1=0 P/V=1:BC<sub>R</sub>-1# # HD64180R/Z # Stack and Exchange | | | | | | | ddressir | _ | | | | | | L | | F | leg | | | |-----------|------------|------------|----------|-----|----|----------|------|------|-----|-------|--------|-----------------------------------|-----|---|---|-----|-----|-----| | Operation | MNEMONICS | OP-code | L | | | | • | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | | | | | | IMMED | EXT | ND | REG | REGI | MP | REL | | | | s | z | н | P۸ | / N | · _ | | PUSH | PUSH zz | 11 zz0 101 | | | | s | | D | | 1 | 11 | zzi.r-(SP - 2) <sub>M</sub> | | | | | | | | | | | | | | | | | | | | zzHr(SP-1)M | | | | | | | | | | | | | 1 | | | | 1 | | | SPR-2-SPR | - | | | | | | | | PUSH IX | 11 011 101 | | | | | İ | S/D | 1 | 2 | 14 | IXLr→(SP-2) <sub>M</sub> | - | | ٠ | | | | | | | 11 100 101 | | | ŀ | | ļ | | i | | | IXHr-(SP-1) <sub>M</sub> | | | | | | | | | | į | | | | | İ | | | | | SPR-2→SPR | | | | | | | | | PUSH IY | 11 111 101 | | | | | ļ | S/0 | | 2 | 14 | IYLr-ISP-2h | · . | | | | | | | | | 11 100 101 | | ļ | | | ŀ | | | | | IYHr→ISP 1) <sub>M</sub> | - | | | | | | | | | | <u>l</u> | | | | | | | | | SPR-2-SPR | 1 | | | | | | | POP | POP 22 | 11 zz0 001 | T | | - | D | | s | | 1 | 9 | (SP+1) <sub>M</sub> -zzHr | 7. | | | | | _ | | | | | | | | | | | | | | (SP) <sub>M</sub> →zzLr | - | | | | | | | | | | | | | 1 | | | | | | SPR+2-SPR | | | | | | | | | POP IX | 11 011 101 | 1 | | | | i | S/D | | 2 | 12 | (SP+1) <sub>M</sub> -D(Hr | 1. | | | | | | | | | 11 100 001 | | | | | | | | l i | | (SP) <sub>M</sub> —IXU | ļ | | | | | | | | | | | | | | | 1 | | | | SPR+2→SPR | | | | | | | | | POP IY | 11 111 101 | | | | | | \$/D | | 2 | 12 | (SP+1ha-IYHr | . | | | | , | | | | | 11 100 001 | | | | | | | | | | (SP) <sub>M</sub> YLr | | | | | | | | _ | 1 | | | | | | | | | | | SPR+ 2-SPR | | | | | | | | xchange | EX AF,AF | 00 001 000 | | | | | | \$/D | | 1 | 4 | AFRAFR' | 7. | | | | | _ | | | EX DE,HL | 11 101 011 | | | | 1 | | S/D | | ۱ ، ا | 3 | DERHLA | . | | | | | | | | EXX | 11 011 001 | | | | | | S/D | | ١ ، | 3 | BC <sub>R</sub> BC <sub>R</sub> ' | . | | | | | | | | | | | | | | | | | 1 | | DERDER | | | | | | | | | | | | | | i | | | | | | HLAHLA' | | | | | | | | | EX (SP),HL | 11 100 011 | | | | l | | S/O | | 1 | 16 | Hr(SP+1) | . | | | | | | | | | | | | | ľ | | | | | | Lr (SP) <sub>M</sub> | | | | | | | | | EX (SP),IX | 11 011 101 | | | | | | S/D | | 2 | 19 | IXHr (SP+ 1)M | 1. | | | | | | | | | 11 100 011 | i i | | | | | | | | | DKLr (SP)M | | | | | | | | | EX (SP),IY | 11 111 101 | | | | | | S/D | , | 2 | 19 | IYHr (SP+1)M | 1. | | | | | | | | "" | 11 100 011 | | | | 1 | | | | | | IYL(SP) | | | | | | | # **Program Control Instructions** | | | | | | | drawin | | | | | | | <u> </u> | | Fle | _ | _ | _ | |----------------|--------------------|-------------------|-------------|-----|--------------|--------|------|-----|-----|----------|--------------|------------------------------------------|----------|---|--------|---|---|---| | Operation name | MINEMONICS | OP-code | | | | | | MP | REL | Bytes | States | Operation | - | | 4<br>H | | _ | 0 | | | <u> </u> | <u> </u> | MMED | EXT | NO | REG | REGI | | MEL | 3 | 16 | PCHr(SP1) <sub>M</sub> | • | ÷ | | | | _ | | • | CALL mn | 11 001 101 | | D | | | | | | ' | 10 | PCLr-(SP - 2) <sub>M</sub> | | | | | | | | | | < n > | 1 | | | | | Ì | | | | mn PCa | 1 | | | | | | | | 1 | < m > | | | | | | | | | | SP <sub>H</sub> -2-SP <sub>H</sub> | | | | | | | | | 1 | | ļ | D | | | ļ | | | 3 | 6if : false) | continue:f is false | ١. | | | | | | | | CALL f, mn | 11 f 100<br>< n > | 1 | " | | | | | | | 166 : sue) | CALL mn:f is true | | | | | | | | | | < n > < m > | } | | | | ļ | 1 | 1 | | | | | | | | | | | | 1 | ` " | 1 | | Ì | | | ļ | | | | | Ì | | | | | | | | <del> </del> | | <del></del> | ├ | <del> </del> | | - | ├ | 0 | 2 | 9 (8-≠0) | | †- | | | _ | | _ | | ump | DJNZ j | 00 010 000 | | | İ | | ļ | ì | - | 2 | 7 (Br≖0) | | 1 | | | | | | | | ļ | < j-2 > | 1 | ] | | l | | ļ | 1 | ` | ļ | Br 1Br | | | | | | | | | | İ | } | 1 | | 1 | l | | 1 | | | continue:Br=0 | [ | | | | | | | | | ļ | | l | 1 | | ļ | 1 | ì | | Ì | PCa+j-PCa®r≠0 | 1 | | | | | | | | | | 1 | | 1 | 1 | l | 1 | ļ | ١. | | | 1. | | | | | | | | JP f, mn | 11 1 010 | | D | | 1 | 1 | | 1 | 3 | 6 tf :false) | | | | | | | | | | | < n > | 1 | 1 | 1 | | ļ | | 1 | 3 | 9 (f : true) | mn-PC <sub>R</sub> :f is true | 1 | | | | | | | | | < m > | 1 | | ļ | | | | Į | | <b>\</b> | continue:f is false | | | | | | | | | | 1 | | 1 | İ | | Į. | 1 | | 1 | 1 | 1 | | | | | | | | | | 1 | | | ŀ | l | ŀ | | 1 | | | <b>\</b> | ļ | | | | | | | | \ _ | 11 000 011 | 1 | D | 1 | 1 | ļ | 1 | | 3 | | mn-PC <sub>R</sub> | ١. | | | | | | | | JP mn | 1 | | , " | 1 | | İ | | 1 | | | | Ì | | | | | | | | 1 | < n > | 1 | 1 | 1 | 1 | | | | | | | 1 | | | | | | | | | 11 101 001 | | 1 | | | ) b | | 1 | ١, | 3 | HLAPCA | . | | | | | | | | JP (ML)<br>JP (DC) | 11 011 101 | | | 1 | 1 | D | i | 1 | 2 | 6 | IX <sub>R</sub> →PC <sub>R</sub> | - - | | | | | | | | | 11 101 001 | | 1 | 1 | 1 | | | 1 | | į . | 1 | -1 | | | | | | | | Je im | 11 111 101 | ı | 1 | | 1 | ь | 1 | ı | 2 | 6 | N <sub>R</sub> →PC <sub>R</sub> | . | | | | ٠ | | | | J | 11 101 001 | 1 | 1 | | | 1 | 1 | 1 | 1 | | | - | | | | | | | | ز جد | 00 011 000 | 1 | 1 | 1 | Į. | | | 0 | 2 | 8 | PC <sub>R</sub> +j→PC <sub>R</sub> | 1. | • | • | • | | | | | , | < j-2 > | | 1 | | 1 | 1 | | 1 | | | | -) | | | | | | | | JR C.j | 00 111 000 | 1 | 1 | 1 | | | 1 | 0 | 2 | 6 | continue: C=0 | ١. | • | • | | • | | | | 1 . | < j-2 > | | | | 1 | 1 | 1 | 1 | 2 | 8 | PC <sub>R</sub> +j→PC <sub>R</sub> : C=1 | - | | | | | | | | ì | \ | | | 1 | ļ | | 1 | 1 | | 1 | | | | | | | | | | JR NCj | 00 110 000 | ĺ | ı | | | | 1 | P | 2 | • | continue: C=1 | Ι. | • | • | | • | | | | | < j-2 > | 1 | l | 1 | 1 | | ļ | | 2 | | PC <sub>R</sub> +j→PC <sub>R</sub> : C=0 | | | | | | | | | | Ì | | | - | | | | 1. | ١. | | continue: Z=0 | ١. | | | | | | | | JR Zj | 00 101 000 | - 1 | - | ì | 1 | | 1 | P | 2 2 | , a | PCn+jPCn: Z=1 | | | | | | | | | ļ | < j-2 > | 1 | ĺ | | | | | 1 | 1 | • | rait product | | | | | | | | | | | | | 1 | 1 | | | ۱. | 2 | | continue: Z= 1 | ١. | | | | | | | | JR NZ.j | 00 100 000 | 1 | | | | | | ١٠ | 2 | | PCa+j-PCa: Z=0 | | | | | | | | | | < j-2 > | ` | 1 | l_ | i | 1_ | | | <u> </u> | ļ | | 4 | | | | | _ | | | | | | Т | | Ţ | | Ь | | ١, | , | (SPI <sub>M</sub> →PCLr | 1 | | | | | | | Return | RET | 11 001 001 | | - | 1 | | | " | - | 1. | | (SP+1) <sub>M</sub> -PCHr | - [ | | | | | | | | 1 | | - } | | Į | | 1 | - 1 | 1 | | 1 | SPR+2-SPR | | | | | | | | | l | 11 1 000 | | | | 1 | | ١٥ | | ١, | 5ff :falsel | continue:f is false | ]. | | | | | | | | RET f | ''' 300 | . | - | | | 1 | | | , | 10ff :trust | RET: f is true | | | | | | | | | | | ı | | 1 | i | | | | | | 1 | | | | | | | | | RETI | 11 101 101 | | - | | | | ٥ | 1 | 2 | 12 | (SPI <sub>M</sub> -→PCLr | | | | | | | | 1 | <b>"</b> " | 01 001 101 | - 1 | - [ | 1 | | | - [ | - | | 1 | (SP+1) <sub>M</sub> PCHr | | | | | | | | l | | 100 | ļ | l | | - | 1 | - 1 | 1 | 1 | | SPR+ 2-SPR | | | | | | | | İ | | | . | | | | | | . | 2 | 12 | (SP) <sub>M</sub> PCLr | | | | | | • | | ļ | RETN | 01 000 101 | - 1 | - | | | 1 | 1 | | | | (SP+ 1) <sub>M</sub> →PCHr | | | | | | | | 1 | 1 | 01 000 101 | ' | | 1 | - | - | - } | 1 | | 1 | SPR+2→SPR | - 1 | | | | | | | ļ | | 1 | | 1 | | | | | | Į. | 1 | EF₂→EF· | ļ | | | | | | | 1 | 1 | 1 | - 1 | 1 | - 1 | - 1 | - 1 | t | - 1 | 1 | 1 | 1 | - 1 | | | | | | # HD64180R/Z | Operation | MNEMONICS | OP-code | | | | ddressir | 9 | | | Bytes | States | Operation | 7 | 6 | | 2 | 1 | 0 | |-----------|-----------|----------|------|-----|-----|----------|------|----|------|-------|--------|-------------------------------------------------------------------------------------------------------------------|----|---|---|-----|---|---| | neme | | | MMED | EXT | IND | REG | REGI | MP | REL. | Ì | | | \$ | z | н | P/V | N | С | | Restart | RST v | 11 v 111 | | | | | | D | | 1 | 11 | PCHr—SP = 11 <sub>M</sub><br>PCLr—SP = 21 <sub>M</sub><br>O—PCHr<br>v—PCLr<br>SP <sub>R</sub> = 2—SP <sub>R</sub> | | | ٠ | • | | | ### I/O Instructions | | | | | | | | _ | | | | | | | | F | leg | | | |----------------|------------|-------------|----------|-----|-----|----------|------|-----|---|-------|------------|-------------------------------------|----------------|---|---|-----|----------|---| | Operation name | MINEMONICS | OP-code | <u> </u> | | | ddressin | | | | Bytes | States | Operation | ⊢ | | | 2 | | | | | <u> </u> | | IMMED | EXT | IND | REG | REGI | MP | ю | | | | s | Z | н | PΛ | N | С | | INPUT | N A.m) | 11 011 011 | | | | | | D | s | 2 | 9 | (AmiyAr | | | ٠ | | | | | | | < m > | | ł | | | | l | | | | m—A₀~-A₁ | | | | | | | | į | İ | - | | | | | | | | | | A-A-A- | | | | | | | | | IN g.(C) | 11 101 101 | | | | D | | | 5 | 2 | 9 | (BC) <sub>t</sub> gr | ı | 1 | R | Р | A | , | | | | 01 g 000 | | | 1 | 1 | | | | | | g=110. Only the | | | | | | | | | | t | | | İ | | | | | | | flags will | | | | | | | | | | | | | l | | | | | | | change. | | | | | | | | 1 | 1 | | | | | | | | | ŀ | | Cr-Ao-A | | | | | | | | 1 | | ľ | | | • | | | İ | | | | Br→Ae~Ais | l | | | | | | | ŀ | INO g.(m) | 11 101 101 | ì | | | D | | | s | 3 | 12 | (00mk→gr | 1 | 1 | R | P | R | ٠ | | | | ∞ g 000 | 1 | | | | | | | | | g=110: Only the | | | | | | | | | | < m > | | ĺ | | | | | | | | flegs will | i | | | | | | | | ł | | | | | | | | | | | change. | | | | | | | | | | | | | | | | | | | | m→Ao~-A7 | | | | | | | | | | Ī | | | | | | | | | | 00-A <sub>0</sub> -A <sub>1</sub> , | | 3 | | | ⊚ | | | | ND | 11 101 101 | | | ] | | ٥ | | S | 2 | 12 | (BC) OHUM | × | ī | X | × | 1 | × | | | | 10 101 010 | 1 : | | Ì | | | | | | | HLa 1-HLa | | | | | | | | | | | | | | | | | | | | 8r-1→8r | | | | | | | | | l | | | | | | | | | 1 | | Cr-Ao-Ar | | | | | | | | | 1 | | | | | | | | | | | BAs~-Ais | ĺ | | | | • | , | | | INDR | 11 101 101 | | | | | D | | S | 2 | 14(Br≠0) | (BC)( HL) <sub>M</sub> | × | s | X | × | 1 | × | | | | 10 111 010 | l | | | | | | | | 12 (Br=0) | a HLa-1-HLa | | | | | | | | | | | | | | | į | | | | | _Br1→Br | | | | | | | | 1 | | ļ | | | | | | | | | | Repeat Q until | | | | | | | | | | 1 | | | | | | i | | | | Br= 0 | | | | | | | | | | , | 1 | | | | | | | | | Cr-Ao-Ar | | | | | | | | l | | | 1 1 | | | | | | | | | Br→As~-Ass | | | | | | | | | i | | i l | | | | | | | | | | | 3 | | | (1) | | | | N | 11 101 101 | | | | | D | | s | 2 | 12 | (BC),→ HU <sub>M</sub> | | | | x | | | | ĺ | | 10 100 010 | | | | | | | | | | Hta+1→HLa | | ٠ | | | ٠ | | | l | ŀ | <u> </u> | | | | | | | | | | Br- 1 → Br | | | | | | | | | <b>\</b> | 1 | | | | | ı | ] | | 1 | | Cr-Ao-Ar | | | | | | | | | 1 | | | | | | | - 1 | | | | B-As-Ass | | | | | <b>@</b> | | | | NR | 11 101 101 | | | | i | 0 | 1 | s | 2 | 14(Br≠0) | Fact HUM | l <sub>x</sub> | s | x | x | | | | | | 10 110 010 | | | | | | | | | 12.69r≔ Oi | Q HLa+1-HLa | Ι. | • | ^ | ^ | • | ^ | | | | | | | | | | | | | | Br−1→Br | | | | | | i | | | | 1 | | | | l | | | | | | Repeat Q until | | | | | | | | | | | | | | | | | | | | Br=0 | | | | | | | | | | | | | | | - 1 | - 1 | | | | Cr→A <sub>0</sub> ~A <sub>7</sub> | | | | | | | | | | | l i | | 1 | - 1 | | - 1 | | | | Br-As-Ais | | | | | | | | | | <del></del> | | | | | | | | | | | | | _ | | | | <sup>3</sup> Z=1:8-1=0 Z=0:8-1≠0 4 N=1:MS8 of Deta=1 N=0:MS8 of Deta=0 | | Ι – – – | | | | | | | | | | | | 1 | | F | •6 | | ļ | |-----------|------------|------------|-------|-----|-----|-----------|------|-----|--------------|-------|----------------------|------------------------|-------|-----|-----|-----|-----|-----| | Operation | MINEMONICS | OP-code | | | • | kidressin | • | | | Bytes | States | Operation | | 6 | | | | 0 | | NUTTE | 1 | | IMMED | EXT | IND | REG | REGI | MP | ю | | | | +- | Z | | | _ | С | | OUTPUT | OUT (m),A | 11 010 011 | T | | | | | s | D | 2 | 10 | Ar (Arn) <sub>1</sub> | 1. | • | • | • | • | • | | | | < m > | | | | | | | | | | m—Ao—Ar | | | | | | | | | | | 1 | ļ | ĺ | | 1 | | | | | Ar-As-Ass<br>gr-(BC) | ١. | | | | | | | | OUT (C),g | 11 101 101 | | | | S | | | P | 2 | 10 | Cr-Ao-A | | | | | | | | | | 01 g 001 | | | | 1 | | 1 | 1 | | | Br-As-As | | | | | | | | | i | 1 | | 1 | 1 | ١. | 1 | | <sub>D</sub> | 3 | 13 | gr (OOm) | | | | | | | | | OUTO (m),g | 11 101 101 | | İ | ļ | S | ľ | ļ | ١ | , | | m—Ao∼A7 | 1 | | | | | | | | | 00 g 001 | | 1 | | | 1 | | | | | 00-As-Ass | Ì | 3 | | | • | j. | | | | < m > | | 1 | i | 1 | s | | ь | 2 | 14 | (HUM-100Ch | 1 | 1 | ı | P | 1 | 1 | | | ОТОМ | 11 101 101 | | 1 | | l | " | ļ | - | | | HLA-1-HLA | ļ | | | | | | | | | 10 001 011 | | | 1 | | 1 | i i | | ļ | 1 | Cr- 1Cr | | | | | | | | | 1 | | 1 | | | 1 | 1 | | l | | 1 | Br 1Br | | | | | | | | | | | 1 | 1 | | 1 | | | ļ | | 1 | Cr→Ao~A7 | | | | | _ | | | | | 1 | | 1 | | | | 1 | | | ì | 00-As~A15 | | | | | € | | | | | 11 101 101 | 1 | | | | s | 1 | Ь | 2 | 16(Br≠0) | F HLIM-HOOCK | Я | 5 | R | s | 1 | R | | | OTDMR | 10 011 011 | 1 | | 1 | 1 | | | | | 148r=0 | Q HLe-1-HLe | Ì | | | | | | | | | 100 0 | 1 | | | ŀ | 1 | 1 | | | | Cr 1Cr | 1 | | | | | | | | 1 | Į. | ì | | 1 | - | 1 | 1 | 1 | | 1 | _Br−1→Br | 1 | | | | | | | | | | 1 | 1 | 1 | | 1 | 1 | 1 | 1 | İ | Repeat Q until | | | | | | | | | | Į | ļ | 1 | 1 | 1 | 1 | | 1 | 1 | İ | <del>Br</del> ≖0 | | | | | | | | l | ì | Į. | 1 | ì | 1 | 1 | 1 | 1 | | | 1 | CrAoAr | - | | | | | | | | <b>\</b> | ļ | | 1 | 1 | Į. | | 1 | 1 | 1 | 1 | 00→As~A:s | | | | | _ | | | | 1 | - | 1 | 1 | 1 | | ١ | 1 | | 1 2 | | F | ١. | | . , | . , | (G | | | | ОТОЯ | 11 101 101 | 1 | 1 | 1 | - [ | S | 1 | ١٠ | 1 ' | 1489r≠0)<br>1269r=0) | 0 HLa-1→HLa | - ^ | • | , , | • | ` ' | • | | | 1 | 10 111 011 | 1 | 1 | 1 | | 1 | 1 | ì | | 12487—07 | Br-1-Br | | | | | | | | | } | 1 | 1 | İ | | l | ŀ | 1 | 1 | - | 1 | Repest Q until | - | | | | | | | | | | 1 | 1 | | | 1 | | | - | | Br=0 | | | | | | | | | | 1 | 1 | 1 | | ŀ | | 1 | | | | Cr→Ao~Ar | | | | | | | | 1 | l | 1 | | | - ] | 1 | 1 | | | | | Br-As-As | | _ | | | _ | _ | | i | | l l | 1 | i | | | 1. | | ١ | 2 | 12 | #HJMBCh | Ι. | . @ | 9 | v | , e | 9 | | | ουπ | 11 101 101 | | 1 | | | s | | " | ' | 12 | HLR+1-HLR | - 11 | ٠, | | ^ | ^ | ' ' | | | | 10 100 011 | ļ | | | ĺ | | | 1 | 1 | | Br~1-Br | - 1 | | | | | | | 1 | İ | İ | - 1 | - | | | | | ĺ | | | Cr-Ao-Ar | | | | | | | | 1 | | | | - 1 | Ì | | | | | | 1 | Br-As~Ais | - 1 | | | | ( | 3 | | | | | - | | | - [ | s | | ٥ | 2 | 14(Br≠0) | FHU <sub>M</sub> —BCh | ١, | | s | х | × | _ | | 1 | опя | 11 101 101 | 1 | - | | | " | - | - | - | 12(Br=0) | Q Ha+1-Ha | | | | | | | | | 1 | 10 110 011 | i | | - | | 1 | - | | | | Br 1→Br | | | | | | | | 1 | | 1 | - 1 | | 1 | | | | | | | Repeat Q until | | | | | | | | | | | - 1 | 1 | | | | 1 | | | | Br=0 | | | | | | | | | | | | | | -1 | - 1 | ĺ | | | | Cr-Ao-A | | | | | | | | | | | | | | | | | | - | | Br-As-As | | | | | | | | | TSTIO m | 11 101 10 | s | | | | 1 | Ì | s | 3 | 12 | (00C) <sub>(</sub> · m | - 1 | ı | ı | s | P | R | | | 1310 111 | 01 110 100 | - 1 | | - | | j | | ľ | - | | Cr→Ao~Ar | | | | | | | | 1 | 1 | 101 7.0 | , , | - 1 | - 1 | 1 | | - 1 | 1 | | 1 | | | | | | | | <sup>3</sup> Z=1:8r-1=0 Z=0:8r-1=0 (A) N=1:MS8 of Deta=1 N=0:MS8 of Deta=0 | Operation | MARACNICS | OP-code | | | , | ddressir | • | | | Bytes | States | Operation | 7 | | | leg<br>2 | 1 | • | |-----------|------------|--------------------------|------|-----|-----|----------|------|-----|---|-------|----------------------|------------------------------------------------------------------------------|----------|---|---|----------|------------|---| | nerne | MINEMONICS | OF-8888 | MMED | EXT | IND | REG | REGI | IMP | ю | | | | $\vdash$ | | | | / N | _ | | OUTPUT | отм | 11 101 101<br>10 000 011 | | | | | s | | D | 2 | 14 | 84Lhr-400Ch<br>Hla+1-Hla<br>Cr+1Cr | 1 | 3 | | P | <b>@</b> ! | | | | OTIMR | 11 101 101 10 011 | | | | | s | | Đ | 2 | 15(Br≠0)<br>14(Br=0) | B1Br CAoAr OOAsArs H-AH-H-A Cr+1Cr B1Br | R | s | R | s | 1 | | | | очто | 11 101 101<br>10 101 011 | | | | | S | | D | 2 | 12 | Breet Q until Br= Q Cr=Aa=Ar OO—Aa=Ars PALha=BCh HAa=1=HAa Br=1=Br Cr=Aa=Ars | x | 3 | | . х | 3 1 | | | | | | | | | | | | | | | | | | | | | | <sup>3</sup> Z=1:Br-1=0 Z=0:Br-1=0 4 N=1:MSB of Deta= ### **Special Control Instructions** | | | | | | | | | | | | | | | | PI | <b>e</b> g | | | |-----------|------------|------------|------|----------------------------------------|----|----------|------|----------------------------------------|----------|----------|--------|-----------------|----|---|----|------------|---|---| | Operation | MINEMONICS | OP-code | | | • | ddresein | 9 | | | Bytes | States | Operation | 7 | 6 | 4 | 2 | 1 | 0 | | neme | ! | | MMED | EXT | ND | REG | REGI | MP | REL | | | | s | z | н | P/V | N | С | | Special | DAA | 00 100 111 | | | | | | 5/0 | | 1 | 4 | Decimal | 1 | 1 | 1 | P | ٠ | 1 | | Function | | | | Į | | | | | | | ļ | Adjust | ļ | | | | | | | | | | | | | L | L., | | <u> </u> | <u> </u> | | Accumulator | ↓_ | | | | | | | Сату | CCF | 00 111 111 | | | | | | | | 1 | 3 | ē⊒c | ŀ | ٠ | R | ٠ | R | ŧ | | Control | SCF | 00 110 111 | | | | l | | <u> </u> | | 1 | 3 | 1c | ŀ | • | R | ٠ | R | 5 | | CPU CPU | DI | 11 110 011 | | | | | | | | , | 3 | 01EF+, 01EF+ (§ | | | | | | | | Control | 8 | 11 111 011 | | | | | 1 | | | ١, | 3 | 1→8F1, 1→8F1 ⑤ | - | | | ٠ | | | | | HALT | 01 110 110 | | l | | İ | İ | 1 | | 1 | 3 | CPU halted | 1. | • | • | | ٠ | ٠ | | | Mo | 11 101 101 | | ļ | | | | | | 2 | 6 | Interrupt | | ٠ | | | | ٠ | | | | 01 000 110 | | 1 | | | 1 | | | 1 | | mode 0 | | | | | | | | | M 1 | 11 101 101 | | l | 1 | 1 | İ | | | 2 | 6 | interrupt | 1 | • | | • | ٠ | | | | | 01 010 110 | | | | İ | | | | | | mode 1 | | | | | | | | | M 2 | 11 101 101 | | | | | | | | 2 | • | Interrupt | 1. | ٠ | • | • | | • | | | | 01 011 110 | 1 | | | | | | | | | mode 2 | 1 | | | | | | | | NOP | 00 000 000 | | | | | 1 | | 1 | 1 | 3 | No operation | | ٠ | • | • | | • | | | SLP | 11 101 101 | | 1 | | | i | 1 | | 2 | 8 | Sleep | 1 | • | • | • | • | • | | | | 01 110 110 | | | | İ | 1 | 1 | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | İ | | | | 1 | j | 1 | | | - | | | | 1 | | | | | | | L | <u> </u> | <u> </u> | Ь | ــــــــــــــــــــــــــــــــــــــ | | 1 | Ь | ــــــــــــــــــــــــــــــــــــــ | 1 | | | | _ | _ | _ | _ | | | <sup>(5)</sup> Interrupts are not sampled at the end of DI or El. # 20 INSTRUCTION SUMMARY IN ALPHABETICAL ORDER | MNEMONICS | Bytes | Machine Cycles | States | |---------------|-------|----------------|-------------------------| | ADC A,m | 2 | 2 | 6 | | ADC A.g | 1 | 2 | 4 | | ADC A, (HL) | 1 | 2 | 6 | | ADC A, (IX+d) | 3 | 6 | 14 | | ADC A, (IY+d) | 3 | 6 | 14 | | ADD A,m | 2 | 2 | 6 | | ADD A.g | 1 | 2 | 4 | | ADD A, (HL) | 1 | 2 | 6 | | ADD A, (IX+d) | 3 | 6 | 14 | | ADD A, (IY+d) | 3 | 6 | 14 | | ADC HLww | 2 | 6 | 10 | | ADD HL,ww | 1 | 5 | 7 | | ADD IX,xx | 2 | 6 | 10 | | ADD IY,yy | 2 | 6 | 10 | | AND m | 2 | 2 | 6 | | AND g | 1 | 2 | 4 | | AND (HL) | 1 | 2 | 6 | | AND (X+d) | 3 | 6 | 14 | | AND (IY+d) | 3 | 6 | 14 | | BIT b, (HL) | 2 | 3 | 9 | | BIT b, (IX+d) | 4 | 5 | 15 | | BIT b, (1Y+d) | 4 | 5 | 15 | | BIT b,g | 2 | 2 | 6 | | CALL f.mn | 3 | 2 | 6 | | | | | (If condition is false) | | | 3 | 6 | 16 | | | _ | | (If condition is true) | | MNEMONICS | Bytes | Machine Cycles | States | |------------|-------|----------------|---------------------------------------------------| | CALL mn | 3 | 6 | 16 | | CCF | 1 | 1 | 3 | | CPD | 2 | 6 | 12 | | CPDR | 2 | 8 | 14 | | | | | (If BC <sub>R</sub> ≠0 and Ar≠(HL) <sub>M</sub> ) | | | 2 | 6 | 12 | | | | | (If BC <sub>R</sub> =0 or Ar=(HL) <sub>M</sub> ) | | CP (HL) | 1 | 2 | 6 | | СРІ | 2 | 6 | 12 | | CPIR | 2 | 8 | 14 | | | | | (If BC <sub>R</sub> ≠0 and Ar≠(HL) <sub>M</sub> ) | | | 2 | 6 | 12 | | | | | (If BC <sub>R</sub> =0 or Ar=(HL) <sub>M</sub> ) | | CP (IX+d) | 3 | 6 | 14 | | CP (TY+d) | 3 | 6 | 14 | | CPL | 1 | 1 | 3 | | CP m | 2 | 2 | 6 | | CP g | 1 | 2 | 4 | | DAA | 1 | 2 | 4 | | DEC (HL) | 1 | 4 | 10 | | DEC IX | 2 | 3 | 7 | | DEC IY | 2 | 3 | 7 | | DEC (IX+d) | 3 | 8 | 18 | | DEC (Y+d) | 3 | 8 | 18 | | DEC g | 1 | 2 | 4 | | DEC ww | 1 | 2 | 4 | | DI | 1 | 1 | 3 | | MNEMONICS | Bytes | Machine Cycles | States | |------------|-------|----------------|--------------| | DJNZ j | 2 | 5 | 9 (If Br≠0) | | | 2 | 3 | 7 (If Br=0) | | EI | 1 | 1 | 3 | | EX AF,AF' | 1 | 2 | 4 | | EX DE,HL | 1 | 1 | 3 | | EX (SP),HL | 1 | 6 | 16 | | EX (SP),IX | 2 | 7 | 19 | | EX (SP),IY | 2 | 7 | 19 | | EXX | 1 | 1 | 3 | | HALT | 1 | 1 | 3 | | IM O | 2 | 2 | 6 | | IM 1 | 2 | 2 | 6 | | IM 2 | 2 | 2 | 6 | | INC g | 1 | 2 | 4 | | INC (HL) | 1 | 4 | 10 | | INC (IX+d) | 3 | 8 | 18 | | INC (IY+d) | 3 | 8 | 18 | | INC ww | 1 | 2 | 4 | | INC IX | 2 | 3 | 7 | | INC IY | 2 | 3 | 7 | | IN A,(m) | 2 | 3 | 9 | | IN g,(C) | 2 | 3 | 9 | | INI | 2 | 4 | 12 | | INIR | 2 | 6 | 14 (If Br≠0) | | | 2 | 4 | 12 (If Br=0) | | IND | 2 | 4 | 12 | | INDR | 2 | 6 | 14 (lf Br≠0) | | MNEMONICS | Bytes | Machine Cycles | States | |-----------|-------|----------------|-------------------------| | INDR | 2 | 4 | 12 (If Br=0) | | INO g.(m) | 3 | 4 | 12 | | JP f,mn | 3 | 2 | 6 | | | | | (If f is false) | | | 3 | 3 | 9 | | | | | (If f is true) | | JP (HL) | 1 | 1 | 3 | | JP (IX) | 2 | 2 | 6 | | JP (IY) | 2 | 2 | 6 | | JP mn | 3 | 3 | 9 | | JR j | 2 | 4 | 8 | | JR C,j | 2 | 2 | 6 | | | | | (If condition is false) | | | 2 | 4 | 8 | | | | | (If condition is true) | | JR NC.j | 2 | 2 | 6 | | | | | (If condition is false) | | | 2 | 4 | 8 | | | | | (If condition is true) | | JR Z,j | 2 | 2 | 6 | | | | | (If condition is false) | | | 2 | 4 | 8 | | | | | (If condition is true) | | JR NZ,j | 2 | 2 | 6 | | | | | (If condition is false) | | | 2 | 4 | 8 | | | | | (If condition is true) | | MNEMONICS | Bytes | Machine Cycles | States | |-------------|-------|----------------|----------------------------| | LD A, (BC) | 1 | 2 | 6 | | LD A, (DE) | 1 | 2 | 6 | | LD A,I | 2 | 2 | 6 | | LD A, (mn) | 3 | 4 | 12 | | LD A,R | 2 | 2 | 6 | | LD (BC),A | 1 | 3 | 7 | | LDD | 2 | 4 | 12 | | LD (DE),A | 1 | 3 | 7 | | LD ww,mn | 3 | 3 | 9 | | LD ww,(mn) | 4 | 6 | 18 | | LDDR | 2 | 6 | 14 (If BC <sub>R</sub> ≠0) | | | 2 | 4 | 12 (If BC <sub>R</sub> =0) | | LD (HL),m | 2 | 3 | 9 | | LD HL,(mn) | 3 | 5 | 15 | | LD (HL),g | 1 | 3 | 7 | | LDI | 2 | 4 | 12 | | LD I,A | 2 | 2 | 6 | | LDIR | 2 | 6 | 14 (If BC <sub>R</sub> ≠0) | | | 2 | 4 | 12 (If BC <sub>R</sub> =0) | | LD IX,mn | 4 | 4 | 12 | | LD IX,(mn) | 4 | 6 | 18 | | LD (IX+d),m | 4 | 5 | 15 | | LD (1X+d),g | 3 | 7 | 15 | | LD IY,mn | 4 | 4 | 12 | | LD IY,(mn) | 4 | 6 | 18 | | LD (IY+d),m | 4 | 5 | 15 | | LD (Y+d),g | 3 | 7 | 15 | | MNEMONICS | Bytes | Machine Cycles | States | |-------------|-------|----------------|--------------| | LD (mn),A | 3 | 5 | 13 | | LD (mn),ww | 4 | 7 | 19 | | LD (mn),HL | 3 | 6 | 16 | | LD (mn),IX | 4 | 7 | 19 | | LD (mn),IY | 4 | 7 | 19 | | LD R,A | 2 | 2 | 6 | | LD g,(HL) | 1 | 2 | 6 | | LD g,(IX+d) | 3 | 6 | 14 | | LD g,(IY+d) | 3 | 6 | 14 | | LD g,m | 2 | 2 | 6 | | LD g.g' | 1 | 2 | 4 | | LD SP,HL | 1 | 2 | 4 | | LD SP,IX | 2 | 3 | 7 | | LD SP,IY | 2 | 3 | 7 | | MLT ww | 2 | 13 | 17 | | NEG | 2 | 2 | 6 | | NOP | 1 | 1 | 3 | | OR (HL) | 1 | 2 | 6 | | OR (IX+d) | 3 | 6 | 14 | | OR (IY+d) | 3 | 6 | 14 | | OR m | 2 | 2 | 6 | | OR g | 1 | 2 | 4 | | ОТОМ | 2 | 6 | 14 | | OTDMR | 2 | 8 | 16 (lf Br≠0) | | | 2 | 6 | 14 (If Br=0) | | OTDR | 2 | 6 | 14 (If Br≠0) | | | 2 | 4 | 12 (If Br=0) | | MNEMONICS | Bytes | Machine Cycles | States | |---------------|-------|----------------|-------------------------| | OTIM | 2 | 6 | 14 | | OTIMR | 2 | 8 | 16 (lf Br≠0) | | | 2 | 6 | 14 (If Br=0) | | OTIR | 2 | 6 | 14 (If Br≠0) | | | 2 | 4 | 12 (If Br=0) | | OUTD | 2 | 4 | 12 | | OUTI | 2 | 4 | 12 | | OUT (m),A | 2 | 4 | 10 | | OUT (C),g | 2 | 4 | 10 | | OUTO (m),g | 3 | 5 | 13 | | POP IX | 2 | 4 | 12 | | POP IY | 2 | 4 | 12 | | POP zz | 1 | 3 | 9 | | PUSH IX | 2 | 6 | 14 | | PUSH IY | 2 | 6 | 14 | | PUSH zz | 1 | 5 | 11 | | RES b,(HL) | 2 | 5 | 13 | | RES b, (IX+d) | 4 | 7 | 19 | | RES b,(IY+d) | 4 | 7 | 19 | | RES b,g | 2 | 3 | 7 | | RET | 1 | 3 | 9 | | RET f | 1 | 3 | 5 | | | | | (If condition is false) | | | 1 | 4 | 10 | | | | | (If condition is true) | | RETI | 2 | 4 | 12 | | RETN | 2 | 4 | 12 | | MNEMONICS | Bytes | Machine Cycles | States | |--------------|-------|----------------|--------| | RLA | 1 | 1 | 3 | | RLCA | 1 | 1 | 3 | | RLC (HL) | 2 | 5 | 13 | | RLC (IX+d) | 4 | 7 | 19 | | RLC (IY+d) | 4 | 7 | 19 | | RLC g | 2 | 3 | 7 | | RLD | 2 | 8 | 16 | | RL (HL) | 2 | 5 | 13 | | RL (IX+d) | 4 | 7 | 19 | | RL (IY+d) | 4 | 7 | 19 | | RL g | 2 | 3 | 7 | | RRA | 1 | 1 | 3 | | RRCA | 1 | 1 | 3 | | RRC (HL) | 2 | 5 | 13 | | RRC (IX+d) | 4 | 7 | 19 | | RRC (IY+d) | 4 | 7 | 19 | | RRC g | 2 | 3 | 7 | | RRD | 2 | 8 | 16 | | RR (HL) | 2 | 5 | 13 | | RR (IX+d) | 4 | 7 | 19 | | RR (IY+d) | 4 | 7 | 19 | | RR g | 2 | 3 | 7 | | RST v | 1 | 5 | 11 | | SBC A,(HL) | 1 | 2 | 6 | | SBC A,(IX+d) | 3 | 6 | 14 | | SBC A,(IY+d) | 3 | 6 | 14 | | SBC A,m | 2 | 2 | 6 | | MNEMONICS | Bytes | Machine Cycles | States | |--------------|-------|----------------|--------| | SBC A,g | 1 | 2 | 4 | | SBC HL,ww | 2 | 6 | 10 | | SCF | 1 | 1 | 3 | | SET b,(HL) | 2 | 5 | 13 | | SET b,(IX+d) | 4 | 7 | 19 | | SET b,(IY+d) | 4 | 7 | 19 | | SET b,g | 2 | 3 | 7 | | SLA (HL) | 2 | 5 | 13 | | SLA (IX+d) | 4 | 7 | 19 | | SLA (IY+d) | 4 | 7 | 19 | | SLA g | 2 | 3 | 7 | | SLP | 2 | 2 | 8 | | SRA (HL) | 2 | 5 | 13 | | SRA (IX+d) | 4 | 7 | 19 | | SRA (IY+d) | 4 | 7 | 19 | | SRA g | 2 | 3 | 7 | | SRL (HL) | 2 | 5 | 13 | | SRL (IX+d) | 4 | 7 | 19 | | SRL (IY+d) | 4 | 7 | 19 | | SRL g | 2 | 3 | 7 | | SUB (HL) | 1 | 2 | 6 | | SUB (IX+d) | 3 | 6 | 14 | | SUB (IY+d) | 3 | 6 | 14 | | SUB m | 2 | 2 | 6 | | SUB g | 1 | 2 | 4 | | TSTIO m | 3 | 4 | 12 | | TST g | 2 | 3 | 7 | | MNEMONICS | Bytes | Machine Cycles | States | |------------|-------|----------------|--------| | TST m | 3 | 3 | 9 | | TST (HL) | 2 | 4 | 10 | | XOR (HL) | 1 | 2 | 6 | | XOR (IX+d) | 3 | 6 | 14 | | XOR (IY+d) | 3 | 6 | 14 | | XOR m | 2 | 2 | 6 | | XOR g | 1 | 2 | 4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Table 18 1st Op-Coole map BC DE HL SP | 21 OP-CODE MAP | _ | | | * | ww (1.0=ALL | =ALL) | | | | | | | | | ш | | L0=0-7 | 7-1 | Γ | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|-----------------------------------------|----|----------|-------------|---------|--------------|----------------|----------|-------------|--------|--------|-------------|----------------|--------|----------|----------|------------------|---------|----| | No. | 00-0 | e bo | O BC | | 28 | B | 呈 | g | | | | | | | | | 90 | - | Ŧ | AF | z | | B 0000 0001 0110 0111 1000 1011 1100 1111 1100 1111 1100 1111 1100 1111 1100 1111 1100 1111 1100 1111 1100 1111 1100 1111 1100 1101 1111 E E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F E F | struct | ion fo | rmat : X | اخ | | | 8 | (L0 <u>=</u> | (2~0: | | | | | | | | ZN | S<br>N | PO | Ь | - | | H | | | | | 8 | ٥ | 1 | ( <u>F</u> | 8 | ٥ | I | (H | į | | | | | _ | - | 爰 | > | | Coto | | | | Т | 0000 | 98 | 0010 | _ | 0100 | | 0110 | 0111 | | 1001 | 1010 | 101 | | _ | | Ξ | | | B 0000 0 NOP DAVZ R NZ | | | /<br>9 | | 0 | - | 2 | 3 | 4 | e<br>S | 8 | 7 | 8 | 6 | ٧ | 60 | ပ | ٥ | E | Ŀ | | | Color 1 | L | 00 | 0000 | 0 | d<br>Q | ZVICO | JR NZ. | IR NC. | | | | | | | | | | RET | į. | | 0 | | D 0010 2 LD (ww), A LD (mn) LD (m) | 上 | O | 1000 | - | | | W, ITIN | | | | | NOTE1) | _ | | | | | РОР | 22 | | | | F 0011 3 1NC www wotes wot | L. | 6 | 0010 | 2 | <u>*</u> | ¥. ₩ | (W) (T) | (m)<br>(D) | | | | | | | | | | JP f, | Œ | | 2 | | F 0011 3 | | 1 | | | ·<br> | | ¥ | ۷. | | | | | | | | | JE III | 3,(14) | ( <del>8</del> ) | ۵ | ო | | H 0100 4 NOTE2 | | ш | 1100 | က | | 2 | ¥ | | _ | .D. g, s | | | 함 | SUB s | AND S | OR s | | ۷. | ₹. | | | | Color 5 | L | I | 0100 | 4 | | NC R | - | WOTE1) | | | | | ø, | | | | | CALL | Ę, | | 4 | | HALT NOTE2 | ( | L | 1010 | 6 | | DEC R | - | NOTE1) | | | | | | | | | | <u>م</u> | Z | | S | | A 0111 7 RLCA RLA DAA SCF RET f | $\Gamma$ | Ê | 0110 | 0 | | .D R. | | NOTE1) | | NOTE2 | | | NOTE2) | NOTE2) | NOTE2) | NOTE2) | ADD A.m. | SUB m | E Q | E. | 6 | | B 1000 8 EWF./F JR j JR Z j JR G, j Rest of the length o | 1_ | 4 | 0111 | 7 | RLCA | ALA<br>A | DAA | SOF | <br> <br> <br> | !<br>! | 1 | | <br> | | | | | RST | > | | 7 | | C 1001 9 ADD HL, www LD HL LD A, (mn) | IH. | 8 | 1000 | œ | EWF. AF | JR. | JR Z.i | R<br>C | | | | | | | | | | RET | - | | æ | | D 1010 A LD A, (ww) LD HL LD A, (mn) | <u> </u> | ပ | 180 | 0 | L | ADD I | IL, ww | | | | | | | | | | RET | ž | <u> </u> | 95<br>O | o, | | Marcol Colored Color | | 0 | 1010 | ⋖ | _ | (MM) | D H. | LD A. | | | | | , | | | | | | | ¥ | | | 1011 B | S | | | | | | Ê | E | | | | | | | | | | 다<br>나 | ٤ | | 4 | | 1100 C INC g INC g INC g INC g INC g INC E | <u>L</u> | ш | 1011 | 00 | | DEC | ¥ | | | 9 | 8 | | ADC A | SBC A | XOR s | g<br>S | | N A (m) | E | ╗ | 8 | | 1101 E C C C C C C C C C | _ | I | 118 | ပ | | ž | 8 | | | | | | ø. | o, | | | | CALL | f,<br>E | | ٥ | | 1110 E | L | L | 1101 | 0 | | ğ | N<br>C) | | | | | | | | | | CALL mm | NOTE3) | Table3 | (OTE3) | ٥ | | 1111 F RRCA RRA CPL COF RST v | | E | 1110 | ш | | 2 | 5 | | 1<br>1<br>1 | 1 | E2) | F | NOTE2) | NOTE2) | NOTE2) | NOTE2) | ADC A.m | SBC A.m | XOR m | m do | ш | | 0 1 2 3 4 5 6 7 8 9 A B C D E F M C E L A C E L A C F M g(L0=8~F) LO=8~F | 1_ | 4 | ======================================= | 4 | RRCA | Œ | | SOF | 1 1 | 1 | †<br>†<br>† | i | <br> | i<br>i<br>I | <br> <br> <br> | <br> | | RST | ۸ | | F | | E L A C E L A O8H 18H 28H 38H<br>g(L0=8~F) | 1 | | | | 0 | - | L. | 8 | 4 | 20 | 9 | 7 | æ | 6 | 4 | 8 | ၁ | a | ш | L | | | 08H 18H 28H 38H | | | | | 0 | ш | ٦ | 4 | O | ш | ٦ | ٨ | | | | | 7 | - | | Σ | - | | | | | | | | | | #(LO= | 8~F) | | | | | | | | H80 | 18H | 28H | 38H | > | | | | | | | | | | | | | | | | | | | | 3=07 | 3~F | | | NOTE1) (HL) replaces g. 2) (HL) replaces s. If DDH is supplemented as 1st op-code for the instructions which have HL or (HL) as an operand in Table 18, the instructions are executed replacing HL with iX and (HL) with 8X + d). ex 22H: LD (mn), HL DDH 22H: LD (mn), IX If FDH is supplemented as 1st op-code for the instructions which have HL or (HL) as an operand in Table 18, the instructions are executed replacing HL with IY and PHL) with (IY + d). However, JP (HL) and EX DE, HL are exception and note the followings. If DDH is supplemented as 1 st op-code for JP (HL), (NZ) replaces (HL) as operand and JP (NZ) is executed. If PDH is supplemented as 1 st op-code for JP (HL), (NZ) replaces HL) as operand and JP (NZ) is executed. If PDH is supplemented as 1 st op-code for JP (HL), (NZ) replaces HL) as operand and JP (NZ) is executed. If PDH or FDH is supplemented as 1 st op-code for EX DE, HL, HL is not replaced and the instruction is regarded as illegal instruction. | map | ormat : CB XX | |-------------|-----------------| | 2nd op-code | Instruction for | | Table 19 | | | | | | | c | , - | - | y c | ۰ | 4 | ಸ | 9 | 7 | . 0 | ٥ | 6 | ⋖ | α | 2 | | 2 | ш | L. | | | | |--------------|---|---------------------------------------------|-----|---|-----|-----------|------|----|-----------|----------|--------------|---------------|-----|------|-------|----------|------|--------|------------------------|------|-------------------------|-------------|-----|-----|-----------| | | 0 | 1111 | u. | | | | | | | | <del> </del> | 1 1 | | | | <b>1</b> | | | | 1 | ! | | Ł | 2 | | | | 4 | 1110 111 | Ш | | | | | | SET b, g | | NOTE1) | 1 1 | | | | | | 4 | 3 n n 2 n | 1 | NOTE1) | | ш | ည | | | | 2 | | ۵ | | | | | 1 | SET | | ĬŎ<br>L | 1 1 1 1 | | | | | | į | ה<br>ה | 1 1 | 2 | | ٥ | က | | | | 0 | 1100 1101 | ပ | | | | | | | | <br> | 1 1 1 | | | | | | | | 1 | | | ပ | _ | | | | 9 | 1011 | 8 | | | | | | | | 1 | 1 1 1 | | | - | | | | | 1 | | | 8 | 7 | | | b (L0=0~7) | 4 | 1010 1011 | A | | | | | | RES b, g | , | TE1) | 1 | | | | | | | HES D'B | 1 | NOTE1) | <br> | ٨ | S | b (L0=8~F | | (L0 <u>=</u> | 7 | | 6 | | | | | | RES | | NOTE1) | | | | | | | ĺ | ž | 1 | 2 | <br> | 6 | က | (Lo | | ٥ | 0 | 1000 1001 | α | | | | | | | | 1<br>1<br>1 | 1 1 1 | | | | | | _ | | 1 | | !<br>!<br>! | 8 | - | <u>ן</u> | | | 9 | 0111 | 7 | | | | | | | | 1 | | | | | | | | | 1 | | ;<br> | 7 | 1 | | | | 4 | 0110 | ď | • | | | | | BIT b.g | • | NOTE1 | | | | | | | | BIT b,g | 1 | NOTE1) | 1 | 8 | (C) | | | | 2 | 0101 | īC | | | | | | BIT | i | CN | 2 | | | | | | | <u> </u> | į | 2 | 1 | 5 | 6 | | | | 0 | H John John John John 1 0100 0101 0110 0111 | 4 | - | | | | | | | 1 | 1 | | | | | | | | | | <u> </u> | 4 | · - | | | | | 1100 | c | , | | | | | _ | | | | | _ | | | | | RRC g RR g SRA g SAL g | | NOTES NOTES NOTES NOTES | i<br>! | 6 | · | | | | | 0100 | 3 | , | | | | | <u>V</u> | <u>,</u> | | NOTE1) NOTE1) | | | | _ | | | <u>88</u> | | NOTE | 1 | 1 | 4 | | | | | 2 | - | - | | | | | D D D D D | i | | MOTET | | _ | | | | | <u>R</u> | | NOTE1 | 1 | ŀ | - | | | | | 2 | 3 | | | | | | | | 1 | NOTE1) | | | _ | | | | | | т. | | | 2 | | | | | Ī | • | / | 0 | - | 7 | 3 | + | | | ٥ | _ | α | 1 | i | V | 1<br>B | ၁၂၀ | 1 | L | 4- | → . | | | | | | 2 | / { | 3 | 8 | 00<br>100 | 0010 | 00 | 2 | 5 6 | _ | _ | | 1000 | 3 5 | 3 | 1010 | 1011 | 1100 | 1101 | 1110 | + | ٦. | | | | | | | | | 80 | ပ | ٥ | ш | | -إ | $_{\rm L}$ | <u> </u> | 4 | α | ┙ | כי | 8 | Ш | I | L | Ī | ٠<br>ا | ₹ | | | | | | | | | | | | | | ( | 17 | Υ: | =1 | H) | | | 8 | | | _ | | | ┙ | | | NOTE1) If DDH is supplemented as 1st op-code for the instructions which have (HL) as operand in Table 19, the instructions are executed replacing (HL) with (IX+d). If FDH is supplemented as 1st op-code for the instructions which have (HL) as operand in Table 19, the instructions are executed replacing (HL) with (IY+d). # 22 BUS AND CONTROL SIGNAL CONDITION IN EACH MACHINE CYCLE \* (ADDRESS) : invalid Z (DATA) : high impedance. | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ΙΟE | LIR | HALT | ST | |------------------------------------------------------------|-------------------------------------|----------------------------------------------|------------------------|------------------|----|----|----|-----|----------|------|----| | 400 14 | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | ٥ | , | 0 | 1 | 0 | 1 | 0 | | ADD HL,ww | MC <sub>2</sub><br>~MC <sub>5</sub> | TATATI | | z | , | 1 | 1 | , | 1 | 1 | 1 | | | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | · | , | 0 | 1 | 0 | 1 | 0 | | ADD IX,xx<br>ADD IY,yy | MC <sub>2</sub> | T+T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | | , | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub><br>~MC <sub>6</sub> | <b>रततत</b> | | Z | 1 | 1 | 1 | 1 | <b>,</b> | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | . 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | ADC HL,ww<br>SBC HL,ww | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub><br>~MC <sub>6</sub> | क्तास्त | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | ADD A.g<br>ADC A.g<br>SUB g | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | SBC A.g<br>AND g<br>OR g<br>XOR g<br>CP g | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | ADD A,m<br>ADC A,m<br>SUB m<br>SBC A,m | MC1 | T:T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | AND m<br>OR m<br>XOR m<br>CP m | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | ADD A, (HL) ADC A, (HL) SUB (HL) SBC A, (HL) AND (HL) | MC1 | T₁T₂T₃ | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | OR (HL)<br>XOR (HL)<br>CP (HL) | MC2 | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | ADD A, (IX+d)<br>ADD A, (IY+d)<br>ADC A, (IX+d) | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | ADC A, (1Y+d)<br>SUB (1X+d)<br>SUB (1Y+d)<br>SBC A, (1X+d) | MC2 | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | IOE | LIR | HALT | ST | |------------------------------------------------------|------------------|----------------------------------------------|------------------------|----------------|----|----|----|-----|-----|----------|----| | SBC A, (IY+d)<br>AND (IX+d) | MC <sub>3</sub> | Τ₁Τ2Τ3՝ | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | AND (IY+d) OR (IX+d) OR (IY+d) XOR (IX+d) XOR (IY+d) | MC4<br>~MC5 | TiŤi | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | CP (IX+d) CP (IY+d) | MC <sub>6</sub> | T1T2T3 | IX+d<br>IY+d | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | DIT 1 - | MC: | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | BIT b,g | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | BIT b, (HL) | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | BIT b, (IX+d)<br>BIT b, (IY+d) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | 3rd op-code<br>Address | 3rd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>5</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | IX+d<br>IY+d | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | n | 0 | 1 | 0 | 1_ | , | 1 | 1 | | CALL mn | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | CALL IIII | MC <sub>4</sub> | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | SP 1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | CALL f,mn | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | is false) | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 fto be | 1 | | Instruction | Machine<br>Cycle | States | ADORESS | DATA | RD | WR | ME | IOE | LIR | HALT | ST | |-----------------------------------------------------|-------------------------------------|----------------------------------------------|------------------------|----------------|----|-----|----|-----|-----|------|----| | | MCı | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | CALL f.mn | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | (If condition is true) | MC <sub>4</sub> | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | SP 1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MCs | T1 <b>T</b> 2 <b>T</b> 3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | CCF | MC 1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | ٥ | | | MC i | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | СРІ | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | CPD | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub><br>~MC <sub>6</sub> | <b>रतत</b> ः | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | o | 1_ | 0 | | CPIR<br>CPDR | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | (#BC <sub>R</sub> ≠0 and<br>Ar≠(HL) <sub>M</sub> ) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1. | 1 | | | MC4<br>~MCa | <b>रततत्त्</b> ता | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1_ | 0 | | CPIR<br>CPDR | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | | 1 | 0 | 1 | 1 | | (If BC <sub>R</sub> =0 or<br>Ar=(HL) <sub>M</sub> ) | MC <sub>3</sub> | T+T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub><br>~MC <sub>6</sub> | тітіті | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | CPL | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | o | ١,_ | 0 | 1 | o | 1 | 0 | | DAA | MC <sub>1</sub> | T+T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | DAA | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | DI | MC: | T 1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1_1 | 0 | 1 | 0 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ЮĒ | UR | HALT | ST | |--------------------------|-------------------------------------|----------------------------------------------|------------------------|----------------|----|----|----|----|----|------|----| | DJNZ j<br>(f Br≠0) | MC, | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | ٥ | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | Ti*1 | • | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub><br>~MC <sub>5</sub> | TiTi | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | DJNZ j<br>(If Br=0) | MC <sub>2</sub> | Ti *1 | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | j-2 | 0 | 1 | o | 1 | 1 | 1 | 1 | | El | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | o | | EX DE, HL<br>EXX | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | EX AF, AF | MCı | T,T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC; | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | EX (SP), HL | MC <sub>3</sub> | T1T2T3 | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | EX (SP), HL | MC <sub>4</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | SP+ 1 | н | 1 | 0 | | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | SP | L | 1 | 0 | 0 | 1 | 1 | 1 | 1_ | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | EX (SP),IX<br>EX (SP),IY | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | SP+ 1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MCs | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | <sup>\*1</sup> DMA, REFRESH, or BUS RELEASE cannot be executed after this state. (Request is ignored) | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ЮĒ | UR | HALT | ST | |----------------------|------------------|----------------------------------------------|-------------------------|-----------------|----|----|----|----------------------------------------------|----|------|------| | EX (SP), IX | MC <sub>6</sub> | T1T2T3 | SP+1 | IXH<br>IYH | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | EX (SP), IY | MC <sub>7</sub> | T1T2T3 | SP | IXL<br>IYL | 1 | 0 | 0 | 1 | 1 | 1_ | 1 | | HALT | MC <sub>1</sub> | T+T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | | | Next op-code<br>Address | Next<br>op-code | 0 | 1 | 0 | 1 | 0 | 0 | 0_ | | MO | MC 1 | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | o | 1 | 0 | | IM 1<br>IM 2 | MC2 | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | o | 1 | 1 | | INC g | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | o | | DEC g | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | INC (HL) | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1_ | | DEC (HL) | MC <sub>3</sub> | Ti | | z | 1 | 1 | 1 | 1 | ì | 1 | 1_ | | | MC <sub>4</sub> | T1T2T3 | HL | DATA | 1 | 0 | 0_ | 1_ | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1_1_ | | INC (IX+d) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | <u> </u> | 1 | 1 | 1 | | INC (IY+d) | MC <sub>4</sub> | TiTi | | z | , | 1 | 1 | 1 | , | 1 | 1 | | DEC (IY+d) | MCs | T1T2T3 | IX+d<br>IY+d | DATA | 0 | 1 | 0 | , | 1 | 1 | 1 | | i | MC7 | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>s</sub> | T1T2T3 | IX+d<br>IY+d | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | INC ww<br>DEC ww | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | INC IX INC IY DEC IX | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-dode | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | o | 1 | 0 | 1 | 1 | | DEC IY | MC <sub>3</sub> | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1_1_ | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ЮE | LIR | HALT | ST | |---------------------------|------------------|----------------------------------------------|-----------------------------|----------------|----|----------|----|----|-----|------|----| | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | IN A,(m) | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 11 | | | MC <sub>3</sub> | T1T2T3 | m to Ao~A7<br>A to Aa~A15 | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | IN g,(C) | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | вс | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1_ | | INO g,(m) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | m to Ao~A7<br>OOH to Aa~A15 | DATA | 0 | 1 | 1_ | 0 | 1 | 1 | 1 | | | MC: | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | <b>N</b> i | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0_ | 1 | 0 | 1 | 1 | | IND | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | BC | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC2 | T 1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | • | 1 | 0 | 1 | 1 | | INIR<br>INDR<br>(If Br≠0) | MC: | T1T2T3 | вс | DATA | | 1 | 1 | 0 | 1 | 1 | 1 | | | MC | T1T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC<br>~MC | | · | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | мс | 1 T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1_ | | 1 | 0 | 1 | 0 | | INIR | мс | 2 T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | (If Br=0) | МС | 3 T1T2T3 | BC | DATA | ٥ | <u> </u> | 1 | 0 | 1 | 1 | 1 | | | мс | T 1T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ЮĒ | LIR | HALT | ST | |----------------------------------|-------------------------------------|----------------------------------------------|------------------------|----------------|----|----|----|----|-----|------|----| | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0_ | | JP mn | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 11 | 1 | | | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | JP f,mn | MC, | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | (If f is false) | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | o | 1 | 0 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | JP f,mn<br>(If f is true) | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | JP (HL) | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | , | 0 | | JP (DX) | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | JP (IY) | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC 1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | JR j | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub><br>~MC <sub>4</sub> | TiTi | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | JR C.j JR NC.j<br>JR Z.j JR NZ.j | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | (If condition is false) | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | JR C,j JR NC,j | MC 1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | JR Z.j JR NZ.j | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | j-2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | is true) | MC <sub>3</sub><br>~MC <sub>4</sub> | TiTi | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | LD g.gʻ | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | LD g.m | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | <b>\$</b> | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | MĒ | ĪŌĒ | ŪR | HALT | ST | |----------------------------|--------------------------------------|----------------------------------------------|------------------------|----------------|----|------|----|-----|----|------|----| | LD g, (HL) | MC <sub>1</sub> | T₁Ť2Ť3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | <b>U</b> | MC <sub>2</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LDg,(IX+d)<br>LDg,(IY+d) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub><br>~MC <sub>5</sub> | TiTi | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | IX+d<br>IY+d | DATA | 0 | 1 | 0 | 1_ | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD (HL),g | MC2 | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | HL | 9 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0_ | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LD (IX+d),g<br>LD (IY+d),g | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub><br>~ MC <sub>6</sub> | TITITI | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>7</sub> | T1T2T3 | IX+d<br>IY+d | 9 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD (HL),m | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1_ | | | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1_ | | | MC , | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1_ | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LD (IX+d),m<br>LD (IY+d),m | MC <sub>3</sub> | T:T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | IX+d<br>IY+d | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | LD A, (BC)<br>LD A, (DE) | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1_1_ | 0 | 1 | 0 | 1 | o | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | IOE | LIR | HALT | ST | |--------------------------|------------------|--------|------------------------|----------------|----|----|----|-----|-----|------|----| | LD A, (BC)<br>LD A, (DE) | MC2 | T1T2T3 | BC<br>DE | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD A,(mn) | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | ED A.((())) | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T+T2T3 | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD (BC),A<br>LD (DE),A | MC <sub>2</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | BC<br>DE | А | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | o | 1 | 1 | 1 | 1 | | LD (mn),A | МС₃ | T1T2T3 | 2nd operand<br>Address | m | o | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC s | T1T2T3 | mn | A | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | LD A,I<br>LD A,R | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD I,A<br>LD R,A | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD ww, mn | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LD IX,mn | MC <sub>2</sub> | T,T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LD IY,mn | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | LD HL, (mn) | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RID | WR | ME | ЮE | UR | HALT | ST | |--------------|------------------|----------------------------------------------|------------------------|----------------|-----|----|----|----|----|------|----| | | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | LD HL, (mn) | MC <sub>4</sub> | T1T2T3 | mn | DATA | 0 | 1 | ٥ | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | mn+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC1 | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | ] | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LD ww.(mn) | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | LD WW, IIIII | MC4 | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd operand<br>Address | m | 0 | , | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | mn | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | mn+1 | DATA | 0 | , | o | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LD IX,(mn) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | o | 1 | 1 | 1 | 1 | | LD IY,(mn) | MC <sub>4</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | mn | DATA | o | 1 | o | 1 | 1 | 1 | 1 | | <u> </u> | MC <sub>6</sub> | T1T2T3 | mn+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | мс | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1 | 1 | , | | LD (mn).HL | MC <sub>3</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | LD WIND,FIL | MC4 | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | mn | L | 1 | o | o | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | mn+1 | н | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | ₩R | ME | ЮĒ | LIR | HALT | ST | |--------------------------|------------------|----------------------------------------------|------------------------|----------------|----|----|----|----|-----|------|----| | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | o | 1 | 1 | 1 | 1 | | LD (mn),ww | MC4 | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | mn | wwL | 1 | 0 | 0 | 1 | 1 | 1 | 1. | | | MC <sub>7</sub> | T1T2T3 | mn+1 | wwH | 1 | 0 | 0 | 1 | 1 | 1 | 1_ | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | n | 0 | 1 | 0 | 1 | 1_ | 1 | 1 | | LD (mn),IX<br>LD (mn),IY | MC <sub>4</sub> | T1T2T3 | 2nd operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | ті | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | mn | IXL<br>IYL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>7</sub> | T1T2T3 | mn+1 | IXH | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | LD SP, HL | MC, | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | 22 01,711 | MC <sub>2</sub> | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC: | T1T2 <b>T</b> 3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | o | | LD SP,IX<br>LD SP,IY | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC 1 | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | LDI | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LDD | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | DE | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | IOE | UR | HALT | ST | |-----------------------------------------|------------------|----------------------------------|---------------------------|----------------|----|----|----|-----|----|------|------------| | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T+T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | LDIR<br>LDDR<br>(If BC <sub>8</sub> ≠0) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | DE | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MCs<br>~MCs | тті | • | Z | 1 | 1 | 1 | 1 | 1 | 1_1_ | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1_ | 0 | 1 | 0 | 1_ | 0 | | LDIR<br>LDDR | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Aridress | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | (If BC <sub>R</sub> =0) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | DE | DATA | 1_ | 0 | 0 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | MLT ww | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC3<br>~MC18 | मतताः<br>मतताः<br>मतताः<br>मतताः | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | NEG | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1_1_ | | NOP | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1. | 0 | 1 | 0 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | OUT (m),A | MC <sub>2</sub> | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | OUT (m),A | MC <sub>3</sub> | Τi | • | z | 1 | 1 | 1 | , | 1 | 1 | 1 | | | MC | T1T2T3 | m to Ao~A7<br>A to Ae~A16 | A | 1 | 0 | 1 | 0 | 1 | 1 | 1 continue | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | MĒ | ЮE | LIR | HALT | ST | |----------------|------------------|-----------------|-------------------------------------------------------------------------------|----------------|----|----|----|----|-----|------|----| | | MC <sub>1</sub> | Ť1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | OUT (C),g | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | ВС | g | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | OUTO (m),g | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | m to Ao~A7<br>OOH to Ad~A15 | 9 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | OTIM<br>OTDM | MC <sub>3</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | O I DIW | MC4 | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1 <b>T2T</b> 3 | C to A <sub>0</sub> ~A <sub>7</sub><br>00H to A <sub>1</sub> ~A <sub>15</sub> | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | MC <sub>6</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | OTIMR<br>OTDMR | MC <sub>3</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | (If Br≠0) | MC <sub>4</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | C to Ao~A7<br>OOH to Ao~A15 | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | MC <sub>6</sub> | TiTiTi | • | z | 1 | 1 | 1 | 1 | 1 | , ] | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WŔ | ME | ΙΌĒ | UR | HALT | ST | |---------------------------|------------------|----------------------------------------------|-----------------------------|----------------|----|-----|----|-----|----|----------------------------------------------|------------| | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | OTIMR | MC <sub>3</sub> | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | OTDMR<br>(If Br=0) | MC <sub>4</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | C to Ao~A7<br>OOH to Aa~A15 | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | МСв | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1_ | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | , | 0 | | OUTI | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1_ | 1 | | OUTD | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1_ | 1 | 1 | 1 | | | MC4 | T1T2T3 | ВС | DATA | 1 | 0 | 1 | 0 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | | 1 | 0 | | 077 | MC2 | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | OTIR<br>OTDR<br>(If Br≠0) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | вс | DATA | 1 | 0 | 1 | 0 | 1 | 1 | , | | | MCs<br>~MCs | TiTi | <u> </u> | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC, | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | OT#R<br>OTDR | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | (If Br=0) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | ١ | 1 | | | MC4 | T1T2T3 | BC | DATA | 1 | 0 | 1 | 0 | 1 | 1 | <u> '</u> | | BOS *- | мс | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | <u> </u> | 0 | | POP zz | MC: | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | POP IX<br>POP IY | мс | , T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1.1 | 0 | 1 | | 1 | O | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | ₩R | MĒ | IOE | LIR | HALT | ST | |--------------------|-------------------------------------|----------------------------------------------|------------------------|----------------|----|----|----|-----|-----|------|----| | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | POP IX<br>POP IY | MC <sub>3</sub> | T1T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC4 | T1T2T3 | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | PUSH zz | MC₂<br>~MC₃ | TiTi | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 7 0017 22 | MC4 | T1T2T3 | SP-1 | zzH | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | SP-2 | zzL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | o | 1 | 0 | 1 | 0 | 1 | 1 | | PUSH IX<br>PUSH IY | MC₃<br>~MC₄ | TiTi | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | SP-1 | IXH<br>IYH | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MCs | T1T2T3 | SP-2 | IXL<br>IYL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | RET | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | o | 1 | 0 | 1 | 0 | 1 | 0 | | nc i | MC <sub>2</sub> | T+T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC₃ | T1T2T3 | SP+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | RET f | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | o | 1 | 0 | 1 | 0 | | is false) | MC <sub>2</sub><br>~MC <sub>3</sub> | TiTi | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC: | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | RET f | MC <sub>2</sub> | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | is true) | MC <sub>3</sub> | T1T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | SP+ 1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | RETI | MC, | T1¥2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | o | 1 | 0 | 1 | 0 | | RETN | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | IOE | UR | HALT | ST | |----------------------------------------|------------------|----------------------------------------------|------------------------|----------------|----|----|----|-----|------|------|----| | RETI | MC <sub>3</sub> | T1T2T3 | SP | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | RETN | MC <sub>4</sub> | T1T2T3 | SP+1 | DATA | 0 | 1_ | 0 | 1 | 1 | 1 | 1 | | RLCA<br>RLA<br>RRCA<br>RRA | MC1 | T₁T2Ť3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | RLC g<br>RL g | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1_ | 0 | 1 | 0 | | RRC g<br>RR g<br>SLA g | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | SRA g<br>SRL g | MC <sub>3</sub> | Ti | | z | 1_ | , | 1 | 1 | 1 | 1 | 1 | | | MC | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1_ | 0_ | 1 | 0 | 1 | 0 | | RLC (HL)<br>RL (HL) | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | RRC (HL)<br>RR (HL)<br>SLA (HL) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | SRA (HL)<br>SRL (HL) | MC <sub>4</sub> | Tì | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MCs | T,T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | RLC (IX+d) | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | RLC (TY+d) | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | RL (IY+d)<br>RRC (IX+d)<br>RRC (IY+d) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1_1_ | 1 | 1 | | RR (IX+d)<br>RR (IY+d) | MC <sub>4</sub> | T1T2T3 | 3rd op-code<br>Address | 3rd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | SLA (IX+d)<br>SLA (IY+d) | MCs | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | IX+d<br>IY+d | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | SRA (IX+d)<br>SRA (IY+d)<br>SRL (IX+d) | MCe | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1. | 1 | | SRL (IY+d) | MC, | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | IX+d<br>IY+d | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | мс | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | RLD<br>RRD | MC | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC: | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | WR | ME | ĪŌĒ | LIR | HALT | ST | |-----------------------------|-------------------------------------|-----------------|------------------------|----------------|----|----|----|-----|-----|------|----| | RLD | MC4<br>~MC7 | <b>रातता</b> त | • | z | 1 | 1 | , | 1 | 1 | 1 | 1 | | RRD | MCa | T+T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub><br>~MC <sub>3</sub> | TiTi | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | RST v | MC4 | T1T2T3 | SP 1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | SCF | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>1</sub> | T1 <b>T2</b> T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | SET b,g<br>RES b,g | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | Ti | • | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T+T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | o | 1 | 1 | | SET b, (HL)<br>RES b, (HL) | MC <sub>3</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | HL | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | SET b, (IX+d) | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | d | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | SET b, (IY+d) RES b, (IX+d) | MC4 | T1T2T3 | 3rd op-code<br>Address | 3rd<br>op-code | 0 | 1 | 0 | 1 | 0 | , | 1 | | RES b, (IY+d) | MCs | T1T2T3 | IX+d<br>IY+d | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | Tí | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC7 | T1T2T3 | IX+d<br>IY+d | DATA | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | Instruction | Cycle | States | ADDRESS | DATA | RD | WR | ME | ЮĒ | UR | HALT | ST | |---------------------|-------------------------------------|----------------------------------------------|------------------------------|----------------|----|----|----|----|----|------|----| | | MC i | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | SLP | MC <sub>2</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | | | 7FFFFH | Z | 1 | 1 | 1 | 1 | 1 | 0 | 1 | | | MC, | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | TSTIO m MC3 T1T2T3 | | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | | T1T2T3 | C to Ao~A7<br>OOH to Aa~A15 | DATA | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | | MC: | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | o | | TST g | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | TST m | MC2 | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | 1st operand<br>Address | m | 0 | 1 | 0 | 1 | 1 | 1_ | 1 | | | MC 1 | T1T2T3 | 1st op-code<br>Address | 1st<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | TST (HL) | MC <sub>2</sub> | T1T2T3 | 2nd op-code<br>Address | 2nd<br>op-code | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | 13, 116, | MC <sub>3</sub> | Ti | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | HL | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1_ | | INTERRUPT | | | | | | , | , | , | _ | , | | | | MC <sub>1</sub> | T1T2T3 | Next op-code<br>Address (PC) | | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | NMI | MC <sub>2</sub><br>~MC <sub>3</sub> | 3 | • | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 191411 | MC <sub>4</sub> | T1T2T3 | SP-1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | 1 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | ı | 1 | 1 | Machine (to be continued) 0 0 PCL 1st op-code z 1 1 SP-2 Next op-code Address (PC) MC<sub>5</sub> MC<sub>2</sub> ~MC₃ INTO MODE 0 (RST INSERTED) T1T2T3 $T_{\mathbf{W}}T_3$ | Instruction | Machine<br>Cycle | States | ADDRESS | DATA | RD | ₩R | MĒ | ЮĒ | ΠŘ | HALT | ST | |-------------------------------------|------------------|-------------------------------------------------------------------------------|------------------------------|----------------|----|----|----|----|----|------|----| | INTo MODE 0<br>(RST INSERTED) | MC4 | T1T2T3 | SP-1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | (NO) MOENTED! | MC 5 | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>W</sub><br>T <sub>W</sub> T <sub>3</sub> | Next op-code<br>Address (PC) | 1st<br>op-code | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | MC <sub>2</sub> | T1T2T3 | PC | n | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | ÑT₀ MODE O | MC <sub>3</sub> | T1T2T3 | PC+1 | m | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | INSERTED) | MC4 | Ті | • | z | ١ | 1 | 1 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | SP-1 | PC+2(H) | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | SP-2 | PC+2(L) | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC1 | T <sub>1</sub> T <sub>2</sub> T <sub>W</sub><br>T <sub>W</sub> T <sub>3</sub> | Next op-code<br>Address (PC) | | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | INTo MODE 1 | MC2 | T1T2T3 | SP-1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>3</sub> | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>1</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>W</sub><br>T <sub>W</sub> T <sub>3</sub> | Next op-code<br>Address (PC) | Vector | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | MC <sub>2</sub> | Ti | | Z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | INT₀ MODE 2 | MC <sub>3</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | SP-1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>4</sub> | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> | I, Vector | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | I, Vector+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC i | T <sub>1</sub> T <sub>2</sub> T <sub>W</sub><br>T <sub>W</sub> T <sub>3</sub> | Next op-code<br>Address (PC) | | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | MC <sub>2</sub> | Ti | | z | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | INT:<br>INT:<br>Internal Interrupts | MC <sub>3</sub> | T1T2T3 | SP 1 | РСН | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | nitorial sitestupis | MC4 | T1T2T3 | SP-2 | PCL | 1 | 0 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>5</sub> | T1T2T3 | l, Vector | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | | | MC <sub>6</sub> | T1T2T3 | I, Vector+1 | DATA | 0 | 1 | 0 | 1 | 1 | 1 | 1 | # 23 REQUEST ACCEPTANCES IN EACH OPERATING MODE | SYSTEM STOP mode | Not acceptable | Not acceptable | Not acceptable | Acceptable | Acceptable Return from SYSTEM STOP mode to normal operation. | Not acceptable | Acceptable Return from SYSTEM STOP mode to normal operation. | |-------------------------------------------------|----------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------| | SLEEP mode | Not acceptable | Not acceptable | Not acceptable | Acceptable | Acceptable Return from SLEEP mode to normal operation. | - | | | BUS RELEASE<br>mode | Not acceptable | Not acceptable | Accentable After BUS RELEASE cycle, DINA cycle begins at the end of one MC. | Continue<br>BUS RELEASE<br>mode. | Not acceptable | - | - | | DMA Cycle | Acceptable | Refresh cycle<br>begins at<br>the end of<br>MC. | Acceptable Refer to "2.9 DMA Controller" for details. | Bus is released<br>at the end of<br>MC. | Not acceptable | ı | Acceptable DMA cycle stops. | | Interrupt<br>Acknowledge<br>Cycle | Acceptable | Refresh cycle<br>begins at<br>the end of<br>MC. | Acceptable DMA cycle begins at the end of MC. | Bus is released<br>at the end of<br>MC. | Not acceptable | - | Not acceptable interrupt acknowledge cycle precedes NIMI is accepted after executing the next instruction. | | Refresh Cycle | Not acceptable | Not acceptable | Acceptable Refresh cycle precedes. DMA cycle begins at the end of one MC. | Not acceptable | Not acceptable | - | - | | WAIT State | Acceptable | Not acceptable | DMA cycle<br>begins at the<br>end of MC. | Not acceptable | Accepted after executing the current instruction | | - | | Normal Operation<br>(CPU mode)<br>(IOSTOP mode) | Acceptable | Refresh cycle<br>begins at<br>the end of MC. | DMA cycle<br>begins at the<br>end of MC. | Bus is released<br>at the end of<br>MC. | Accepted after executing the current instruction. | - | - | | Current | | Refresh Request<br>(Request of<br>Refresh by the on-chip<br>Refresh Controller) | | | NTO, NTT. | internal<br>I/O<br>Interrupt | Ī. Σ | | | WAIT | Refresh Request<br>(Request of<br>Refresh by the on-<br>Refresh Controller) | DREQ. | BUSREO | Interrupt | | | NOTE) • not acceptable when DMA Request is in level sense. | same as the above MC: Machine Cycle **(1)** HITACHI # HD64180R/Z ### 24 REQUEST PRIORITY The HD64180 has the following three types of requests. Type 1. Type 2. To be accepted in each machine cycle . . . . . Refresh Req. Type 3. To be accepted in each instruction..... Interrupt Req. DMA Req. Bus Reg. Type 1, Type 2, and Type 3 requests priority is shown as follows. highest priority Type 1 > Type 2 > Type 3 lowest priority Each request priority in Type 2 is shown as follows. highest priority Bus Req. > Refresh Req. > DMA Req. lowest priority (NOTE) If Bus Req. and Refresh Req. occurs simultaneously, Bus Req. is accepted but Refresh Req. is cleared. Refer to "2.7 Interrupts" for each request priority in Type 3. #### 25 OPERATION MODE TRANSITION - NOTE) \*1 NORMAL: CPU executes instructions normally in NORMAL mode - \*2 DMA request: DMA is requested in the following cases. (1) DREQo, DREQ1 = 0 (memory -> (memory mapped) I/O DMA transfer) (2) DEO = 1 (memory <---> memory DMA transfer) - 13 DMA end: DMA ends in the following cases (1) DREQ<sub>0</sub>, DREQ<sub>1</sub> = 1 (memory ← → - (memory mapped) I/O DMA transfer) (2) BCRO, BCR1 = 0000H (all DMA transfers) - (3) NIMI = 0 (all DMA transfers) #### Other operation mode transitions The following operation mode transitions are also possible 1. HALT DMA **BUS RELEASE** REFRESH BUS RELEASE IOSTOP (DMA REFRESH BUS RELEASE SYSTEM STOP THE BUS RELEASE 2. SLEEP ## **26 STATUS SIGNALS** The following table shows pin outputs in each operating mode. | | Mode | LIR | ME | ЮĒ | RD | ₩R | REF | HALT | BUSACK | ST | Address<br>BUS | Data<br>BUS | |------------------------|------------------------------------------|-----|----|----|----|----|-----|------|--------|----|----------------|-------------| | | Op-code Fetch<br>(1st op-code) | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | A | IN | | CPU | Op-code Fetch<br>(except 1st<br>op-code) | 0 | o | 1 | 0 | 1 | 1 | 1 | 1 | 1 | A | 2 | | operation | Memory Read | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Α | IN | | - | Memory Write | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | Α | OUT | | | I/O Read | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | Α | IN | | | I/O Write | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | Α | OUT | | | Internal<br>Operation | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | A | 2 | | Refresh | | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | • | A | N | | Interrupt | NMI | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | A | 2 | | Acknowledge<br>Cycle | INT <sub>0</sub> | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Α | IN | | (1st machine<br>cycle) | INT1, INT2 & Internal Interrupts | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | A | 2 | | BUS RELEAS | SE | 1 | z | z | z | z | 1 | 1 | 0 | | z | N | | HALT | | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | Α | IN | | SLEEP | | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | IN | | | Memory Read | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | Α | N | | Internal | Memory Write | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | Α | OUT | | DMA | I/O Read | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | Α | IN | | | I/O Write | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | Α | OUT | | RESET | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Z | IN | NOTE) 1 : HIGH 0 : LOW A : Programmable 2 : High Impedance IN : Input OUT : Output • : Invalid ## 27 PIN STATUS DURING RESET AND LOW POWER OPERATION MODES | <b>D</b> 1 - <b>D</b> 1 - | | DI. 4 | | Pin status in each | operation mode | | |---------------------------|------------------|--------------------------------|----------------|--------------------|----------------|-------------| | Pin No. | Symbol | Pin function | RESET | SLEEP | IOSTOP | SYSTEM STOP | | 4 | WAIT | - | IN (N) | IN (N) | IN (A) | IN (N) | | 6 | BUSACK | - | 1 | OUT | OUT | OUT | | 6 | BUSREO | - | IN (N) | IN (A) | IN (A) | IN (A) | | 7 | RESET | - | 0 | IN (A) | IN (A) | IN (A) | | 8 | NAME. | - | IN (N) | IN (A) | in (a) | IN (A) | | 9 | NTo | - | IN (N) | IN (A) | IN (A) | IN (A) | | 10 | NT: | - | IN (N) | IN (A) | in (a) | IN (A) | | 11 | NTz | - | IN (N) | IN (A) | IN (A) | IN (A) | | 12 | ST | - | 1 | 1 | OUT | 1 | | 13~30 | A0~A17 | - | Z | 1 | A | 1 | | 31 | A14/TOUT | Ata | Z | 1 | Α | 1 | | | | TOUT | Z | OUT | н | н | | 34~41 | Do~D₁ | - | Z | Z | Α | Z | | 42 | RTS <sub>0</sub> | - | 1 | н | OUT | н | | 43 | CTS. | <del>-</del> | #N (N) | IN (A) | IN (N) | IN (N) | | 44 | DCD <sub>0</sub> | - | IN (N) | IN (A) | IN (N) | IN (N) | | 45 | TXAo | _ | 1 | OUT | Н | н | | 46 | RXAo | _ | IN (N) | IN (A) | IN (N) | IN (N) | | 47 | CKAo/DREQo | CKAo<br>(internal clock mode) | Z | OUT | Z | Z | | | | CKA: (external clock mode) | Z | IN (A) | IN (N) | IN (N) | | | | DREGo | Z | IN (N) | iN (A) | iN (N) | | 48 | TXA <sub>1</sub> | - | 1 | OUT | н | н | | 49 | RXA | - | IN (N) | in (A) | IN (N) | IN (N) | | 50 | CKA1/TENDo | CKA:<br>(internal clock mode) | Z | OUT | Z | Z | | | | CKA i<br>(external clock mode) | Z | IN (A) | IN (N) | IN (N) | | | | TEND₀ | Z | 1 | OUT | 1 | | 51 | TXS | - | 1 | OUT | Н | н | | 52 | RXS/CTS1 | RXS | IN (N) | IN (A) | IN (N) | IN (N) | | | | CTS. | IN (N) | IN (A) | IN (N) | IN (N) | | 53 | CKS | CKS<br>(internal clock mode) | Z | OUT | 1 | 1 | | | | CKS<br>(external clock mode) | Z | in (A) | Z | Z | | 54 | DREQ. | - | IN (N) | in (N) | IN (A) | IN (N) | | 55 | TEND: | | 1 | 1 | OUT | 1 | | 56 | HALT | | 1 | 0 | OUT | 0 | | 57 | REF | | 1 | 1 | OUT | 1 | | 58 | IOE | | 1 | 1 | OUT | 1 | | 59 | ME | - | 1 | 1 | OUT | 1 | | 60 | E | | 0 | E clock output | - | - | | 61 | UR | - | 1 | 1 | OUT | 1 | | 62 | WR | _ | 1 | 1 | OUT | 1 | | 63 | RD | | 1 | 1 | OUT | 1 | | 64 | φ | - | φ clock output | - | | - | <sup>1:</sup> HIGH 0: LOW A: Programmable Z: High Impedance IN (A): Input (Active) IN (N): Input (Not active) OUT: Output H: Holds the previous state <sup>←:</sup> same as the left 28 INTERNAL I/O REGISTERS By programming IOA7 and IOA6 in the I/O control register, in- ternai I/O register addresses are relocatable within ranges from 0000H to 00FFH in the I/O address space. | REGISTER | MNEMONICS | ADDRESS | | | | REM | ARKS | | | | | |-------------------------|-------------------------|---------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------|----------------------------|-----------------------------------|-------------------|-----------------------| | ASCI Control Register A | Channel 0<br>: CNTLA0 | 0 0 | bit | MPE | RE | TE | RTSO | MPBR/<br>EFR | MOD2 | MOD1 | MODO | | | | | during RESET | 0 | 0 | 0 | 1 | invalid | 0 | 0 | 0 | | | | | R/W | | | | | | Multi Pr | leceive | Transmit<br>Enable | Em<br>quest T | iti Proce<br>or Flag f<br>o Send | ssor Bit<br>Reset | Selection<br>Receive/ | | ASCI Control Register A | Channel 1<br>: CNTLA1 | 0 1 | bit | MPE | RE | TE | CKA1D | MPBR/<br>EFR | MOD2 | MOD1 | моро | | | | | during RESET | 0 | 0 | 0 | 1 | invalid | 0 | 0 | 0 | | | | | R/W | | | | MOD2, 1, 0<br>0 0 0<br>0 0 1<br>0 1 0<br>0 1 1<br>1 0 0<br>1 0 1<br>1 1 1 | Start +<br>Start +<br>Start +<br>Start +<br>Start +<br>Start +<br>Start + | Aulti Pro 7 bit D 7 bit D 7 bit D 7 bit D 8 bit D 8 bit D 8 bit D | ata + : | Enable 1 Stop 2 Stop Parity + Parity + 1 Stop 2 Stop | 1 Stop<br>2 Stop<br>1 Stop | | | | | ASCI Control Register B | 3 Channel 0<br>: CNTLBO | 0 2 | bit<br>during RESET<br>R/W | MPBT<br>invalid<br>R/W | MP<br>0<br>R/W | CTS/<br>PS<br>• | PEO<br>O<br>R/W | DR<br>0<br>R/W | SS2 | SS1 | SSO<br>1<br>R/W | | | | | · CTS : Dej | pending ( | MultiPro | Multi Pr<br>cessor l | Clear To<br>rocessor<br>Bit Trans | Send/Po | - Divide <br>ven or O<br>rescale | Speed S<br>Ratio | ource an<br>Select | | REGISTER | MNEMONICS | ADD | RESS | | | | REM | ARKS | | | | | |------------------------|------------------------|-----|------|---------------------|--------------------------------------------------|----------------|-----------------|--------------|----------------|----------------|-----------------|-----------------------| | ASCI Transmit Data R | egister Channel | 0 | 6 | | | | | | | | | | | 0 | : TDRO | | | | | | | | | | | | | | | _ | _ | | | | | | | | | | | ASCI Transmit Data F | _ | 0 | 7 | | | | | | | | | | | | : TDR1 | | | | | | | | | | | | | ASCI Receive Data Re | gister Channel | 0 | 8 | | | | | | | | | | | • | : TSRO | | | | | | | | | | | | | ASCI Receive Data Re | gister Channel | ٥ | 9 | | | | | | | | | | | 1 | : TSR1 | } | | | | | | | | | | | | 0010 | | | | | | | | | <b>,</b> | | | , | | CSI/O Control Registe | r<br>: CNTR | ľ | A | bit | EF | EIE | RE | TE | <u> </u> | SS2 | SS1 | SSO | | | | İ | | during RESET | O<br>R | R/W | R/W | 0<br>R/W | 1 | R/W | R/W | 1<br>R/W | | | | | | N/W | <del>- </del> | 1 | 1,000 | 1.000 | L | <u> </u> | 1 | | | | | | | | | | | Τ | ansmit E | -abla | _ Spee | d Select | | | | | | | | | | ceive Er | nable | Nacre | | | | | | İ | | | LEn | L-Er<br>ndFlæg | nd Intern | upt Enab | nie . | | | | | | | | | | S2,1,0 | l R | aud Rate | . 1 . | SS2,1,0 | ا ه | oud Rate | | | | | | | | 000 | | + 20 | + | 100 | $\overline{}$ | + 320 | _ | | | | | | | 001<br>010 | | + 40<br>+ 80 | 1 | 101<br>110 | | + 640<br>+ 1280 | | | | | | | | 011 | | + 160 | 1 | 111 | Exte | emal | | | CSI/O Transmit/Receiv | e Data | ٥ | В | | | | | | | (Trec | quency • | < + 20) | | Register | : TRDR | | | | | | | | | | | | | | | | _ | | | | | | | | | | | Timer Data Register C | : TMDROL | 0 | C | | | | | | | | | | | Timer Data Register C | hannel OH | 0 | D | | | | | | | | | | | | : TMDROH | | | | | | | | | | | | | Tirner Reload Register | | 0 | E | | | | | | | | | | | | : RLDROL | | | | | | | | | | | | | Timer Reload Register | Channel OH<br>: RLDROH | 0 | F | | | | | | | | | | | Timer Control Bosinton | | ١, | 0 | | | T | 1 | | T=== | 1 | 1 | T====7 | | Timer Control Register | : TCR | ' | J | bit<br>during RESET | TIF1 | TIFO | TIE1 | TIEO<br>O | TOC1 | TOC0 | TDE1 | TDEO O | | | | | | R/W | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | <del></del> | $\overline{}$ | <u> </u> | $\overline{}$ | | | 1 | | | | | | | | | | | | ner Down<br>nable 1,0 | | | | | | | | | | _ <b>T:_</b> | | Timer 0 | utput Co | ontrol 1,0 | | | | | | | | L Timer | Interrup | | Interrupt<br>O | cna <b>dia</b> | 1,0 1 | | | | | | | | | | | | | | | | | | | | | _ | TOC1 | | A 18/T | | | | | | | | | | | | | 00 | inhibit<br>Togg | | | | | | | | | | | | 1 | 10 | 0 | | | | | | | | | | | | | | ' | | | | | | | | | Ļ | | <u> </u> | | | | | | | 4 | na aantinus d | | | | | | | | | | | | | TEO I | be continued | **OHITACHI** | REGISTER | MNEMONICS | ADDRESS | REMARKS | |------------------------------------|------------------------|---------|---------------------------------------------------------------| | Timer Data Register Ch | nannel 1L<br>: TMDR1L | 1 4 | | | Timer Data Register Ch | nannel 1H<br>: TMDR1H | 1 5 | | | Timer Reload Register | Channel 1L<br>: RLDR1L | 1 6 | | | Timer Reload Register | Channel 1H<br>: RLDR1H | 1 7 | | | Free Running Counter | | 1 8 | read only | | | : FRC | | | | DMA Source Address I<br>Channel OL | | 2 0 | | | İ | : SAROL | | | | DMA Source Address I<br>Channel OH | Register | 2 1 | | | | : SAROH | | | | DMA Source Address F | Register | 2 2 | Bits 0-2 are used for SAROB. | | Chennel 0B | : SAROB | | A 16, A 17, A 16 DMA Transfer Request X O O DREQ: (external) | | | | | X 0 1 RDRO (ASCIO) | | DMA Destination Addre | as Register | 2 3 | X 1 0 RDR1 (ASCI1)<br>X 1 1 Not Used | | Channel OL | : DAROL | | ' | | DMA Destination Addre | | 2 4 | | | | : DAROH | | | | DMA Destination Addre | ss Register | 2 5 | Bits 0-2 are used for DAROB. | | Channel OB | : DAROB | | A 16, A 17, A 16 DMA Transfer Request | | | | | X 0 1 TDRO (ASCIO) | | DMA Byte Count Regist<br>OL | | 2 6 | X 1 0 TDR1 (ASCI1)<br>X 1 1 Not Used | | | : BCROL | | | | DMA Byte Count Regist<br>OH | ter Channel | 2 7 | | | 1 | : BCROH | | | | DMA Memory Address<br>Channel 1L | _ | 2 8 | | | | : MAR1L | | | | DMA Memory Address<br>Channel 1H | Register<br>: MAR1H | 2 9 | | | DMA Memory Address<br>Channel 1B | Register | 2 A | Bits 0-2 are used for MAR1B. | | | : MAR1B | | | | DMA I/O Address Regis | | 2 B | | | | : IAR1L | | | | DMA I/O Address Regis | ster Channel | 2 C | | | | : IAR1H | | | | L | | | to be continued. | | REGISTER | MNEMONICS | ADD | RESS | | | | REM | ARKS | | | | | | | | |-----------------------------------------|-------------------|-----|------|----------------------------|----------|---------|-------|--------|-----|-----|-----|------------------|--|--|--| | MMU Common Base | Register<br>: CBR | 3 | 8 | bit | <u> </u> | СВ6 | CB5 | CB4 | СВЗ | CB2 | CB1 | СВО | | | | | | . CBN | | | during RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | R/W | | | | | | | | L MMU Common Base Register | | | | | | | | | | | | | MMU Bank Base Regi | ster<br>: BBR | 3 | 9 | bit | [ - | BB6 | 885 | BB4 | 883 | 882 | 881 | 880 | | | | | | | | | during RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | R/W | | | | | | | | MMU Bank Base Register | | | | | | | | | | | | | MMU Common/Bank Area Register<br>: CBAI | | 3 | A | bit | CA3 | CA2 | CA1 | CAO | ВАЗ | BA2 | BA1 | BAO | | | | | | . 00.111 | | | during RESET | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | R/W | | | | VO Control Register | | | F | | | | | IU Com | | | | Bank<br>Register | | | | | AC COURS Hediester | : ICR | , | • | bit | 10A7 | ЮА6 | IOSTP | _ | - | - | - | | | | | | | | | | during RESET | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | R/W | R/W | R/W | R/W | | | | | | | | | | | | | | | | - VO Ac | | Stop | | | | | | | |