# HD63701X0, HD637A01X0, HD637B01X0 (Limiting Supplies. For Development Only.) The HD63701X0 is a high performance 8-bit CMOS single chip microcomputer unit (MCU) which, including 4k bytes of EPROM, is object code compatible with the HD6301X0. The HD63701X0 contains 4k bytes of EPROM, 192 bytes of RAM, serial communication interface and 53 parallel I/O pins in addition to CPU. It includes functions of halt, memory ready, low speed access and releasing external bus for system expansion. The HD 63701X0 is available in a hermetically scaled 64-pin shrunk ceramic package which includes a glass window that allows for programming and EPROM crasure in the same way as 2732A type EPROM. #### **■ FEATURES** - Instruction Set Compatible with the HD6301X0 and 6801 - 4k Bytes of EPROM (compatible with 2732A type) - 192 Bytes of RAM - 53 Parallel I/O Pins - 24 I/O Common Pins (Port 2, 3, 6) - 21 Output Pins (Port 1, 4, 7) - 8 Input Pins (Port 5) - Driving Darlington Transistor (Port 2, 6) - 16-bit Programmable Timer Input Capture Register x 1 - Free Running Counter x 1 - Output Compare Register x 2 8-bit Reloadable Timer - **External Event Count** - Spare Wave Generation Serial Communication Interface (SCI) - Asynchronous Mode/Clock Synchronous Mode 3 Transfer Formats (Asynchronous Mode) - 6 Clock Sources - Memory Ready for Low Speed Memory Access - Halt - Error-Detection (Address Error, Op-code Error) - Interrupts 3 External, 7 Internal - Operation Mode - Mode 1 -- Expanded (Internal ROM Inhibited) MCU Mode - Mode 2 - Expanded (Internal ROM Valid) Mode 3 - Single-chip Mode - EPROM Mode - Up to 65k Bytes of Address Space - Low Power Dissipation Mode - Sleep Standby - Minimum Instruction Execution Time $0.5\mu s$ (f=2.0MHz) - Wide Operation Range $$V_{CC}=5V\pm10\%$$ $f=0.5$ to 1.0MHz; HD63701X0 $f=0.5$ to 1.5MHz; HD637A01X0 $f=0.5$ to 2.0MHz; HD637B01X0 #### [Precautions on using EPROM On-chip Single-chip Microcomputer] - (1) If the MCU is exposed to strong light especially a fluorescent lamp or the sunlight, EPROM data may be erased or the MCU may malfunction by photocurrent. Therefore, after programming, it is suggested that applications which expose the LSI to ambient light may require an opaque label over the window. - (2) Do not rub the window with materials like plastics, or do not touch a charged body on the window. Electro static charge may adversely affect the functionality of the LSI. A conductive opaque label, suggested above, is effective on distributing charge equally. #### ■ PROGRAM DEVELOPMENT SUPPORT TOOLS - Cross assembler and C compiler software for IBM PCs and compatibles - In circuit emulator for use with IBM PCs and compatibles - Programming socket adapter for programming the EPROM-on-chip device. #### **■ BLOCK DIAGRAM** #### **ABSOLUTE MAXIMUM RATINGS** | Item | Symbol | Value | Unit | |-----------------------|------------------|-----------------------------|------| | Supply Voltage | V <sub>cc</sub> | -0.3 ~ +7.0 | V | | Program Voltage | V <sub>PP</sub> | -0.3~ +22 | V | | Input Voltage | Vin | -0.3 ~ V <sub>CC</sub> +0.3 | ٧ | | Operating Temperature | Topr | 0~+70 | °c | | Storage Temperature | T <sub>stg</sub> | -55 ∼ +125 | °c | (Note) This product has protection circuits in input terminal from high static electricity voltage and high electric field. But be careful not to apply overvoltage more than maximum ratings to these high input impedance protection circuits. To assure the normal operation, we recommend Vin, Vout: VSS (Vin or Vout) VCC. #### **ELECTRICAL CHARACTERISTICS** DC CHARACTERISTICS ( $V_{CC} = 5V \pm 10\%$ , f = 0.1 to 2.0 MHz, $V_{SS} = V_{PP} = 0V$ , Ta = -20 $\sim$ +70°C, unless otherwise noted). | lten | 1 | Symbol | Test Condition | V <sub>CC</sub> -0.5 - V <sub>CC</sub> +0.3 2.0 - 0.8 5V - 1.0 2.4 V <sub>CC</sub> -0.7 | Unit | | | |--------------------------------------------|-----------------------------------------|------------------|----------------------------------------------|--------------------------------------------------------------------------------------------|------|---------|-----| | | RES, STBY, MPo, MP1 | | | V <sub>CC</sub> -0.5 | | | | | Input "High" Voltage | EXTAL | ViH | | V <sub>CC</sub> x0.7 | | Vcc+0.3 | l v | | | | - 413 | | | | 1 0,00 | • | | | Other Inputs | | | 2.0 | | | | | Input "Low" Voltage | All Inputs | VIL | | -0.3 | | 8.0 | V | | Input Leakage Current | NMI, RES, STBY,<br>MPo, MP1, Port 5 | l <sub>in</sub> | $V_{in}$ =0.5 $\sim V_{CC}$ -0.5V | | - | 1.0 | μΑ | | Three State (off-state)<br>Leakage Current | Ports 1, 2, 3, 4, 6, 7 | I <sub>TSI</sub> | V <sub>in</sub> =0.5 ~ V <sub>CC</sub> -0.5V | _ | _ | 1.0 | μΑ | | Output "High" Voltage | All Outputs | ., | I <sub>OH</sub> =-200μA | 2.4 | | _ | V | | Output riigit voitage | An Outputs | V <sub>OH</sub> | I <sub>OH</sub> =-10μA | V <sub>CC</sub> -0.7 | _ | | ٧ | | Output "Low" Voltage | | VOL | I <sub>OL</sub> =1.6mA | | | | | | - Voltage | All Outputs | *OL | .0L | _ | | 0.4 | V | | <b>Darlington Drive Current</b> | | -l <sub>он</sub> | V <sub>ou1</sub> =1.5V | 1.0 | _ | 10.0 | mA | | Input Capacitance | All Inputs (Except V <sub>PP</sub> /OE) | C <sub>in</sub> | V <sub>in</sub> =0V, f=1MHz,<br>Ta=25°C | - | _ | 12.5 | pF | | | V <sub>PP</sub> /OE | | 114-25 C | _ | _ | 25.0 | рF | | Standby Current | Non Operation | I <sub>STB</sub> | | - | 3.0 | 15.0 | μА | | | | | Sleeping (f=1MHz**) | - | 1.5 | 3.0 | mA | | | | ISLP | Sleeping (f=1.5MHz**) | _ | 2.3 | 4.5 | mA | | Current Dissipation* | | | Sleeping (f=2MHz**) | | 3.0 | 6.0 | mA | | Current Dissipation | | | Operating (f=1MHz**) | _ | 7.0 | 10.0 | mA | | | | lcc | Operating (f=1.5MHz**) | | 10.5 | 15.0 | mA | | | | | Operating (f=2MHz**) | | 14.0 | 20.0 | mA | | RAM Standby Voltage | | VRAM | | 2.0 | _ | - | ٧ | typ. value $(f = X MHz) = typ. value (f = 1MHz) \times X$ max. value (f = X MHz) = max. value (f = 1MHz) $\times X$ (both the sleeping and operating) <sup>\*</sup>VIH min = VCC- 1.0V, VIL max = 0.8V (All output terminals are at no load.) \*\*Current Dissipation of the operating or sleeping condition is proportional to the operating frequency. So the typ. or max. values about Current Dissipations at x MHz operation are decided according to the following formula; ### • AC CHARACTERISTICS ( $V_{CC} = 5V \pm 10\%$ , f = 0.1 to 2.0 MHz, $V_{SS} = V_{PP} = 0V$ , Ta = 0 $\sim +70$ °C, unless otherwise noted). #### BUS TIMING | | | | Test | HE | 63701 | XO | HD | 637A01 | X0 | HD | 637B01 | X0 | Unit | |--------------------------|------------|------------------|-------------------|----------|--------------|-----|----------|----------|-----|----------|----------|----------|------------------| | Item | | Symbol | Condition | min | typ | max | min | typ | max | min | typ | max | | | Cycle Time | | t <sub>cyc</sub> | | 1 | - | 10 | 0.666 | - | 10 | 0.5 | | 10 | μs | | Enable Rise Time | | ter | | 1 | _ | 25 | _ | - | 25 | - | | 25 | ns | | Enable Fall Time | | ter | | _ | - | 25 | _ | _ | 25 | - | | 25 | ns | | Enable Pulse Width "Hi | gh" Level* | PWEH | 1 | 450 | - | - | 300 | | - | 220 | | | ns | | Enable Pulse Width "Lo | w" Level* | PWEL | | 450 | - | | 300 | _ | - | 220 | | | ns | | Address, R/W Delay Tir | ne* | t <sub>AD</sub> | | _ | | 250 | | | 190 | | | 160 | ns | | Data Delay Time | Write | t <sub>DDW</sub> | | | | 200 | - | _ | 160 | | | 120 | ns | | Data Set-up Time | Read | tosa | Fig. 1 | 80 | | | 70 | | - | 70 | | <u> </u> | ns | | Address, R/W Hold Tin | ne * | t <sub>AH</sub> | ''y.' | 70 | | _ | 45 | | | 30 | | <u> </u> | ns | | | Write" | t <sub>HW</sub> | ] | 70 | | | 50 | | | 35 | <u> </u> | | ns | | Data Hold Time | Read | tHR | | 0 | | _ | 0 | | | 0 | | | ns | | RD, WR Pulse Width* | | PWRW | | 450 | L <u>-</u> _ | | 300 | | - | 220 | | | ns | | RD, WR Delay Time | | TRWD | 1 | _ | - | 40 | <u> </u> | | 40 | - | | 40 | ns | | RD, WR Hold Time | | t <sub>HRW</sub> | 1 | | | 30 | <u> </u> | _ | 30 | - | | 25 | ns | | LIR Delay Time | | tola | 1 | _ | | 200 | | | 160 | | - | 120 | ns | | LIR Hold Time | | THLR | 1 | 10 | - <u> </u> | - | 10 | - | | 10 | <u> </u> | | ns | | MR Set-up Time* | | tsmr | | 400 | - | | 280 | | | 230 | <u> </u> | | ns | | MR Hold Time* | | tHMR | Fig. 2 | | | 90 | <u> </u> | | 40 | <u> </u> | <u> </u> | 0 | ns | | E Clock Pulse Width at | MR | PWEMR | 1 | <u> </u> | | 9 | | <u> </u> | 9 | | _ | 9 | μs | | Processor Control Set- | ıp Time | t <sub>PCS</sub> | Fig. 3,<br>10, 11 | 200 | | _ | 200 | | _ | 200 | | <u> </u> | ns | | Processor Control Rise | Time | t <sub>PCr</sub> | 5:- 2.2 | - | - | 100 | <u> </u> | - | 100 | | | 100 | ns | | Processor Control Fall | Time | tpcf | Fig. 2, 3 | _ | | 100 | _ | <u> </u> | 100 | _ | <u> </u> | 100 | ns | | BA Delay Time | | tBA | Fig. 3 | T- | - | 250 | - | | 190 | | | 160 | ns | | Oscillator Stabilization | Time | tac | Fig. 11 | 20 | T- | T - | 20 | | _ | 20 | | | ms | | Reset Pulse Width | | PWRST | | 3 | _ | _ | 3 | T - | I - | 3 | | | t <sub>cyc</sub> | These timings change in approximate proportion to t<sub>CYC</sub>. These figures characteristically represent those when t<sub>CYC</sub> is minimum (= in the highest speed operation). #### PERIPHERAL PORT TIMING | | | Ι | Test HD63701X0 | | | X0 | HD637A01X0 | | | HD | 1X0 | Unit | | |-------------------------------------------------------------|------------------|-------------------|----------------|-----|-----|-----|------------|-----|-----|-----|-----|------|----| | lte | m | Symbol | Condition | min | typ | max | min | typ | max | min | typ | max | | | Peripheral Data<br>Set-up Time | Ports 2, 3, 5, 6 | t <sub>PDSU</sub> | Fig. 5 | 200 | _ | | 200 | _ | - | 200 | - | _ | ns | | Peripheral Data<br>Hold Time | Ports 2, 3, 5, 6 | t <sub>PDH</sub> | Fig. 5 | 200 | _ | _ | 200 | _ | - | 200 | | | ns | | Delay Time (Enal<br>positive Transitio<br>Peripheral Data V | n to 3 4 6 7 | t <sub>PWED</sub> | Fig. 6 | - | - | 300 | _ | - | 300 | - | _ | 300 | ns | TIMER, SCI TIMING | 1. | tem | Symbol | Test | н | 63701 | X0 | н | D637A0 | 01 X O | HD | 637B01 | X0 | Unit | |---------------------------------|---------------------------------|--------------------|-----------|-----|-------|-----|-----|--------|--------|-----|--------|-----|-------------------| | | (eiii | Symbol | Condition | min | typ | max | min | typ | max | min | typ | max | Unit | | Timer 1 Input | t Pulse Width | t <sub>PWT</sub> | Fig. 8 | 2.0 | - | - | 2.0 | - | _ | 2.0 | - | _ | teye | | | nable Positive<br>Timer Output) | t <sub>TOD</sub> | Fig. 7 | - | - | 400 | - | - | 400 | _ | _ | 400 | ns | | SCI Input | Async. Mode | | Fig. 8 | 1.0 | _ | - | 1.0 | _ | _ | 1.0 | | _ | t <sub>cyc</sub> | | Clock Cycle | Clock Sync. | t <sub>Scyc</sub> | Fig. 4, B | 2.0 | - | - | 2.0 | _ | - | 2.0 | - | | teye | | SCI Transmit<br>Time (Clock S | | t <sub>TXO</sub> | | - | - | 200 | _ | - | 200 | - | - | 200 | ns | | SCI Receive D<br>Time (Clock S | | t <sub>SRX</sub> | Fig. 4 | 290 | - | - | 290 | - | - | 290 | - | - | ns | | SCI Receive D<br>(Clock Sync. I | )ata Hold Time<br>Mode) | t <sub>HRX</sub> | | 100 | - | _ | 100 | - | - | 100 | _ | _ | ns | | SCI Input Clo | ck Pulse Width | t <sub>PWSCK</sub> | | 0.4 | - | 0.6 | 0.4 | _ | 0.6 | 0.4 | - | 0.6 | t <sub>Scyc</sub> | | Timer 2 Input | Clock Cycle | t <sub>tcyc</sub> | 1 | 2.0 | _ | | 2.0 | - | _ | 2.0 | - | - | t <sub>cyc</sub> | | Timer 2 Input<br>Width | Clock Pulse | †PWTCK | Fig. 8 | 200 | | | 200 | _ | - | 200 | - | - | ns | | Timer 1·2, SC<br>Rise Time | I Input Clock | t <sub>CKr</sub> | | - | - | 100 | - | _ | 100 | - | - | 100 | ns | | Timer 1-2, SC<br>Fall Time | I Input Clock | t <sub>CKf</sub> | | - | - | 100 | - | - | 100 | _ | - | 100 | ns | Figure 1 Mode 1, Mode 2 Bus Timing Figure 2 Memory Ready and E Clock Timing **OHITACHI** 682 Figure 3 HALT and BA Timing Figure 4 SCI Clocked Synchronous Timing Figure 5 Port Data Set-up and Hold Times (MCU Read) Figure 6 Port Data Delay Times (MCU Write) (a) Timer 1 Output Timing (b) Timer 2 Output Timing Figure 7 Timer Output Timing **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 683 Figure 8 Timer 1-2, SCI Input Clock Timing Figure 9 Bus Timing Test Loads (TTL Load) Figure 10 Interrupt Sequence Figure 11 Reset Timing (1) HITACHI 684 - EPROM PROGRAMMING ELECTRICAL CHARACTERISTICS - DC CHARACTERISTICS (V<sub>CC</sub>=5V±5%, V<sub>PP</sub>=21V±0.5V, V<sub>SS</sub>=0V, Ta=25°C±5°C, unless otherwise noted.) | Item | Symbol | Test Condition | min | typ | max | Unit | | |-----------------------|-----------------|----------------------------------------|------|-----|----------------------|------|--| | Program Voltage | Vpp | | 20.5 | 21 | 21.5 | V | | | Program Current | lpp | $V_{pp} = 21V, \overline{CE} = V_{IV}$ | _ | _ | 30 | mA | | | Input Leakage Current | 1,1 | V <sub>in</sub> =5.25V/0.4V | _ | | 10 | μА | | | Input "Low" Voltage | V <sub>IL</sub> | | -0.1 | - | 0.8 | ٧ | | | Input "High" Voltage | VIH | | 2.2 | | V <sub>CC</sub> +1.0 | ٧ | | | Output "Low" Voltage | VoL | I <sub>OL</sub> + 1.6mA | _ | | 0.45 | V | | | Output "High" Voltage | V <sub>OH</sub> | I <sub>OH</sub> =-200 μA | 2.4 | | _ | V | | ### AC CHARACTERISTICS (V<sub>CC</sub>=5V±5%, V<sub>PP</sub>=21V±0.5V, V<sub>SS</sub>=0V, Ta=25°C±5°C, unless otherwise noted.) | item | Symbol | Test Condition | min | typ | max | Unit | |-------------------------------|-----------------|--------------------------------------------------|-----|-----|-----|------| | Address Set-up Time | tas | <del> </del> | 2 | _ | - | μs | | Address Hold Time | t <sub>AH</sub> | | 0 | | - | μs | | OE Set-up Time | toes | | 2 | - | _ | μς | | OE Hold Time | toeh | | 2 | - | | μs | | Data Set-up Time | t <sub>DS</sub> | | 2 | - | T | μs | | Data Hold Time | t <sub>DH</sub> | | 2 | - | | μs | | Output Disable Delay Time | t <sub>DF</sub> | | 0 | - | 130 | ns | | Data Valid from CE | t <sub>DV</sub> | CE=VIL, OE=VIL | - | | 1 | μς | | CE Pulse Width | tpw | | 45 | 50 | 55 | ms | | OE Pulse Rise Time | tPRT | | 50 | _ | | ns | | V <sub>po</sub> Recovery Time | tvR | | 2 | - | - | μs | (Note) top is defined when output becomes open because output level can not be refered. Figure 12 EPROM Programming Timing #### **■ FUNCTIONAL PIN DESCRIPTION** #### v<sub>cc</sub>, v<sub>ss</sub> $V_{CC}$ and $V_{SS}$ provide power to the MCU with 5V $\pm$ 10% supply. $V_{SS}$ pin should be tied to ground. #### XTAL, EXTAL These two pins interface a crystal (an AT-cut type). Divideby-four circuit is on chip. When 4MHz crystal is used, the system clock is 1MHz for example. EXTAL pin may be driven with an external clock of 45 to 55% duty, and one fourth frequency of the external clock is produced in the LSI. The external clock frequency should be less Figure 13 Connection Circuit than four times of the maximum frequency. When using the external clock, XTAL pin should be open. Fig. 13 shows an example of connection circuit. The crystal and $C_{L1}$ , $C_{L2}$ should be mounted as close as possible to XTAL and EXTAL pins. Any line must not cross the line between the crystal and XTAL, EXTAL. #### • STEV This pin is used for standby mode or EPROM mode. In standby mode, the oscillation may be stopped. To retain the contents of RAM at standby, "0" should be written into RAM enable bit (RAMW). RAME is the bit 6 of the RAM/port 5 control register at \$0014. RAM is disabled by this operation and its contents is sustained. Refer to "LOW POWER DISSIPATION MODE" for standby mode. When this pin and Mode Program pins, MP<sub>0</sub> and MP<sub>1</sub>, are "Low" level, the MCU is in EPROM mode. Refer to "PROGRAMMING THE EPROM" for details. #### Reset (RES) This pin is used to reset the MCU's internal state and provide a startup procedure. During power up, RES pin must be held below "Low" level for more than 20 ms. The CPU registers (accumulator, index register, stack pointer, condition code register except for interrupt mask bit), RAM and data registers of ports are not initialized during reset, so their contents are unknown in a startup procedure. To reset the MCU during operation, RES should be held "Low" for at least 3 system-clock cycles. At the 3rd cycle, all the address buses become "High". When RES remains "Low", the address buses keep "High". If RES turns "High", the MCU restart sequence is: - (1) Latch the value of the mode program pins: MP0 and MP1. - (2) Initialize each internal register (refer to Table 5). - (3) Set the interrupt mask bit. For the CPU to recognize the maskable interrupts IRQ<sub>1</sub>, IRQ<sub>2</sub> and IRQ<sub>3</sub>, this bit should be cleared in advance. - (4) Put the contents (=start address) of the last two addresses (\$FFFE, \$FFFF) into the program counter and start the program from this address. (Refer to Table 1). - The MCU is unable to accept a reset input until the clock becomes normal oscillation after power on (max. 20ms). During this transient time, the MCU and I/O pins are undefined. Please be aware of this for system designing. #### ● Enable (E) This pin provides a TTL-compatible clock used for bus synchronization. Its frequency is one fourth that of the internal oscillator or external clock. This pin can drive one TTL load and 90pF capacitance. #### ● Non-Maskable Interrupt (NMI) When the negative edge of the input signal is detected at this pin, the CPU will begin a non-maskable interrupt sequence. But the current instruction will be completed before it responds to the request. The interrupt mask bit of the condition code register doesn't affect non-maskable interrupt at all. When the interrupt occurs, the contents of the program counter, the index register, the accumulators and the condition code register will be pushed onto the stack. Upon completion of this sequence, a vector is fetched from SFFFC and SFFFD, transferred their contents to the program counter and the non-maskable interrupt service routine starts. After reset, the stack pointer should be initialized on an appropriate memory area before NMI input. #### ● Interrupt Request (IRQ , IRQ ,) These are level-sensitive pins which request an internal interrupt sequence. At interrupt request, the CPU will complete the current instruction before it responds to the request. If the interrupt mask in the condition code register is clear, the CPU will begin an interrupt sequence; if set, the interrupt request will be ignored. When the sequence starts, the contents of the program counter, the index register, the accumulators and the condition code register will be pushed onto the stack, then the interrupt mask bit will be set and inhibits all maskable interrupt. Finally, a vector is fetched from an address depicted in Table 1 and transferred to the program counter, and instruction execution is resumed. The external interrupt pins, $\overline{IRQ_1}$ and $\overline{IRQ_2}$ are also used for port pins $P_{50}$ and $P_{51}$ , so it is controlled by Bit 0 and 1 of the RAM/port 5 control register at \$0014. Refer to "RAM/PORT 5 CONTROL REGISTER" for details. One of the internal interrupts, ICI, OCI, TOI, CMI or SIO can generate an internal interrupt (IRQ<sub>0</sub>). IRQ<sub>1</sub> function is just the same as $\overline{\text{IRQ}}_1$ or $\overline{\text{IRQ}}_2$ except the vector address. Fig. 14 shows the block diagram of the interrupt circuit. #### ● Mode Program (MP<sub>o</sub>, MP<sub>1</sub>) These two pins decide the operation mode. Refer to "MODE SELECTION" for more details. **@ HITACHI** Table 1 Interrupt Vector Memory Map | | Ved | ctor | Interrupt | |--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------| | Priority | Vector MSB LSB FFFE FFFF FFEE FFFF FFFC FFFD FFFA FFFB FFF6 FFF7 FFF4 FFF5 FFF2 FFF3 FFEC FFED | LSB | menup | | Highest | FFFE | FFFF | RES | | <b>†</b> | FFEE | FFEF | TRAP | | | FFFC | FFFD | NMI | | l | FFFA | FFFB | SWI (Software Interrupt) | | | FFF8 | FFF9 | ÎRQ, | | | FFF6 | FFF7 | ICI (Timer 1 Input Capture) | | | FFF4 | FFF5 | OCI (Timer 1 Output Compare 1, 2) | | | FFF2 | FFF3 | TOI (Timer 1 Overflow) | | | FFEC | FFED | CM1 (Timer 2 Counter Match) | | | FFEA | FFEB | IRQ <sub>2</sub> | | <b>▼</b><br>Lowest | FFF0 | FFF1 | SIO (RDRF+ORFE+TDRE) | Figure 14 Interrupt Circuit Block Diagram The following signal descriptions are applied only for expanded mode. #### Read/Write (R/W; P72) This signal, usually in read state ("High"), shows whether the MCU is in read ("High") or write ("Low") state. This can drive one TTL load and 30pF capacitance. #### RD, WR (P10, P11) These outputs will turn "Low" when the CPU read/write operation is completed. This enables the CPU easy to access the peripheral LSI with $\overline{RD}$ and $\overline{WR}$ input pins. These pins can drive one TTL load and 30pF capacitance. #### Load Instruction Register (LIR; P73) This is output for the instruction opecode on data bus (active low). This pin can drive one TTL load and 30pF capacitance. #### Memory Ready (MR; P<sub>52</sub>) This input is used to stretch the system clock's "High" period in order to access low-speed memories. During this signal being in "High", the system clock operates in normal sequence. But in "Low", the "High" period of the system clock will be stretched in integral multiples of the cycle time. This allows the CPU to interface with low-speed memories (See Fig. 2). Up to 9µs can be stretched. During internal address access or nonvalid memory access, MR is prohibited internally to prevent decrease of operation speed. Even in the halt state, MR can also stretch "High" period of system clock to allow peripheral devices to access low-speed memories. As this pin is used also for P<sub>32</sub>, an enable bit is provided at bit 2 of the RAM/port 5 control register at \$0014. Refer to "RAM/PORT 5 CONTROL REGISTER" for more details. ### ● Halt (HALT; P<sub>53</sub>) This input is used to stop instruction execution or to release buses free. When this signal turns "Low", the CPU will be in the halt state after completing the current instruction. During the halt state, BA $(P_{74})$ is in "High", and an address bus, data bus, $\overline{RD}$ , $\overline{WR}$ and $R/\overline{W}$ are high impedance. When an interrupt is requested in the halt state, the CPU responds to the interrupt request after the halt is cancelled. When halted during the sleep state, the CPU keeps the sleep state, and BA is "High" and the buses are high impedance. Then the CPU returns to the previous sleep state when the HALT goes "High" (Note) When the CPU is interrupt wait state in WAI instruction execution, HALT should be held "High". If HALT turns "Low", the CPU may malfunction after releasing the halt Bus Available (BA; P<sub>74</sub>) This output is normally "Low" but "High" when the CPU accepts HALT and releases the buses. The HD6800 and HD6802 make BA "High" and release the buses at WAI execution, while the HD63701X0 doesn't make BA "High" under the same condition. The following pin functions are applied only in EPROM mode. Refer to "PROGRAMMING THE EPROM" for details of EPROM mode. #### Chip Enable (CE; P<sub>57</sub>) This pin is input for programming and verifying the EPROM. When this pin is "Low" level, EPROM will be enable. The EPROM can not be programmed or verified in "High" #### Program Voltage/Output Enable (V<sub>PP</sub>/OE) This pin is used for program voltage and data output control in verification. Data from Port 3 (EO<sub>0</sub> to EO<sub>7</sub>) can be programmed into the EPROM when applying 21V±0.5V to Vpp and holding CE in "Low" level. The EPROM address is provided to Port 1 and Port 4 (EA, to EA,). In verification, the EPROM data is output from Port 3 (EO, to EO,) when this pin is "Low" level. In "High" level, Port 3 will be high-impedance. In MCU mode, this pin should be connected to VSS. The HD63701X0 has six 8-bit ports and a 5-bit port. Table 2 gives the address of ports and the data direction register and Fig. 15 the block diagrams of each port. Table 2 Port and Data Direction Register Address | Port | Port Address | Data Direction Register | |--------|--------------|-------------------------| | Port 1 | \$0002 | | | Port 2 | \$0003 | \$0001 | | Port 3 | \$0006 | \$0004 | | Port 4 | \$0007 | _ | | Port 5 | \$0015 | _ | | Port 6 | \$0017 | \$0016 | | Port 7 | \$0018 | | #### Port 1 In MCU mode, port 1 is used for an 8-bit output port. In mode 3, port 1 is high impedance during reset, and keeps the state even after reset is released. When the CPU writes on the port I data register, the written data will appear at Port I. Once port 1 gets in the output state, it operates as an output till reset. The CPU can read the Port 1 data register for the bit manipulation instruction. In mode 1 and 2, port 1 is used for lower address buses. This port can drive one TTL load and 90pF capacitance In EPROM mode, port 1 is lower address bus (EA, to EA-) for the EPROM. #### Port 2 An 8-bit input/output port. Its I/O state depends on the data direction register (DDR) of port 2 which provides two bits, bit 0 decides the I/O direction of P20 and bit 1 the I/O direction of P20 to P27 ("0" for input, "1" for output). Port 2 is also used for the timers and the SCI. When used for the timers and the SCI, P21 to P27 are decided I/O regardless of the DDR (except for P20). Port 2 Data Direction Register | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|---|---|---|---|---|---|--------------|----------|--------| | i | _ | _ | - | - | - | - | DDR<br>1 - 7 | DDR<br>O | \$0001 | The DDR of port 2 is cleared at reset and port 2 is configured as an input. This port can drive one TTL and 30pF. In addition, it is capable of sinking 1mA current at Vout=1.5V to drive directly the base of Darlington transistors. #### Port 3 An 8-bit I/O port. I/O state depends on the DDR of Port 3 which has only one bit ("0" for input and "1" for output). It is cleared at reset. In mode 1 and 2, port 3 is used for data bus. This port can drive one TTL load and 90pF capacitance Port 3 is used for data bus (EO, to EO,) of EPROM in Figure 15 Port Block Diagram EPROM mode. In this case, I/O state of Port 3 is selected by $\overline{OE}$ but not the DDR. #### Port 3 Data Direction Register | _ 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---|---|---|---|---|---|---------------------| | _ | - | | 1 | _ | _ | - | Port3<br>DDR \$0004 | #### Port 4 In MCU mode, port 4 is used for an 8-bit output port like Port 1. In mode 1 and 2, it is used for upper address bus. In EPROM mode, $P_{40}$ to $P_{43}$ are used for upper address bus (EA, to EA, ) of EPROM. #### Port 5 An 8-bit input port. The lower 4 bits are used for interrupt, MR, HALT, and $P_{57}$ is $\overline{CE}$ for the EPROM control. #### Port 6 An 8-bit I/O port. This port is programmable as either input or output under software control of the corresponding the DDR ("0" for input, "1" for output). This port can drive one TTL load and 30pF. The DDR of port 6 is cleared at reset. In addition, it is capable to sinking 1mA current at Vout=1.5V to drive directly the base of Darlington transistors. #### • Port 7 A 5-bit output port. In mode 3, port 7 is high impedance during reset and keeps the state even after reset is released. When the CPU writes on the port 7 data register, the written data will appear at Port 7. Once port 7 gets in the output state, it operates as an output till reset. The CPU can read the data register for the bit manipulation instruction. In this case $b_7$ to $b_6$ are "1". In mode 1 and 2, port 7 is used for control signals (RD, WR, R/W, LIR and BA). This port can drive one TTL load and 30pF. #### ■ RAM/PORT 5 CONTROL REGISTER The control register located at \$0014 controls on-chip RAM and port 5. #### RAM/Port 5 Control Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------|------|---|---|------|-----|-----------------------|-----------|--------| | STBY | RAME | - | - | HLTE | MRE | IRQ <sub>2</sub><br>£ | IRQ:<br>E | \$0014 | #### Bit O, Bit 1 IRQ, IRQ, Enable Bit (IRQ,E, IRQ,E) When using $P_{sn}$ and $P_{s1}$ for interrupt pins, write "1" in these bits. When "0", the CPU doesn't accept an external interrupt or a sleep cancellation by the external interrupt. These bits are cleared at reset. #### Bit 2 Memory Ready Enable Bit (MRE) When using P<sub>32</sub> for an input for Memory Ready signal, write "1" in this bit. When "0", the memory ready function is prohibited and P<sub>32</sub> is for port. In mode 3, the memory ready function is prohibited regardless of the value of this bit. This bit is set at reset. #### Bit 3 Halt Enable Bit (HLTE) When using $P_{n3}$ for an input for Halt signal, write "1" in this bit. When "0", the halt function is prohibited. In mode 3, the halt function is prohibited regardless of the value of this bit. This bit is set at reset. (Note) When using P<sub>52</sub> and P<sub>53</sub> for port in mode 1 and 2, MRE and MLTE must be cleared after reset. #### Bit 4. Bit 5 Not Used. #### Bit 6 RAM Enable (RAME) The RAM is controlled by this bit. It is set at reset and the RAM is enabled. This bit is programmable by software. When the RAM is disabled (=logic "0"), the CPU can access an external memory. This bit should be cleared at the beginning of standby mode to protect the RAM data. #### Bit 7 Standby Power Bit (STBY PWR) This bit is cleared whenever $V_{CC}$ decreases below $V_{RAM}$ (min). This is a read/write status bit by software. If this bit is set before standby mode, it indicates that $V_{CC}$ is applied and the RAM is valid. (1) HITACHI #### ■ MODE SELECTION The HD63701X0 provides two fundamental modes, MCU mode and EPROM mode. MCU mode is grouped into three; two expanded modes (mode 1, mode 2) and a single chip mode (mode 3). These operating modes are selectable by mode program pins, MP<sub>0</sub> and MP<sub>1</sub>, and standby pin, $\overline{STBY}$ as shown in Table 3. #### Mode 1 (Expanded Mode) In this mode, Port 3 is data bus, Port 1 is lower address bus and Port 4 is upper address bus to interface with the HMCS6800 buses. Port 7 is used for control signal such as R/W. In mode 1, the EPROM is disable and external address space are expandable up to 65k bytes (refer to Fig. 16). #### Mode 2 (Expanded Mode) This mode is also expanded mode. But in mode 2, address space is expandable up to 61k bytes and the EPROM is enable (refer to Fig. 17). #### Mode 3 (Single-chip Mode) In this mode, all ports are available (refer to Fig. 18). #### ● EPROM Mode In this mode, the EPROM can be programmed. Refer to "PROGRAMMING THE EPROM" for details. #### Mode and Ports Table 4 shows the MCU signals in each mode. Table 3 Mode Selection | Mode | | MPı | MPo | STBY | EPROM | RAM | Interrupt Vector | Operation Mode | |-----------|----|-----|-----|------|-------|----------|------------------|------------------------| | | 1 | "L" | "H" | • | E | (Note 1) | E | Expanded Mode | | MCU Mode | 2 | "H" | "L" | * | 1 | (Note 1) | ı | Expanded Mode | | | 3 | "H" | "H" | * | ı | 1 | 1 | Single-chip Mode | | EPROM Mod | le | "L" | "L" | "L" | ı | • | • | EPROM Programming Mode | <sup>&</sup>quot;L"=Logic "0", "H"=Logic "1", I; Internal, E; External, \*; Don't care (Note 1) The RAM address area will be external by clearing RAME bit at \$0014. Table 4 MCU Signals in Each Mode | Mode | | MCU Mode | EPROM Mode | | |--------|------------------------|-------------------------|-------------|----------------------------------| | Port | Mode 1 | Mode 2 | Mode 3 | Er Now Wode | | Port 1 | Address Bus (Ao ~ A7) | Address Bus (A o ~ A 7) | Output Port | Address Bus (EAo ~ EA7) | | Port 2 | I/O Port | I/O Port | I/O Port | No use (Note 3) | | Port 3 | Data Bus (Do ~:D7) | Data Bus (Do ~ D1) | I/O Port | Data Bus (EOo ~ EO7) | | Port 4 | Address Bus (As ~ A15) | Address Bus (As ~ A15) | Output Port | Address Bus (EAs ~EA11) (Note 1) | | Port 5 | Input Port | Input Port | Input Port | CE (P57) (Nate 2) | | Port 6 | I/O Port | I/O Port | I/O Port | No use (Note 3) | | Port 7 | RD, WR, R/W, LIR, BA | RD, WR, R/W, LIR, BA | Output Port | No use (Note 3) | <sup>(</sup>Note 1) Use only 4 pins Pag to Pag, Pag to Pag are not used. <sup>(</sup>Note 2) 7 pins Pso to Pss are not used. <sup>(</sup>Note 3) Unused ports should be connected to Vss. Figure 16 MCU Mode; Mode 1 Figure 17 MCU Mode; Mode 2 Figure 18 MCU Mode; Mode 3 Figure 19 EPROM Mode #### ■ MEMORY MAP The MCU has ability to access a 65k byte memory space depending on the operating mode. A memory map for each operating mode is shown in Fig. 20. The first 32 locations of each map are reserved for the MCU's internal register area, as shown in Table 5. Table 5 Internal Register | Address | Registers | R/W*** | Initialize at RESET | |---------|------------------------------------|----------|---------------------| | 00 | - | | | | 01 | Port 2 Data Direction Register | <u>w</u> | \$FC | | 02* | Port 1 | R/W | Undefined | | 03 | Port 2 | R/W | Undefined | | 04* | Port 3 Data Direction Register | W | \$FE | | 05 | - | _ | | | 06* | Port 3 | R/W | Undefined | | 07* | Port 4 | R/W | Undefined | | 08 | Timer Control/Status Register 1 | R/W | \$00 | | 09 | Free Running Counter ("High") | R/W | \$00 | | 0A | Free Running Counter ("Low") | R/W | \$00 | | OB | Output Compare Register 1 ("High") | R/W | \$FF | | OC OC | Output Compare Register 1 ("Low") | R/W | \$FF | | 0D | Input Capture Register ("High") | R | \$00 | | 0E | Input Capture Register ("Low") | R | \$00 | | 0F | Timer Control/Status Register 2 | R/W | \$10 | | 10 | Rate, Mode Control Register | R/W | \$00 | | 11 | Tx/Rx Control Status Register | R/W | \$20 | | 12 | Receive Data Register | R | \$00 | | 13 | Transmit Data Register | W | \$00 | | 14 | RAM/Port 5 Control Register | R/W | \$7C or \$FC | | 15 | Port 5 | R | _ | | 16 | Port 6 Data Direction Register | w | \$00 | | 17 | Port 6 | R/W | Undefined | | 18* | Port 7 | R/W | Undefined | | 19 | Output Compare Register 2 ("High") | R/W | \$FF | | 1A | Output Compare Register 2 ("Low") | R/W | \$FF | | 18 | Timer Control/Status Register 3 | R/W | \$20 | | 1C | Time Constant Register | w | \$FF | | 1D | Timer 2 Up Counter | R/W | \$00 | | 1E | | | - | | 1F** | Test Register | _ | | <sup>\*</sup> External Address in Mode 1, 2. <sup>\*\*</sup> Test Register. Do not access to this register. R : Read Only Register W : Write Only Register R/W: Read/Write Register Figure 20 HD63701X0 Memory Map #### PROGRAMMING THE EPROM The HD63701X0 does not operate as the MCU in EPROM mode, which allows to be programmable as equivalent EPROM 2732A type. When three pins, MP<sub>0</sub>, MP<sub>1</sub> and $\overline{STBY}$ should be held low, the MCU will be in EPROM mode as shown in Table 3. In this mode, P<sub>30</sub> to P<sub>37</sub> are used for data bus, P<sub>10</sub> to P<sub>17</sub> and P<sub>40</sub> to P<sub>43</sub> for address bus, and P<sub>57</sub> for $\overline{CE}$ input. (Refer to Fig. 19.). #### • Programming/Verification When $\overline{CE}$ pin is held low after the program voltage $(V_{PP})$ is applied to $V_{PP}/\overline{OE}$ pin, the data byte can be applied to Port 3. When $V_{PP}/\overline{OE}$ pin and $\overline{CE}$ pin are held low after programming, the programmed data is output from Port 3 and user can verify the data. I/O timing of these signals are referred to Fig. 12. When CE pin is returned to high, Port 3 will be tri-state and EPROM programming/verification will be inhibited. Table 6 shows the condition of the each pin is EPROM mode. Unused pins should be connected to GND in EPROM mode. #### Erasure Erasure of EPROM begins to occur when the LSI is exposed to ultraviolet light (wavelength, 2537 Å, an intensity of at least: 1.5W.sec/cm). Exposing the LSI to an ultraviolet lamp of 1,200 µW/cm² rating for 20 to 30 minutes, at a distance of about 1 inch, should be sufficient. (Note) If the glass window is stained, erasure time will be extended. Remove stains from the window with a solvent which has no influence on the package like alcohol. Don't rub the window hard but wipe out softly. #### ■ TIMER 1 The HD63701X0 has a 16-bit programmable timer which can be used to perform input waveform measurements while generating two independent output waveforms. The pulse width can vary from several microseconds to many seconds. Timer 1 is configurated as follows (refer to Fig. 22). | Table 6 | Pin | Condition | in | EDDOM | mada | |----------|-------|-----------|----|--------|------| | l able b | F 151 | Condition | m | EFRUNN | mone | | Pin | v <sub>cc</sub> | V <sub>SS</sub> | V <sub>PP</sub> /OE | CE | P30 to P37 | P10 to P17<br>P40 to P43 | MPo, MP1, STBY | Other pins | |----------------------------------------|-----------------|-----------------|---------------------|-----|-------------------|--------------------------|----------------|------------| | No. | 33 | 1 | 42 | 24 | 51 to 58 | 43 to 50<br>38 to 41 | 4, 5, 7 | | | Programming | +5 | GND | Vpp | "L" | Data input | Address input | "L" | GND | | Verification | +5 | GND | "L" | "L" | Data output | Address input | "L" | GND | | Inhibition of programming/verification | +5 | GND | Don't care | "H" | High<br>impedance | Don't care | "L" | GND | <sup>&</sup>quot;H"; VIH level, "L": VIL level - · Control/Status Register 1 (8 bit) - Control/Status Register 2 (7 bit) - Free Running Counter (16 bit) - · Output Compare Register 1 (16 bit) - · Output Compare Register 2 (16 bit) - · Input Capture Register (16 bit) #### Free-Running Counter (FRC) (\$0009 : 000A) The key timer element is a 16-bit Free-Running Counter which is incremented by system clock (E). The counter value is readable by software without affecting the FRC. It is cleared by A write to the high byte of the FRC (\$09) will preset the high and low byte of the FRC to \$FFF8. A continuous write to the high and low byte FRC, however, will set them to the write data. high and low byte FRC, however, will set them to the write data. The FRC write timing will be as follows when double store instructions (STD, STX etc.) execute. In the case of a write (\$5AF3) to the FRC. Figure 21 Counter Write Timing #### Output Compare Register (OCR) (\$000B, \$000C; OCR1) (\$0019, \$001A; OCR2) The Output Compare Register is a 16-bit read/write register used to control an output waveform. It is always compared with the FRC on each E-cycle. When a match is found, Output Compare Flag (OCF) in the Timer Control/Status Register (TCSR) is set. If an output enable bit (OE) in the TCSR2 is "1", an output level bit (OLVL) in the TCSR will appear at Port 21 (Tout 1) or Port 25 (Tout 2). The OCR and OLVL can then be changed for the next compare. The OCR is set to \$FFFF at reset. The compare function is inhibited for a cycle after a write to the OCR or to the high byte of the FRC. This is to set the 16-bit value valid in the register for compare. In addition, it is because \$FFF8 is set at the next cycle of a write to the high byte of the FRC. For a write to the FRC or the OCR, 2-byte transfer instruction (such as STX etc.) should be used. #### • Input Capture Register (ICR) (\$000D : 000E) The Input Capture Register is a 16-bit read only register used to store the FRC when an external input transition occures defined by input edge bit (IEDG) in the TCSR1. In order to input the external signal to the edge detective circuit, Port 20 should be configured as an input. When an input capture occures at the next cycle of a read the high-byte of the ICR, the input capture will delay one cycle. In order to ensure the input capture, a read to the ICR needs 2-byte transfer instruction, and the input pulse width should be at least 2 system cycles. This register is cleared (\$0000) at reset. ### • Timer Control/Status Register 1 (TCSR1) (\$0008) The Timer Control/Status Register 1 is an 8-bit register of which all bits are readable while the lower 5 bits can be written. The upper 3 bits indicate the following timer's status. Bit 5 The FCR has overflowed. (TOF). Bit 6 A match has been found between the FCR and the OCR 1 (OCF1). Bit 7 A level transition of the timer input has been detected (ICF). The followings are each bit descriptions. #### Timer Control/Status Register 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----|------|-----|------|-------|------|------|-------|--------| | ICF | OCF1 | TOF | EICI | EOC11 | ETOI | IEDG | OLVLI | \$0008 | #### Bit 0 OLVL1 Output Level 1 When a match is found between the FCR and the OCR1, OLVL1 will appear at Port 21 if OE1, bit 0 of the TCSR2, is set. #### Bit 1 IEDG Input Edge This bit controls which level transition will trigger the FCR transfer to the ICR. For this function, the DDR corresponding to Port 20 should be cleared. IEDG=0, transferred on a negative edge IEDG=1, transferred on a positive edge Bit 2 ETOI Enable Timer Overflow Interrupt When this bit is set, an internal interrupt (IRQ<sub>3</sub>) is enabled for TOI. When cleared, the interrupt is inhibited. Bit 3 EOCi1 Enable Output Compare Interrupt 1 When this bit is set, an internal interrupt (IRQ<sub>3</sub>) is enabled for OCII. When cleared, the interrupt is inhibited. Bit 4 EICI Enable Input Capture Interrupt When this bit is set, an internal interrupt (IRQ3) is enabled for ICI. When cleared, the interrupt is inhibited. Bit 5 TOF Timer Overflow Flag This read only bit is set when the FCR contains all 1's. It is cleared by reading the TCSR1 followed by the FCR's high byte (\$0009). Bit 6 OCF1 Output Compare Flag 1 This read only bit is set when a match is found between the OCR1 and the FRC. It is cleared by writing to the OCR1 (\$000B or \$000C) followed by reading the TCSR1 or TCSR2. #### Bit 7 ICF Input Capture Flag This read only bit is set to indicate a level transition defined by IEDG. It is cleared by reading the high byte (\$000D) of the ICR followed by the TCSR1 or TCSR2. ### Timer Control/Status Register 2 (TCSR2) (\$000F) The Timer Control/Status Register 2 is a 7-bit register. All bits are readable while the lower 4 bits can be written. The upper 3 bits indicate the following timer's status. Bit 5 A match has been found between the FRC and the OCR2 (OCF2). Bit 6 The same flag as the OCF1 of the TCSR1. Bit 7 The same flag as the ICF of the TCSR1. The followings are each bit descriptions. #### Bit O OE1 Output Enable 1 If this bit is set, the OLVL1 will appear at Port 21 when a match is found between the FCR and the OCR1. When it is cleared, Port 21 will be 1/O port. When set, it will be an output of OLVL1 automatically. Bit 1 OE2 Output Enable 2 If this bit is set, the OLVL2 will appear at Port 25 when a match between the FCR and the OCR2. When this bit is cleared, Port 25 will be I/O port. When set, it will be an output of OLVL2 automatically. **@HITACHI** 695 #### Bit 2 OLVL2 Output Level 2 OLVL2 is transferred to Port 25 when a match is found between the FCR and the OCR2. If OE2, bit 5 of the TCSR2, is set, OLVL2 will appear at Port 25. Bit 3 EOCI2 Enable Output Compare Interrupt 2 When this bit is set, an internal interrupt $(IRQ_3)$ is enabled for OC12. When cleared, the interrupt is inhibited. Bit 4 Not Used Bit 5 OCF2 Output Compare Flag 2 This read-only bit is set when a match is found between the FCR and the OCR2. It is cleared by writing to the OCR2 (\$0019 or \$001A) followed by reading the TCSR2. Bit 6 OCF1 Output Compare Flag 1 Bit 7 ICF Input Capture Flag OCF1 and ICF addresses are partially decoded. CPU read of the TCSR1/TCSR2 makes it possible to read OCF1 and ICF into bit 6 and bit 7. Both the TCSR1 and TCSR2 will be cleared by reset. - (Note) If OE1 or OE2 is set before the first output compare match is found after reset, Port 21 and Port 25 will output "0" respectively. - (Note) Because the set condition of ICF precedes its reset condition. ICF is not cleared when the set condition and the reset condition occur simultaneously. The same phenomenon applies to OCF1, OCF2 or TOF respectively. Figure 22 Timer 1 Block Diagram #### TIMER 2 In addition to the timer 1, the HD63701X0 provides an 8-bit reloadable timer, which is capable of counting the external event. This timer 2 contains a timer output, so the MCU can generate three independent waveforms. (Refer to Fig. 23.) The timer 2 is configured as follows: Control/Status Register 3 (7 bit) 8-bit Up Counter Time Constant Register (8 bit) #### • Timer 2 Up Counter (T2CNT) (\$001D) This is an 8-bit up counter which is incremented by the clock controlled by CKS0 and CKS1 of the TCSR3. The T2CNT is always readable without affecting itself. In addition, any value can be written to the T2CNT by software even during counting. The counter is cleared when a match is found between the T2CNT and the TCONR or by reset. A write to the T2CNT at the clear cycle does not reset it but put the data to it. #### • Time Constant Register (TCONR) (\$001C) The Timer Constant Register is an 8-bit write only register. It is always compared with the T2CNT. When a match has been found, counter match flag (CMF) of the Timer Control/Status Register 3 (TCSR3) is set and the value selected by TOSO and TOS1 of the TCSR3 will appear at Port 26. When CMF is set, the FCR will be cleared simultaneously and then a counting starts from \$00. This enables regular interrupts and waveform outputs without any software support. The TCONR is set to "\$FF" by reset. #### Timer Control/Status Register 3 (TCSR3) (\$001B) The Timer Control/Status Register 3 is a 7-bit register. All bits are readable while 6 bits except for CMF can be written. Figure 23 Timer 2 Block Diagram The followings are each bit descriptions. Timer Control/Status Register 3 7 6 5 4 3 2 1 0 CMF ECMI - TZE TOS1 TOSO CKS1 CKS0 \$0018 Bit 0 CKS0 Input Clock Select 0 Bit 1 CKS1 Input Clock Select 1 An input clock to the T2CNT is selected by these bits as shown in Table 7. When an external clock is selected, Port 27 will be an input automatically. The positive edge of the external clock increments the T2CNT. The maximum external clock is half of the system clock frequency. Table 7 Input Clock Select | CKS1 | CKS0 | Input Clock to the Counter | |------|------|----------------------------| | 0 | 0 | E clock | | 0 | 1 | E clock/8* | | 1 | 0 | E clock/128* | | 1 | 1 | External clock | These clocks come from the FRC of the timer 1. If one of these clocks is selected as an input clock to the up counter, a write to the FRC of the timer 1 should be inhibited. Bit 2 TOSO Timer Output Select 0 Bit 3 TOS1 Timer Output Select 1 When a match is found between the T2CNT and the TCONR, timer 2 output selected by these bits shown in Table 8 will appear at Port 26. When both TOS0 and TOS1 are cleared, Port 26 will be an I/O port. Table 8 Timer 2 Output Select | TOS1 | TOS0 | Timer Output | |------|------|------------------------| | 0 | 0 | Timer Output Inhibited | | 0 | 1 | Toggle Output* | | 1 | 0 | Output "0" | | 1 | 1 | Output "1" | When a match is found between the T2CNT and the TCONR, timer 2 output level is reversed. This leads to production of a square wave with 50% duty to the external without any software support. Bit 4 T2E Timer 2 Enable Bit When this bit is cleared, the T2CNT will stop. When set, a clock selected by CKS1 and CKS0 (Table 7) provides to the T2CNT. (Note) P<sub>26</sub> is "0" when T2E is cleared and P<sub>28</sub> is configured as an output by TOSI or TOSO. It also is "0" when T2E is set and P<sub>26</sub> is configured as an output before the first counter match. Bit 5 Not Used Bit 6 ECMI Enable Counter Match Interrupt When this bit is set, an internal interrupt (IRQ<sub>s</sub>) is enabled for CMI. When cleared, the interrupt is inhibited. Bit 7 CMF Counter Match Flag This read only bit is set when a match is found between the T2CNT and the TCONR. It is cleared by writing "0". (It cannot be written "1" by software). Each bit of the TCSR3 is cleared by reset. #### ■ SERIAL COMMUNICATION INTERFACE (SCI) The HD63701X0 SCI provides two operation modes; one is an asynchronous mode by the NRZ format and the other is a clocked synchronous mode to transfer data synchronizing with the serial clock. The serial interface is configured as follows: - Transmit/Receive Control and Status Register (TRCSR) - Rate/Mode Control Register (RMCR) - · Receive Data Register (RDR) - Receive Data Shift Register (RDSR) - · Transmit Data Register (TDR) - · Transmit Data Shift Register (TDSR) The SCI is initialized by software. The procedure is usually as follows: - Write a operation mode into each corresponding control bit of the RMCR. - Write a operation mode into each corresponding control bit of the TRCSR. When setting the baud rate and operation mode, TE and RE should be "0". When TE and RE is set again, more than 1 bit cycle of the current baud rate is necessary. If set in less than 1 bit cycle, the SCI cannot be initialized occasionally. #### Asynchronous Mode An asynchronous mode contains the following two data formats: 1 Start Bit + 8 Bit Data + 1 Stop Bit; 8 Bit Data Format 1 Start Bit + 9 Bit Data + 1 Stop Bit; 9 Bit Data Format In 9 Bit Data Format, if the 9th bit is "1", the format of 1 Start Bit + 8 Bit Data + 2 Stop Bit The SCI is initialized by writing desirable control bytes to the RMCR and then to the TRCSR. The transmit operation is enabled by TE in the TRCSR. When TE is set, the output of the TDSR is connected to P<sub>24</sub> which will be configured as an output regardless of the DDR, and then the serial output is initiated by transmitting to a 10-bit preamble of "1" in the 8 Bit Data Format or an 11-bit preamble of "1" in the 9 Bit Data Format. Following the preamble, the internal synchronization is established and the transmitter section is ready for operation. At this point one of two situation exist: - If the TDR is empty (TDRE=1), a continuous string of ones will be sent indicating an idle line. - If a byte has been written to the TDR (TDRE=0), it is transferred to the TDSR, TDRE will be set and transmission will begin. During the transfer itself, the start bit (0) is first transmitted. Then the 8 data bits or the 9 data bits (beginning with bit 0) followed by the stop bit (1) are transmitted. When the TDR has been emptied, TDRE is set. If the MCU fails to respond to the flag within the proper time, (TDRE is still set when the next normal transfer from the TDR to the TDSR should occure) then a "1" will be sent (instead of a "0") at start bit time, followed by more 1's until more data is supplied to the TDR. No 0's will be sent while TDRE remains as "1". The receive operation is enabled by RE which configures P<sub>23</sub>. The receive operation is controlled by the contents of the TRCSR and the RMCR. The receiver bit interval is divided into 8 sub-intervals for internal synchronization. The received bit stream is synchronized by the first "0" (space) encountered. The approximate center of each bit time is strobed during the next 10 bits. If the tenth bit is not a "1" (stop bit), a framing error is assumed and ORFE is set. If the tenth bit is a "1", the data is transferred to the RDR and interrupt flag RDRF is set. If RDRF is still set at the next tenth bit time, ORFE will be set, indicating an over-run has occurred. When the CPU responds to either flag Figure 24 Serial Communication Interface Block Diagram (C) HITACHI 698 (RDRF or ORFE) by reading the TRCSR followed by reading the RDR, RDRF (or ORFE) will be cleared. (Note) Clock Source in Asynchronous Mode When using an internal clock for the SCI, the following requirements are applicable: - Set CC1 and CC0 to "1" and "0" respectively. - A clock is generated regardless of the value of TE, RE. - · The maximum clock rate is E+16. - · The output clock is the same as the bit rate. When using an external clock for the SCI, the following requirements are applicable: - Set CC1 and CC0 in the RMCR to "1" and "1" respectively. - The external clock should be set 16 times the desired baud rate. - the maximum clock frequency is the same as the system clock. #### Clocked Synchronous Mode In the clocked synchronous mode, the transmit operation is synchronized with the clock pulse. In the clocked synchronous mode an SCI clock I/O pin is only $P_{22}$ , so the receive and transmit operation cannot be simultaneously enabled. Therefore, TE and RE should not be set simultaneously. Fig. 25 gives a synchronous clock and a data format in the clocked synchronous mode. The transmit operation is enabled by TE in the TRCSR. $P_{24}$ is configured as an output regardless of the value of the corresponding DDR. Both the RMCR and TRCSR should be set in the desirable operating conditions for data transmit. If the user wishes to provide an external clock, the data bits (beginning with bit 0) are transmitted from $P_{24}$ , synchronizing with 8 clock pulses supplied to $P_{22}$ , when TDRE is "0". TDRE is set when the TDSR is "empty". More the 9th clock pulse is ignored - Transmit data is sent between the negative edge of a synchronous clock and the next negative edge. - · Receive data is latched at the positive edge Figure 25 Clocked Synchronous Mode Format The receive operation is enabled by RE. $P_{22}$ is configured as an input for the 8 bit external clock and $P_{23}$ is configured as an input for the receive data. The operating mode of data receive is decided by the TRCSR and the RMCR. If the external clock is provided, RE should be set when $P_{22}$ is "High". The receive data is transferred to the RDSR by this clock, and RDRF is set. More the 9th clock pulse are ignored. When RDRF is cleared by reading the RDR, the MCU starts receiving the next data. RDRF, therefore, should be cleared with $P_{22}$ "High". When the first byte data is received, RDRF is set. After the second byte, the receive operation is enabled by clearing RDRF. #### Transmit/Receive Control and Status Register (TRCSR) (\$0011) The TRCSR is an 8 bit register which is readable. Bits 0 to 4 are also writable. This register is initialized to \$20 by reset. Each bit functions as follows. Transmit/Receive Control Status Register #### Bit 0 WU Wake-up In a typical multi-processor configuration, the software protocol will usually identify the address at the beginning of the message. In order to permit uninterested MCU's to ignore the remaining message, a wake-up function is available. By this, uninterested MCU can inhibit all further receive processing till the next message starts. Then wake-up function is triggered by consecutive 1's with 1 frame length (10 bits for the 8-bit data format, or 11 bits for the 9-bit data format). The software protocol should provide the idle time between messages. By setting this bit, the MCU stops data receive till the next message. The receive of consecutive "I" with one frame length wakes up and clears this bit and then the MCU restarts the receive operation. However, the RE flag should be set before setting this bit. In the clocked synchronous mode WU is not available, so this bit should not be set. #### Bit 1 TE Transmit Enable When this bit is set, transmit data will appear at P<sub>24</sub> after one frame preamble in asynchronous mode, while in clocked synchronous mode appear immediately. This is executed regardless of the value of the corresponding DDR. When TE is cleared, the serial I/O doesn't affect D #### Bit 2 TIE Transmit Interrupt Enable When this bit is set, an internal interrupt (IRQ<sub>3</sub>) is enabled when TDRE (bit 5) is set. When cleared, the interrupt is inhibited. #### Bit 3 RE Receive Enable When set, $P_{23}$ is configured as an input for the receive operation regardless of the value of the DDR. When RE is cleared, the serial I/O doesn't affect $P_{23}$ . #### Bit 4 RIE Receive Interrupt Enable When this bit is set, an internal interrupt, IRQ<sub>3</sub> is enabled when RDRF (bit 7) or ORFE (bit 6) is set. When cleared, the interrupt is inhibited. Bit 5 TDRE Transmit Data Register Empty **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 699 TDRE is set when the TDR is transferred to the TDSR in the asynchronous mode, while it is set when the TDSR is "empty" in clocked synchronous mode. This bit is cleared by reading the TRCSR and writing the new transmit data to the TDR. TDRE is set by reset. (Note) TE should be set before clearing TDRE. #### Bit 6 ORFE Overrun Framing Error ORFE is set when an overrun or a framing error is occured (during data receive only). An overrun error occurs when a new receive data is ready to be transferred to the RDR with RDRF still set. A framing error occurs when a stop bit is "0". But in clocked synchronous mode, this bit is not affected. This bit is cleared when reading the TRCSR, then the RDR, or by reset. Bit 7 RDRF Receive Data Register Full RDRF is set when the RDSR is transferred to the RDR. Cleared when reading the TRCSR, then the RDR, or by reset. (Note) When a few bits are set between bit 5 to bit 7 in the TRCSR, a read of the TRCSR is sufficient for clearing those bits. It is not necessary to read the TRCSR everytime to clear each bit. #### Rate/Mode Control Register (RMCR) The RMCR controls the followings: · Baud Rate · Data Format · Clock Source · P22 Function In addition, if 9-bit data format is set in the asynchronous mode, the 9th bit is put in this register. All bits are readable and writable except bit 7 (read only). This register is cleared by reset. These bits select the baud rate when using the internal clock. Table 9 lists the available bit times and baud rates. The timer 1's FRC (SS2=0) and the timer 2's up counter (SS2=1) provide #### Rate/Mode Control Register the internal clock for the SCI. When the source of the SCI internal clock is the timer 2's up counter, the desired baud rates may be selected by the TCONR shown in Table 10. (Note) When operating the SCI with internal clock, do not write to the counter which is the source of the SCI clock. These bits select the data format and the clock source (refer to Table 11). CC0, CC1 and CC2 are cleared and the MCU will be in the clocked synchronous mode (the external clock operation) by reset. Then P22 is forced to be configured as an input for the clock. If using $P_{22}$ for an output, the DDR of port 2 should be set to "1" and CC1, CC0 must be set to Table 9 SCI Bit Times and Rates #### (1) Asynchronous Mode | | | | XTAL | 2.4576MHz | 4.0MHz | 4.9152MHz | | |-----|-----|-----|----------|------------------|--------------------|-------------------|--| | SS2 | SS1 | SSO | E | 614.4kHz | 1.0MHz | 1 2288MHz | | | 0 | 0 | 0 | E÷16 | 26 µs/38400Baud | 16 µs/62500Baud | 13 µs/76800Baud | | | ō | 0 | 1 | E÷128 | 208 //s/4800Baud | 128 /rs/7812.5Baud | 104.2 µs/9600Baud | | | 0 | 1 | 0 | E ÷ 1024 | 1.67ms/600Baud | 1.024ms/976.6Baud | 833.3 µs/1200Baud | | | 0 | i | 1 | F÷4096 | 6.67ms/150Baud | 4 096ms/244 1Baud | 3.333ms/300Baud | | | 1 | _ | _ | | * | * | * | | <sup>\*</sup> When SS2 is "1", Timer 2 provides SCI clocks. The haud rate is shown as follows with the TCONR as N. Baud Rate = $$\frac{f}{32 \text{ (N+1)}}$$ $\left(\begin{array}{c} \text{f: input clock frequency to the} \\ \text{timer 2 counter} \\ \text{N} = 0 \sim 255 \end{array}\right)$ #### (2) Clocked Synchronous Mode \* | | | | X TAL | 4.0MHz | 6.0MHz | 8.0MHz | |-----|-----|-----|--------|------------|-------------|-----------| | SS2 | SS1 | sso | E | 1.0MHz | 1.5MHz | 2.OMHz | | 0 | 0 | 0 | E ÷ 2 | 2 µs/bit | 1.33µs/bit | 1μs/bit | | 0 | 0 | 1 | E ÷ 16 | 16µs/bit | 10.7μs/bit | 8µs/bit | | o | 1 | اه | E÷128 | 128//s/bit | 85.3 µs/bit | 64µs/bit | | o | 1 | 1 | E÷512 | 512µs/bit | 341 µs/bit | 256μs/bit | | 1 | _ | _ | | * * | * * | * * | <sup>\*</sup> Bit rates in the case of internal clock operation. In the case of external clock operation, the external clock is operatable up to DC $\sim 1/2$ system clock. \*\* The bit rate is shown as follows with the TCONR as N. Bit Rate ( $$\mu$$ s/bit) = $\frac{4 (N+1)}{f}$ $\begin{pmatrix} f : \text{ input clock frequency to the timer 2 counter} \\ N = 0 \sim 255 \end{pmatrix}$ Table 10 Baud Rate and Time Constant Register Example | XTAL Baud Rate (Baud) | 2.4576MHz | 3.6864MHz | 4.0MHz | 4.9152MHz | 8.0MHz | |-----------------------|-----------|-----------|--------|-----------|--------| | 110 | 21* | 32. | 35. | 43* | 70' | | 150 | 127 | 191 | 207 | 255 | 51" | | 300 | 63 | 95 | 103 | 127 | 207 | | 600 | 31 | 47 | 51 | 63 | 103 | | 1200 | 15 | 23 | 25 | 31 | 51 | | 2400 | 7 | 11 | 12 | 15 | 25 | | 4800 | 3 | 5 | - | 7 | 12 | | 9600 | 1 | 2 | | 3 | | | 19200 | o | - | Asset | 1 | _ | | 38400 | | _ | | 0 | - | <sup>\*</sup>E/8 clock is provided to the timer 2's up counter. Table 11 SCI Format and Clock Source Control | CC2 | CC1 | CCO | Format | Mode | Clock Source | Port 2, Bit 2 | Port 2, Bit 3 | Port 2, Bit 4 | | |-----|-----|-----|------------|---------------------|--------------|---------------|----------------------------------------|---------------------------|--| | 0 | 0 | 0 | 8-bit data | Clocked Synchronous | External | Input | h | | | | 0 | 0 | 1 | 8-bit data | Asynchronous | Internal | Not Used** | | | | | 0 | 1 | 0 | 8-bit data | Asynchronous | Internal | Output* | When RE is "1", I<br> a serial input. | is "1", bit 3 is used for | | | 0 | 1 | 1 | 8-bit data | Asynchronous | External | Input | l some mpon | | | | 1 | 0 | 0 | 8-bit data | Clocked Synchronous | Internal | Output | } | | | | 1 | 0 | 1 | 9-bit data | Asynchronous | Internal | Not Used** | | | | | 1 | 1 | 0 | 9-bit data | Asynchronous | Internal | Output* | When TE is "1", to a serial output. | oit 4 is used for | | | 1 | 1 | 1 | 9-bit data | Asynchronous | External | Input | u serial output. | | | <sup>\*</sup> Clock output regardless of RE or TE in the TRCSR. #### Bit 6 TD8 Transmit Data Bit 8 When selecting the 9-bit data format in the asynchronous mode, this bit is transmitted as the 9th data. #### Bit 7 RD8 Receive Data Bit 8 When selecting the 9-bit data format in the asynchronous mode, this bit stores the 9th bit data. #### TIMER, SCI STATUS FLAG Table 12 shows set and clear conditions of each status flag in the timer 1, the timer 2 and the SCI. If the flag set and clear conditions occur at the same time, the flag of the Timer 1 and the Timer 2 will be set, and the SCI cleared. Therefore the OCF1 and OCF2 of the Timer 1 may not be cleared correctly because set signal is generated periodically whenever the OCR matches the FRC. In order to clear these flags correctly, the match should be prohibited during the period between reading the TSCR and writing the OCR. For instance, these flags will be cleared correctly if the TCSR is read and the OCR is written continuously soon after matching the value of the OCR and the FCR. Table 12 Timer 1, Timer 2 and SCI Status Flag | | | Set Condition | Reset Condition | |------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------| | | ICF | FRC → ICR by edge input to P <sub>20</sub> . | Read the TCSR1 or TCSR2 then ICRH,<br>when ICF=1 | | | | | 2. RES=0 | | <b>-</b> . | OCF1 | OCR1=FRC | 1. Read the TCSR1 or TCSR2 then write to the OCR1H or OCR1L, when OCF1=1 2. RES=0 | | Timer<br>1 | OCF2 | OCR2=FRC | 1. Read the TCSR2 then write to the OCR2H or OCR2L, when OCF2 = 1 2. RES=0 | | | TOF | FRC=\$FFFF+1 cycle | 1. Read the TCSR1 then FRCH, when TOF = 1 2. RES=0 | | Timer<br>2 | CMF | T2CNT=TCONR | <ol> <li>Write "0" to CMF, when CMF = 1</li> <li>RES=0</li> </ol> | | | RDRF | Receive Shift Register → RDR | <ol> <li>Read the TRCSR then RDR, when RDRF=1</li> <li>RES=0</li> </ol> | | SCI | ORFE | <ol> <li>Framing Error (Asynchronous Mode) Stop Bit = 0</li> <li>Overrun Error (Asynchronous Mode) Receive Shift Register → RDR when RDRF=1</li> </ol> | 1. Read the TRCSR then RDR, when ORFE=1 2. RES=0 | | | TDRE | Asynchronous Mode TDR → Transmit Shift Register Clocked Synchronous Mode Transmit Shift Register is "empty" RES=0 | Read the TRCSR then write to the TDR, when TDRE = 1 (Note) Clear TDRE after setting TE. | <sup>(</sup>Nate) 1. →; transfer <sup>\*\*</sup> Not used for the SCI. <sup>2.</sup> For example; "ICRH" means High byte of ICR. #### LOW POWER DISSIPATION MODE The HD63701X0 provides two low power dissipation modes; sleep and standby. #### Sleep Mode The MCU will be in the sleep mode when SLP instruction is executed. In the sleep mode, the CPU stops and the registers' contents are retained. While the peripherals such as timers, SCI etc. continue their functions. The power dissipation of the sleepcondition is one fifth that of the operating condition. The MCU returns from this mode by an interrupt, RES or STBY; it will be reset by RES and the standby mode by STBY. When the CPU responds to an interrupt request, it cancels the sleep mode, returns to the operation mode and branches to the interrupt routine. When the CPU masks this interrupt, it cancels the sleep mode and executes the next instruction. However, for example if the timer 1 or 2 prohibits a timer interrupt, the CPU doesn't cancel the sleep mode because of no interrupt request. This sleep mode is effective to reduce the power dissipation for a system with no need of the HD63701X0's consecutive operation. #### Standby Mode In MCU mode, the HD63701X0 stops and reset with STBY "low". In this mode, the power dissipation is reduced conspicuously. All pins except for the power supply, STBY and XTAL are detached from the MCU internally and will be the high impedance state. While the contents of RAM is retained. The MCU returns from this mode by reset. The followings are typical usage of this Save the CPU information and SP contents on RAM by NMI. Then disable the RAME bit of the RAM control register and set the STBY PWR bit to go to the standby mode. If the STBY PWR bit is still set at reset, that indicates the power is supplied to the MCU and RAM contents are retained properly. So system can restore itself by returning their pre-standby informations to the SP and the CPU. Fig. 26 depicts the timing at each pin with this example. Figure 26 Standby Mode Timing #### **■ TRAP FUNCTION** The CPU generates an interrupt with the highest priority (TRAP) when fetching an undefined instruction or an instruction from non-memory space. The TRAP prevents the system-burst caused by noise or a program error. #### Op Code Error When fetching an undefined op code, the CPU saves CPU registers as well as a normal interrupt and branches to the TRAP (\$FFEE, \$FFEF). This provides the priority next to reset. #### Address Error When an instruction fetch is made excluding internal ROM, RAM and external memory area, the MCU generates an interrupt as well as an op code error. But on the system with no memory in its external memory area, this error processing is not applicable if an instruction fetch is made from the external nonmemory area. Table 13 provides addresses where an address error occurs to each mode. This processing is available only for an instruction fetch and is not applicable to the access of normal data read/write. Table 13 Addresses Applicable to Address Errors | Mode | 1 | 2 | 3 | |---------|--------|-----------------------|--------| | Address | \$0000 | \$0000<br>}<br>\$001F | \$0000 | (Note) The TRAP interrupt provides a retry function differently from other interrupts. This is a program flow return to the address where the TRAP occurs when a sequence returns to a main routine from the TRAP interrupt routine by RTI. The retry can prevent the system burst caused by > However, if another TRAP occurs, the program repeats the TRAP interrupt forever, so the consideration is necessary in programming. ### #### **■ INSTRUCTION SET** The HD63701X0 provides object code upward compatible with the HD6801 to utilize all instruction set of the HMC56800. It also reduces the execution times of key instructions for throughout improvement. Bit manipulation instruction, change instruction of the index register and accumulator and sleep instruction are also added. The followings are explained here. - CPU Programming Model (refer to Fig. 27) - · Addressing Mode - · Accumulator and Memory Manipulation Instruction - (refer to Table 14) - New Instruction - Index Register and Stack Manipulation Instruction (refer to Table 15) - · Jump and Branch Instruction (refer to Table 16) - · Condition Code Register Manipulation - (refer to Table 17) - · Op Code Map (refer to Table 18) #### Programming Model Fig. 27 depicts the HD63701X0 programming model. The double accumulator D consists of accumulator A and B, so when using the accumulator D, the contents of A and B are destroyed. Figure 27 CPU Programming Model #### CPU Addressing Mode The HD63701X0 provides 7 addressing modes. The addressing mode is decided by an instruction type and code. Table 14 through 18 show addressing modes of each instruction with the execution times counted by the machine cycle. When the clock frequency is 4MHz, the machine cycle time becomes microseconds directly. #### Accumulator (ACCX) Addressing Only an accumulator is addressed and the accumulator A or B is selected. This is a one-byte instruction. #### Immediate Addressing This addressing locates a data in the second byte of an instruction. However, LDS and LDX locate a data in the second and third byte exceptionally. This addressing is a 2 or 3-byte instruction. #### Direct Addressing In this addressing mode, the second byte of an instruction shows the address where a data is stored. 256 bytes (\$0 through \$255) can be addressed directly. Execution times can be reduced by storing data in this area so it is recommended to make it RAM for users' data area in configurating a system. This is a 2-byte instruction, while 3 byte with regard to AIM, OIM, EIM and TIM. #### Extended Addressing In this mode, the second byte shows the upper 8 bit of the data stored address and the third byte the lower 8 bit. This indicates the absolute address of 3 byte instruction in the memory. Indexed Addressing The second byte of an instruction and the lower 8 bit of the index register are added in this mode. As for AIM, OIM, EIM and TIM, the third byte of an instruction and the lower 8 bits of the index register are added. This carry is added to the upper 8 bit of the index register and the result is used for addressing the memory. The modified address is retained in the temporary address register, so the contents of the index register doesn't change. This is a 2-byte instruction except AIM, OIM, EIM and TIM (3-byte instruction). Implied Addressing An instruction itself specifies the address. That is, the instruction addresses a stack pointer, index register etc. This is a onebyte instruction. #### Relative Addressing The second byte of an instruction and the lower 8 bits of the program counter are added. The carry or borrow is added to the upper 8 bit. So addressing from -126 to +129 byte of the current instruction is enabled. This is a 2-byte instruction. (Note) CLI, SEI Instructions and Interrupt Operation When accepting the IRQ at a preset timing with the help of CLI and SEI instructions, more than 2 cycles are necessary between the CLI and SEI instructions. For example, the following program (a) (b) don't accept the IRQ but (c) accepts it. The same thing can be said to the TAP instruction instead of the CLI and SEI instructions. Table 14 Accumulator, Memory Manipulation Instructions | _ | | | | | | , | Add | ressu | ng M | Mode | es | | | | | | S | _ | | | on C<br>iste | Cod<br>r | le . | |-----------------------------------------|----------|--------------------------------------------------|--------------|---------|--------------------------------------------------|----------|----------|------------|------|----------|--------------------------------------------------|---------------|----|--------------------------------------------------|-----|----------|-------------------------------------------------------|------------|----|-----|----------------------------------------|----------|----------| | Operations | Mnemonic | IMI | ME E | 5 ] | DIR | EC. | T | INI | DEX | | EKT | EN | ō | IMP | LIE | 2 | Boolean/<br>Arithmetic Operation | 5 | 4 | 3 | 2 | 1 | 0 | | | | OP | ~ | - | ОР | ~ ] | # | ОР | ~ | , | OP | ~ | # | OP | ~ | * | | н | - | Z | z | v | c | | Add | ADDA | 88 | 2 | 2 | 98 | 3 | 2 | AB | 4 | 2 | 88 | 4 | 3 | | | | A + M→ A | 1 | • | : | ı | 1 | Ŀ | | Ì | ADDB | СВ | 2 | 2 | DB | 3 | 2 | EΒ | 4 | 2 | FB | 4 | 3 | | | | B + M → 8 | 1 | • | 1 | 1 | : | Ŀ | | Add Double | ADDD | C3 | 3 | 3 | D3 | 4 | 2 | E3 | 5 | 2 | F3 | 5 | 3 | | | | A.B+M:M+1-A.B | • | ٠ | 1 | 1 | 1 | 1 | | Add Accumulators | ABA | $\vdash$ | | Н | | | $\neg$ | | - | | | | | 18 | 1 | 7 | A + B - A | 1 | • | 1 | 1 | 1 | 1 | | Add With Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | В9 | 4 | 3 | | | | A + M + C → A | 1 | • | : | ī | 1 | Ti | | | ADCB | C9 | 7 | 2 | D9 | _ | 2 | E9 | 4 | 2 | F9 | 4 | 3 | | | | B + M + C → B | 1 | • | 1 | 1 | 1 | Ti | | AND | ANDA | RA | 2 | 2 | 94 | | 2 | A4 | 4 | 2 | 84 | 4 | 3 | | | _ | A·M → A | • | • | 1 | 1 | R | 1 | | 1110 | ANOB | C4 | 2 | 2 | D4 | | 2 | E4 | 4 | 2 | F4 | 4 | 3 | | | $\vdash$ | B-M → B | | • | 1 | 1 | R | ١. | | | | 85 | 2 | 2 | 95 | | 2 | A5 | 4 | 2 | 85 | 4 | 3 | $\vdash$ | - | - | A·M | | | 1 | 1 | R | ١. | | Bit Test | BITA | + | + | | | _ | _ | | 4 | 2 | F5 | 4 | 3 | $\vdash$ | - | | B·M | | | 1 | 1 | F | - | | | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E 5 | - | | _ | - | _ | | _ | Н | | • | • | Ė | - | R | 4 | | Clear | CLA | ↓ | 1 | Н | | Ι., | - | 6F | 5 | 2 | 7 F | 5 | 3 | <del> _ </del> | Ļ. | H | 00 → M | : | ŀ | R | - | R | | | 1 | CLRA | 1 | ـ | _ | | <u> </u> | | | | | | <u> </u> | - | 4F | 1 | 1 | 00 + A | ₩ | ٠. | - | ــــــــــــــــــــــــــــــــــــــ | - | 4 | | | CLRB | <u> </u> | ┖ | | L' | L | $\vdash$ | | Ш | Щ | <u> </u> | <b>-</b> | L | 5F | 1 | 1 | 00 · B | | ŀ | R | +- | R | - | | Compare | CMPA | 81 | 2 | 2 | 91 | - | 2_ | Α1 | 4 | 2 | B 1 | 4 | 3 | Ш | _ | - | A - M | | • | 1 | +- | - | <b>-</b> | | | СМРВ | Cı | 2 | 2 | D1 | 3 | 2 | E 1 | 4 | 2 | F1 | 4 | 3 | L | | L | B - M | • | • | 1 | 1: | 1 | 1 | | Compare<br>Accumulators | СВА | | | | | | | | | | | | | 11 | 1 | 1 | A - B | · | ٠ | 1 | ┺ | 1. | _ | | Complement, 1's | сом | T | Г | | | Г | Г | 63 | 6 | 2 | 73 | 6 | 3 | | | 1 | M - M | • | • | 1 | 1 | | | | | COMA | 1 | T | Т | | Г | T | | | | | | Г | 43 | 1 | ī | A A | • | • | : | 1 | A | 1 | | | COMB | 1 | Т | Т | | | Γ | | Г | | | Г | Г | 53 | 1 | 1 | 8 → 8 | • | • | 1 | 1: | R | गः | | Complement, 2's | NEG | <del> </del> | + | 1 | - | 1 | 1 | 60 | 6 | 2 | 70 | 6 | 3 | <u> </u> | _ | | 00 - M -+ M | • | • | 1 | 1 | (1) | 0 1 | | (Negate) | NEGA | + | T | 1 | | 1 | 1 | 1 | Г | | $\vdash$ | 1 | T | 40 | 1 | 1 | 00 - A → A | • | • | 1 | 1 | 11 | i) ( | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | NEGB | 1 | 1- | 1 | <del> </del> | Г | 1 | 1 | | Т | | 1 | Г | 50 | 1 | 1 | 00 - B → B | • | • | 1 | 1 | (i | ijζ | | Decimal Adjust, A | DAA | T | T | Γ | | | Ī | | T | | | Г | Г | 19 | 2 | 1 | Converts binary add of BCD characters into BCD format | • | • | 1 | 1 | : | 1 4 | | Decrement | DEC | + | +- | - | <del> </del> | $\vdash$ | 1 | 6A | 6 | 2 | 7A | 6 | 3 | <del> </del> | _ | 1 | M - 1 - M | 1. | 1. | 12 | 1 | (4 | ı, İ, | | Detrement | DECA | + | ✝ | ╁ | H | ┰ | ✝ | 1 | + | $\vdash$ | <del> </del> | +- | 1- | 4A | 1 | 1 | A - 1 - A | 1. | ١. | 1; | 1 | 10 | ō | | | DECB | <del> </del> | +- | ╁╌ | ┪ | ┢ | ╁ | | ╁ | t | 1 | 1 | 1 | 5A | 1 | 1 | B - 1 - B | ١. | ١. | 1 | 1: | _ | | | r | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | 88 | 4 | 3 | 15. | ÷ | +- | A 🕙 M → A | ١. | | + | - | - | - | | Exclusive OR | <u></u> | | - | - | - | - | - | | ٠ | 2 | F B | 4 | 3 | ├ | ⊬ | ╁ | B ⊕ M → B | - | + | + | | _ | | | | EORB | C8 | 2 | 2 | 08 | 3 | 2 | E8 | 4 | 1- | | + | ┿ | | ┼- | ⊢ | | +- | | +; | _ | | -+ | | Increment | INC | 1 | 4 | $\perp$ | 1 | ↓_ | 1- | <b>6</b> C | 6 | 2 | 7C | 6 | 3 | +- | 1 | 1. | M + 1 - M | +: | ŀ | +; | | _ | 5 | | | INCA | - | ┸ | 丰 | 1_ | 1 | ┺ | ١_ | 1 | 1 | 1- | - | 1 | 4C | 11 | 1 | A+1 + A | | 1 | | _ | | · 1 | | | INCB | 1 | 1 | 1 | 1 | ـــ | 1 | 1_ | 1 | ↓ | ١ | 1 | L | 5C | 1 | 1 | B + 1 -+ B | ١. | ŀ | -1- | | - | 5)<br>a | | Load | LDAA | 86 | 2 | - | 96 | 3 | + | A6 | +- | 2 | 86 | 4 | 3 | 1 | 1 | ╀ | M - A | <b>!</b> • | ŀ | -1: | | - | - | | Accumulator | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | €6 | 4 | 2 | F6 | 4 | 3 | 1_ | _ | 1_ | M B | ٠. | 1. | 1 | Ŀ | 4 | 3 | | Load Double<br>Accumulator | LOD | cc | з | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 | | L | | M + 1 -+ B, M -+ A | ŀ | • | ŀ | 1 | ┸ | _ | | Multiply Unsigned | MUL | $\perp$ | $\perp$ | L | L | L | L | Ш_ | L | L | L | L | L | 30 | 7 | 1 | | • | 1 | _ | 1 | _ | R | | OR, Inclusive | AARO | 8.4 | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | Ī | | | Γ | A+M-A | 1. | _L | -I. | . 1 . | ъ. | | | | ORAB | C/ | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 73 | 1 | Т | Τ | B + M + B | • | 1. | 1 | 1 | T | ĦŢ | | Push Data | PSHA | + | +- | + | 1 | 1 | t | 1 | 1 | T | <b>—</b> | $\top$ | t | 36 | 4 | 1 | A → Msp, SP - 1 → SP | ١. | • | 1 | • | 4 | •1 | | | PSHB | $\top$ | $^{\dagger}$ | 1 | | $\top$ | 1 | 1 | 1 | T | 1 | 1 | T | 37 | 4 | 1 | B → Msp, SP = 1 → SP | 1. | - | 1 | ٠. | • | • | | Pull Data | PULA | 1 | + | $\top$ | 1 | 1 | 1 | 1 | 1 | 1 | †- | 1 | T | 32 | 3 | 1 | SP + 1 → SP, Msp → A | 1. | 1- | ٠, | • | ٠, | • | | | PULB | _ | + | +- | 1 | 1 | 1 | 1 | T | T | T | $\top$ | T | 33 | 13 | 1 | · | ٦. | 1. | 1 | ٠, | • 1 | • | | Rotate Left | ROL | $\top$ | $^{+}$ | t | 1 | t | 1 | 69 | 6 | 12 | 79 | 6 | 3 | <del></del> | 1 | 1 | | ٦. | 1. | . 1 | 1 | 1 ( | • | | DOUBLE CENT | ROLA | + | ╁ | +- | +- | +- | + | ۳ | ۲ | 宀 | + | Ť | Ť | 49 | + | 1 | <u> </u> | ١. | - | - | _ | _ | 3 | | | ROLB | + | ╁ | + | 1 | ╁ | + | + | + | ╁ | + | + | + | 59 | + | | C 62 80 | 1. | ١. | | _ | | 6 | | | 4 | - | + | + | +- | +- | | 66 | 6 | 2 | 76 | 6 | 3 | | +' | + | ł., | ١. | | | | _1. | 6 | | Barres Braha | | | | | | | | | | | | | | | | | | | | | | | | | Rotate Right | ROR | + | ╀ | +- | + | ╁ | ╁ | 100 | + | ť | | <del>۱°</del> | ۲ | 46 | 17 | †ī | *\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | ١, | ٦. | ٠ti | . 1 | 1 6 | (8) | (Note) Condition Code Register will be explained in Note of Table 17. Table 14 Accumulator, Memory Manipulation Instructions | | | | | | | | Add | Iressi | ng f | Mod | es | | | | | | | L° | iond<br>F | | on ( | | • | |----------------------------------|----------|-----|----|----------|----------|----|-----|----------|----------|-----|------------|-----|----------------|----------|------|----|----------------------------------|----------|-----------|----|------|----------|---| | Operations | Mnemonic | IMI | ME | _ | DIF | EC | Т | IN | DE) | < | EX. | ren | D | IMI | PLIE | D | Boolean/<br>Arithmetic Operation | 5 | 4 | 3 | 2 | - | o | | | | OP | ~ | * | OP | ~ | * | OP | ~ | * | ОP | ~ | # | OP | ~ | # | | н | 1 | Z | z | ٧ | ٧ | | Shift Left | ASL | | | | | | | 68 | 6 | 2 | 78 | 6 | 3 | | | | M1 | • | • | 1 | | 0 | * | | Arithmetic | ASLA | | | | | | | | | | | | | 48 | 1 | 1 | ]v} [> <del> </del> | • | • | 1 | | 0 | • | | | ASLB | | | Г | | | | | | | | | | 58 | 1 | 1 | B C 57 50 | • | • | • | * | 0 | 1 | | Double Shift<br>Left, Arithmetic | ASLD | | | | | | | | | | | | | 05 | 1 | 1 | C A7 A0 87 80 | • | • | * | 1 | 6 | 1 | | Shift Right | ASR | | 1 | Γ | | | Г | 67 | 6 | 2 | 77 | 6 | 3 | | Г | Г | M) | • | • | ŧ | | ⑥ | | | Arithmetic | ASRA | 1 | 1 | | | | T | | | Г | | Г | | 47 | 1 | 1 | ^} <del>- </del> | • | ٠ | 1 | | ⑥ | | | | ASRB | | Γ | | | | | | L | | | | | 57 | 1 | 1 | ] • , • , • • • · · | Ē | • | : | 1 | ⑥ | | | Shift Right | LSR | | | Ι | | | Γ | 64 | 6 | 2 | 74 | 6 | 3 | | | | м, | · | ٠ | R | : | (3) | 1 | | Logical | LSRA | 1 | | | | | | | | | | Г | Γ | 44 | 1 | ī | *\0+[]+C | • | • | R | | 0 | | | | LSRB | | | | | | | _ | | | Г | Γ | | 54 | 1 | 1 | m) 67 80 C | • | • | R | 1 | <b>©</b> | Γ | | Double Shift<br>Right Logical | LSRD | | | | | | | | | | | | | 04 | 1 | 1 | 0 | • | • | R | 1 | 6 | | | Store | STAA | | | | 97 | 3 | 2 | A7 | 4 | 2 | <b>B</b> 7 | 4 | 3 | | Γ | Г | A → M | • | • | : | 1 | R | ŀ | | Accumulator | STAB | 1 | Π | | D7 | 3 | 2 | E 7 | 4 | 2 | F7 | 4 | 3 | | Т | | B → M | • | • | 1 | 1 | я | Ī | | Store Double<br>Accumulator | STD | | | | 00 | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 | | | | A → M<br>B → M + 1 | • | • | • | 1 | R | ŀ | | Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | ВО | 4 | 3 | | | | A-M-A | • | • | ŧ | 1 | 1 | L | | | SUBB | œ | 2 | 2 | 00 | 3 | 2 | ΕO | 4 | 2 | FO | 4 | 3 | | L | L | B - M → B | • | • | ŧ | 1 | 1 | I | | Double Subtract | SUBD | 83 | 3 | 3 | 93 | 4 | [2 | A3 | 5 | 2 | 83 | 5 | 3 | l | 1 | 1 | A:B-M:M+1-A:B | • | • | : | ŧ | 1 | ŀ | | Subtract<br>Accumulators | SBA | | | | | | | | | | | | | 10 | 1 | 1 | A - B → A | ŀ | • | : | 1 | ı | I | | Subtract | SBCA | 82 | 2 | 1 | 92 | 3 | 2 | A2 | 4 | 2 | 82 | 4 | 3 | | L | L | A-M-C→A | <u>•</u> | • | ŧ | ŀ | 1 | L | | With Carry | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 | | | | B - M - C → B | • | ٠ | 1 | 1 | 1 | I | | Transfer | TAB | | _ | L | <u> </u> | ╙ | 上 | ـــــ | _ | ┖ | | ┖ | 1 | 16 | 1 | 11 | A→B | • | ٠ | 1 | 12 | R | ŀ | | Accumulators | TBA | ↓ | L | <u> </u> | _ | _ | L | ـــــ | _ | L | <b>↓</b> | ╙ | L | 17 | ₽1 | 11 | B → A | ŀ | ŀ | Ŀ | L. | R | ŀ | | Test Zero or | TST | 1 | L | 1_ | _ | ╙ | L | 60 | 4 | 2 | 70 | 4 | 3 | <u> </u> | ┺ | ┺ | M - 00 | ŀ | ŀ | 1: | 1: | R | Ľ | | Minus | TSTA | 1 | L | L | L. | 1_ | L | $\vdash$ | $\vdash$ | 1_ | _ | 1 | L | 40 | 1 | 11 | A - 00 | ŀ | ٠ | ŀ | 1: | R | ľ | | | TSTB | | L | $\perp$ | <u></u> | L | L | L_ | L | _ | L_ | L | L | 5D | 1 | 11 | B - 00 | · | Ŀ | 1 | 1 | P | ļ | | And Immediate | AIM | 1_ | L. | 1_ | 71 | 6 | 3 | 61 | 7 | - | L | L | L | <u>_</u> | _ | L | M·IMM⊶M | • | • | 1 | 1 | R | 1 | | OR Immediate | OIM | _ | | | 72 | 6 | 3 | 62 | 7 | 3 | _ | L | L | _ | _ | 1_ | M+IMM→M | • | • | ŀ | 1 | R | l | | EOR Immediate | EIM | | L | L | 75 | 6 | 3 | 65 | 7 | 3 | L | L | L | | 1 | L | M⊕IMM-+M | • | • | : | : | R | I | | Test Immediate | TIM | | Ι_ | | 7B | 4 | 3 | 68 | 5 | 3 | | 1 | l <sup>-</sup> | | 1 | 1 | M-IMM | • | • | 1 | 1 | R | ſ | (Note) Condition Code Register will be explained in Note of Table 17. #### Additional Instruction 706 In addition to the HD6801 instruction set, the HD63701X0 prepares the following new instructions. $$AIM.....(M)\cdot(IMM) \rightarrow (M)$$ Executes "AND" operation to immediate data and the memory contents and stores its result in the memory. $$OIM.....(M) + (IMM) \rightarrow (M)$$ Executes "OR" operation to immediate data and the memory contents and stores its result in the memory. $$EIM \dots (M) \oplus (IMM) \rightarrow (M)$$ Executes "EOR" operation to immediate data and the memory contents and stores its result in the memory. Executes "AND" operation to immediate data and changes the relative flag of the condition code register. These area 3-byte instructions; the first byte is op code, the second immediate data and the third address modifier. $$XGDX.....(ACCD) \leftrightarrow (IX)$$ Exchanges the contents of accumulator and the index reg- #### SLP Goes to the sleep mode. Refer to "LOW POWER DIS-SIPATION MODE" for more details of the sleep mode. Table 15 Index Register, Stack Manipulation Instructions | | | | | | | | Add | dress | ing | Mod | des | | | | | | Bopiesn/ | C | | ditk<br>Tog | | | • | |------------------------|----------|--------|----------|-----|-----|-----|-----|--------|-----|-----|-----|-----|----|-----|-----|---|------------------------------------------------|---|---|-------------|---|---|---| | Painter Operations | Mnemonic | IM | ME | D . | Dil | REC | T | IN | DE: | × | EX | TEN | ID | IMF | LIE | D | Arithmetic Operation | 5 | 4 | 3 | 2 | 1 | ō | | | | OP | <b>-</b> | # | OP | ~ | * | OP | - | * | OP | - | * | OP | ~ | * | | I | - | 2 | Z | > | c | | Compare Index Reg | CPX | BC | 3 | 3 | 9C | 4 | 2 | AC | 5 | 2 | BC | 5 | 3 | | | Г | X = M:M + 1 | • | ٠ | : | 1 | : | 1 | | Decrement Index Reg | DEX | | Г | | | | | | | | | Π | | 09 | 1 | 1 | X – 1 → X | ٠ | ٠ | • | 1 | ٠ | • | | Decrement Stack Potr | DÉS | T | Г | | | | | | | | | | Ι. | 34 | 1 | 1 | SP - 1 - SP | ٠ | ٠ | • | • | • | • | | Increment Index Reg | INX | 1 | | _ | | | Г | | Г | Г | | | | 80 | 1 | 1 | X + 1 → X | ٠ | • | • | 1 | ٠ | • | | Increment Stack Potr | INS | $\top$ | Г | Г | | ı | Ι_ | | Γ | Г | | | | 31 | 1 | ١ | SP + 1 → SP | ٠ | ٠ | • | • | ٠ | • | | Load Index Reg | LDX | CE | 3 | 3 | ΟE | 4 | 2 | €€ | 5 | 2 | FE | 5 | 3 | | Г | П | M → XH, (M+1) → XL | • | • | .7 | 1 | A | • | | Load Stack Potr | LDS | BE | 3 | 3 | 9E | 4 | 2 | AE | 5 | 2 | ÐΈ | 5 | 3 | | | | M - SPH. (M+1) - SPL | • | • | Ĩ, | : | æ | • | | Store Index Reg | STX | 1 | | | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 | Ī | | | $X_H \rightarrow M, X_L \rightarrow (M+1)$ | • | • | 7, | : | Ħ | • | | Store Stack Potr | STS | T | T | | 9F | 4 | 2 | AF | 5 | 2 | B₽ | 5 | 3 | | | Ī | SP <sub>H</sub> → M, SP <sub>L</sub> → (M+1) | ٠ | • | 7 | 1 | R | • | | Index Reg → Stack Pntr | TXS | T- | Т | 1 | T | T | 1 | | T | T | | | | 35 | 1 | 1 | X - 1 → SP | • | • | • | • | • | • | | Stack Pntr - Index Reg | TSX | 1 | t | T | T | T | 1 | | 1 | 1 | | | | 30 | 1 | 1 | SP + 1 - X | • | • | • | • | • | • | | Add | ABX | 1 | T | T | | T | | 1 | 1 | | | Г | | 3A | 1 | 1 | 8 + X → X | • | • | • | • | • | • | | Push Data | PSHX | 1 | 1 | | | T | | 1 | Τ | T | | Γ | Г | зс | 5 | 1 | XL → Mmp. SP - 1 → SP | • | • | • | • | • | ŀ | | | | 1 | | l | 1 | 1 | | | | l | i | | | l | | | X <sub>H</sub> → M <sub>sp</sub> , SP = 1 → SP | l | | | ı | į | 1 | | Pull Data | PULX | 1 | T | T | 1 | Τ | 1 | $\Box$ | 1 | Г | T | Τ | 1 | 38 | 4 | 1 | SP + 1 → SP, M <sub>SP</sub> → X <sub>H</sub> | • | ٠ | • | • | ٠ | T | | | Ì | 1 | 1 | ı | 1 | | | | | l | l | Į. | 1 | | 1 | l | SP + 1 → SP, M <sub>SP</sub> → X <sub>L</sub> | l | | | l | l | | | Exchange | XGDX | 1 | T | T | 1 | Т | 1 | | T | Γ | Γ | Τ | T | 18 | 2 | 1 | ACCDIX | • | • | | | | T | (Note) Condition Code Register will be explained in Note of Table 17. Table 16 Jump, Branch Instruction | | | | | | | | Ad | dress | ıng | Мо | des | | | | | | | 9 | | diti<br>Reg | | | ie | |-----------------------------|----------|--------|-----|----|-----|-----|----|-------|-----|----|-----|----|---|-----|-----|---|------------------------------|---|---|-------------|---|---|----| | Operations | Mnemonic | REL | ATI | VE | DII | REC | т: | IN | DE | × | EX1 | EN | D | IMP | LIE | 0 | Branch Test | 5 | 4 | 3 | 2 | ī | 0 | | ļ | | OP | T~ | # | OP | ~ | * | OP | ~ | # | ОP | ~ | * | OР | ~ | * | | H | - | 2 | Z | v | C | | Branch Always | BAA | 20 | 3 | 2 | | | | | | | | | | | | | None | • | • | • | • | · | • | | Branch Never | BRN | 21 | 3 | 2 | | | | | Ì | | | | | | | | None | • | • | • | • | • | • | | Branch If Carry Clear | BCC | 24 | 3 | 2 | Ι | | | | | | | | | | | | C • 0 | • | ٠ | • | • | • | • | | Branch If Carry Set | BCS | 25 | 3 | 2 | | | | | | | | | | | | | C = 1 | • | • | • | • | • | • | | Brench If = Zero | BEQ | 27 | 3 | 2 | | | | | | | | | | | | | Z = 1 | • | ٠ | ٠ | • | • | • | | Branch If > Zero | BG€ | 2C | 3 | 2 | | | | | | l | | | | | | | N ( V • 0 | • | ٠ | ٠ | • | • | • | | Branch If > Zero | 8GT | 2E | 3 | 2 | | | Г | | | | | | Г | | | | Z + (N @ VI - 0 | • | • | • | • | • | • | | Branch If Higher | ВНІ | 22 | 3 | 2 | | | | | | | | | Г | П | | | C+Z+0 | • | • | • | • | • | • | | Branch If < Zero | BLE | 2F | 3 | 2 | | | П | | | Π | | | | | | | Z + (N @ V) = 1 | • | ٠ | • | • | • | ┍ | | Branch If Lower Or<br>Same | BLS | 23 | 3 | 2 | Γ | | | | | | | | Γ | | | | C + Z = 1 | • | • | • | • | • | • | | Branch If < Zero | BLT | 20 | 3 | 2 | | Г | | | Γ | Г | | Γ | Г | | | | N ⊕ V • 1 | • | • | • | • | ┍ | • | | Branch If Minus | BMI | 28 | 3 | 2 | | Г | Г | | Г | T | | | | | | | N = 1 | • | • | • | • | • | • | | Brench If Not Equal<br>Zero | BNE | 26 | 3 | 2 | | | | | | Γ | | | | | | | z - o | • | • | • | • | • | • | | Branch If Overflow<br>Clear | BVC | 28 | 3 | 2 | | | | | Γ | | | | | | | | V-0 | • | • | • | • | ٠ | • | | Branch If Overflow Set | BVS | 29 | 3 | 2 | | | | | | | | | | | | | V = 1 | • | ٠ | ŀ | • | • | ŀ | | Branch If Plus | BPL | 2A | 3 | 2 | Ι | П | | | | Γ | | | 1 | | | | N = 0 | • | • | • | • | • | • | | Branch To Subroutine | BSR | 80 | 5 | 2 | T | Г | Г | | Г | Г | П | Γ | Г | | | | | • | • | • | • | • | • | | Jump | JMP | 1 | 1 | 1 | | Г | 1 | 6E | 3 | 2 | 7 E | 3 | 3 | | Г | | 1 | • | • | • | • | • | • | | Jump To Subroutine | JSR | 1 | | Г | 90 | 5 | 2 | AD | 5 | 2 | BD | 6 | 3 | | | | 1 | • | • | • | • | • | • | | No Operation | NOP | Γ | | T | | | | | | | | | | 01 | 1 | , | Advances Prog. Cntr.<br>Only | • | • | • | • | • | • | | Return From Interrupt | RTI | 1 | Т | Τ | | | | | | ſ | | Γ | Г | 38 | 10 | 1 | | Г | | - ( | | _ | _ | | Return From<br>Subroutine | ATS | Γ | | Γ | | | Γ | Г | | | | Г | | 39 | 5 | 1 | | • | • | • | • | • | • | | Softwere Interrupt | SWI | T- | Т | Т | 1. | Ι | Ι | | | | | | | 3F | 12 | 1 | | • | S | • | • | • | ٠ | | Wait for Interrupt* | WAI | T | Τ | Т | П | Π | | Γ | Γ | ľ | | Ι_ | Γ | 3E | 9 | 1 | | • | 3 | • | • | • | • | | Sleep | SLP | $\top$ | 1 | ✝ | 1 | | 1 | | | 1 | Ι | Ι | Г | 1A | 4 | 1 | | • | • | • | • | • | • | (Note) \* WAI put R/W high; Address Bus goes to FFFF; Data Bus becomes tri-stated. Condition Code Register will be explained in Note of Table 17. Table 17 Condition Code Register Manipulation Instructions | | | Addre | ssingA | Aodes | | C | ondit | ion C | ode l | Regist | ter | |----------------------|----------|-------|--------|-------|-------------------|---|-------|-------|-------|----------|----------| | Operations | Mnemonic | IM | PLIE | 0 | Boolean Operation | 5 | 4 | 3 | 2 | 1 | 0 | | | | QP | ~ | * | | н | 1 | N | Z | <u> </u> | C | | Clear Carry | CLC | ОС | 1 | 1 | 0 → C | • | • | • | • | • | P | | Clear Interrupt Mask | CLI | 0E | 1 | 1 | 0 1 | • | R | • | • | • | Ŀ | | Clear Overflow | CLV | OA. | 1 | 1 | 0 - V | • | • | • | • | R | Ŀ | | Set Carry | SEC | 00 | 1 | 1 | 1 → C | • | • | • | • | • | s | | Set Interrupt Mask | SEI | 0F | 1 | 1 | 1 → ( | • | S | • | • | • | <u> </u> | | Set Overflow | SEV | ОВ | 1 | , | 1 → V | • | • | • | • | S | • | | Accumulator A → CCR | TAP | 06 | 1 | 1 | A - CCR | | | ( | i - | _ | _ | | CCR → Accumulator A | TPA | 07 | 1 | 1 | CCR → A | • | • | • | • | • | | #### LEGEND - OP Operation Code (Hexadecimal) - Number of MCU Cycles MSP Contents of memory location pointed to by Stack Pointer - Number of Program Bytes - Arithmetic Plus - **Arithmetic Minus** - Boolean AND - Boolean Inclusive OR Boolean Exclusive OR - Complement of M - Transfer into - Bit = Zero - 00 Byte = Zero #### CONDITION CODE SYMBOLS - Half-carry from bit 3 to bit 4 - Interrupt mask - Negative (sign bit) - Zero (byte) - Overflow, 2's complement - Carry/Borrow from/to bit 7 Reset Always - Set Always - Set if true after test or clear - Not Affected (Note) Condition Code Register Notes: (Bit set if test is true and cleared otherwise) - (i) (Bit V) Test: Result = 10000000? - (2) (Bit C) Test: Result \ 00000000? - Test: BCD Character of high-order byte greater than 10? (Not cleared if previously set) (3) (Bit C) - (4) (Bit V) Test: Operand = 10000000 prior to execution? - (5) (Bit V) Test: Operand = 01111111 prior to execution? Test: Set equal to N@ C = 1 after the execution of instructions (6) - (Bit V) (7) (Bit N) Test: Result less than zero? (Bit 15=1) - (8) (All Bit) Load Condition Code Register from Stack. - Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exist the wait state. (9) (Bit I) - (All Bit) Set according to the contents of Accumulator A. (in) - (Bit C) Result of Multiplication Bit 7=1? (ACCB) Table 18 OP-Code Map | OP | | | | | | ACC | ACC | | EXT | | ACCA | or SP | | | ACCE | or X | | ] | |------|-----|------|------|------|------|------|------|------|------|------|------|-------|------|------|------|------|------|---| | COL | - 1 | | | | | A | В | IND | DIR. | IMM | DIR | IND | EXT | IMM | DIR | :ND | EXT | ] | | < H | 11 | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1180 | 1103 | 1110 | 1111 | ] | | ιο | \ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | 8 | С | D | E | F | L | | 0000 | • | | SBA | BRA | TSX | | N | EG | | | | | | UB | | | | Ľ | | 1000 | 1 | NOP | CBA | BRN | INS | | | A | IM | | | | | MP | | | | L | | 0010 | 2 | | | вні | PULA | | | 0 | IM | | | | S | вс | | | | Ľ | | 0011 | 3 | | | BLS | PULB | | C | MC | | | SU | BD | | l | AC | DD | | Ŀ | | 0100 | 4 | LSRD | | BCC | DES | | L | SR | | | | | | ND | | | | Ľ | | 0101 | 5 | ASLD | | BCS | TXS | | | E | IM | | | | В | IIT | | | | Ŀ | | 0110 | 6 | TAP | TAB | BNE | PSHA | | A | OR | | | | | LI | DA | | | | Ŀ | | 0111 | 7 | TPA | TBA | BEQ | PSHB | | A | SR | | | | STA | | | | STA | | Ŀ | | 1000 | 8 | INX | XGDX | BVC | PULX | | Α | SL | | | | | E | OR | | | | Ŀ | | 1001 | 9 | DEX | DAA | BVS | RTS | | R | OL | | | | | A | DC | | | | Ŀ | | 1010 | A | CLV | SLP | BPL. | ABX | İ | | EC | | | | | Ō | RA | | | | Ľ | | 1011 | В | SEV | ABA | ВМІ | RTI | | | T | IM | | | | Α | DD | | | | 1 | | 1100 | c | CLC | | BGE | PSHX | | | NC | | | С | PX | | 1 | L | DD | | Ľ | | 1101 | 0 | SEC | | BLT | MUL | | Т | ST | | BSR | | JSR | | | | STD | | Ŀ | | 1110 | E | ČLI | | BGT | WAI | | | J | MP | - | L | DS | | | L | DX | | Ŀ | | 1111 | F | SEI | | BLE | SWI | T | ( | LR | | | 1 | STS | | | | STX | | ŀ | | | _ | 0 | ١, | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | Γ | UNDEFINED OF CODE (1) HITACHI <sup>\*</sup> Occurs only on each instruction of AIM, OIM, EIM, TIM #### ■ CPU OPERATION #### ● CPU Instruction Flow When operating, the CPU fetches an instruction from a memory and executes the required functions. This sequence starts after the reset release and repeats itself limitlessly if not affected by a special instruction or a control signal. SWI, RTI, WAI and SLP instructions are to change this operation, while NMI, IRQ, IRQ, HALT and STBY are to control it. Fig. 28 gives the CPU mode shift and Fig. 29 the CPU system flow-chart. Table 19 shows the CPU operating states and port states. #### Operation at Each Instruction Cycle Table 20 provides the operation at each instruction cycle. By the pipeline control of the HD63701XO, MULT, PUL, DAA and XGDX instructions etc. prefetch the next instruction. So attention is necessary to the counting of the instruction cycles because it is different from the existent one from op code fetch to the next instruction op code. Table 19 CPU Operation State and Port State | Port | Mode | Reset | STBY*** | HALT*** | Sleep | |------------|-----------|----------|---------|---------|----------| | Port 1 | Mode 1, 2 | н | - | Т | н | | (A. ~ A.) | Mode 3 | T | T | | Keep | | | Mode 1, 2 | Т | т | Keep | Keep | | Port 2 | Mode 3 | <u> </u> | l | | Keep | | Port 3 | Mode 1, 2 | 7 | т | Т | Т | | (D, ~ D,) | Mode 3 | 1 ' | ' | | Keep | | Port 4 | Mode 1,2 | Н | - | т | Н | | (A. ~ A.s) | Mode 3 | Т | 1 ' | | Keep | | | Mode 1,2 | T - | - | T | Т | | Port 5 | Mode 3 | 1 T_ | ' | | <u> </u> | | | Mode 1, 2 | - | _ | Кеер | Keep | | Port 6 | Mode 3 | 1' | 1 ' | | 1 | | | Mode 1, 2 | • | T - | •• | • | | Port 7 | Mode 3 | T | 1 ' | | Keep | H; High, L; Low, T; High Impedance Figure 28 CPU Operation Mode Transition <sup>.</sup> AD, WR, A/W, LIR+H, BA=L <sup>..</sup> RD, WR, R/W-T, LIR, BA-H <sup>\*\*\*\*</sup> HALT is unacceptable in mode 3. \*\*\*\* E pin goes to high impedance state. Figure 29 HD63701X0 System Flow Chart Table 20 Cycle-by-Cycle Operation | | s Mode & uctions | Cycles | Cycle | Address Bus | R/₩ | RD | WR | LIR | Data Bus | |--------|------------------|--------|-------|-------------------------|---------------------------------------------------|-----|----------|-----|--------------------------| | MMEDIA | | | | | | | | | | | ADC | ADD | | 1 | Op Code Address + 1 | T 1 | 0 | 1 | - ; | Operand Data | | AND | BIT | 1 | 2 | Op Code Address + 2 | l i l | o. | | 0 | Next Op Code | | CMP | EOR | 2 | ' | Op Code Address 12 | 1 ' | | ' | | | | LDA | ORA | 1 1 | | | | | 1 | | 1 | | | SUB | | 1 | | | | . ! | | | | ADDD | CPX | | 1 | Op Code Address + 1 | + , | 0 | 1 | , | Operand Data (MSB) | | LDD | LDS | 3 | 2 | Op Code Address + 2 | 1 1 | ő | 1 ; | 1 | Operand Data (LSB) | | | SUBD | 1 3 | 3 | Op Code Address + 3 | 1 ; | ň | 1 1 | أما | Next Op Code | | LDX | 5080 | 1 | 3 | Op Code Address 5 | <u> </u> | | <u> </u> | | | | PIRECT | | | | | | | | | T | | ADC | ADD | | 1 1 1 | Op Code Address + 1 | 1 1 | 0 | 1 | 1 1 | Address of Operand (LSB | | AND | BIT | 1 | 2 | Address of Operand | 1 1 | 0 | 1 1 | 1 | Operand Data | | CMP | EOR | 3 | 3 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code | | LDA | ORA | 1 | 1 | | 1 | 1 | | 1 | | | SBC | SUB | 1 | | | | İ | <u> </u> | | L | | STA | | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address | | | | 3 | 2 | Destination Address | 0 | 1 | 0 | 1 | Accumulator Data | | | | 1 | 3 | Op Code Address + 2 | 1 | 0 | 11 | 0 | Next Op Code | | ADDD | CPX | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (LSB | | LDD | LDS | 1. | 2 | Address of Operand | 1 1 | 0 | 1 | 1 | Operand Data (MSB) | | LDX | SUBD | 4 | 3 | Address of Operand + 1 | 1 1 | 0 | 1 | 1 | Operand Data (LSB) | | | | - | 4 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code | | STD | STS | + | 1-1- | Op Code Address + 1 | 1 | 0 | 1 | 1 | Destination Address (LSB | | STX | | 1 | 2 | Destination Address | 0 | 1 | 0 | 1 | Register Data (MSB) | | 0 | | 4 | 3 | Destination Address + 1 | 0 | | 0 | 1 1 | Register Data (LSB) | | | | 1 | 4 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code | | JSR | | + | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (LSB) | | 00 | | | 2 | FFFF | 1 | 1 | 1 1 | 1 | Restart Address (LSB) | | | | 5 | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) | | | | 1 | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) | | | | 1 | 5 | Jump Address | 1 | 0 | 1 | 0 | First Subroutine Op Code | | TIM | | + | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Immediate Data | | | | | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSE | | | | 4 | 3 | Address of Operand | 1 i | 0 | 1 | 1 | Operand Data | | | | | 1 4 | Oo Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code | | AIM | EIM | + | 1 | Op Code Address + 1 | <del>- - </del> | 0 | 1 | 1 | Immediate Data | | OIM | E ITH | 1 | 2 | Op Code Address + 2 | 1 1 | ō | 1 1 | 1 1 | Address of Operand (LSE | | OW | | | 3 | Address of Operand | l i | Ď | 1 | 1 | Operand Data | | | | 6 | J 4 | FFFF | 1 ; | 1 | 1 | 1 | Restart Address (LSB) | | | | | 5 | Address of Operand | o | 1 1 | 0 | 1 | New Operand Data | | | | 1 | 6 | Op Code Address + 3 | 1 1 | 0 | ۱ĭ | 1 6 | Next Op Code | | Address Mode &<br>Instructions | Cycles | Cycle | Address Bus | R/₩ | ŔĎ | WR | [IR | Data Bus | |--------------------------------|--------|-------|---------------------|--------------------------------------------------|-----|------|--------|-------------------------------| | NDEXED | | | | | | | | | | JMP | Т | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | | 3 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 3 | Jump Address | 1 | 0 | 1 | 0 | First Op Code of Jump Routine | | ADC ADD | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | AND BIT | i | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | CMP EOR | ١. | 3 | IX + Offset | 1 | 0 | 1 | 1 | Operand Data | | LDA ORA | 4 | 4 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code | | SBC SUB | i | | | | | | | | | TST | | | | | | | | | | STA | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | | 4 | 2 | FFFF | 1 1 | 1 | 1 | 1 | Restart Address (LSB) | | | * | 3 | IX + Offset | 0 | 1 | 0 | 1 | Accumulator Data | | | | 4 | Op Code Address + 2 | 1_1_ | 0 | 1_ | 0 | Next Op Code | | ADDD | 1 | 1 | Op Code Address + 1 | 1 | 0 | - | 1 | Offset | | CPX LDD | 1 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | LDS LDX | 5 | 3 | IX + Offset | 1 | 0 | 1 | 1 | Operand Data (MSB) | | SUBD | 1 | 4 | IX + Offset + 1 | 1 | 0 | 1 | 1 | Operand Data (LSB) | | | 1 | 5 | Op Code Address + 2 | 11 | 0 | 1 | 0 | Next Op Code | | STD STS | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | STX | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | 5 | 3 | IX + Offset | 0 | 1 | 0 | 1 | Register Data (MSB) | | | | 4 | IX + Offset + 1 | 0 | 1 | 0 | 1 | Register Data (LSB) | | | | 5 | Op Code Address + 2 | 1 | 0 | 1 | 0 | Next Op Code | | JSR | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | 5 | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) | | | | 4 | Stack Pointer – 1 | 0 | 1 | 0 | 1 | Return Address (MS8) | | | | 5 | IX + Offset | 1 1 | 0 | 1 | 0 | First Subroutine Op Code | | ASL ASR | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | COM DEC | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | INC LSR | 6 | 3 | IX + Offset | 1 | 0 | 1 | 1 | Operand Data | | NEG ROL | " | 4 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | ROR | 1 | 5 | 1X + Offset | 0 | 1 | 0 | 1 | New Operand Data | | | | 6 | Op Code Address + 1 | 1 | 0 | 1.1. | 0 | Next Op Code | | TIM | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Immediate Data | | | | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Offset | | | 5 | 3 | FFFF | 1 1 | 1 | 1 | 1 | Restart Address (LSB) | | | 1 | 4 | IX + Offset | 1 | 0 | 1 | 1<br>0 | Operand Data | | | | 5 | Op Code Address + 3 | <del> </del> | | 1 | 1 | Next Op Code<br>Offset | | CLR | - | 2 | Op Code Address + 1 | | l i | ; | ; | Restart Address (LSB) | | | 5 | 3 | IX + Offset | 1 ; | اهٰ | 1 ; | 1 ; | Operand Data | | | 1 2 | 4 | IX + Offset | Ö | Ĭ | ó | 'i | 00 | | | | 5 | Op Code Address + 2 | l ĭ | 6 | ı | 6 | Next Op Code | | AIM EIM | | 1 | Op Code Address + 1 | <del> ;</del> | 0 | l-i- | 1 | Immediate Data | | OIM EIM | | 2 | Op Code Address + 2 | 1 ; | 0 | l i | l i | Offset | | UIM | | 3 | FFFF | 1 ; | 1 1 | i | ; | Restart Address (LSB) | | | 7 | 4 | IX+Qffset | 1 ; | 0 | l i | l i | Operand Data | | | 1 ′ | 5 | FFFF | Ι'n | 1 | l i | l i | Restart Address (LSB) | | | 1 | 6 | IX + Offset | 6 | 1 1 | ; | l i | New Operand Data | | | 1 | 7 | Op Code Address + 3 | l ĭ | 10 | i | اهٔ | Next Op Code | | Address Mode & | Cycles | Cycle | Address Bus | R/W | RD | WR | LIR | Data Bus | |----------------|--------------|-------|----------------------------------|-----|----|------------------|----------------|----------------------------------------| | | <u> </u> | | | | | | | | | XTEND | | | Op Code Address + 1 | 1 1 | 0 | 1 | 1 | Jump Address (MSB) | | JMP | 3 | 2 | Op Code Address + 2 | 1 ; | o | | i | Jump Address (LSB) | | | 3 | 3 | | ; | 0 | i | Ö | Next Op Code | | | <del> </del> | 3 | Jump Address Op Code Address + 1 | + ; | 0 | <del>- i -</del> | 1 | Address of Operand (MS8 | | ADC ADD TST | 1 | 1 ' 1 | | | o | ; | l i | Address of Operand (LSB) | | AND BIT | 4 | 2 | Op Code Address + 2 | 1 ; | 0 | 1 | 1 ; | Operand Data | | CMP EOR | 1 | 3 | Address of Operand | 1 ; | ő | 1 | Ö | Next Op Code | | LDA ORA | 1 | 4 | Op Code Address + 3 | 1 ' | | ' | " | I WERT OF CODE | | SBC SUB | <u> </u> | | | | 0 | 1 | <del>-,-</del> | Destination Address (MSE | | STA | | 1 | Op Code Address + 1 | 1 | 0 | | 1 ; | Destination Address (LSB | | | 4 | 2 | Op Code Address + 2 | ' | 1 | Ö | 1 ; | Accumulator Data | | | | 3 | Destination Address | 1 1 | 6 | i | 6 | Next Op Code | | | | 4 | Op Code Address + 3 | + ; | 8 | | 1 | Address of Operand (MSI | | ADDD | 1 | 1 | Op Code Address + 1 | 1 ; | 0 | 1 ; | 1 | Address of Operand (LSB | | CPX LDD | 1 | 2 | Op Code Address + 2 | 1 ' | | 1 ; | 1 ; | Operand Data (MSB) | | LDS LDX | 5 | 3 | Address of Operand | 1 1 | ŏ | l i | l i | Operand Data (LSB) | | SUBD | İ | 4 | Address of Operand + 1 | | 0 | ; | 6 | | | | | 5 | Op Code Address + 3 | 1 | - | | | Next Op Code Destination Address (MS) | | STD STS | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | | | STX | 1 | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 ! | Destination Address (LSB | | | 5 | 3 | Destination Address | 0 | 1 | 0 | 1 1 | Register Data (MSB) | | | 1 | 4 | Destination Address + 1 | 0 | 1 | 0 | 1 | Register Data (LSB) | | | | 5 | Op Code Address + 3 | 1 | 0 | 1 | 0 | Next Op Code | | JSR | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Jump Address (MSB) | | | | 2 | Op Code Address + 2 | 1 | 0 | 1 ! | 1 | Jump Address (LSB) | | | 6 | 3 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | ľ | 4 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) | | | ļ | 5 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MS8) | | | 1 . | 6 | Jump Address | 1 | 0 | 1 | 0 | First Subroutine Op Code | | ASL ASR | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 7 1 | Address of Operand (MS | | COM DEC | | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSE | | INC LSR | 6 | 3 | Address of Operand | 1 | 0 | 1 | 1 | Operand Data | | NEG ROL | ٠, | 4 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | ROR | | 5 | Address of Operand | 0 | 1 | 0 | 1 | New Operand Data | | | 1 | 6 | Op Code Address + 3 | 1 | 0 | 1 1 | 0 | Next Op Code | | CLR | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Address of Operand (MS | | | 1 | 2 | Op Code Address + 2 | 1 | 0 | 1 | 1 | Address of Operand (LSI | | | 5 | 3 | Address of Operand | 1 1 | 0 | 1 | ١ | Operand Data | | | | 4 | Address of Operand | 0 | 1 | 0 | 1 | 00 | | | l l | 5 | Op Code Address + 3 | 1 1 | 0 | 1 | 0 | Next Op Code | | Address Mode & Instructions | | Cycles Cycle Address Bus | | Address Bus | R/W RD WR | | LIR | Data Bus | | |-----------------------------|------|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----|----------|---------------------------------| | IMPLIED | | | | To be a second s | | | | | | | ABA | ABX | T | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code | | ASL | ASLD | | | | i | | | ŀ | | | ASR | CBA | 1 | | | | | | | | | CLC | CLI | 1 | 1 | | | | 1 | | ! | | CLR | CLV | 1 | | | | | | ĺ | i | | СОМ | DEC | | | | 1 | | l | | | | DES | DEX | | | | i | | | l | | | INC | INS | | | | | | İ | ! | ļ | | INX | LSR | 1 | | | | 1 | | | | | LSRD | ROL | 1 | | | | ł | l | l | | | ROR | NOP | ł | ŀ | | 1 | 1 | ! | | | | SBA | SEC | 1 | | | 1 | i | | 1 | | | SEI | SEV | 1 | l . | | | l | | | ! | | TAB | TAP | 1 | ] | | | 1 | l | l | 1 | | TBA | TPA | i | | | 1 | | ł | 1 | i i | | TST | TSX | 1 | i | | | | Į | | | | TXS | | 1 | | | | | | | | | DAA | XGDX | 2 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code | | | | <u>*</u> | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | PULA | PULB | <del></del> | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code | | | | 3 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | | 3 | Stack Pointer + 1 | 1 | 0 | 1 | 1 | Data from Stack | | PSHA | PSHB | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Next Op Code | | | | 4 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 4 | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Accumulator Data | | | | i | 4 | Op Code Address + 1 | 1 | 0 | 1 1 | 0 | Next Op Code | | PULX | PULX | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 0 | Next Op Code | | | | ۱ ۵ | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | * | 3 | Stack Pointer + 1 | [ 1 | 0 | 1 | 1 | Data from Stack (MSB) | | | | ì | 4 | Stack Pointer + 2 | 1 1 | 0 | 1 | 1 | Data from Stack (LSB) | | PSHX | | 1 | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Next Op Code | | | | 1 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 5 | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Index Register (LSB) | | | | 1 | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Index Register (MSB) | | | | 1 | 5 | Op Code Address + 1 | 1 1 | 0 | 1 | 0 | Next Op Code | | RTS | | 1 | 1 | Op Code Address + 1 | 77 | 0 | 1 | 1 | Next Op Code | | | | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 5 | 3 | Stack Pointer + 1 | 1 | 0 | 1 | 1 | Return Address (MSB) | | | | ì | 4 | Stack Pointer + 2 | 1 | 0 | 1 | 1 | Return Address (LSB) | | | | 1 | 5 | Return Address | 1 | 0 | 1 | 0 | First Op Code of Return Routine | | MUL | | | 1 | Op Code Address + 1 | 7 | 0 | 1 | 0 | Next Op Code | | | | 1 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 1 | 3 | FFFF | 1 | 1.1 | 1 | 1 | Restart Address (LSB) | | | | 7 | 4 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | | 5 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | Į. | 6 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | | 1 | 7 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LS8) | | Address Mode & Cycles Instructions | | Cycle<br># | Address Bus | R/₩ | RO | WR | LIR | Data Bus | |------------------------------------|------|------------|------------------------------------|----------|-----|------------------|------------|----------------------------------------| | MPLIED | | | | | | | | | | WAI | Т | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Next Op Code | | | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | i | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) | | | 1 | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) | | | 9 | 5 | Stack Pointer 2 | 0 | 1 | 0 | 1 | Index Register (LSB) | | | | 6 | Stack Pointer - 3 | 0 | 1 | 0 | 1 | Index Register (MSB) | | | | 7 | Stack Pointer - 4 | 0 | 1 | 0 | 1 | Accumulator A | | | 1 | 8 | Stack Pointer - 5 | 0 | 1 | 0 | 1 | Accumulator 8 | | | | 9 | Stack Pointer – 5 | 0 | 1 | 1 | 1- | Conditional Code Register Next Op Code | | RTI | 1 | 1 | Op Code Address + 1 | 1 | 1 | 1 ; | ; | Restart Address (LSB) | | | 1 | 2 | FFFF | 1 | 6 | ; | ; | Conditional Code Register | | | | 3 | Stack Pointer + 1 | 1 | Ö | ; | ; | Accumulator B | | | | 4 | Stack Pointer + 2 | 1 | 0 | i i | 1 | Accumulator A | | | 10 | 5 | Stack Pointer + 3 | ; | 0 | l i | 1 ; | Index Register (MSB) | | | | 6 | Stack Pointer + 4 | ; | 0 | 1 ; | ; | Index Register (LSB) | | | l | 7 | Stack Pointer + 5 | | 0 | l i | ; | Return Address (MSB) | | | 1 | 8 | Stack Pointer + 6 | | 0 | 1 ; | 1 ; | Return Address (LSB) | | | | 9 | Stack Pointer + 7 | ; | 0 | ; | 0 | First Op Code of Return Routin | | | | 10 | Return Address | 1 | 0 | 1 | 1 | Next Op Code | | SWI | | 1 1 | Op Code Address + 1 | ; | 1 | 1 ; | 1 ; | Restart Address (LSB) | | | | 2 | FFFF | 6 | i ; | انا | 1 | Return Address (LSB) | | | 1 | 3 | Stack Pointer | 0 | ; | 0 | 1 | Return Address (MSB) | | | 1 | 4 | Stack Pointer 1 | 0 | ; | ŏ | ; | Index Register (LSB) | | | 1 | 5 | Stack Pointer - 2 | 0 | 1 ; | ŏ | ; | Index Register (MSB) | | | 12 | 6 | Stack Pointer - 3 | | ; | 0 | ; | Accumulator A | | | 1 '- | 7 | Stack Pointer 4 | 0 | ; | 0 | ; | Accumulator B | | | 1 | 8 | Stack Pointer - 5 | 0 | ; | 0 | 1 ; | Conditional Code Register | | | | 9 | Stack Pointer - 6 | 0 | 0 | " | 1 : | Address of SWI Routine (MSB) | | | | 10 | Vector Address FFFA | 1 | 0 | 1: | 1 ; | Address of SWI Routine (LSB) | | | Į. | 11 | Vector Address FFFB | 1 ' | 1 6 | ; | | First Op Code of SWI Routine | | | | 12 | Address of SWI Routine | 1 | 1 6 | <del> ;</del> - | 1-1- | Next Op Code | | SLP | | 1 | Op Code Address + 1 | ; | 1 1 | | ; | Restart Address (LSB) | | | | 2 | FFFF | 1 : | 1 : | 1 ; | l i | nestart Address (COD) | | | 1 | | | 1 1 | | 1 1 | | | | | 4 | Sleep | | | 1 1 | 1 | | 1 | | | 1 | 1 1 | | | | | | | | | | 1 1 | | 1 | ; | 1 ; | 1 ; | Restart Address (LSB) | | | - | 3 | FFFF | | 1 6 | 1 ; | 0 | Next Op Code | | | | 4 | Op Code Address + 1 | <u>'</u> | | <u> </u> | 1 <u>~</u> | 1 HEAR OF GODE | | RELATIVE | | | | | | | | | | BCC BCS | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Branch Offset | | BEQ BGE | 3 | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | BGT BHI | | 1 - | Branch Address Test = 11 | ١, | 0 | 1 | ۱ ، | First Op Code of Branch Routi | | BLE BLS | 1 | 3 | Op Code Address + 1 ··· Test = "0" | 1 ' | 1 | 1 . | ١ " | Next Op Code | | BLT BMT | | 1 | | 1 | ĺ | 1 | 1 | 1 | | BNE BPL | 1 | 1 | 1 | 1 | 1 | | 1 | 1 | | BRA BRN | - | 1 | 1 | ł | | ł | 1 | 1 | | BVC BVS | 1 | ı | 1 | | 1 | | 1 | | | BSA | | 1 | Op Code Address + 1 | 1 | 0 | 1 | 1 | Offset | | | | 2 | FFFF | 1 | 1 | 1 | 1 | Restart Address (LSB) | | | 5 | 3 | Stack Pointer | 0 | 1 | 0 | 1 | Return Address (LSB) | | | | 4 | Stack Pointer - 1 | 0 | 1 | 0 | 1 | Return Address (MSB) | | | 1 | 5 | Branch Address | 1 1 | 1 0 | 1 | 0 | First Op Code of Subroutine | #### **■ DIFFERENCES BETWEEN HD63701X0 AND HD6301X0** | Item | HD63701X0 | | | HD6301X0 | | | | | | |---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------|---------------------------------------------------------|----------------------------------------------------------------------|-----------|-----------|--|--| | Vpp/OE pin function | V <sub>PP</sub> /OE<br>MCU mode; Col<br>PROM mode; In<br>programming vo | put for the | / <sub>SS</sub> voltage | V <sub>SS</sub><br>Connected to V <sub>SS</sub> Voltage | | | | | | | Input capacitance | V <sub>PP</sub> /OE, 25pF r<br>All other inputs, | | ( | All inputs, 12.5pF max | | | | | | | Input high voltage of MP <sub>0</sub> , MP <sub>1</sub> | V <sub>IH</sub> = V <sub>SS</sub> - 0.5V min | | | | V <sub>IH</sub> = 2.0V min | | | | | | Bus Timing | HD63701X0 | HD637A01X0 | HD637B01X0 | | HD6301X0 | HD63A01X0 | HD63B01X0 | | | | <ul> <li>Address, R/W,</li> </ul> | t <sub>AH</sub> 70 | 45 | 30 | t <sub>AH</sub> | 80 | 50 | 35 | | | | hold timing | t <sub>HW</sub> 70 | 50 | 35 | t <sub>HW</sub> | 80 | 50 | 40 | | | | <ul> <li>Data hold timing</li> </ul> | | | Unit: ns | | | | Unit: ns | | | | Crystal oscillator characteristics | Internal resistance of crystal oscillator | | | | Internal resistance of crystal oscillator $R_S$ $R_S = 60\Omega$ max | | | | | | Storage<br>temperature | T <sub>stg</sub> = -55 to 125°C | | | | $T_{stg} = -55 \text{ to } 150^{\circ}\text{C}$ | | | | | | Caution | The HD63701X0 differs from HD6301X0 in chip design and manufacturing process. When applying the HD63701X0 system to HD6301X0, and HD6301X0 system to HD63701X0, note that characteristic values are not exactly the same even if guaranteed values are the same. | | | | | | | | | # ■ PRECAUTION TO THE BOARD DESIGN OF OSCILLATION CIRCUIT As shown in Fig. 30, there is a case that the cross talk disturbs the normal oscillation if signal lines are put near the oscillation circuit. When designing a board, pay attention to this. Crystal and $C_L$ must be put as near the HD63701X0 as possible. Figure 30 Precaution to the board design of oscillation circuit Figure 31 Example of Oscillation Circuits in Board Design #### RECEIVE MARGIN OF THE SCI Receive margin of the SCI contained in the HD63701X0 shown in Table 21. Note: SCI=Serial Communication Interface | IADIO 21 | | | | | | | |-------------------------------------|----------------------------------------------|--|--|--|--|--| | Bit distortion tolerance (t-to) /to | Character distortion tolerance<br>(T-To) /To | | | | | | | ±43.7% | ±4.37% | | | | | | #### **■ WARNING CONCERNING WAI INSTRUCTION** If the HALT signal is accepted by the MCU while the WAI instruction is executing, the CPU will not operate correctly after HALT mode is canceled. WAI is a instruction which waits for an interrupt. The corresponding interrupt routine is executed after an interrupt occurs. However, during the execution of the WAI instruction, HALT input makes the CPU malfunction and fetch an abnormal interrupt vectoring address. In HALT mode, the CPU operates correctly without the WAI instruction and WAI is executed correctly without $\overline{HALT}$ input. Therefore, if $\overline{HALT}$ input is necessary, make interrupts wait during the loop routine, as shown in Figure 32. Figure 32 MAC function during WAI i) MAL function ii) Recommended method Figure 33 Program to wait for interrupt #### **WARNING CONCERNING POWER START-UP** RES must be held low for at least 20 ms when the power starts up. In this case, the internal reset function is not effective until the oscillation begins at power-on. The $\overline{RES}$ signal is input to the LSI in synchronism with the internal clock (shown in Figure 33). Therefore, after power starts up, the LSI conditions such as its I/O ports and operating mode, are unstable. Fix the level of I/O ports by means of an external circuit to determine the level for system operation during the oscillator stabilization time. Figure 33 RES circuit #### **■ WRITE-ONLY REGISTER** When the CPU reads a write-only register, the read data is always \$FF, regardless of the value in the write-only register. Therefore, be careful of the results of instructions which read write-only register and perform an arithmetic or logical operation on its contents, such as AIM, ADD, or ROL, is executed, because the arithmetic or logical operation is always done with the data \$FF. In particulars, don't use the AIM, OIM or EIM instruction to manipulate the DDR bit of PORT.