# HD6301V0, HD63A01V0,—HD63B01V0 CMOS MCU (Microcomputer Unit) The HD6301V0 is an 8-bit CMOS single-chip microcomputer unit, Object Code compatible with the HD6801. 4kB ROM, 128 bytes RAM, Serial Communication Interface (SCI), parallel I/O terminals as well as three functions of timer on chip are incorporated in the HD6301V0. It is bus compatible with HMCS6800, provided with some additional functions such as an improved execution time of key instruction plus several new instructions of operation to increase system throughput. The HD6301V0 can be expanded up to 65k words. Like the HMCS6800 family, I/O level is TTL compatible with +5.0V single power supply. By using the Hitachi's 3µm CMOS process, low power consumption is realized. And as lower power dissipation mode, HD6301V0 has Sleep Mode and Stand-By Mode. So flexible low power consumption application is possible. # FEATURES - Object Code Upward Compatible with HD6801 Family - Abundant On-Chip Functions Compatible with HD6801V0; 4kB ROM,128 Bytes RAM,29 Parallel I/O Lines, 2 Lines of Data Strobe, 16-bit Timer, Serial Communication Interface - Low Power Consumption Mode: Sleep Mode, Standby Mode - Minimum Instruction Cycle Time $1\mu s$ (f=1MHz), 0.67 $\mu s$ (f=1.5MHz), 0.5 $\mu s$ (f=2MHz) - Bit Manipulation, Bit Test Instruction - Protection from System Burst: Address Trap, Op-Code Trap - Up to 65k Words Address Space - Wide Operation Range $V_{CC}$ =3 to 6V (f=0.5MHz), f=0.1 to 1.5MHz ( $V_{CC}$ =5V $\pm$ 10%), f=0.1 to 2.0MHz ( $V_{CC}$ =5V $\pm$ 5%) ## BLOCK DIAGRAM # **■ PIN ARRANGEMENT** TYPE OF PRODUCTS | Type No. | Bus Timing | |-----------|------------| | HD6301V0 | 1 MHz | | HD63A01V0 | 1.5 MHz | | HD63B01V0 | 2 MHz | # ■ ABSOLUTE MAXIMUM RATINGS | Item | Symbol | Value | Unit | |-----------------------|------------------|-----------------------------|------| | Supply Voltage | Vcc | -0.3 ∼ +7.0 | V | | Input Voltage | V <sub>in</sub> | -0.3 ~ V <sub>cc</sub> +0.3 | V | | Operating Temperature | Topr | 0 ~ +70 | °C | | Storage Temperature | T <sub>stg</sub> | -55 ~ +150 | °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 $V_{in}$ , $V_{out}$ : $V_{SS} \leq (V_{in} \text{ or } V_{out}) \leq V_{CC}$ . ## ■ ELECTRICAL CHARACTERISTICS • DC CHARACTERISTICS ( $V_{CC} = 5.0V \pm 10\% - f = 1.0 \sim 1.5 MHz$ , $V_{CC} = 5.0V \pm 5\% - f = 2.0 MHz$ , $V_{SS} = 0V$ , Ta = $0 \sim +70^{\circ}$ C, unless otherwise noted.) | lt | em | Symbol | Test Condition | _min | typ | max | Unit | |--------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------|----------------------|-----|------|------| | | RES, STBY | | | V <sub>CC</sub> -0.5 | _ | Vcc | | | Input "High" Voltage | EXTAL | ViH | | V <sub>CC</sub> x0.7 | _ | +0.3 | V | | | Other Inputs | | | 2.0 | _ | 10.5 | | | Input "Low" Voltage | All Inputs | VIL | | - 0.3 | _ | 0.8 | V | | Input Leakage Current | NMI, IRO, , RES, STBY | <sub>in</sub> | V <sub>in</sub> = 0.4~5.1V | _ | _ | 1.0 | μΑ | | Three State (off-state)<br>Leakage Current | $P_{10} \sim P_{17}, P_{20} \sim P_{24},$<br>$P_{30} \sim P_{37}, P_{40} \sim P_{47}, \overline{1S3}$ | li <sub>TSI</sub> I | V <sub>in</sub> = 0.4~5.1V | - | _ | 1.0 | μΑ | | Output "High" Voltage | All Outputs | ., | 1 <sub>OH</sub> = -200μA | 2.4 | _ | - | V | | Output High Voltage | All Outputs | V <sub>OH</sub> | I <sub>OH</sub> = -10μA | V <sub>CC</sub> -0.7 | _ | - | ٧ | | Output "Low" Voltage | All Outputs | VoL | I <sub>OL</sub> = 1.6mA | - | _ | 0.55 | ٧ | | Input Capacitance | All Inputs | C <sub>in</sub> | $V_{in} = 0V$ , $f = 1.0MHz$ ,<br>$Ta = 25^{\circ}C$ | - | _ | 12.5 | pF | | Standby Current | Non Operation | Icc | | _ | 2.0 | 15.0 | μА | | Comment Dissipation 4 | | | Operating (f=1MHz**) | - | 6.0 | 10.0 | _ | | Current Dissipation* | | Icc | Sleeping (f=1MHz**) | _ | 1.0 | 2.0 | mΑ | | RAM Stand-By Voltage | | VRAM | | 2.0 | _ | _ | ٧ | <sup>\*</sup> $V_{IH}$ min = $V_{CC}$ -1.0V, $V_{IL}$ max = 0.8V typ. value $(f = x \text{ MHz}) = \text{typ. value } (f = 1 \text{ MHz}) \times x$ max, value (f = x MHz) = max, value $(f = 1 \text{ MHz}) \times x$ (both the sleeping and operating) <sup>\*\*</sup> Current Dissipation of the operating or sleeping condition is proportional to the operating frequency. So the typ. or max, values about Current Dissipations of the when of f = x MHz operation are decided according to the following formula; • AC CHARACTERISTICS ( $V_{CC} = 5.0V \pm 10\% - f = 1.0 \approx 1.5 MHz$ , $V_{CC} = 5.0V \pm 5\% - f = 2.0 MHz$ , $V_{SS} = 0V$ , $T_a = 0 \approx +70 ^{\circ} C$ , unless otherwise noted.) # **BUS TIMING** | ltem | | | Symbol | Test<br>Con- | Н | 06301 | V0 | HD | 63A0 | 170 | HD | 63B0 | 1V0 | Unit | | | | | | | | | | | | | | | | | | | | | | |------------------------------------------------------|------------------------------|----------------------|---------------------------------------|------------------|-----|--------|-------|-------|------|-----|-----|------|-----|------|-----|-----|---|----|---|---|----|---|---|----|----------|----|----|---|-----|---|---|-----|---|---|----| | | ····· | | | dition | min | typ | max | min | typ | max | min | typ | max | Unit | | | | | | | | | | | | | | | | | | | | | | | Cycle Time | ie | | | | 1 | _ | 10 | 0.666 | _ | 10 | 0.5 | _ | 10 | цs | | | | | | | | | | | | | | | | | | | | | | | Address Strobe P | ulse Wi | dth | t <sub>cyc</sub><br>PW <sub>ASH</sub> | | 200 | - | _ | 135 | _ | _ | 120 | - | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Address Strobe F | Rise Tim | ne | tasr | | _ | _ | 35 | _ | _ | 35 | _ | _ | 35 | ns | | | | | | | | | | | | | | | | | | | | | | | Address Strobe F | all Tim | е | tasf | 1 | _ | _ | 35 | _ | _ | 35 | _ | _ | 35 | ns | | | | | | | | | | | | | | | | | | | | | | | Address Strobe D | elay Ti | me | t <sub>ASD</sub> | | 40 | | - | TBD | _ | | TBD | _ | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Enable Rise Time | ; | | ter | | _ | _ | 35 | _ | _ | 35 | _ | _ | 35 | ns | | | | | | | | | | | | | | | | | | | | | | | Enable Fall Time | | | ter | | - | _ | 35 | _ | _ | 35 | - | _ | 35 | ns | | | | | | | | | | | | | | | | | | | | | | | Enable Pulse Wid | th "Hig | h" Level | PW <sub>EH</sub> | | 450 | | _ | TBD | _ | _ | TBD | _ | | ns | | | | | | | | | | | | | | | | | | | | | | | Enable Pulse Wid | th "Lov | w" Level | PWEL | | 450 | | _ | TBD | _ | _ | TBD | _ | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Address Strobe to<br>Time | dress Strobe to Enable Delay | | t <sub>ASED</sub> | | | | 60 | - | _ | TBD | - | _ | TBD | - | - | ns | | | | | | | | | | | | | | | | | | | | | Address Delay Time | | t <sub>AD1</sub> | | _ | _ | 250 | _ | _ | TBD | - 1 | - | TBD | ns | | | | | | | | | | | | | | | | | | | | | | | | Address Delay 11 | ille | | t <sub>AD2</sub> | Fig. 1<br>Fig. 2 | 4 | - | 350 | _ | | TBD | _ | _ | TBD | _ | ns | | | | | | | | | | | | | | | | | | | | | | Address Delay Ti | me for | Latch | t <sub>ADL</sub> | | | Fig. 2 | _ | _ | 250 | _ | _ | 220 | _ | - | 140 | ns | | | | | | | | | | | | | | | | | | | | | Data Set-up Time | | Write | t <sub>DSW</sub> | | 230 | _ | _ | TBD | | _ | TBD | _ | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Data Set-up Time | | Read | t <sub>DSR</sub> | | 80 | _ | _ | TBD | - | _ | TBD | - | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Data Hold Time | | Read | t <sub>HR</sub> | | 0 | - | - | 0 | - | _ | 0 | _ | - | ns | | | | | | | | | | | | | | | | | | | | | | | Data Hold Tille | | Write | t <sub>HW</sub> | | 20 | _ | _ | 20 | _ | _ | 20 | _ | _ | ns | | | | | | | | | | | | | | | | | | | | | | | Address Set-up T | ime for | Latch | tASL | | | | | | | | | | | | Ì | - | - | } | ŀ | | | | | | <u> </u> | 60 | _ | _ | TBD | _ | _ | TBD | _ | _ | nş | | Address Hold Tir | ne for L | atch | t <sub>AHL</sub> | | | | | | 20 | _ | _ | TBD | _ | _ | TBD | - | | ns | | | | | | | | | | | | | | | | | | | Address Hold Tir | Address Hold Time | | t <sub>AH</sub> | | | | | | ļ. | | | | | 1 | 1 | 1 1 | 1 | 20 | _ | _ | 20 | _ | _ | 20 | _ | _ | ns | | | | | | | | | | A <sub>0</sub> ~ A <sub>7</sub> Set-up Time Before E | | t <sub>ASM</sub> | | 200 | _ | _ | TBD | - | _ | TBD | - | | ns | | | | | | | | | | | | | | | | | | | | | | | | Peripheral Read Bus | | (t <sub>ACCN</sub> ) | | - | - | (635) | - | - | тво | - | - | TBD | ns | | | | | | | | | | | | | | | | | | | | | | | | Access Time | Access Time Multiplexed Bus | | (t <sub>ACCM</sub> ) | | _ | _ | (635) | _ | _ | TBD | _ | _ | TBD | ns | | | | | | | | | | | | | | | | | | | | | | | Oscillator stabiliz | ation T | ime | t <sub>RC</sub> | Fig. 10 | 20 | _ | - | 20 | _ | _ | 20 | - | _ | ms | | | | | | | | | | | | | | | | | | | | | | | Processor Contro | l Set-up | Time | tecs | Fig. 11 | 250 | _ | · | 250 | _ | - | 250 | - | - | ns | | | | | | | | | | | | | | | | | | | | | | # PERIPHERAL PORT TIMING | laam | | Sumbal | Test | н | 06301 | V0 | HD | 63A0 | 1V0 | НС | 63B0 | 1V0 | Unit | |------------------------------------------------------------------------|--------------------|-------------------|----------------|-----|-------|-----|-----|------|-----|-----|------|-----|------| | Item | | Symbol | Con-<br>dition | min | typ | max | min | typ | max | min | typ | max | Onit | | Peripheral Data<br>Set-up Time | t 1, 2, 3, 4 | t <sub>PDSU</sub> | Fig. 3 | 200 | _ | - | 200 | _ | _ | 200 | _ | - | ns | | Peripheral Data<br>Hold Time | t 1, 2, 3, 4 | tpDH | Fig. 3 | 200 | - | _ | 200 | - | - | 200 | - | - | ns | | Delay Time, Enable Po<br>Transition to OS3 Neg<br>Transition | | tospi | Fig. 5 | _ | - | 300 | - | _ | 300 | 1 | 1 | 300 | ns | | Delay Time, Enable Po<br>Transition to OS3 Posi<br>Transition | | t <sub>OSD2</sub> | Fig. 5 | _ | - | 300 | - | _ | 300 | - | - | 300 | ns | | Delay Time, Enable No<br>tive Transition to Peri-<br>pheral Data Valid | Port 1,<br>2, 3, 4 | t <sub>PWD</sub> | Fig. 4 | _ | _ | 300 | - | _ | 300 | _ | _ | 300 | ns | | Input Strobe Pulse Wid | th | t <sub>PWIS</sub> | Fig. 6 | 200 | _ | _ | 200 | _ | _ | 200 | - | - | ns | | Input Data Hold Time | Port 3 | t <sub>IH</sub> | Fig. 6 | 150 | - | _ | 150 | _ | _ | 150 | - | - | ns | | Input Data Setup Time | Port 3 | t <sub>IS</sub> | Fig. 6 | 0 | _ | _ | 0 | _ | - | 0 | _ | - | ns | <sup>\*</sup> Except P<sub>21</sub> TIMER, SCI TIMING | Item | Cumbal | Test<br>Con- | н | 06301 | V0 | HE | 63A | )1V0 | н | 63BC | 1V0 | Unit | |--------------------------------------------------------|-------------------|--------------|-----|-------|-----|-----|-----|----------|-----|------|-----|------------------| | item | Symbol | dition | min | typ | max | min | typ | max | min | typ | max | Unit | | Timer Input Pulse Width | t <sub>PWT</sub> | | 2.5 | _ | _ | TBD | _ | - | TBD | _ | - | t <sub>cyc</sub> | | Delay Time, Enable Positive<br>Transition to Timer Out | t <sub>TOD</sub> | Fig. 7 | _ | - | 400 | _ | - | 400 | _ | _ | 400 | ns | | SCI Input Clock Cycle | t <sub>Scyc</sub> | | 2.0 | _ | _ | TBD | _ | <u> </u> | TBD | _ | - | μs | | SCI Input Clock Pulse Width | tpwsck | | 0.4 | _ | 0.6 | 0.4 | - | 0.6 | 0.4 | - | 0.6 | t <sub>cyc</sub> | # **MODE PROGRAMMING** | Item | Symbol | Test | нс | 6301 | V0 | нс | 063A0 | )1V0 | н | 6380 | 1V0 | Unit | |------------------------------|------------------|--------|-----|------|-----|-----|----------|------|-----|------|-----|------------------| | item | | dition | min | typ | max | min | typ | max | min | typ | max | | | RES "Low" Pulse Width | PWRSTL | | 3 | _ | _ | 3 | <u> </u> | _ | 3 | - | - | t <sub>cyc</sub> | | Mode Programming Set-up Time | t <sub>MPS</sub> | Fig. 8 | 2 | - | - | 2 | - | - | 2 | - | - | t <sub>cyc</sub> | | Mode Programming Hold Time | t <sub>HMP</sub> | | 150 | - | | 150 | _ | _ | 150 | - | _ | ns | Figure 1 Expanded Multiplexed Bus Timing Figure 2 Expanded Non-Multiplexed Bus Timing \*Port 3 Non-Latched Operation Figure 3 Port Data Set-up and Hold Times (MPU Read) Figure 4 Port Data Delay Times (MPU Write) \*Access matches Output Strobe Select (OSS = 0, a read; OSS = 1, a write) Figure 5 Port 3 Output Strobe Timing (Single Chip Mode) Figure 6 Port 3 Latch Timing (Single Chip Mode) Figure 7 Timer Output Timing Figure 9 Bus Timing Test Loads (TTL Load) Figure 10 Interrupt Sequence Figure 11 Reset Timing ## **■ FUNCTIONAL PIN DESCRIPTION** ## V<sub>CC</sub>, V<sub>SS</sub> These two pins are used for power supply and GND. Recommended power supply voltage is $5V \pm 10\%$ (HD6301V0, HD63A01V0), $5V \pm 5\%$ (HD63B01V0) or 3 to 6V other than for high speed operation (500kHz). ## XTAL, EXTAL These two pins are connected with parallel resonant fundamental crystal, AT cut. For instance, in order to obtain the system clock 1MHz, a 4MHz resonant fundamental crystal is useful because the devide by 4 circuitry is included. EXTAL accepts an external clock input of duty 50% (±10%) to drive, then internal clock is a quarter the frequency of an external clock. External driving frequency will be less than 4 times as maximum internal clock. For external driving, no XTAL should be connected. An example of connection circuit is shown in Fig. 12. Figure 12 Crystal interface ## • STBY This pin is used to place the MCU in the Stand-by mode. Setting to "Low" level, the internal condition is reset with inactive oscillation and fixed internal clock. In order to retain information in RAM during stand-by, write "0" into RAM enable bit (RAME). RAME is bit 6 of the RAM Control Register at address \$0014. This disables the RAM, so the contents of RAM is guaranteed. For details of the stand-by mode, see the STAND-BY section. ## Reset (RES) This input is used to reset the MCU and start it from a power off condition. RES must be held "Low" for at least 20ms when power is on. To reset the MCU during system operation, it must be held "Low" at least 3 system clock cycles. From the third cycle on, all address buses become "High" with RES at "Low" level. Detecting "High" level, MPU does the following. - I/O Port 2 bits 2,1,0 are latched into bits PC2, PC1, PC0 of program control register. - (2) The contents of the two Start Addresses, \$FFFE, \$FFFF are brought to the program counter, from which program starts (see Table 1). - (3) The interrupt mask bit is set. In order to have the MPU recognize the maskable interrupts IRQ<sub>1</sub> and IRQ<sub>2</sub>, clear it beforehand. ## • Enable (E) With the internal oscillator in use, this supplies system clock for the rest of the system. Output is a single-phase, TTL compatible and 1/4 the crystal oscillation frequency. It will drive two LS TTL load and 40pF. # Non maskable Interrupt (NMI) When the input signal of this pin is recognized to fall, NMI sequence starts. The current instruction may be continued to the last if $\overline{\text{NMI}}$ signal is detected as well as the following $\overline{\text{IRQ}}_1$ interrupt. Interrupt mask bit in Condition Code Register has no effect on NMI. In response to NMI interrupt, the information of Program Counter, Index Register, Accumulators, and Condition Code Register are stored on the stack. On completion of this sequence, vectoring address \$FFFC and FFFD will occur to load the contents to the program counter and branch to a non maskable interrupt service routine. Inputs IRQ<sub>1</sub>, and NMI are hardware interrupt lines sampled by internal clock. After the execution of instructions, start the interrupt routine in synchronization with E. # ● Interrupt Request (IRQ₁) This level sensitive input requests that an interrupt sequence be generated within the machine. The MPU will wait receiving the request until it completes the current instruction that being executed before it recognizes the request. At that time, if the interrupt mask bit in Condition Code Register is not set, MPU begins interrupt sequence; otherwise, interrupt request is neglected. Once the sequence has started, the information of Program Counter, Index Register, Accumulator, Condition Code Register are stored on the stack. Then the MPU sets the interrupt bit so that no further maskable interrupts may occur. Table 1 Interrupt Vectoring memory map | | Vec | tor | Interrupt | |------|------|------|---------------------------| | hest | MSB | LSB | I TOTAL | | rity | FFFE | FFFF | AES | | | FFEE | FFEF | TRAP | | | FFFC | FFFD | NMI | | | FFFA | FFFB | Software Interrupt (SWI) | | | FFF8 | FFF9 | IRQ, (or IS3) | | | FFF6 | FFF7 | ICF (Timer Input Capture) | | | FFF4 | FFF5 | OCF (Timer Output Compare | | | FFF2 | FFF3 | TOF (Timer Overflow) | | vest | FFFO | FFF1 | SCI (RDRF + ORFE + TDRE) | | | | | | Lowest At the end of the cycle, the MPU generates 16 bit vectoring addresses indicating memory addresses \$FFF8 and \$FFF9, and locates the contents in Program Counter to branch to an interrupt service routine. The Internal Interrut will generate signal $(\overline{IRQ_2})$ which is quite the same as $\overline{IRQ_1}$ except that it will use the vector address \$FFF0 to \$FFF7. When $\overline{IRQ_1}$ and $\overline{IRQ_2}$ are generated at the same time, the former precede the latter. Interrupt Mask Bit in the condition code register, if being set, will keep the both interrupts off. On occurrence of following Address Error or Op-code error, TRAP interrupt is invoked. This interrupt has priority next to RES. Independently of the Mask Bit condition, the MPU will start an interrupt sequence. The vector for this interrupt will be FFEE, FFEF. The following pins are available only for Port 3 in single chip mode. • Input Strobe (IS3) (SC1) This signal controls $\overline{1S3}$ interrupt and the latch of Port 3. When detected the signal fall, the flag of Port 3 Control Status Register is set. For respective bits of Port 3 Control Status Register, see the I/O PORT 3 CONTROL STATUS REGISTER section. ## Output Strobe (OS3) (SC<sub>2</sub>) This signal is used to strobe to an external device, indicating effective data is on the I/O pins. The timing chart for Output Strobe are shown in figure 5. The following pins are available for Expanded Modes. # Read/Write (R/W) (SC<sub>2</sub>) This TTL compatible output signal indicates peripheral and memory devices whether MCU is in Read ("High"), or in Write ("Low"). The normal stand-by state is Read ("High"). Its output will drive one TTL load and 90pF. # ● I/O Strobe (IOS) (SC<sub>1</sub>) In expanded non multiplexed mode 5 of operation, $\overline{IOS}$ decodes internally A<sub>9</sub> to A<sub>15</sub> as zero's and A<sub>8</sub> as a one. This allows external access up to 256 addresses from \$0100 to \$01FF in memory. The timing chart is shown in Figure 2. ## Address Strobe (AS) (SC<sub>1</sub>) In the expanded multiplexed mode, address strobe appears at this pin. It is used to latch the lower 8 bits addresses multiplexed with data at Port 3 and to control the 8-bit latch by address strobe as shown in Figure 18. Thereby, I/O Port 3 can become data bus during E pulse. The timing chart of this signal is shown in Figure 1. ## PORTS There are four I/O ports on HD6301V MCU (three 8-bit ports and one 5-bit port). 2 control pins are connected to one of the 8-bit port. Each port has an independent write-only data direction register to program individual I/O pins for input or output.\* When the bit of associated Data Direction Register is "1", I/O pin is programmed for output, if "0", then programmed for an input. There are four ports.: Port 1, Port 2, Port 3, and Port 4. Addresses of each port and associated Data Direction Register are shown in Table 2. Only one exception is bit 1 of Port 2 which becomes either a data input or a timer output. It cannot be used as an output port. Table 2 Port and Data Direction Register Addresses | Ports | Port Address | Data Direction<br>Register Address | |------------|--------------|------------------------------------| | I/O Port 1 | \$0002 | \$0000 | | I/O Port 2 | \$0003 | \$0001 | | I/O Port 3 | \$0006 | \$0004 | | I/O Port 4 | \$0007 | \$0005 | # I/O Port 1 This is an 8-bit port, each bit being defined individually as input or outputs by associated Data Direction Register. The 8-bit output buffers have three-state capability, maintaining in high impedance state when they are used for input. In order to be read accurately, the voltage on the input lines must be more than 2.0V for logic "1" and less than 0.8V for logic "0". These are TTL compatible. After the MCU has been reset, all I/O lines are configured as inputs in all modes except mode 1. In all modes other than expanded non multiplexed mode, mode 1, Port 1 is always parallel I/O. In mode 1, Port 1 will be output line for lower order address lines (A<sub>0</sub> to A<sub>7</sub>). # I/O Port 2 This port has five lines, whose I/O direction depends on its data direction register. The 5-bit output buffers have three-state capability, going high impedance state when used as inputs. In order to be read accurately, the voltage on the input lines must be more than 2.0V for logic "1" and less than 0.8V for logic "0". After the MCU has been reset, I/O lines are configured as inputs. These pins on Port 2 (pins 10, 9, 8 of the chip) are used to program the mode of operation during reset. The values of these three pins during reset are latched into the upper 3 bits (bit 7, 6 and 5), which is expanded in the MODE SELECTION section. In all modes, Port 2 can be configured as I/O lines. This port also provides access to the Serial I/O and the Timer. However, note that bit I $(P_{21})$ is the only pin restricted to data input or Timer output. ## I/O Port 3 This is an 8-bit port which can be configured as I/O lines, a data bus, or an address bus multiplexed with data bus. Its function depends on hardware operation mode programmed by the user using 3 bits of Port 2 during Reset. Port 3 as a data bus is bi-directional. For an input from peripherals, regular TTL level must be supplied, that is greater than 2.0V for a logic "1" and less than 0.8V for a logic "0". This TTL compatible three-state buffer can drive one TTL load and 90pF. In the expanded Modes, data direction register will be inhibited after Reset and data flow will be dependent on the state of the R/W line. Port 3 in each mode assumes the following characteristics. Single Chip Mode (Mode 7): Parallel Inputs/Outputs as programmed by its corresponding Data Direction Register. There are two control lines associated with this port in this mode, an input strobe (IS3) and an output strobe (OS3), both being used for handshaking. They are controlled by I/O Port 3 Control/Status Register. Additional 3 characteristics of Port 3 are summarized as follows: - (1) Port 3 input data can be latched using $\overline{\text{IS3}}$ (SC<sub>1</sub>) as a control signal. - (2) OS3 cam be generated by MPU read or write to Port 3's data register. - (3) IRQ<sub>1</sub> interrupt can be generated by an IS3 negative edge. Port 3 strobe and latch timing is shown in Figs. 5 and 6, respectively. I/O Port 3 Control/Status Register | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------------|-----------------------|---|---|-----------------|---|---|---| | \$000F | IS3<br>FLAG | IS3<br>IRQ1<br>ENABLE | × | \ | LATCH<br>ENABLE | | × | × | Bit 0 Not used. Bit 1 Not used. Bit 2 Not used. ## Bit 3 LATCH ENABLE. Bit 3 is used to control the input latch of Port 3. If the bit is set at "1", the input data on Port 3 is latched by the falling edge of $\overline{IS3}$ . The latch is cleared by the MCU read to Port 3; it can now be latched again. Bit 3 is cleared by a reset. Bit 4 OSS (Output Strobe Select) This bit identifies the cause of output strobe generation: a write operation or read operation to I/O Port 3. When the bit is cleared, the strobe will be generated by a read operation to Port 3. When the bit is not cleared, the strobe will be generated by a write operation. Bit 4 is cleared by a reset. ## Bit 5 Not used. # Bit 6 IS3 ENABLE. If the 183 flag (bit 7) is set with bit 6 set, an interrupt is enabled. Clearing the flag causes the interrupt to be disabled. The bit is cleared by a reset. Bit 7 IS3 FLAG. Bit 7 is a read-only bit which is set by the falling edge of $\overline{IS3}$ (SC<sub>1</sub>). It is cleared by a read of the Control/Status Register followed by a read/write of I/O Port 3. The bit is cleared by reset. Expanded non multiplexed mode (mode 1,5) In this mode, Port 3 becomes data bus. (Do to D7) Expanded Multiplexed Mode (mode 0, 4, 6) Port 3 becomes both the data bus $(D_0 \sim D_7)$ and lower bits of the address bus $(A_0 \sim A_7)$ . An address strobe output is true when the address is on the port. #### I/O Port 4 This is an 8-bit port that becomes either I/O or address outputs depending on the operation mode selected. In order to be read accurately, the voltage at the input lines must be greater than 2.0V for a logic "1", and less than 0.8V for a logic "0". For outputs, each line is TTL compatible and can drive one TTL load and 90pF. After reset, this port becomes inputs. To use these pins as addresses, they should be programmed as outputs. In each mode, Port 4 assumes following characteristics. Single Chip Mode (Mode 7): Parallel Inputs/Outputs as programmed by its associated data direction register. Expanded Non Multiplexed Mode (Mode 5): In this mode, Port 4 becomes the lower address lines (A<sub>0</sub> to A<sub>7</sub>) by writing "1"s on the data direction register. When all of the eight bits are not required as addresses, the remaining lines can be used as I/O lines (Inputs only) starting with the MSB. Expanded Non Multiplexed Mode (Mode 1): In this mode, Port 4 becomes output for upper order address lines (A<sub>8</sub> to A<sub>15</sub>). Expanded Multiplexed Mode (Mode 0, 4): In this mode, Port 4 becomes output for upper order address lines (A<sub>8</sub> to A<sub>15</sub>) regardless of the value of data direction register. The relation between each mode and I/O Port 1 to 4 is summarized in Table 3. ## ■ MODE SELECTION The operation mode after the rest must be determined by the user wiring the 10, 9, and 8 externally. These three pins are lower order bits; I/O 0, I/O 1, I/O 2 of Port 2. They are latched into the programmed control bits PC0, PC1, PC2 in I/O Port 2 register when reset goes "High", I/O Port 2 Register is shown below. ## Port 2 DATA REGISTER An example of external hardware used for Mode Selection is shown in Fig. 13. During reset, the HD14053B is available to seperate the peripheral device from the MCU. It is necessary where the data conflict can occur between peripheral device and Mode generation circuit. No mode can be changed through software because the bits 5, 6, and 7 of Port 2 are for read only. The mode selection of the HD6301V0 is shown in Table 4. The HD6301V0 operates in three basic modes: (1) Single Chip Mode, (2) Expanded Multiplexed Mode (compatible with the HMCS6800 peripheral family), (3) Expanded Non Multiplexed Mode (compatible with HMCS6800 peripheral family) # Single Chip Mode In the Single Chip Mode, all ports will become I/O. This is shown in figure 15. In this mode, SC1, SC2 pins are configured for control lines of Port 3 and can be used as input strobe (IS3) and output strobe (OS3) for handshaking data. ## Expanded Multiplexed Mode In this mode, Port 4 is configured for I/O (inputs only) or address lines. The data bus and the lower order address bus are multiplexed in Port 3 and can be seperated by an output called Address Strobe. Port 2 is configured for 5 parallel I/O or Serial I/O, or Timer, or any combination thereof. Port 1 is configured for 8 parallel I/O. In this mode, HD6301V0 is expandable to 65k words (See Fig. 16). ## Expanded Non Multiplexed Mode In this mode, the HD6301V0 can directly address HMCS6800 peripherals with no external logic. In mode 5, Port 3 becomes a data bus. Port 4 becomes $A_0$ to $A_7$ address bus or partial address bus and I/O (inputs only). Port 2 is configured for a parallel I/O, Serial I/O, Timer or any combination thereof. Port 1 is configured as a parallel I/O only. In this mode, HD6301V0 is expandable to 256 locations. In the application system enough with fewer addresses, idle pins of Port 4 can be used as I/O lines (inputs only) (See Fig. 17). In mode 1, Port 3 becomes a data bus and Port 1 becomes A<sub>0</sub> to A<sub>7</sub> address bus, and Port 4 becomes A<sub>8</sub> to A<sub>15</sub> address bus In this mode, the HD6301V0 is expandable to 65k words with no external logic. ## Lower Order Address Bus Latch Because the data bus is multiplexed with the lower order address bus in Port 3 in the expanded multiplexed mode, address bits must be latched outside the board. It requires the 74LS373 Transparent octal D-type to latch the LSB. Latch connection of the HD6301V0 is shown in Figure 18. Figure 13 Recommended Circuit for Mode Selection Figure 14 HD14053B Multiplexers/De-Multiplexers Figure 15 HD6301V0 MCU Single-Chip Mode Figure 16 HD6301V0 MCU Expanded Multiplexed Mode Figure 17 HD6301V0 MCU Expanded Non Multiplexed Mode Figure 18 Latch Connection # Mode and Port Summary MCU Signal Description This section gives a description of the MCU signals for the various modes. $SC_1$ and $SC_2$ are signals which vary with the mode that the chip is in. Table 3 Feature of each mode and lines | MOI | DE | PORT 1<br>Eight Lines | PORT 2<br>Five Lines | PORT 3<br>Eight Lines | PORT 4<br>Eight Lines | SC <sub>1</sub> | SC <sub>2</sub> | |------------|--------|--------------------------------------------------|----------------------|------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------|-----------------| | SINGLE CHI | P | I/O | I/O | 1/0 | 1/0 | IS3 (I) | OS3 (O) | | EXPANDED | MUX | 1/0 | I/O | ADDRESS BUS (A <sub>0</sub> ~A <sub>7</sub> ) DATA BUS (D <sub>0</sub> ~D <sub>7</sub> ) | ADDRESS BUS* | AS(O) | R/₩(0) | | EXPANDED | Mode 5 | 1/0 | I/O | DATA BUS<br>(D <sub>0</sub> ~D <sub>7</sub> ) | ADDRESS BUS* (A <sub>0</sub> ~A <sub>7</sub> ) | ios(o) | R/W(O) | | NON-MUX | Mode 1 | ADDRESS BUS<br>(A <sub>0</sub> ~A <sub>7</sub> ) | 1/0 | DATA BUS<br>(D <sub>0</sub> ~D <sub>7</sub> ) | ADDRESS BUS<br>(A <sub>6</sub> - A <sub>15</sub> ) | Not Used | R/ <b>W</b> (O) | <sup>\*</sup>These lines can be substituted for I/O (Input Only) starting with the MSB (except Mode 0, 4). I = Input O ≈ Output IS3 = Input Strobe OS3 = Output Strobe SC = Strobe Control R/W = Read/Write IOS = I/O Select AS = Address Strobe Table 4 Mode Selection Summary | Mode | (PC2) | (PC1) | (PCO) | ROM | RAM | Interrupt<br>Vectors | Bus<br>Mode | Operating<br>Mode | |------|-------|-------|-------|------------------|------|----------------------|-------------|--------------------------------| | 7 | Н | Н | Н | - 1 | 1 | ı | ī | Single Chip | | 6 | Н | н | L | 1 | 1 | 1 | MUX(4) | Multiplexed/Partial Decode | | 5 | н | L | н | - | | ı | NMUX(4) | Non-Multiplexed/Partial Decode | | 4 | Н | L | L | E(2) | J(1) | E | MUX | Multiplexed/RAM | | 3 | L | н | н | 1 | _ | _ | | Not Used | | 2 | L | н | L | | _ | _ | _ | Not Used | | 1 | L | L | Н | E <sup>(2)</sup> | 1 | 1 | NMUX | Non-Multiplexed | | 0 | L | L | L | 1 | 1 | (3) | MUX | Multiplexed Test | # LEGEND : I — Internal E — External MUX — Multiplexed NMUX — Non-Multiplexed L - Logic "0" H - Logic "1" ## (NOTES) - 1) Internal RAM is addressed at \$0080. - 2) Internal ROM is disabled. - 3) Reset vector is external for 3 or 4 cycles after RES goes "high". - 4) Idle lines of Port 4 address outputs can be assigned to Input Port. # ■ Memory Map The MCU can provide up to 65k byte address space depending on the operating mode. Fig. 19 shows a memory map for each operating mode. The first 32 locations of each map are for the MCU's internal register only, as shown in Table 5. Table 5 Internal Register Area | Register | Address | |----------------------------------------------|---------| | Port 1 Data Direction Register**** | 00. | | Port 2 Data Direction Register*** | 01 | | Port 1 Data Register | 02. | | Port 2 Data Register | 03 | | Port 3 Data Direction Register **** | 04** | | Port 4 Data Direction Register **** | 05*** | | Port 3 Data Register | 06** | | Port 4 Data Register | 07*** | | Timer Control and Status Register | 08 | | Counter (High Byte) | 09 | | Counter (Low Byte) | OA. | | Output Compare Register (High Byte) | ОВ | | Output Compare Register (Low Byte) | ос | | Input Capture Register (High Byte) | OD. | | Input Capture Register (Low Byte) | 0E | | Port 3 Control and Status Register | OF** | | Rate and Mode Control Register | 10 | | Transmit/Receive Control and Status Register | 11 | | Receive Data Register | 12 | | Transmit Data Register | 13 | | RAM Control Register | 14 | | Reserved | 15-1F | - External address in Mode 1 - \*\* External address in modes 0, 1, 4, 6; cannot be accessed in Mode 5 - \*\*\* External address in Modes 0, 1, 4 - \*\*\*\* 1 = Output, 0 = Input (to be continued) Figure 19 HD6301V0 Memory Maps (to be continued) Figure 19 HD6301V0 Memory Maps Figure 19 HD6301V0 Memory Maps #### ■ PROGRAMMABLE TIMER The HD6301V0 contains 16-bit programmable timer and used to make measurement of input waveform. In addition independently it can generate an output waveform by itself. For both input and output waveform, the pulse width may vary from a few microseconds to many seconds. The timer hardware consists of - an 8-bit control and status register - · a 16-bit free running counter - a 16-bit output compare register, and - a 16-bit input capture register A block diagram of the timr is shown in Figure 20. Figure 20 Programmable Timer Block Diagram # • Free Running Counter (\$0009:000A) The key element in the programmable timer is a 16-bit free running counter, that is driven by an E (Enable) clock to increment its values. The counter value will be read out by the MPU software at any time desired with no effects on the counter. Reset will clear the counter. When the MPU writes arbitrary data to the MSB of \$09, then value of \$FFF8 is being pre set to the counte (\$09, \$0A) indepently of the write data value. When the MPU writes arbitrary data to the LSB (\$0A), the data is set to the "Low", on the other hand, the data preceedingly written in "High" byte is set to "High". The counter value written to the counter using the double store instruction is shown in Figure 21. (5AF3 written to the counter) Figure 21 Counter Write Timing \* To write to the counter can disturb serial operations, so it should be inhibited during using the SCI. # • Output Compare Register (\$000B:\$000C) This is a 16-bit read/write register which is used to control an output waveform. The contents of this register are constantly being compared with current value of the free running counter. When the contents match with the value of the free running counter, a flag (OCF) in the timer control/status register (TCSR) is set and the current value of an output level Bit (OLVL) in the TCSR is transferred to Port 2 bit 1. When bit 1 of the Port 2 data direction register is "1" (output), the OLVL value will appear on the bit 1 of Port 2. Then, the value of Output Compare Register and Output level bit should be changed to control an output level again on the next compare values. The output compare register is set to \$FFFF during reset. The compare function is inhibited for one cycle immediately after writing of the output compare register to the upper bytes, or, a writing of the Counter to the upper bytes. This is because for one thing, the operation makes sure to set the values of 16 bits in the register before comparing, and for another, the counter is set to FFF8 in the cycle following writing to "High" of the counter.\* \* For the data writing on Compare Register, 2-byte transfer instruction such as STX is available, ## Input Capture Register (\$000D: \$000E) The input capture register is a 16-bit read-only register used to hold the current value of free running counter obtained when the proper transition of an external input signal occurs. The input transition change required to trigger the counter transfer is controlled by the input Edge bit (IEDG). To allow the external input signal to gate in the edge detect unit, the bit of the Data Direction Register corresponding to bit 0 of Port 2 must have been cleared (to zero). To insure input capture in all cases, the width of an input pulse requires at least 2 Enable cycles. # • Timer Control/Status Register (TCSR) (\$0008) This is an 8-bit register. All 8 bits are readable and the lower 5 bits may be written. The upper 3 bits are read-only, indicating the timer status information below. - A proper transition has taken place on the input pin with a subsequent transfer of the current counter value to the input capture register (ICF). - (2) A match has been found between the value in the free running counter and the output compare register (OCF). - (3) When counting up to \$0000 (TOF). Each flag may contains an individual enable bit in TCSR where controls whether or not an interrupt request may be output to internal interrupt signal $(\overline{RQ_2})$ . If the 1-bit in Condition Code Register has been cleared, a priority vectored address occurs corresponding to each flag being set. A description of each bit is as follows. Timer Control / Status Register Bit 0 OLVL (Output Level); When a match is found in the value between the counter and the output compare register, this bit is transferred to the Port 2 bit 1. If the DDR corresponding to Port 2 bit 1 is set "1", the value will appear on the output pin of Port 2 bit 1. - Bit 1 IEDG (Input Edge); This bit control which transition of an input of Port 2 bit 0 will trigger the data transfer from the counter to the input capture register. The DDR corresponding to Port 2 bit 0 must be clear in advance of using this function. When IEDG = 0, trigger takes place on a negative edge ("High":to-"Low" transition). When IEDG = 1, trigger takes place on a leading edge ("Low":to-"High" transition). - Bit 2 ETOI (Enable Timer Overflow Interrupt); When set, this bit enables TOF interrupt to generate the interrupt request (IRQ<sub>2</sub>) but when clear, the interrupt is inhibited. - Bit 3 EOCI (Enable Output Compare Interrupt); When set, this bit enables OCF interrupt to generate the interrupt request (IRQ<sub>2</sub>), when clear, the interrupt is inhibited. - Bit 4 EICI (Enable Input Capture Interrupt); When set, this bit enables ICF interrupt to generate the interrupt request (IRQ<sub>2</sub>) but when clear, the interrupt is inhibited. - Bit 5 TOF (Timer Over Flow Flag); This read-only bit is set when the counter value is \$0000. It is cleared by MPU read of TCSR (with TOF set) following an MPU read of the counter (\$0009). - Bit 6 OCF (Output Compare Flag); This read-only bit is set when a match is found in the value between the output compare register and the counter. It is cleared by a read of TCSR (with OCF set) following an MCU write to the output compare register (\$000B or \$000C). - Bit 7 ICF (Input Capture Flag); The read-only bit is set by a proper transition on the input, and is cleared by a read of TCSR (with ICF set) followed by an MPU read of Input Capture Register (\$000D). Reset will clear each bit of Timer Control and Status Register. ## ■ SERIAL COMMUNICATION INTERFACE The HD6301VO contains a full-duplex asynchronous Serial Communication Interface (SCI). SCI may select the several kinds of the data rate and comprises a transmitter and a receiver which operate independently on each other but with the same data format at the same data rate. Both of transmitter and receiver communicate with the MPU via the data bus and with the outside world, through Port 2 bit 2, 3 and 4. Description of hardware, software, register is as follows. ## ● Wake-Up Feature In typical multiprocessor applications the software protocol will usually have the designated address at the initial byte of the message. The purpose of Wake-Up feature is to have the non-selected MPU neglect the remainder of the message. Thus the non-selected MPU can inhibit the all further interrupt process until the next message begins. Wake-Up feature is triggered by a ten consecutive "1"s which indicates an idle transmit line. Therefore software protocol needs an idle period between the messages. With this hardware feature, the non-selected MPU be re-enabled (or "wakes-up") for the appearing next message. ## • Programmable Option The HD6301VO has the following optional features provided for its Serial I/O. They are all programmable. - · data format; standard mark/space (NRZ) - · Clock Source; external or internal - baud rate; one of 4 rates per given MPU E clock frequency or 1/8 of external clock - · wake-up feature; Enabled or disabled - Interrupt requests; enabled or masked individually for transmitter and receive data registers - Clock Output; internal clock enabled or disabled to Port 2 bit 2 - Port 2 (bits 3, 4); dedicated or not dedicated to serial I/O individually for receiver and transmitter. ## Serial Communication Hardware The serial communications hardware is controlled by 4 registers as shown in Figure 22. The registers include: - · an 8-bit control/status register - · a 4-bit rate/mode control register (write-only) - · an 8-bit read-only receive data register - · an 8-bit write-only transmit data register Besides these 4 registers, Serial I/O utilizes Port 2 bit 3 (input) and bit 4 (output). Port 2 bit 2 can be used when an option is selected for the internal-clock-out or the external-clock-in. ## Transmit/Receive Control Status Register (TRCSR) TRCS Register consists of 8 bits which all may be read while only bits 0 to 4 may be written. The register is initialized to \$20 on RES. The bits of the TRCS register are defined as follows. Transmit / Receiver Control Status Register | | | 6 | 5 | 4 | 3 | 2 | _ 1 | 0 | | |----|----|------|------|-----|----|-----|-----|----|-------| | RD | RF | ORFE | TDRE | RIE | RE | TIE | TE | wu | ADDR: | - Bit 0 WU (Wake Up); Set by software and clear by hardware on receipt of ten consecutive "1"s. It should be noted that RE flag has already set in advance of WU flag's set. - Bit 1 TE (Transmit Enable); Set to produce preample of ten consecutive "1"s and to enable the data of transmitter to output subsequently to the Port 2 bit 4 independently of its corresponding DDR value. When clear, serial I/O affects nothing on Port 2 bit 4. - Bit 2 TIE (Transmit Interrupt Enable); When this bit is set with TDRE (bit 5) set, it will permit an IRQ2 interrupt. When clear, TDRE interrupt is masked. - Bit 3 RE (Receive Enable); When set, gates Port 2 bit 3 to input of receiver regardless of DDR value for this bit. When clear, the serial I/O affects nothing on Port 2 bit 3. - Bit 4 RIE (Receive Interrupt Enable); When this bit is set with bit 7 (RDRF) or a bit 6 (ORFE) set, it will permit an IRQ2. When clear, IRQ2 interrupt is masked. - Bit 5 TDRE (Transmit Data Register Empty); When the data transfer is made from the Transmit Data Register to Output Shift Register, it is set by hardware. The bit is cleared by reading the status register and followed by writing the next new data into the Transmit Data Register. TDRE is initialized to 1 by RES. - Bit 6 ORFE (Over Run Framing Error); When overrun or framing error occurs (receive only), it is set by hardware. Over Run Error occurs if the attempt is made to transfer the new byte to the receive data register with the RDRF set. Framing Error occurs when the bit counters are not synchronized with the boundary of the byte in the bit stream. The bit is cleared by reading the status register and followed by reading the receive data register, or by RES. Bit 7 RDRF (Receive Data Register Full); It is set by hardware when the data transfer is made from the receive shift register to the receive data register. It is cleared by reading the status register and followed by reading the receive data register, or by RES. Transfer Mate / Mode Contion Register Table 6 SCI Bit Times and Transfer Rates | | | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152MHz | |------|-----|----------|-------------------|--------------------|--------------------| | SS1: | SSO | E | 614.4 kHz | 1.0 MHz | 1.2288MHz | | 0 | 0 | E ÷ 16 | 26 µs/38,400 Baud | 16 μs/62,500 Baud | 13 μs/76,800Bauc | | 0 | 1 | E + 128 | 208µs/4,800 Baud | 128 µs/7812.5 Baud | 104.2µs/ 9,600Bau | | 1 | 0 | E ÷ 1024 | 1.67ms/600 Baud | 1.024ms/976.6 Baud | 833.3μs/ 1,200Bauc | | 1 | 1 | E ÷ 4096 | 6.67ms/150 Baud | 4.096ms/244.1 Baud | 3.333ms/ 300Bauc | Table 7 SCI Format and Clock Source Control | CC1, CC0 | Format | Clock Source | Port 2 Bit 2 | Port 2 Bit 3 | Port 2 Bit 4 - | |----------|--------|--------------|--------------|--------------|----------------| | 00 | _ | _ | _ | _ | _ | | 01 | NRZ | Internal | Not Used | •• | •• | | 10 | NRZ | Internal | Output* | •• | •• | | 11 | NRZ | External | Input | •• | •• | Clock output is available regardless of values for bits RE and TE. <sup>\*\*</sup> Bit 3 is used for serial input if RE = "1" in TRCS. Bit 4 is used for serial output if TE = "1" in TRCS. # • Transfer rate/Mode Control Register (RMCR) The register controls the following serial I/O variables: · Bauds rate · data format · clock source · Port 2 bit 2 feature It is 4-bit write-only register, cleared by RES. The 4 bits are considered as a pair of 2-bit fields. The lower 2 bits control the bit rate of internal clock while the upper 2 bits control the format and the clock select logic. Bit 0 SS0 Bit 1 SS1 Speed Select These bits select the Baud rate for the internal clock. The rates selectable are function of E clock frequency within the MPU. Table 6 lists the available Band Rates. Bit 2 CC0 Bit 3 CC1 Clock Control/Format Select They control the data format and the clock select logic. Table 7 defines the bit field. ## Internally Generated Clock If the user wish to employ externally a internal clock for the serial I/O, the following requirements should be noted. - . The values of RE and TE have no effect. - · CC1, CC0 must be set to "10". - The maximum clock rate will be E/16. - The clock is once the bit rate. ## Externally Generated Clock If the user wish to supply an external clock for the Serial I/O, the following requirements should be noted. - The CC1, CC0, field in the Rate and Mode Control Register must be set to "11" (See Table 7). - The external clock must be set to 8 times the desired baud rate. - The maximum external clock frequency is the same as E clock. # Serial Operations The serial I/O hardware must be initialized by the HD6301V0 software prior to operation. The sequence will be normally as follows - Writing the desired operation control bits to the Rate and Mode Control Register. - Writing the desired operation control bits to the TRCS register. If using Port 2 bit 3, 4 for serial I/O exclusively, TE, RE bits may be preserved set. When TE, RE bit cleared during SCI operation, and subsequently set again, it should be noted that the setting of TE, RE must refrain for at least one bit time of the current baud rate. If set within one bit time, there may be the case where the initializing of internal function for transmit and receive does not take place. ## Transmit Operation Data transmission is enabled by the TE bit in the TRCS register. When set, gates the output of the serial transmit shift register to Port 2 bit 4 which is unconditionally configured as an output irrespectively of corresponding DDR value. Following RES the user should configure both the RMC register and the TRCS register for desired operation. Setting the TE bit during this procedure causes a transmission of ten-bit preamble of "1"s. Following the preamble, internal synchronization is established and the transmitter section is ready to operate. Then either of the following states exists. (1) If the transmit data register is empty (TDRE = 1), the consecutive "1"s are transmitted indicating an idle lines. (2) If the data has been loaded into the Transmit Data Register (TDRE = 0), it is transferred to the output shift register and data transmission begins. During the data transfer, the 0 start bit is first transferred. Next the 8-bit data (beggining at bit0) and the stop bit. When the transmit data register has been empty, the hardware sets the TDRE flag bit: If the MCU fails to respond to the flag within the proper time, TDRE is preserved set and then a 1 will be sent (instead of a 0 at start bit time) and more 1s will be set successively until the data is supplied to the data register. While the TDRE remains a "1", no "0" will be sent. ## Receive Operation The receive operation is enabled by the RE bit, gating the serial input through Port 2 bit 3. The receive section operation is conditioned by the contents of the TRCS and RMC register. In the normal non-biphase mode, the received bit stream is synchronized by the first "0" (space). During 10-bit time, the approximate center is strobed. If the tenth bit is not "1" (stop bit), the system assumes a framing error and the ORFE is set. If the tenth bit is "1", the data is transferred to the receive data register, with the interrupt flag set. If the tenth bit of the next data is received, however, still RDRF is preserved set, then ORFE is set indicating that an overrun error has occurred. After the MCU read of the status register as a response to RDRF flag or ORFE flag, following the MCU read of the receive data register, RDRF or ORFE will be cleared. ## ■ RAM CONTROL REGISTER The register assigned to the address \$0014 gives a status information about standby RAM. Bit 0 Not used. Bit 1 Not used. Bit 2 Not used. Bit 3 Not used. Bit 4 Not used. Bit 5 Not used. Bit 6 RAM Enable. data in the RAM is valid. Using this control bit, the user can disable the RAM. When the MPU is reset, "1" is set in the RAM Enable bit thus enabling the standby RAM. With the program control, it is capable of writing "1" or "0". With the disabled RAM (logic "0"), the RAM address becomes external address and the MPU may read the data from the outside memory. Bit 7 Standby Bit This bit is cleared when the $V_{CC}$ voltage is removed. This bit is a read/write status flag that user can read. If this bit is preserved set, indicating that $V_{CC}$ voltage is applied and the # ■ GENERAL DESCRIPTION OF INSTRUCTION SET The HD6301VO has an upward object code compatible with the HD6801 to utilize all instruction sets of the HMCS6800. The execution time of the key instruction is reduced to increase the system through-put. In addition, the bit operation instruction, the change instruction of the index and the accumulator, the sleep instruction are added. This section describes: - •MCU programming model (See Fig. 23) - Addressing modes - Accumulator and memory manipulation instructions (See Table 8) - New instructions - Index register and stack manipulation instructions (See Table 9) - Jump and branch instructions (See Table 10) - Condition code register manipulation instructions (See Table 11) - · Op-code map (See Table 12) ## MCU Programming Model The programming model for the HD6301V0 is shown in Figure 23. The double accumulator is physically the same as the accumulator A concatenated with the accumulator B, so that the contents of A and B is changed with executing operation of an accumulator D. Figure 23 MCU Programming Model ## MCU Addressing Modes The HD6301V0 has seven address modes which depend on both of the instruction type and the code. The address mode for every instruction is shown along with execution time given in terms of machine cycles (Table 8 to 12). When the clock frequency is 4 MHz, the machine cycle will be microseconds. ## Accumulator (ACCX) Addressing Only the accumulator (A or B) is addressed. Either accumulator A or B is specified by one-byte instructions. ## Immediate Addressing In this mode, the operand is stored in the second byte of the instruction except that the operand in LDS and LDX, etc are stored in the second and the third byte. These are two or three-byte instructions. #### Direct Addressing In this mode, the second byte of instruction indicates the address where the operand is stored. Direct addressing allows the user to directly address the lowest 256 Bytes in the machine ie; locations zero through 255. Enhanced execution times are achieved by storing data in these locations. For system configuration, it is recommended that these locations should be RAM and be utilized preferably for user's data realm. These are two-byte instructions except the AIM, OIM, EIM and TIM each have three. #### Extended Addressing In this mode, the second byte indicates the upper 8 bit addresses where the operand is stored, while the third byte indicates the lower 8 bits. This is an absolute address in memory. These are three-byte instructions. # Indexed Addressing In this mode, the contents of the second byte is added to the lower 8 bits in the Index Register. For each of AIM, OIM, EIM and TIM instructions, the contents of the third byte are added to the lower 8 bits in the Index Register. In addition, this carry is added to the upper 8 bits in the Index Register. The result is used for addressing memory. Because the modified address is held in the Temporary Address Register, there is no change to the Index Register. These are two-byte instructions but AIM, OIM, EIM, TIM have three. ## Implied Addressing In this mode, the instruction itself gives the address; stack pointer, index register, etc. These are 1-byte instructions. Relative Addressing In this mode, the contents of the second byte is added to the lower 8 bits in the program counter. The resulting carry or borrow is added to the upper 8 bits. This helps the user to address the data within a range of -126 to +129 bytes of the current execution instruction. These are two-byte instructions. Table 8 Accumulator, Memory Manipulation Instructions | | Section De | | | | | | Add | iress | ng l | Mod | les | | | | | | | Condition Code<br>Register | | | | | | | |----------------------------|------------|----------|--------------|--------------|----------|----------|----------|--------------------------------------------------|----------|----------|------------|----------|----------|-----|--------------|----------|-------------------------------------------------------|----------------------------|---|----|----|------------|-----|--| | Operations | Mnemonic | IM | ME | 0 | DIF | REC | т | IN | DE | X | EX. | TEN | ID | IMF | LIE | D | Boolean/<br>Arithmetic Operation | 5 | 4 | 3 | _ | 1 | 0 | | | | | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | Antimetic Operation | н | 1 | N | z | v | С | | | Add | ADDA | 88 | 2 | 2 | 98 | 3 | 2 | AB | 4 | 2 | 88 | 4 | 3 | | Г | Т | A + M→ A | 1 | • | 1 | 1 | \$ | 1 | | | | ADDB | СВ | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 | | | | B + M → B | : | • | \$ | : | \$ | ‡ | | | Add Double | ADDD | C3 | 3 | 3 | D3 | 4 | 2 | E3 | 5 | 2 | F3 | 5 | 3 | | | $\vdash$ | A:B+M:M+1-A:B | | • | 1 | 1 | : | : | | | Add Accumulators | ABA | $t^-$ | T | | | | | | | | | | | 18 | 1 | 1 | A+B-A | 1 | • | \$ | : | : | \$ | | | Add With Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | 89 | 4 | 3 | | | 1 | A + M + C - A | \$ | • | : | : | 1 | \$ | | | | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 | | | Γ | B + M + C → B | # | • | : | : | 1 | | | | AND | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 | | | | A·M → A | • | • | : | : | R | • | | | | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 | | | | B·M → B | • | • | \$ | | R | • | | | Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | <b>B</b> 5 | 4 | 3 | | | | A·M | • | • | \$ | : | R | • | | | | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 | | Ţ | | в-м | • | • | : | : | R | • | | | Clear | CLR | | | | | Г | | 6F | 5 | 2 | 7F | 5 | 3 | | | Г | 00 → M | • | • | R | s | R | R | | | | CLRA | | Ī | 1 | | $\vdash$ | | | | | | | | 4F | 1 | 1 | 00 → A | • | • | R | S | R | R | | | | CLRB | | | | Γ | | Γ | | | | | | | 5F | 1 | 1 | 00 → B | • | • | R | S | R | R | | | Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | <b>B1</b> | 4 | 3 | | | | A - M | • | • | 1 | 1 | 1 | : | | | | СМРВ | C1 | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 | | | | 8 - M | • | • | : | : | : | : | | | Compare<br>Accumulators | CEA | | | | | | | | | | | | | 11 | 1 | 1 | A - B | • | • | 1 | : | : | : | | | Complement, 1's | сом | <u> </u> | T | 1 | | t | T | 63 | 6 | 2 | 73 | 6 | 3 | | | | M → M | • | • | | 1 | R | S | | | | COMA | T | t | - | t | T | 1 | | | | 1 | $\vdash$ | $\vdash$ | 43 | 1 | 1 | Ā → A | • | • | 1 | 1 | R | S | | | | СОМВ | $\top$ | Г | | _ | | $\vdash$ | | | | | Т | | 53 | 1 | 1 | B → B | • | • | : | : | R | s | | | Complement, 2's | NEG | | T | 1 | 1 | 1 | | 60 | 6 | 2 | 70 | 6 | 3 | | | | 00 - M → M | • | • | ŧ | 1 | 1 | 2 | | | (Negate) | NEGA | $\top$ | 1 | | | | | | | | 1 | | | 40 | 1 | 1 | 00 - A → A | • | • | 1 | : | (1) | (2) | | | | NEGB | $\top$ | T | 1 | _ | 1 | T | | | | _ | T | - | 50 | 1 | 1 | 00 - B → B | | • | : | 1 | 1 | (2) | | | Decimal Adjust, A | DAA | | Ť | Ì | | T | T | | | | | T | Γ | 19 | 1 | , | Converts binary add of BCD characters into BCD format | • | • | : | : | : | (3) | | | Decrement | DEC | + | t | T | $\vdash$ | $\vdash$ | t | 6A | 6 | 2 | 7A | 6 | 3 | | $\vdash$ | t | M - 1 → M | • | • | 1 | 1 | <b>(4)</b> | ٠ | | | | DECA | 1 | $\vdash$ | ✝ | T | 1- | $\vdash$ | | | 1 | | | | 4A | 1 | 1 | A - 1 → A | • | • | 1 | 1 | (1) | • | | | | DECB | 1 | | $\vdash$ | $\vdash$ | | | | | 1 | $\vdash$ | $\vdash$ | | 5A | 1 | 1 | B - 1 → B | • | • | 1 | : | (4) | ٠ | | | Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | 88 | 4 | 3 | - | - | - | A 💮 M → A | • | • | : | : | R | | | | | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 | _ | $\vdash$ | + | B ⊕ M→ B | ١. | • | 1 | 1 | R | | | | Increment | INC | - | - | - | 1 | - | - | 6C | 6 | 2 | 7C | 6 | 3 | | <del> </del> | ╁╴ | M + 1 → M | • | • | 1 | 1 | (3) | | | | | INCA | 7 | +- | 1 | _ | $\vdash$ | 1 | - | - | - | | 1 | - | 4C | 1 | 1 | A+1 → A | • | • | 1 | 1 | (3) | | | | | INCB | +- | 1 | t | T | 1 | 1 | <del> </del> | t | 1 | - | + | - | 5C | 1 | 1 | 8 + 1 → 8 | • | • | : | : | (3) | | | | Load | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | 86 | 4 | 3 | - | ŕ | 1 | M → A | • | • | : | 1 | R | | | | Accumulator | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 | | 1 | T | M → B | • | • | | 1 | R | | | | Load Double<br>Accumulator | LDD | cc | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 | | T | T | M + 1 → B, M → A | • | • | : | : | R | • | | | Multiply Unsigned | MUL | | T | T | | | 1 | | $\vdash$ | 1 | | T | Т | 3D | 7 | 1 | A×B → A:B | • | • | • | • | • | O | | | OR, Inclusive | ORAA | 84 | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 | | 1 | Ť | A+M-A | • | • | : | : | R | • | | | | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 | - | H | + | B + M → B | • | • | 1 | 1 | R | • | | | Push Data | PSHA | 1 | Ť | +- | 1 | 1 | Ť | + | 1 | 1 | 7.7 | + | Ť | 36 | 4 | 1 | A - Msp, SP - 1 - SP | • | ┢ | • | • | • | • | | | 7.7 | PSHB | + | + | T | $\vdash$ | - | t | t | T | t | t- | $\vdash$ | T | 37 | 4 | 1 | B → Mso, SP - 1 → SP | • | • | • | ١. | • | • | | | Pull Data | PULA | | t | t | T | 1 | T | $\vdash$ | T | T | $t^-$ | + | t | 32 | 3 | 1 | SP + 1 → SP, Msp → A | • | • | • | • | • | • | | | | PULB | + | $^{\dagger}$ | $^{\dagger}$ | $\vdash$ | 1 | T | <u> </u> | 1 | T | T | t | T | 33 | 3 | 1 | SP + 1 → SP, Msp → B | • | • | | • | • | | | | Rotate Left | ROL | 1 | T | t | | | T | 69 | 6 | 2 | 79 | 6 | 3 | | Ť | Ť | | • | • | : | 1 | (6) | | | | | ROLA | + | t | $\vdash$ | $\vdash$ | - | + | - | ۲ | - | 1 | + | Ť | 49 | 1 | 1 | *) | • | • | : | _ | (6) | | | | | ROLB | + | + | + | +- | + | + | - | +- | $\vdash$ | + | + | + | 59 | 1 | 1 | B C 67 60 | - | • | : | 1 | (6) | | | | Rotate Right | ROR | + | + | $\vdash$ | +- | $\vdash$ | ╁ | 66 | 6 | 2 | 76 | 6 | 3 | - | + | t. | W | ١. | • | 1 | 1 | 6 | - | | | | RORA | + | $\vdash$ | $^{+}$ | $\vdash$ | - | + | - | ۲ | - | 1.5 | 1 | - | 46 | 1 | 1 | ( <u>*</u> ) | - | • | 1 | - | 0 | _ | | | | RORB | + | +- | + | + | $\vdash$ | + | ₩ | +- | + | ₩- | + | _ | 56 | 1 | 1 | L C 67 60 | - | + | : | _ | (6) | _ | | Note) Condition Code Register will be explained in Note of Table 11. (to be continued) Condition Code Addressing Modes Register Boolean/ **Operations** Mnemonic IMMED DIRECT INDEX EXTEND IMPLIED 5 4 3 2 1 0 Arithmetic Operation INZV С OP # OP OP # OP # OP • 1 1 6 Shift Left ASL 68 6 2 78 6 3 : 48 1 1 • • **; ; (6) ;** ASLA • 1 1 6 58 1 1 ASLB **Double Shift** 1: 6 1 1 ASLD 05 Left, Arithmetic 6 2 77 6 • : : **6** : Shift Right ASR Arithmetic <del>1111111111111111111</del> • : : 6 : 47 1 1 **ASRA** • : : **6** : 57 1 1 • ASRB • R 1 6 Shift Right LSR 64 6 2 74 6 3 : Logical LSRA 44 1 1 - R : 6 : • R 1 6 1 54 1 1 LSRB ACC A/ ACC B BO C Double Shift R : 6 : 04 1 1 • LSRD Right Logical 3 2 A7 4 2 B7 4 3 • 1 1 R • Store STAA $A \rightarrow M$ • Accumulator • : : R • STAB D7 3 2 E7 4 2 F7 4 3 B - M ٠ A → M B → M + 1 Store Double • 1 1 R • ED 5 2 FD ٠ STD 4 2 5 3 Accumulator 0 1 1 1 1 Subtract 3 2 ΑO 4 2 80 4 3 A - M → A • SUBA 80 2 2 90 SUBB œ 2 2 D0 3 2 E0 4 2 F0 4 3 B - M → B • 0 1 1 1 1 83 3 3 93 4 2 A3 5 2 B3 5 3 A:B-M:M+1-A:B • : : : : **Double Subtract** SUBD Subtract • [: [ : [ : [ 10 1 [1 A - B → A SBA Accumulators . . . . . . A-M-C-A SBCA 82 2 2 92 3 2 A2 4 2 B2 4 3 Subtract With Carry • • : : : : SBCB C2 2 2 D2 3 2 E2 4 2 F2 4 3 B - M - C → B 16 1 1 A → B • • 1 1 R • Transfer TAB Accumulators 1 1 B - A • • 1 1 R • TBA 17 • • ; ; R R 6D 4 2 7D M - 00 Test Zero or TST 4 Minus TSTA 4D 1 1 A - 00 • • | 1 | R R • • 1 1 R R **TSTB** 1 1 B - 00 And Immediate AIM 71 6 3 61 7 3 M-IMM→M • I I R • • **OR Immediate** 72 6 3 62 7 3 • 1 1 R • OIM M+IMM→M • • • : : R • **EOR Immediate** EIM 75 6 3 65 7 3 M⊕IMM→M 7B 4 3 6B M-IMM • 1 1 R • Test Immediate TIM 5 3 • Table 8 Accumulator, Memory Manipulation Instructions Note) Condition Code Register will be explained in Note of Table 11. # New Instructions In addition to the HD6801 Instruction Set, the HD6301V0 has the following new instructions: $AIM - \cdots (M) \cdot (\overline{I}MM) \rightarrow (M)$ Evaluates the AND of the immediate data and the memory, places the result in the memory. $OIM - \cdots (M) + (IMM) \rightarrow (M)$ Evaluates the OR of the immediate data and the memory, places the result in the memory. $EIM - \cdots (M) \oplus (IMM) \rightarrow (M)$ Evaluates the EOR of the immediate data and the contents of memory, places the result in memory. TIM----(M) · (IMM) Evaluates the AND of the immediate data and the memory, changes the flag of associated condition code register Each instruction has three bytes; the first is op-code, the second is immediate data, the third is address modifier. XGDX--(ACCD) ++ (IX) Exchanges the contents of accumulator and the index register. **SLP----The MPU** is brought to the sleep mode. For sleep mode, see the "sleep mode" section. Table 9 Index Register, Stack Manipulation Instructions | | CAPAR | | | | | | Add | dress | ing | Mod | des | | | Ī | | | Boolean/ | Condition Code<br>Register | | | | | | | |------------------------|----------|--------|----------|---|-----|-----|-----|-------|-----|-----|-----|-----|---|-----|-----|----|----------------------------------------------------------------------------------------------------------|----------------------------|---|-----|----|---|---|--| | Pointer Operations | Mnemonic | IM | ME | D | DII | REC | T | IN | DE: | Κ. | EX | TEN | D | IMP | LIE | D | Arithmetic Operation | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | | I | - | N | Z | ٧ | C | | | Compare Index Reg | CPX | 8C | 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 | • | • | • | \$ | | • | | | Decrement Stack Potr | DES | $\top$ | | | | - | | | | | | | | 34 | 1 | 1 | SP - 1 → SP | • | • | • | • | • | • | | | Increment Index Reg | INX | T | 1 | | | Г | Γ | | | | | | | 80 | 1 | 1 | X + 1 → X | • | • | • | : | • | • | | | Increment Stack Pntr | INS | 1 | | | | | | | | | | | | 31 | 1 | 1 | SP + 1 → SP | • | • | • | • | • | • | | | Load Index Reg | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 | | | Г | $M \rightarrow X_H$ , $(M + 1) \rightarrow X_L$ | • | • | (7) | 1 | R | • | | | Load Stack Pntr | LDS | 8E | 3 | 3 | 9E | 4 | 2 | AE | 5 | 2 | BE | 5 | 3 | | | | M → SPH. (M+1) → SPL | • | • | Ø | # | R | • | | | Store Index Reg | STX | | | | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 | | П | | $X_H \rightarrow M, X_L \rightarrow (M+1)$ | • | • | 0 | : | R | • | | | Store Stack Pntr | STS | T | | | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 | | | | SPH - M, SPL - (M+1) | • | • | Ø | : | R | • | | | Index Reg → Stack Pntr | TXS | | Γ | | | | | | | | | | | 35 | 1 | 1 | X - 1 → SP | • | • | • | • | • | • | | | Stack Pntr - Index Reg | TSX | | | Τ | | Ţ- | | | | | | Г | | 30 | 1 | 1 | SP + 1 → X | • | • | • | • | • | • | | | Add | ABX | $\top$ | T | | | | 1 | | 1 | | | | 1 | 3A | 1 | 1 | B + X → X | • | • | • | • | • | • | | | Push Data | PSHX | | | | | | | | | | | | | 3C | 5 | 1 | $X_L \rightarrow M_{BD}$ , $SP - 1 \rightarrow SP$<br>$X_H \rightarrow M_{BD}$ , $SP - 1 \rightarrow SP$ | • | • | • | • | • | • | | | Pull Data | PULX | | | | | | | | | | | | | 38 | 4 | 1 | SP + 1 → SP, M <sub>SP</sub> → X <sub>H</sub><br>SP + 1 → SP, M <sub>SP</sub> → X <sub>L</sub> | • | • | • | • | • | • | | | Exchange | XGDX | 1 | $\vdash$ | 1 | | | 1 | T | T | 1 | 1 | Т | T | 18 | 2 | 1. | ACCD⊷IX | • | • | | | | • | | Note) Condition Code Register will be explained in Note of Table 11. Table 10 Jump, Branch Instruction | | | | | | | | Ad | dres | ing | Мо | des | | | | | | | Γ | | diti<br>Reg | | | ie | |-----------------------------|----------|-----|----------|----|----------|----------|----------|----------|-----|----|-------|--------------|-----|----------|-----|---|------------------------------|---|---|-------------|---|---|----| | Operations | Mnemonic | REL | AT. | VE | DII | REC | T | IN | DE | x | EX. | TEN | ID. | IMF | LIE | D | Branch Test | 5 | 4 | 3 | 2 | 1 | 0 | | | | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | | н | Ī | Ν | Z | ٧ | С | | Branch Always | BRA | 20 | 3 | 2 | | | | | | | | | | | | | None | • | • | • | • | • | • | | Branch Never | BRN | 21 | 3 | 2 | | | | | | | | | | Ī | | | Nane | • | • | • | • | • | • | | Branch If Carry Clear | BCC | 24 | 3 | 2 | | | | | | | | | Π | | | | C = 0 | • | • | • | • | • | • | | Branch If Carry Set | BCS | 25 | 3 | 2 | | | 1 | | | _ | | | | İ | | | C = 1 | • | • | • | • | • | • | | Branch If = Zero | BEQ | 27 | 3 | 2 | | | | | | | | | | | | | Z = 1 | • | • | • | • | • | • | | Branch If > Zero | BGE | 2C | 3 | 2 | | | | | | | | | | | | | N ⊕ V • O | • | • | • | • | • | • | | Branch If > Zero | BGT | 2E | 3 | 2 | | | | | | | | | | Г | | | Z + (N + V) = 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 | 2D | 3 | 2 | | | | | Γ | Г | | | Г | T | Г | | N | • | • | • | • | • | • | | Branch If Minus | BMI | 2B | 3 | 2 | | | | | 1 | | _ | T | | | | | N = 1 | • | • | • | • | • | • | | Branch If Not Equal<br>Zero | BNE | 26 | 3 | 2 | | | | Ī | | | | | | | | | z <b>-</b> 0 | • | • | • | • | • | • | | Branch If Overflow<br>Clear | BVC | 28 | 3 | 2 | | | | | | | | | | | | | V-0 | • | • | • | • | • | • | | Branch If Overflow Set | B∨S | 29 | 3 | 2 | | <u> </u> | $\vdash$ | | | | | | T | T | | | V = 1 | • | • | • | • | • | • | | Branch If Plus | BPL | 2A | 3 | 2 | | T | Г | | 1 | | | | 1 | | | | N = 0 | • | • | • | • | • | • | | Branch To Subroutine | BSR | 80 | 5 | 2 | Γ | $\Box$ | Γ | | | | | T | | | | | | • | • | • | • | • | • | | Jump | JMP | t | $\vdash$ | _ | $\vdash$ | Т | t | 6E | 3 | 2 | 7E | 3 | 3 | <b>†</b> | | | See Special Operations | • | • | • | • | • | • | | Jump To Subroutine | JSR | | | | 9D | 5 | 2 | AD | 5 | 2 | BD | 6 | 3 | Г | | | ) | • | • | • | • | • | • | | No Operation | NOP | | | | | | | | | | | | | 01 | 1 | 1 | Advances Prog. Cntr.<br>Only | • | • | • | • | • | • | | Return From Interrupt | RTI | 1 - | Г | | | | | | | | | Π | 1 | 38 | 10 | 1 | 1 | - | Ξ | - ( | D | _ | _ | | Return From<br>Subroutine | RTS | | | Г | | | | | T | | | | | 39 | 5 | 1 | See Special Operations | • | • | • | • | • | • | | Software Interrupt | SWI | | | T | $\vdash$ | | | | | Τ | Г | T | 1 | 3F | 12 | 1 | | • | s | • | • | • | • | | Wait for Interrupt® | WAI | | Г | Γ | | | | | | | | | | 3E | 9 | 1 | <b>}</b> | • | 1 | • | • | • | • | | Sleep | SLP | 1 | | - | <b>-</b> | $\vdash$ | +- | $\vdash$ | 1 | _ | $t^-$ | $^{\dagger}$ | 1- | 1Ā | 4 | 1 | | • | • | • | • | • | t. | Note) \*WAI puts R/W high; Address Bus goes to FFFF; Data Bus goes to the three state level. Condition Register will be explained in Note of Table 11. | | | AddressingModes | | | | Condition Code Register | | | | | | | | | | |----------------------|----------|-----------------|------|---|--------------------------|-------------------------|---|-----|------------|---|---|--|--|--|--| | Operations | Mnemonic | IM | PLIE | D | <b>Boolean Operation</b> | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | OP | ~ | # | | н | 1 | N | z | V | C | | | | | | Clear Carry | CLC | ос | 1 | 1 | 0 → C | • | • | • | • | • | R | | | | | | Clear Interrupt Mask | CLI | OE | 1 | 1 | 0 -+ 1 | • | R | • | • | • | • | | | | | | Clear Overflow | CLV | 0A | 1 | 1 | 0 → V | • | • | • | • | R | • | | | | | | Set Carry | SEC | 0D | 1 | 1 | 1 → C | • | • | • | • | • | S | | | | | | Set Interrupt Mesk | SEI | OF | 1 | 1 | 1 → 1 | • | S | • | • | • | | | | | | | Set Overflow | SEV | ОВ | 1 | 1 | 1 → V | • | • | • | • | s | • | | | | | | Accumulator A → CCR | TAP | 06 | 1 | 1 | A-+ CCR | _ | | _ ( | <b>0</b> – | | _ | | | | | | CCR → Accumulator A | TPA | 07 | 1 | 1 | CCR → A | • | • | • | • | • | | | | | | Table 11 Condition Code Register Manipulation Instructions [NOTE] Condition Code Register Notes: (Bit set if test is true and cleared otherwise) - (Bit V) Test: Result = 10000000? - (Bit C) Test: Result \* 00000000? - ② ③ Test: BCD Character of high-order byte greater than 10? (Not cleared if previously set) (Bit C) - (Bit V) Test: Operand = 10000000 prior to execution? - **4 5 6** (Bit V) Test: Operand = 01111111 prior to execution? - Test: Set equal to N#C=1 after the execution of instructions (Bit N) - Ō (Bit N) Test: Result less than zero? (Bit 15=1) - (AII) Load Condition Code Register from Stack. 8 - Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exist the wait 9 (Bit 1) - state. - (All Bit) Set according to the contents of Accumulator A. - 1 Result of Multiplication Bit 7=1? (ACCB) (Bit C) OP ACC ACC FXT. ACCA or SP ACCB or X IND CODE В DIR" IMM DIR IND EXT IMM DIR IND EXT A н 0000 0001 0010 0011 0100 0101 1000 1111 0110 0111 1001 1010 1011 1100 1101 1110 LO 3 7 F 2 С D 9 A E SBA BRA TSX NEG SUB 1000 0 0 0001 1 NOP CBA BRN INS CMP 1 0010 2 BHI PULA OIM SBC 2 COM 0011 3 BLS PULB SUBD ADDD 3 LSRD LSR AND 0100 4 BCC DES 4 0101 5 ASLD BCS TXS EIM BIT 5 0110 6 TAP TAB BNE PSHA ROR LDA 6 TPA TBA BEQ **PSHB** ASR STA STA 0111 7 7 1000 8 INX XGDX BVC PULX ASL EOR В 1001 9 DEX DAA BVS RTS ROL ADC 9 SLP 1010 A CLV RPI ARX DEC ORA A ADD 1011 B SEV ABA BMI RTI TIM В PSHX 1100 C CLC BGF INC CPX LDD С 1101 D SEC BL T MUL TST BSR JSR STD ٥ 1110 E CLI BGT WAI JMP LDS IDX Ε 1111 F SEI RIF SWI CLR STS STX F В c E Table 12 OP-Code Map UNDEFINED OF CODE # LOW POWER CONSUMPTION MODE The HD6301V0 has two low power consumption modes; sleep and standby mode # Sleep Mode On execution of SLP instruction, the MCU is brought to the sleep mode. In the sleep mode, the MPU sleeps (the MPU clock becomes inactive), but the contents of the register in the MPU is secured. In this mode, the peripherals of MPU will remain operational. So the operations such as transmit and receive of the SCI data and counter may keep on functioning. In this mode, the power consumption is reduced to about 1/10 the value of a normal operation. The escape from this mode can be done by interrupt, RES, STBY. The RES resets the MCU and the STBY brings it into the standby mode (This will be mentioned later). When interrupt is requested to the MPU and accepted, the sleep mode escapes, then the MPU is brought to the operation mode and vectors to the interrupt routine. When the MPU has masked the interrupt, after releasing from the sleep mode, the next instruction of Only each instructions of AIM, OIM, EIM, TIM # HD6301V0, HD63A01V0, HD63B01V0- sleep starts to execute. However, in such a case that the timer interrupt is inhibited on the timer side, the sleep mode cannot be released due to the absence of the interrupt request to the MPU. This sleep mode is available to reduce an average power consumption in the applications of the HD6301V0 which may not always drive. ## Standby Mode Bringing STBY "Low", the MPU becomes reset with all c'ocks of the HD6301V0 inactive and goes into the standby mode. This mode remarkably reduces the power consumptions of the HD6301V0. In the standby mode, the HD6301V0 is continuously supplied with power so the contents of RAM is retained. The standby mode should escape by the reset start. The following is the typical application of this mode. First, NMI routine stacks the MCU's internal information and the contents of SP in RAM, disables RAME bit of RAM control register, sets the STBY bit, and then goes into the standby mode. If the STBY bit keeps set on reset start, it means that the power supply and the contents of RAM is normally guaranteed. The system recovery may be possible by returning SP and bringing into the condition before the standby mode has started. The timing relation for each line in this application is shown in Figure 24. Figure 24 Standby Mode Timing ## **■ ERROR PROCESSING** When the HD6301V0 fetches an undefined instruction or fetches an instruction from nonresident memory area, it generates the most precedent internal interrupt, that may protect the system from system burst due to noise or a program error. # Op-Code Error Fetching an undefined op-code, the HD6301V0 will stack the MPU register as in the case of a normal interrupt and vector to the TRAP (\$FFEE, \$FFEF), that has a second highest priority (RES is the highest). # Address Error When an instruction is fetched from other than a resident ROM, RAM, or an external memory area, the MPU starts the same interrupt as op-code error. In case where the instruction is fetched from external memory area of non-resident memory, it cannot function. The addresses which cause address error in particular mode are as shown in Table 13. This feature is applicable only to the instruction fetch, not to normal read/write of data accessing. Table 13 Address Error | Mode | 0 | 1 | 4 | 5 | 6 | 7 | |---------|-----|---|---|-------------------------------|---|---| | Address | 1 - | 5 | 1 | \$ 0000<br>\$ 007F<br>\$ 0200 | 1 | 1 | Transitions among the active mode, sleep mode, standby mode and reset are shown in Fig. 25. Figures 26, 27, 28 and 29 shows a system configuration. Figure 25 Transitions among Active Mode, Standby Mode Sleep Mode, and Reset Figure 26 HD6301V0 MCU Single-Chip Dual Processor Configuration Figure 27 HD6301V0 MCU Expanded Non-Multiplexed Mode (Mode 5) Figure 28 HD6301V0 MCU Expanded Multiplexed Mode Figure 29 HD6301V0 MCU Expanded Non-Multiplexed Mode (Mode 1)