# HD6801V0, HD6801V5 MCU (Microcomputer Unit) The HD6801V MCU is an 8-bit microcomputer unit which is compatible with the HD6801S except the ROM size. The HD6801V MCU is object code compatible with the HD6800 with improved execution times of key instructions plus several new 16-bit and 8-bit instructions including an 8×8 unsigned multiply with 16-bit result. The HD6801V MCU can operate as a single chip microcomputer or be expanded to 65k bytes. The HD6801V MCU is TTL compatible and requires one +5.0 volt power supply. The HD6801V MCU has 4k bytes of ROM and 128 bytes of RAM on chip. Serial Communications Interface (SCI), and parallel I/O as well as a three function 16-bit timer. Features and Block diagram of the HD6801V include the following: ## ■ FEATURES - Expanded HMCS6800 Instruction Set - 8 × 8 Multiply - On-Chip Serial Communication Interface (SCI) - Object Code Compatible With The HD6800 MPU - 16-Bit Timer - Single Chip Or Expandable To 65k Bytes - 4k Bytes Of ROM - 128 Bytes Of RAM (64 Bytes Retainable On Power Down) - 29 Parallel I/O Lines And 2 Handshake Control Lines - Internal Clock/Divided-By-Four Circuitry - TTL Compatible Inputs And Outputs - Interrupt Capability - Compatible with MC6801 (except ROM size) ### BLOCK DIAGRAM ## PIN ARRANGEMENT ## **■ TYPE OF PRODUCTS** | MCU | Bus Timing | |----------|------------| | HD6801V0 | 1 MHz | | HD6801V5 | 1.25 MHz | ## ■ PROGRAM DEVELOPMENT SUPPORT TOOLS - Cross assembler software for use with IBM PCs and compatibles - In circuit emulator for use with IBM PCs and compatibles ## HD6801V0, HD6801V5 ## ■ ABSOLUTE MAXIMUM RATINGS | Item | Symbol | Value | Unit | |-----------------------|-------------------|-------------|------| | Supply Voltage | V <sub>cc</sub> * | -0.3 ∼ +7.0 | V | | Input Voltage | V <sub>in</sub> * | -0.3 ~ +7.0 | V | | Operating Temperature | T <sub>opr</sub> | 0 ~+70 | °c | | Storage Temperature | T <sub>etg</sub> | - 55 ~+150 | °c | With respect to V<sub>SS</sub> (SYSTEM GND) ## **ELECTRICAL CHARACTERISTICS** ## • DC CHARACTERISTICS ( $V_{CC}$ =5.0V±5%, $V_{SS}$ = 0V, $T_a$ = 0 $\sim$ +70°C, unless otherwise noted.) | lter | n | Symbol | Test Condition | min | typ | max | Unit | | |--------------------------|--------------------------------------------------------------------------|---------------------------------------|---------------------------------------|------|-------------------|------|------|--| | Input "High" Voltage | RES | , , , , , , , , , , , , , , , , , , , | | 4.0 | _ | Vcc | V | | | | Other Inputs* | VIH | | 2.0 | - V <sub>cc</sub> | | , , | | | 1 | EXTAL | | | -0.3 | _ | 0.6 | | | | Input "Low" Voltage | Other Inputs* | VIL | | -0.3 | _ | 0.8 | V | | | | P40 ~ P47 | | | - | _ | 0.5 | | | | Input Load Current | SC <sub>1</sub> | l <sub>in</sub> | Vin = 0 ~ 2.4V | | _ | 0.8 | mA | | | | EXTAL | | V <sub>in</sub> = 0 ~ V <sub>CC</sub> | _ | - | 1,2 | | | | Input Leakage Current | NMI, IRQ <sub>1</sub> , RES | lin | V <sub>in</sub> = 0 ~ 5.25V | _ | _ | 2.5 | μΑ | | | Three State (Offset) | $P_{10} \sim P_{17}, P_{30} \sim P_{37}$ | | V <sub>in</sub> = 0.5 ~ 2.4V | | _ | 10 | | | | Leakage Current | P <sub>20</sub> ~ P <sub>24</sub> | I <sub>TSI</sub> | | - | _ | 100 | μΑ | | | | P <sub>30</sub> ~ P <sub>37</sub> | | I <sub>LOAD</sub> = -205 μA | 2.4 | - | - | v | | | Output "High" Voltage | P <sub>40</sub> ~ P <sub>47</sub> , E, SC <sub>1</sub> , SC <sub>2</sub> | VoH | I <sub>LOAD</sub> = -145 μA | 2.4 | _ | _ | | | | | Other Outputs | | I <sub>LOAD</sub> = -100 μA | 2.4 | _ | - | | | | Output "Low" Voltage | All Outputs | Vol | I <sub>LOAD</sub> = 1.6 mA | _ | _ | 0.5 | ٧ | | | Darlington Drive Current | $P_{10} \sim P_{17}$ | -l <sub>oh</sub> | V <sub>out</sub> = 1.5V | 1.0 | - | 10.0 | mA | | | Power Dissipation | | ₽ <sub>D</sub> | | - | _ | 1200 | mW | | | Innut Considered | $P_{30} \sim P_{37}$ , $P_{40} \sim P_{47}$ , $SC_1$ | | V <sub>in</sub> = 0V, Ta = 25°C, | - | | 12.5 | | | | Input Capacitance | Other Inputs | Cin | f = 1.0 MHz | - | - | 10.0 | pF | | | Van Standby | Powerdown | V <sub>SBB</sub> | | 4.0 | - | 5.25 | 1/ | | | CC Standby | Operating | V <sub>SB</sub> | | 4.75 | - | 5.25 | v | | | Standby Current | Powerdown | I <sub>SBB</sub> | V <sub>SBB</sub> = 4.0 V | _ | - | 8.0 | mA | | <sup>\*</sup>Except Mode Programming Levels. <sup>[</sup>NOTE] Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI. # • AC CHARACTERISTICS BUS TIMING (V<sub>CC</sub> = $5.0V\pm5\%$ , V<sub>SS</sub> = 0V, Ta = $0 \sim +70^{\circ}$ C, unless otherwise noted.) | | | Τ | Symbol Test Condition | | 06801 | /0 | HD6801V5 | | | Unit | |---------------------------------------------------------|-------------------------------------------------------------|------------------|-----------------------|-----|----------|----------|----------|--------------|------------------|----------| | | ltem | Symbol | Test Condition | min | typ | max | min | typ | max | | | Cycle Time | | t <sub>cyc</sub> | | 1 | - | 10 | 8.0 | | 10 | μs | | Address Strobe Puls | e Width "High" * | PWASH | 1 | 200 | _ ] | | 150 | | | ns | | Address Strobe Ris | | tasr | | 5 | _ | 50 | 5 | _ | 50 | ns | | Address Strobe Fall | | tasf | Ţ | 5_ | | 50 | 5 | _ | 50 | ns | | Address Strobe Del | | t <sub>ASD</sub> | 1 | 60 | | | 30 | | | ns | | Enable Rise Time | | ter | 1 | 5 | | 50 | 5 | | 50 | ns | | Enable Fall Time | | ter | | 5 | | 50 | 5 | | 50 | ns | | Enable Pulse Width "High" Time * | | PWEH | | 450 | - | - | 340 | | | ns | | Enable Pulse Width "Low" Time * | | PWEL | | 450 | | | 350 | - | | ns | | Address Strobe to Enable Delay Time * | | TASED | 1 | 60 | T | | 30 | | | ns | | Address Delay Time | | t <sub>AD</sub> | Fig. 1 | _ | <u> </u> | 260 | | | 260 | ns | | Address Delay Time for Latch * | | TADL | Fig. 2 | | | 270 | | _ | 260 | l n | | Data Set-up Write | | tosw | 1 | 225 | - | | 115 | | <u> </u> | n: | | Data Set-up Read | | t <sub>DSB</sub> | 1 | 80 | <b>-</b> | | 80 | | <u> </u> | n | | Data Set op Tieso | Read | tHB | † | 10 | | | 10 | <u> </u> | <del> -</del> | - n | | Data Hold Time | Write | t <sub>HW</sub> | 7 | 20 | | | 20 | - | <del> </del> - | ⊢ | | Address Set-up Tir | | tast | 7 | 60 | | <u> </u> | 20 | <u> -</u> _ | <del> -</del> - | <u>n</u> | | | | TAHL | 1 | 20 | Ī | | 20 | <u> </u> | 1= | n | | Address Hold Time for Latch | | tAH | 1 | 20 | _ | l | 20 | | | ┵ | | Address Hold Time Peripheral Read Non-Multiplexed Bus* | | (taccn) | | _ | Τ – | (610) | | | (410) | ١, | | Peripheral Read<br>Access Time | Multiplexed Bus* | (tACCM) | | - | Ī - | (600) | | <u> </u> | (410) | 1 | | | | t <sub>BC</sub> | Fig. 10 | 100 | - | T | 100 | | | | | | Oscillator stabilization Time Processor Control Set-up Time | | Fig. 11 | 200 | - | T- | 200 | - | - | l n | <sup>\*</sup>These timings change in approximate proportion to toyc. The figures in this characteristics represent those when toyc is minimum (=in the highest speed operation). ## PERIPHERAL PORT TIMING ( $V_{CC} = 5.0V \pm 5\%$ , $V_{SS} = 0V$ , $T_0 = 0 \sim +70^{\circ}$ C, unless otherwise noted.) | Item | | Symbol | Test Condition | min | typ | max | Unit | |----------------------------------------------------------------------------|------------------|-------------------|----------------|-----|----------|----------------|------| | Peripheral Data Setup Time | Port 1, 2, 3, 4 | t <sub>PDSU</sub> | Fig. 3 | 200 | | | ns | | Peripheral Data Hold Time | Port 1, 2, 3, 4 | t <sub>PDH</sub> | Fig. 3 | 200 | | ļ <u>-</u> - | ns | | Delay Time, Enable Positive Transition to OS3 Negative Transition | | t <sub>OSD1</sub> | Fig. 5 | _ | | 350 | ns | | Delay Time, Enable Positive T<br>to OS3 Positive Transition | ransition | t <sub>OSD2</sub> | Fig. 5 | | - | 350 | ns | | Delay Time, Enable Negative<br>Transition to Peripheral Data<br>Valid | Port 1, 2*, 3, 4 | t <sub>PWD</sub> | Fig. 4 | - | _ | 400 | ns | | Delay Time, Enable Negative<br>Transition to Peripheral<br>CMOS Data Valid | Port 2**, 4 | tcmos | Fig. 4 | _ | - | 2.0 | μ | | Input Strobe Pulse Width | | tpwis | Fig. 6 | 200 | <u> </u> | <del>-</del> - | ns | | Input Data Hold Time | port 3 | tiH | Fig. 6 | 50 | | | ns | | Input Data Set-up Time | Port 3 | t <sub>IS</sub> | Fig. 6 | 20 | | | n | <sup>\*</sup>Except $P_{21}$ \*\*10k $\Omega$ pull up register required for Port 2 TIMER, SCI TIMING (V<sub>CC</sub> = 5.0V $\pm 5\%$ , V<sub>SS</sub> = 0V, Ta = 0 $^{\sim}$ +70 $^{\circ}$ C, unless otherwise noted.) | Item | Symbol | Test Condition | min | typ | max | Unit | |--------------------------------------------------------|-------------------|----------------|------------------------|-----|--------------|-------| | Timer Input Pulse Width | tpwT | | 2t <sub>cvc</sub> +200 | | - | ns | | Delay Time, Enable Positive Transition to<br>Timer Out | t <sub>TOD</sub> | Fig. 7 | - | _ | 600 | ns | | SCI Input Clock Cycle | t <sub>Scyc</sub> | 778 | 1 | - | <del> </del> | teye | | SCI Input Clock Pulse Width | tpwsck | | 0.4 | _ | 0.6 | tscyc | ## MODE PROGRAMMING (V<sub>CC</sub> = 5.0V $\pm$ 5%, V<sub>SS</sub> = 0V, Ta = 0 $\sim$ +70°C, unless otherwise noted.) | Item | 1 | Symbol | Test Condition | min | typ | max | Unit | |---------------------------------------|----------------------|------------------|----------------|-----|-----|-----|------------------| | Mode Programming Input "Low" Voltage | | V <sub>MPL</sub> | | - | - | 1.7 | V | | Mode Programming Input "High" Voltage | | V <sub>MPH</sub> | | 4.0 | _ | _ | V | | RES "Low" Pulse Width | | PWRSTL | Fig. 8 | 3.0 | - | - | t <sub>cyc</sub> | | Mode Programming Set-up Time | | tMPS | | 2.0 | _ | | t <sub>cyc</sub> | | Mode Programming | RES Rise Time ≥ 1μs | * | | 0 | | _ | | | Hold Time | RES Rise Time < 1 µs | <sup>1</sup> MPH | | 100 | _ | _ | ns | Figure 1 Expanded Multiplexed Bus Timing Figure 2 Expanded Non-Multiplexed Bus Timing Figure 3 Data Set-up and Hold Times. (MCU Read) \*Access matches Output Strobe Select (OSS = 0, a read. OSS = 1, a write) Figure 5 Port 3 Output Strobe Timing (Single Chip Mode) #### (Note) - 1. 10 k $\Omega$ Pullup resistor required for Port 2 to reach 0.7 V<sub>CC</sub> 2. Not applicable to P , 3. Port 4 cannot be pulled above V<sub>CC</sub> Figure 4 Port Data Delay Timing (MCU Write) Figure 6 Port 3 Latch Timing (Single Chip Mode) Figure 11 Reset Timing Not Valid ## ■ SIGNAL DESCRIPTIONS #### Vcc and Vss These two pins are used to supply power and ground to the chip. The voltage supplied will be +5 volts $\pm 5\%$ . ## XTAL and EXTAL These connections are for a parallel resonant fundamental crystal, AT cut. Divide-by-4 circuitry is included with the internal clock, so a 4 MHz crystal may be used to run the system at 1 MHz. The divide-by-4 circuitry allows for use of the inexpensive 3.58 MHz Color TV crystal for non-time critical applications. Two 22pF capacitors are needed from the two crystal pins to ground to insure reliable operation. An example of the crystal interface is shown in Fig. 12. EXTAL may be driven by an external TTL compatible clock source with a 45% to 55% duty cycle. It will divide by 4 any frequency less than or equal to 5 MHz. XTAL must be grounded if an external clock is used. Nominal Crystal Parameter | Crystal | 4 MHz | 5 MHz | |---------|-----------|------------------| | Co | 7 pF max. | 4.7 pF max. | | Rs | 60Ω max. | <b>30</b> Ω typ. | Figure 12 Crystal Interface ## Vcc Standby This pin will supply +5 volts $\pm 5\%$ to the standby RAM on the chip. The first 64 bytes of RAM will be maintained in the power down mode with 8 mA current max. The circuit of figure 13 can be utilized to assure that $V_{CC}$ Standby does not go below $V_{SBB}$ during power down. To retain information in the RAM during power down the following procedure is necessary: - Write "0" into the RAM enable bit, RAME. RAME is bit 6 of the RAM Control Register at location \$0014. This disables the standby RAM, thereby protecting it at power down. - 2) Keep V<sub>CC</sub> Standby greater than V<sub>SBB</sub>. Figure 13 Battery Backup for V<sub>CC</sub> Standby #### Reset (RES) This input is used to reset and start the CPU from a power down condition, resulting from a power failure or an initial startup of the processor. On power up, the reset must be held "Low" for at least 100 ms. When reset during operation, RES must be held "Low" at least 3 clock cycles. When a "High" level is detected, the MCU does the follow- - 1) All the higher order address lines will be forced "High". 2) I/O Port 2 bits 2, 1, and 0 are latched into programmed - I/O Port 2 bits 2, 1, and 0 are latched into programmed control bits PC2, PC1 and PC0. - The last two (\$FFFE, \$FFFF) locations in memory will be used to load the program addressed by the program counter. - 4) The interrupt mask bit is set. Clear before the CPU can recognize maskable interrupts. ## ● Enable (E) This supplies the external clock for the rest of the system when the internal oscillator is used. It is a single phase, TTL compatible clock, and will be the divide-by-4 result of the crystal oscillator frequency. It will drive one TTL load and 90 pF capacitance. ## ● Non-Maskable Interrupt (NMI) A low-going edge on this input requests that a non-maskable-interrupt sequence be generated within the processor. As with interrupt Request signal, the processor will complete the current instruction that is being executed before it recognizes the NMI signal. The interrupt mask bit in the Condition Code Register has no effect on NMI. In response to an NMI interrupt, the Index Register, Program Counter, Accumulators, and Condition Code Register are stored on the stack. At the end of the sequence, a 16-bit address will be loaded that points to a vectoring address located in memory locations SFFFC and SFFFD. An address loaded at these locations causes the CPU to branch to a non-maskable interrupt service routine in memory. A 3.3 k $\Omega$ external resistor to VCC should be used for wire-OR and optimum control of interrupts. Inputs $\overline{IRQ}_1$ and $\overline{NMI}$ are hardware interrupt lines that are sampled during E and will start the interrupt routine on the $\overline{E}$ following the completion of an instruction. ## ● Interrupt Request (IRQ<sub>1</sub>) This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will complete the current instruction before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The Index Register, Program Counter, Accumulators, and Condition Code Register are stored on the stack. Next the CPU will respond to the interrupt request by setting the interrupt mask bit "High" so that no further maskable interrupts may occur. At the end of the cycle, a 16-bit address will be loaded that points to a vectoring address which is located in memory locations SFFF8 and SFFF9. An address loaded at these locations causes the CPU to branch to an interrupt routine in memory. The $\overline{IRQ_1}$ requires a 3.3 k $\Omega$ external resistor to $V_{CC}$ which should be used for wire-OR and optimum control of interrupts. Internal Interrupts will use an internal interrupt line ( $\overline{IRQ_2}$ ). This interrupt will operate the same as $\overline{IRQ_1}$ except that it will use the vector address of SFFF0 through SFFF7. $\overline{IRQ_1}$ will have priority over $\overline{IRQ_2}$ if both occur at the same time. The Interrupt Mask Bit in the condition code register masks both interrupts (See Table 1). Table 1 Interrupt Vector Location Highest Priority | Vec | tor | Interrupt | | | | |------|------|--------------------------|--|--|--| | MSB | LSB | merape | | | | | FFFE | FFFF | RES | | | | | FFFC | FFFD | NMI | | | | | FFFA | FFFB | Software Interrupt (SWI) | | | | | FFF8 | FFF9 | IRQ, (or IS3) | | | | | FFF6 | FFF7 | ICF (Input Capture) | | | | | FFF4 | FFF5 | OCF (Output Compare) | | | | | FFF2 | FFF3 | TOF (Timer Overflow) | | | | | FFFO | FFF1 | SC, (RDRF + ORFE + TDRE) | | | | Lowest Priority The following pins are available in the Single Chip Mode, and are associated with Port 3 only. ## • Input Strobe (IS3) (SC1) The function of the $\overline{1S3}$ signal depends on the I/O Port 3 Control/Status Register. If $\overline{1S3}$ Enable bit is set, an interrupt will occur by the fall of the $\overline{1S3}$ signal. If the latch enable bit is set, the data in the I/O Port 3 will be latched at the I/O Port 3 Data Register. The timing condition of the $\overline{1S3}$ signal that is necessary to be latched the input data normally is shown in Figure 6. ## Output Strobe (OS3) (SC<sub>2</sub>) This signal is used by the processor to strobe an external device, indicating valid data is on the I/O pins. The timing for the Output Strobe is shown in Figure 5. I/O Port 3 Control/Status Register is discussed in the following section. The following pins are available in the Expanded Modes. ## Read/Write (R/W) (SC<sub>2</sub>) This TTL compatible output signals the peripherals and memory devices whether the CPU is in a Read ("High") or a Write ("Low") state. The normal standby state of this signal is Read ("High"). This output can drive one TTL load and 90 pF capacitance. ## • I/O Strobe (IOS) (SC.) In the expanded non-multiplexed mode of operation, $\overline{IOS}$ internally decodes $A_9$ through $A_{15}$ as zero's and $A_8$ as a one. This allows external access of the 256 locations from \$0100 to \$01FF. The timing diagrams are shown as figure 2. #### Address Strobe (AS) (SC,) In the expanded multiplexed mode of operation, address strobe is output on this pin. This signal is used to latch the 8 LSB's of address which are multiplexed with data on Port 3. An 8-bit latch is utilized in conjunction with Address Strobe, as shown in figure 19. So I/O port 3 can become data bus during the E pulse. The timing for this signal is shown in Figure 1 of Bus Timing. This signal is also used to disable the address from the multiplexed bus allowing a deselect time, t<sub>ASD</sub> before the data is enabled to the bus. #### PORTS There are four I/O ports on the HD6801V MCU; three 8-bit ports and one 5-bit port. There are two control lines associated with one of the 8-bit ports. Each port has an associated write only Data Direction Register which allows each I/O line to be programmed to act as an input or an output\*. A "1" in the corresponding Data Direction Register bit will cause that I/O line to be an output. A "0" in the corresponding Data Direction Register bit will cause that I/O line to be an input. There are four ports: Port 1, Port 2, Port 3, and Port 4. Their addresses and the addresses of their Data Direction registers are given in Table 2. \* The only exception is bit 1 of Port 2, which can either be data input or Timer output. 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 whose individual bits may be defined as inputs or outputs by the corresponding bit in its data direction register. The 8 output buffers have three-state capability, allowing them to enter a high impedance state when the peripheral data lines are used as inputs. In order to be read properly, the voltage on the input lines must be greater than 2.0 V for a logic "1" and less than 0.8 V for a logic "0". As outputs these lines are TTL compatible and may also be used as a source of up to 1 mA at 1.5 V to directly drive a Darlington base. After Reset, the I/O lines are configured as inputs. In all three modes, Port 1 is always parallel I/O. #### I/O Port 2 This port has five lines that may be defined as inputs or outputs by its data direction register. The 5 output buffers have three-state capability, allowing them to enter a high impedance state when used as an input. In order to be read properly, the voltage on the input lines must be greater than 2.0 V for a logic "1" and less than 0.8 V for a logic "0". As outputs, this port has no internal pullup resistors but will drive TTL inputs directly. For driving CMOS inputs, external pullup resistors are required. After Reset, the I/O lines are configured as inputs. Three pins on Port 2 (pins 10, 9, and 8 of the chip) are used to program the mode of operation during reset. The values of these pins at reset are latched into the three MSB's (bits 7, 6, and 5) of Port 2 which are read only. This is explained in the Mode Selection Section. In all three modes, Port 2 can be configured as I/O and provides access to the Serial Communications Interface and the Timer. Bit I is the only pin restricted to data input or Timer output. ## I/O Port 3 This is an 8-bit port that can be configured as I/O, a data bus or an address bus multiplexed with the data bus - depending on the mode of operation hardware programmed by the user at reset. As a data bus, Port 3 is bi-directional. As an input for peripherals, it must be supplied regular TTL levels, that is, greater than 2.0 V for a logic "1" and less than 0.8 V for a logic "0" Its TTL compatible three-state output buffers can drive one TTL load and 90 pF capacitance. In the Expanded Modes, after reset, the data direction register is inhibited and data flow depends on the state of the $R/\overline{W}$ line. The input strobe ( $\overline{IS3}$ ) and the output strobe (OS3) used for handshaking are explained In the three modes, Port 3 assumes the following characteristics: Single Chip Mode: Parallel Inputs/Outputs as programmed by its associated Data Direction Register. There are two control lines associated with this port in this mode, an input strobe and an output strobe, that can be used for handshaking. They are controlled by the I/O Port 3 Control/Status Register explained at the end of this section. Three options of Port 3 operations are sumarized as follows: (1) Port 3 input data can be latched using $\overline{1S3}$ (SC<sub>1</sub>) as a control signal, (2) $\overline{OS3}$ can be generated by either an CPU read or write to Port 3's Data Register, and (3) and $\overline{IRQ}_1$ interrupt can be enabled by an $\overline{IS3}$ negative edge. Port 3 latch and strobe timing is shown in Fig. 5 and Fig. 6. Expanded Non-Multiplexed Mode: In this mode, Port 3 becomes the data bus $(D_0 \sim D_7)$ . Expanded Multiplexed Mode: In this mode, Port 3 becomes both the data bus $(D_0{\sim}D_7)$ and lower bits of the address bus (A<sub>0</sub>~A<sub>7</sub>). An address strobe output is true when the address is on the port. ## I/O PORT 3 CONTROL/STATUS REGISTER | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------|------|------------------|---|-----|--------|---|---|---|---| | | | Ī <del>S</del> 3 | × | oss | LATCH | × | × | × | l | | | IS3 | IRQ <sub>1</sub> | | | | | ļ | | l | | 000F | FLAG | ENABLE | | ŀ | ENABLE | | | | ١ | Bit 0; Not used. Bit 1: Not used. Bit 2: Not used. - Bit 3; LATCH ENABLE. This controls the input latch for I/O Port 3. If this bit is set "High" the input data will be latched with the falling edge of the Input Strobe, 1S3. This bit is cleared by reset, and the latch is "re-opened" with CPU read Port 3. - Bit 4; OSS. (Output Strobe Select) This bit will select if the Output Strobe should be generated at OS3 (SC2) by a write to I/O Port 3 or a read of I/O Port 3. When this bit is cleared the strobe is generated by a read Port 3. When this bit is set the strobe is generated by a write to Port 3. Bit 5; Not used. Bit 6; IS3 IRQ1 ENABLE. When set, interrupt will be enabled whenever IS3 FLAG is set; when clear, interrupt is inhibited. This bit is cleared by reset. Bit 7; IS3 FLAG. This is a read-only status bit that is set by the falling edge of the input strobe, $\overline{1S3}$ (SC<sub>1</sub>). It is cleared by a read of the Control/Status Register followed by a read or write of I/O Port 3. Reset will clear this bit. ## I/O Port 4 This is an 8-bit port that can be configured as I/O or as address output lines depending on the mode of operation. In order to be read properly, the voltage on the input lines must be greater than 2.0 V for a logic "1" and less than 0.8 V for a logic "0" As outputs, each line is TTL compatible and can drive 1 TTL load and 90 pF capacitance. After reset, the lines are configured as inputs. To use the pins as addresses, therefore, they should be programmed as outputs. In the three modes, Port 4 assumes the following characteristics: Single Chip Mode: Parallel Inputs/Outputs as programmed by its associated Data Direction Register. Expanded Non-Multiplexed Mode: Port 4 is configured as the lower order address lines ( $A_0 \sim A_7$ ) by writing "1"s to the data direction register. When all eight address lines are not needed, the remaining lines, starting with the most significant bit, may be used as I/O (inputs only). Expanded Multiplexed Mode: Port 4 is configured as the higher order address lines $(A_8 \sim A_{15})$ by writing "1"s to the data direction register. When all eight address lines are not needed, the remaining lines, starting with the most significant bit, may be used as I/O (inputs only). ## **■ OPERATION MODES** The operation modes that HD6801V will operate after Reset is determined by hardware that the user must wire on pins 10, 9, and 8 of the chip. These pins are the three LSB's (1/O 2, I/O 1, and I/O 0 respectively) of Port 2. They are latched into programmed control bits PC2, PC1, and PC0 when reset goes high. I/O Port 2 Register is shown below. ## PORT 2 DATA REGISTER | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-------|-------|-------|-------|-------| | \$0003 | PC2 | PC1 | PC0 | 1/0 4 | 1/0 3 | 1/0 2 | 1/0 1 | 1/0 0 | An example of external hardware that could be used for Mode Selection is shown in Fig 14. The HD14053B provides the isolation between the peripheral device and MCU during reset, which is necessary if data conflict can occur between peripheral device and Mode generation circuit. As bits 5, 6 and 7 of Port 2 are read-only, the mode cannot be changed through software. The mode selections are shown in The HD6801V can operate three basic modes; (1) Single Chip Mode, (2) Expanded Multiplexed Mode (compatible with HMCS6800 peripheral family) (3) Expanded Non-Multiplexed Mode. ### Single Chip Mode In the Single Chip Mode the Ports are configured as I/O. This is shown in Figure 16 the single Chip Mode. In this mode, Port 3 will have two associated control lines, an input strobe and an output strobe for handshaking data. ## Expanded Non-Multiplexed Mode In this mode the HD6801V will directly address HMCS6800 peripherals with no external logic. In this mode Port 3 becomes the data bus. Port 4 becomes the A<sub>0</sub>~A<sub>7</sub> address bus or partial address and I/O (inputs only). Port 2 can be parallel I/O, serial I/O, Timer, or any combination of them. Port 1 is parallel I/O only. In this mode the HD6801V is expandable to 256 locations. The eight address lines associated with Port 4 may be substituted for I/O (inputs only) if a fewer number of address lines will satisfy the application (See Figure 17). ## (A) HITACHI 869 Figure 14 Recommended Circuit for Mode Selection Figure 15 HD14053B Multiplexers/Demultiplexers Figure 17 HD6801V MCU Expanded Non-Multiplexed Mode **OHITACHI** 870 ## Expanded Multiplexed Mode In this mode Port 4 becomes higher order address lines with an alternative of substituting some of the address lines for I/O (inputs only). Port 3 is the data bus multiplexed with the lower order address lines differentiated by an output called Address Strobe. Port 2 is 5 lines of Parallel I/O, SCI, Timer, or any combination of them. Port 1 is 8 Parallel I/O lines. In this mode it is expandable to 65k bytes. (See Figure 18). #### Lower order Address Bus Latches Since the data bus is multiplexed with the lower order address bus in Port 3, latches are required to latch those address bits. The 74LS373 Transparent octal D-type latch can be used with the HD6801V to latch the least significant address byte. Figure 19 shows how to connect the latch to the HD6801V. The output control to the 74LS373 may be connected to ground. Figure 18 HD6801V MCU Expanded Multiplexed Mode Function Table | Output | Ena | ble | Output | |---------|-----|-----|----------| | Control | G | D | Q | | L | н | н | н | | L | н | L | L | | L | L | × | Q, | | н | × | × | z | | | | | <u> </u> | Figure 19 Latch Connection #### Mode and Port Summary MCU Signal Description This section gives a description of the MCU signals for the various modes. SC1 and SC2 are signals which vary with the mode that the chip is in. | MODE | PORT 1<br>Eight Lines | PORT 2<br>Five Lines | PORT 3<br>Eight Lines | PORT 4 Eight Lines | SC <sub>1</sub> | SC₂ | |------------------|-----------------------|----------------------|--------------------------------------------------------|-------------------------------------------------|-----------------|---------| | SINGLE CHIP | 1/0 | 1/0 | 1/0 | 1/0 | IS3 (I) | ŌS3 (O) | | EXPANDED MUX | 1/0 | 1/0 | ADDRESS BUS $(A_0 \sim A_7)$ DATA BUS $(D_0 \sim D_7)$ | ADDRESS BUS* (A <sub>8</sub> ~A <sub>15</sub> ) | AS(O) | R/W(O) | | EXPANDED NON-MUX | 1/0 | I/O | DATA BUS (D <sub>0</sub> ~D <sub>7</sub> ) | ADDRESS BUS* (A <sub>0</sub> ~A <sub>7</sub> ) | īōs(o) | R/W(O) | <sup>\*</sup>These lines can be substituted for I/O (Input Only) starting with the most significant address line. (2) HITACHI l = Input O = Output R/W = Read/Write IOS = I/O Select IS3 = Input Strobe OS3 = Output Strobe SC = Strobe Control AS = Address Strobe Table 3 Mode Selection Summary | Mode | P <sub>22</sub><br>(PC2) | P <sub>2</sub> ,<br>(PC1) | P.<br>(PC0) | ROM | RAM | Interrupt<br>Vectors | Bus<br>Mode | Operating Mode | |------|--------------------------|---------------------------|-------------|-----|-----|---------------------------------------|-------------|--------------------------------| | 7 | н | н | Н | ı | ı | · · · · · · · · · · · · · · · · · · · | 1 | Single Chip | | 6 | н | н | L | 1 | I | 1 | MUX(6) | Multiplexed/Partial Decode | | 5 | н | L | н | ı | Ī | ı | NMUX(6) | Non-Multiplexed/Partial Decode | | 4 | н | L | L | (2) | (1) | ı | 1 | Single Chip Test | | 3 | L | н | Н | E | Е | E | MUX | Multiplexed/No RAM & ROM | | 2 | L | н | L | E | 1 | E | MUX | Multiplexed/RAM | | 1 | Ł | L | н | ı | ı | E | MUX | Multiplexed/RAM & ROM | | 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 \$XX80 - 2) Internal ROM is disabled - 3) RES vector is external for 2 cycles after RES goes "High" - 4) Addresses associated with Ports 3 and 4 are considered external in Modes 0, 1, 2, and 3 - 5) Addresses associated with Port 3 are considered external in Modes 5 and 6 - 6) Port 4 default is user data input; address output is optional by writing to Port 4 Data Direction Register #### MEMORY MAPS The MCU can provide up to 65k bytes address space depending on the operating mode. A memory map for each operating mode is shown in Figure 20. The first 32 locations of each map are reserved for the MCU's internal register area, as shown in Table 4. With exceptions as indicated. Table 4 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) | 0A | | Output Compare Register (High Byte) | ОВ | | Output Compare Register (Low Byte) | 0C | | Input Capture Register (High Byte) | 0Đ | | Input Capture Register (Low Byte) | 0E | | Port 3 Control and Status Register | 0F* | | 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 Modes 0, 1, 2, 3, 5, 6; cannot be accessed in Mode 5 (No. IOS) \*\*\* 1=Output, 0=Input- ## ■ INTERRUPT FLOWCHART The Interrupt flowchart is depicted in Figure 24 and is common to every interrupt excluding reset. <sup>\*</sup> External addresses in Modes 0, 1, 2, 3 Figure 20 HD6801V Memory Maps Figure 20 HD6801V Memory Maps (Continued) Figure 20 HD6801V Memory Maps (Continued) Figure 20 HD6801V Memory Maps (Continued) ### ■ PROGRAMMABLE TIMER The HD6801V contains an on-chip 16-bit programmable timer which may be used to perform measurements on an input waveform while independently generating an output waveform. Pulse widths for both input and output signals 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 timer registers is shown in Figure 21. ## • Free Running Counter (\$0009:\$000A) The key element in the programmable timer is a 16-bit free running counter which is driven to increasing values by E (Enable). The counter value may be read by the CPU software at any time. The counter is cleared to zero by reset and may be considered a read-only register with one exception. Any CPU write to the counter's address (\$09) will always result in preset value of \$FFF8 being loaded into the counter regardless of the value involved in the write. This preset figure is intended for testing operation of the part, but may be of value in some applications. ## Output Compare Register (\$000B:\$000C) The Output Compare Register is a 16-bit read/write register which is used to control an output waveform. The contents of this register are constantly compared with the current value of the free running counter. When a match is found, a flag is set (OCF) in the Timer Control and Status Register (TCSR) and the current value of the Output Level bit (OLVL) in the TCSR is clocked to the Output Level Register. Providing the Data Direction Register for Port 2, Bit 1 contains a "1" (Output), the output level register value will appear on the pin for Port 2 Bit 1. The values in the Output Compare Register and Output level bit may then be changed to control the output level on the next compare value. The Output Compare Register is set to \$FFFF during reset. The Compare function is inhibited for one cycle following a write to the high byte of the Output Compare Register to insure a valid 16-bit value is in the register before a compare is made. ## • Input Capture Register (\$000D:\$000E) The Input Capture Register is a 16-bit read-only register used to store the current value of the free running counter 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) in the TCSR. The Data Direction Register bit for Port 2 Bit 0, should\* be clear (zero) in order to gate in the external input signal to the edge detect unit in the timer. The input pulse width must be at least two E-cycles to ensure an input capture under all conditions. \* With Port 2 Bit 0 configured as an output and set to "1", the external input will still be seen by the edge detect unit. ## • Timer Control and Status Register (TCSR) (\$0008) The Timer Control and Status Register consists of an 8-bit register of which all 8 bits are readable but only the low order 5 bits may be written. The upper three bits contain read-only timer status information and indicate the followings: - a proper transition has taken place on the input pin with a subsequent transfer of the current counter value to the input capture register. - a match has been found between the value in the free running counter and the output compare register, and - · when \$0000 is in the free running counter. Each of the flags may be enabled onto the HD6801V internal bus $(\overline{IRQ_2})$ with an individual Enable bit in the TCSR. If the Figure 21 Block Diagram of Programmable Timer Timer Control and Status Register | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|-----|-----|-----|------|------|------|------|------|--------| | I | ICF | OCF | TOF | EICI | EOCI | ETOI | IEDG | OLVL | \$0008 | 1-bit in the HD6801V Condition Code Register has been cleared, a priority vectored interrupt will occur corresponding to the flag bit(s) set. A description for each bit follows: Bit 0 OLVL Output Level – This value is clocked to the output level register on a successful output compare. If the DDR for Port 2 bit 1 is set, the value will appear on the output pin. Bit 1 IEDG Input Edge — This bit controls which transition of an input will trigger a transfer of the counter to the input capture register. The DDR for Port 2 Bit 0 must be clear for this function to operate. IEDG = 0 Transfer takes place on a negative edge ("High"-to-"Low" transition). IEDG = 1 Transfer takes place on a positive edge ("Low"-to-"High" transition). Bit 2 ETOI Enable Timer Overflow Interrupt — When set, this bit enables IRQ<sub>2</sub> to occur on the internal bus for a TOF interrupt; when clear the interrupt is inhibited. Bit 3 EOCI Enable Output Compare Interrupt — When set, this bit enables $\overline{IRQ}_2$ to appear on the internal bus for an output compare interrupt; when clear the interrupt is inhibited. Bit 4 EICI Enable Input Capture Interrupt — When set, this bit enables IRQ2 to occur on the internal bus for an input capture interrupt; when clear the interrupt is inhibited. Bit 5 TOF Timer Overflow Flag — This read-only bit is set when the counter contains \$FFFF. It is cleared by a read of the TCSR (with TOF set) followed by an CPU read of the Counter (\$09). Bit 6 OCF Output Compare Flag — This read-only bit is set when a match is found between the output compare register and the free running counter. It is cleared by a read of the TCSR (with OCF set) followed by an CPU write to the output compare register (\$0B or \$0C). Bit 7 ICF Input Capture Flag — This read-only status bit is set by a proper transition on the input; it is cleared by a read of the TCSR (with ICF set) followed by an CPU read of the Input Capture Register (\$0D). ## ■ SERIAL COMMUNICATION INTERFACE The HD6801V contains a full-duplex asynchronous serial communication interface (SCI) on chip. The controller comprises a transmitter and a receiver which operate independently or each other but in the same data format and at the same data rate. Both transmitter and receiver communicate with the CPU via the data bus and with the outside world via pins 2, 3, and 4 of Port 2. The hardware, software, and registers are explained in the following paragraphs. #### Wake-Up Feature In a typical multi-processor application, the software protocol will usually contain a destination address in the initial byte(s) of the message. In order to permit non-selected MCU's to ignore the remainder of the message, a wake-up feature is included whereby all further interrupt processing may be optionally inhibited until the beginning of the next message. When the next message appears, the hardware re-enables (or "wakes-up") for the next message. The "wake-up" is automatically triggered by a string of ten consecutive 1's which indicates an idle transmit line. The software protocol must provide for the short idle period between any two consecutive messages. #### Programmable Options The following features of the HD6801V serial I/O section are programmable: - · format standard mark/space (NRZ) - Clock external or internal - baud rate one of 4 per given CPU φ<sub>2</sub> clock frequency or external clock ×8 input - wake-up feature enabled or disabled - Interrupt requests enabled or masked individually for transmitter and receiver data registers - clock output internal clock enabled or disabled to Port 2 (Bit 2) - Port 2 (bits 3 and 4) dedicated or not dedicated to serial I/O individually for transmitter and receiver. #### Serial Communication Hardware The serial communication hardware is controlled by 4 registers as shown in Figure 22. The registers include: - an 8-bit control and status register - a 4-bit rate and mode control register (write only) - · an 8-bit read only receive data register and - · an 8-bit write only transmit data register. In addition to the four registers, the serial I/O section utilizes bit 3 (serial input) and bit 4 (serial output) of Port 2. Bit 2 of Port 2 is utilized if the internal-clock-out or external-clock-in options are selected. ## Transmit/Receive Control and Status (TRCS) Register The TRCS register consists of an 8-bit register of which all 8 bits may be read while only bits 0~4 may be written. The register is initialized to \$20 by reset. The bits in the TRCS register are defined as follows: Transmit/Receive Control and Status Register **OHITACHI** 878 Figure 22 Serial I/O Registers Bit 0 WU "Wake-up" on Next Message - set by HD6801V software and cleared by hardware on receipt of ten consecutive 1's or reset of RE flag. It should be noted that RE flag should be set in advance of CPU set of WU flag. Bit 1 TE Transmit Enable - set by HD6801V to produce preamble of nine consecutive 1's and to enable gating of transmitter output to Port 2, bit 4 regardless of the DDR value corresponding to this bit; when clear, serial I/O has no effect on Port 2 bit 4. TE set should be after at least one bit time of data transmit rate from the set-up of transmit data rate and mode. Bit 2 TIE Transmit Interrupt Enable - when set, will permit an IRQ2 interrupt to occur when bit 5 (TDRE) is set; when clear, the TDRE value is masked from the bus. Bit 3 RE Receiver Enable - when set, gates Port 2 bit 3 to input of receiver regardless of DDR value for this bit; when clear, serial I/O has no effect on Port 2 bit 3. Bit 4 RIE Receiver Interrupt Enable - when set, will permit an IRQ2 interrupt to occur when bit 7 (RDRF) or bit 6 (ORFE) is set, when clear, the interrupt is masked. Bit 5 TORE Transmit Data Register Empty - set by hardware when a transfer is made from the transmit data register to the output shift register. The TDRE bit is cleared by reading the status register, then writing a new byte into the transmit data register, TDRE is initialized to 1 by reset. Bit 6 ORFE Over-Run-Framing Error - set by hardware when an overrun or framing error occurs (receive only). An overrun is defined as a new byte received with last byte still in Data Register/Buffer. A framing error has occurred when the byte boundaries in bit stream are not synchronized to bit counter. If WU flag is set, the ORFE bit will not be set. The ORFE bit is cleared by reading the status register, then reading the Receive Data Register, or by reset. Bit 7 RDRF Receiver Data Register Full - set by hardware when a transfer from the input shift register to the receiver data register is made. If WU flag is set, the RDRF bit will not be set. The RDRF bit is cleared by reading the status register, then reading the Receive Data Register, or by reset. ## Rate and Mode Control Register The Rate and Mode Control register controls the following serial I/O variables: - Baud rate - format - · clocking source, and - Port 2 bit 2 configuration The register consists of 4 bits all of which are write-only and cleared by reset. The 4 bits in the register may be considered as a pair of 2-bit fields. The two low order bits control the bit rate for internal clocking and the remaining two bits control the format and clock select logic. The register definition is as follows: ## Rate and Mode Control Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | • | |---|---|---|---|-----|-----|-----|-----|---------------| | × | × | × | × | CC1 | cco | SS1 | SS0 | ADDR : \$0010 | ♠ HITACHI ## HD6801V0, HD6801V5 Bit 0 SSO | Speed Select - These bits select the Baud rate for Bit 1 \$\$1) the internal clock. The four rates which may be selected are a function of the CPU $\phi_2$ clock frequency. Table 5 lists the available Baud rates. Bit 2 CC0 Clock Control and Format Select - this 2-bit field Bit 3 CC1 controls the format and clock select logic. Table 6 defines the bit field. Table 5 SCI Bit Times and Rates | 991 | : SSO | XTAL | 2.4576 MHz | 4.0 MHz | 4.9152 MHz* | |-------|-------|----------|-------------------|---------------------|---------------------| | 331 . | . 550 | E | 614.4 kHz | 1.0 MHz | 1.2288 MHz | | 0 | 0 | E ÷ 16 | 26 μs/38,400 Baud | 16 μs/62,500 Baud | 13 μs/76,800 Baud | | 0 | 1 | E ÷ 128 | 208 µs/4,800 Baud | 128 µs/7812.5 Baud | 104.2 μs/9,600 Baud | | 1 | 0 | E ÷ 1024 | 1.67 ms/600 Baud | 1.024 ms/976.6 Baud | 833.3 µs/1,200 Baud | | 1 | 1 | E ÷ 4096 | 6.67 ms/150 Baud | 4.096 ms/244.1 Baud | 3.33 ms/300 Baud | <sup>\*</sup>HD6801V5 Only Table 6 SCI Format and Clock Source Control | CC1: C | CCO | Format | Clock Source | Port 2 Bit 2 | Port 2 Bit 3 | Port 2 Bit 4 | |--------|-----|--------|--------------|--------------|--------------|--------------| | 0 | 0 | _ | - | _ | - | _ | | 0 | 1 | NRZ | Internal | Not Used | ** | ** | | 1 | 0 | NRZ | Internal | Output* | •• | ** | | 1 | 1 | NRZ | External | Input | ** | ** | ## **Internally Generated Clock** If the user wishes for the serial I/O to furnish a clock, the following requirements are applicable: - the values of RE and TE are immaterial. - CC1, CC0 must be set to 10 - the maximum clock rate will be E ÷ 16. - the clock will be at 1× the bit rate and will have a rising edge at mid-bit. #### **Externally Generated Clock** If the user wishes to provide an external clock for the serial I/O, the following requirements are applicable: · the CC1, CC0, field in the Rate and Mode Control Register - must be set to 11, - the external clock must be set to 8 times (×8) the desired baud rate and - the maximum external clock frequency is 1.0 MHz. ## Serial Operations The serial I/O hardware should be initialized by the HD6801V software prior to operation. This sequence will normally consist of; - · writing the desired operation control bits to the Rate and Mode Control Register and - · writing the desired operational control bits in the Transmit/ Receive Control and Status Register. The Transmitter Enable (TE) and Receiver Enable (RE) bits may be left set for dedicated operations. ## Transmit Operations The transmit operation is enabled by the TE bit in the Transmit/Receive Control and Status Register. This bit when set, gates the output of the serial transmit shift register to Port 2 Bit 4 and takes unconditional control over the Data Direction Register value for Port 2, Bit 4. Following a RES the user should configure both the Rate and Mode Control Register and the Transmit/Receive Control and Status Register for desired operation. Setting the TE bit during this procedure initiates the serial output by first transmitting a nine-bit preamble of 1's. Following the preamble, internal synchronization is established and the transmitter section is ready for operation. At this point one of two situation exist: - 1) if the Transmit Data Register is empty (TDRE = 1), a continuous string of ones will be sent indicating an idle line, or. - 2) if data has been loaded into the Transmit Data Register (TDRE = 0), the word is transferred to the output shift register and transmission of the data word will begin. During the data transmit, the 0 start bit is first transmitted. Then the 8 data bits (beginning with bit 0) followed by the stop bit, are transmitted. When the Transmitter Data Register has been emptied, the hardware sets the TDRE flag bit. If the HD6801V fails to respond to the flag within the proper time, (TDRE is still set when the next normal transfer from the parallel data register to the serial output register should occur) 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 data register. No 0's will be sent while TDRE remains a 1. ♠ HITACHI Clock output is available regardless of values for bits RE and TE. Bit 3 is used for serial input if RE = "1" in TRCS; bit 4 is used for serial output if TE = "1" in TRCS. ## Receive Operation The receive operation is enabled by the RE bit which gates in the serial input through Port 2 Bit 3. The receiver section operation is conditioned by the contents of the Transmit/ Receive Control and Status Register and the Rate and Mode Control Register. The receiver bit interval is divided into 8 sub-intervals for internal synchronization. In the NRZ Mode, 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 bit ORFE is set. If the tenth bit as a 1, the data is transferred to the Receive Data Register, 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 HD6801V responds to either flag (RDRF or ORFE) by reading the status register followed by reading the Data Register, RDRF (or ORFE) will be cleared. ## ■ RAM CONTROL REGISTER This register, which is addressed at \$0014, gives status information about the standby RAM. A 0 in the RAM enable bit (RAME) will disable the standby RAM, thereby protecting it at power down if VCC Standby is held greater than VSBB volts, as explained previously in the signal description for V<sub>CC</sub> Standby. | | | RA | M Cor | troi Re | gister | | | | | |--------|-------------|------|-------|---------|--------|---|---|---|--| | \$0014 | STBY<br>PWR | RAME | × | × | × | × | x | × | | Bit 0 Not used. Not used. Bit 1 Not used. Bit 2 Not used. Bit 3 Bit 4 Not used. Bit 5 Not used. Bit 6 RAME The RAM Enable control bit allows the user the ability to disable the standby RAM. This bit is set to a logic "1" by RES which enables the standby RAM and can be written to one or zero under program control. When the RAM is disabled, data is read from external memory. Big 7 STBY The Standby Power bit is cleared when the stand-PWR by voltage is removed. This bit is a read/write status flag that the user can read which indicates that the standby RAM voltage has been applied, and the data in the standby RAM is valid. ## GENERAL DESCRIPTION OF INSTRUCTION SET The HD6801V is upward object code compatible with the HD6800 as it implements the full HMCS6800 instruction set. The execution times of key instructions have been reduced to increase throughout. In addition, new instructions have been added; these include 16-bit operations and a hardware multiply. Included in the instruction set section are the following: - · CPU Programming Model (Figure 23) - Addressing modes - Accumulator and memory instructions Table 7 - · New instructions - Index register and stack manipulations instructions Table - Jump and branch instructions Table 9 - · Condition code register manipulation instructions Table 10 - Instructions Execution times in machine cycles Table - · Summary of cycle by cycle operation Table 12 - · Summary of undefined instructions operation - · Op codes Map Table 13 ## CPU Programming Model The programming model for the HD6801V is shown in Figure 23. The double (D) accumulator is physically the same as the Accumulator A concatenated with the Accumulator B so that any operation using accumulator D will destroy information in A and B. Figure 23 CPU Programming Model ## CPU Addressing Modes The HD6801V eight-bit microcomputer unit has seven address modes that can be used by a programmer, with the addressing mode a function of both the type of instruction and the coding within the instruction. A summary of the addressing modes for a particular instruction can be found in Table 11 along with the associated instruction execution time that is given in machine cycles. With a clock frequency of 4 MHz, these times would be microseconds. ## Accumulator (ACCX) Addressing In accumulator only addressing, either accumulator A or accumulator B is specified. These are one-byte instructions. #### Immediate Addressing In immediate addressing, the operand is contained in the second byte of the instruction except LDS and LDX which have the operand in the second and third bytes of the instruction. The CPU addresses this location when it fetches the immediate instruction for execution. These are two or three-byte instructions. Table 7 Accumulator & Memory Instructions | | | | | | | | Ad | dress | ing | Мо | es | | | | | | | ' | Con | | ion<br>aist | | de | |----------------------------|----------|--------------------------------------------------|----------|---------------|-----------------|----------|--------------|----------|----------|---------------|------------|----------|--------------|--------------|----------------|--------------|-------------------------------------------------------|----|---------------|---|----------------|------------|----| | Operations | Mnemonic | IM | ME | D. | Di | RE | ст | 1N | IDE | x | EX | TEI | ND | IM | PLI | ED | Boolean/ | 5 | | | - | _ | П | | | | ОР | ~ | # | ОР | ~ | # | OP | ~ | # | OP | ~ | # | ОP | ~ | # | Arithmetic Operation | Н | +- | N | † | $^{+}$ | 7 | | Add | ADDA | 88 | 2 | 2 | 9В | 3 | 2 | АВ | 4 | 2 | вв | 4 | 3 | T | 1 | † | A+M→A | †፣ | • | 1 | 1: | 1 | + | | | ADDB | СВ | 2 | 2 | DB | 3 | 2 | EB | 4 | 2 | FB | 4 | 3 | 1 | t | 1 | B + M → B | 1 | • | ‡ | 1 | 1 | 1 | | Add Double | ADDD | СЗ | 4 | 3 | D3 | 5 | 2 | €3 | 6 | 2 | F3 | 6 | 3 | 1 | 1 | | A:B+M:M+1→A:B | • | | ŧ | 1 | 1 | + | | Add Accumulators | ABA | | 1 | T | <b>†</b> | T | 1 | T | 1- | t | t | | $t^-$ | 1B | 2 | 1 | A+B→A | 1 | | t | + | 1 | _ | | Add With Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | A9 | 4 | 2 | В9 | 4 | 3 | | 1 | T | A+M+C→A | 1 | • | ‡ | +- | 1 | - | | | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 | T | | 1 | B + M + C → B | 1 | • | 1 | 1 | 1 | _ | | AND | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | Α4 | 4 | 2 | В4 | 4 | 3 | | | 1 | A·M → A | • | | 1 | 1 | R | _ | | 1 | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 | | | $\vdash$ | B·M → B | | | ‡ | † <del>;</del> | R | _ | | Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 | A5 | 4 | 2 | B5 | 4 | 3 | <b>-</b> | t | † | A·M | ١. | • | 1 | † | R | _ | | | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 | <b>†</b> | 1 | T | в-м | ١. | | 1 | 1 | R | - | | Clear | CLR | T | T | T | | 1 | t | 6F | 6 | 2 | 7F | 6 | 3 | † | - | $\vdash$ | 00 → M | | | R | - | R | | | | CLRA | † | | †- | | † | $^{\dagger}$ | <u> </u> | † | | _ | Ė | + | 4F | 2 | 1 | 00 → A | • | | R | s | R | | | | CLRB | | †- | t | <u> </u> | † – | t | <b>-</b> | | H | | - | | 5F | 2 | 1 | 00 → B | | + | R | s | R | -4 | | Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | <b>B</b> 1 | 4 | 3 | - | - | ÷ | A - M | - | • | 1 | 1 | 1 | -4 | | | СМРВ | C1 | 2 | 2 | D1 | 3 | 2 | EI | 4 | 2 | F1 | 4 | 3 | <del> </del> | <del> </del> | t | B - M | • | • | ; | : | 1 | - | | Compare | 20.4 | <del> </del> | † | ╁┈ | + | - | F | + | Ė | - | | Ė | <del> </del> | | <del>-</del> - | ╁╌ | | + | + | + | + | + | + | | Accumulators | CBA | | <u> </u> | _ | | | <u> </u> | | | | | | | 11 | 2 | 1 | A - B | • | • | ‡ | ŧ | 1 | | | Complement, 1's | СОМ | | 1 | | L. | | | 63 | 6 | 2 | 73 | 6 | 3 | | | Ī | M → M | • | • | ţ | ŧ | R | 1 | | | COMA | | | | | | | | | | | | | 43 | 2 | 1 | Ā→A | • | • | 1 | 1 | R | ٦ | | | сомв | | | | | | L | | | | | | | 53 | 2 | 1 | B → B | • | • | : | ‡ | R | 1 | | Complement, 2's | NEG | <u> </u> | L | L | | | <u> </u> | 60 | 6 | 2 | 70 | 6 | 3 | | | ĺ | 00 - M → M | • | • | 1 | 1 | 1 | 1 | | (Negate) | NEGA | | | | L., | | | | | | | | | 40 | 2 | 1 | 00 - A → A | • | • | ‡ | 1 | (1) | , | | | NEGB | <u></u> | L | | L | | | | L | | | | | 50 | 2 | 1 | 00 - B → B | • | • | ‡ | ŧ | (i) | 1 | | Decimal Adjust, A | DAA | | | | | | | <br> | | | | | | 19 | 2 | 1 | Converts binary add of BCD characters into BCD format | • | • | 1 | 1 | ‡ | | | Decrement | DEC | | | | | | | 6A | 6 | 2 | 7A | 6 | 3 | | | | M = 1 → M | • | • | ŧ | ‡ | 3 | 1 | | | DECA | | | | Ī. — | | | | | | | | | 4A | 2 | 1 | A - 1 → A | • | • | ‡ | 1 | 4 | 4 | | | DECB | Π | | | | | | | | | | | | 5A | 2 | 1 | B - 1 → B | • | • | ‡ | 1 | (1) | + | | Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | B8 | 4 | 3 | | | | A ⊕ M → A | • | • | ‡ | 1 | R | t | | | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 | | | | B ⊕ M→ B | • | • | ‡ | 1 | R | t | | ncrement | INC | | | | | | | 6C | 6 | 2 | 7C | 6 | 3 | | | | M + 1 → M | • | • | 1 | 1 | 5 | + | | Í | INCA | | | | | | | | | | | | | 4C | 2 | 1 | A + 1 → A | • | • | 1 | 1 | (5) | t | | | INCB | | | | | | | | | | | | П | 5C | 2 | 1 | B + 1 → B | • | • | 1 | ‡ | 5 | + | | Load | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | В6 | 4 | 3 | | | - | M → A | • | | 1 | 1 | R | t | | Accumulator | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 | | | | M → B | | | ‡ | ‡ | R | † | | Load Double<br>Accumulator | LDD | сс | 3 | 3 | DС | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 | | | | M + 1 → B, M → A | • | • | 1 | ‡ | R | Ì | | Multiply Unsigned | MUL | | Ī | _ | | | | | | ┪ | | | | 3D | 10 | 1 | A×B→A:B | • | • | • | • | ٠ | t | | OR, Inclusive | ORAA | 8A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | ВА | 4 | 3 | | $\neg$ | | A + M → A | | | t | ŧ | R | ł | | <u> </u> | ORAB | CA | 2 | 2 | DA | 3 | 2 | EΑ | 4 | _ | FA | 4 | 3 | $\dashv$ | -+ | $\dashv$ | B + M → B | • | • | 1 | 1 | R | ł | | ush Data | PSHA | | Н | $\dashv$ | | | $\vdash$ | - | $\dashv$ | $\dashv$ | $\dashv$ | - | - | 36 | 3 | 1 | A → Msp, SP – 1 → SP | • | • | • | • | - | ł | | | PSHB | | П | $\exists$ | | | $\dashv$ | $\dashv$ | - | 寸 | -+ | + | + | 37 | 3 | <del>,</del> | $B \rightarrow Msp, SP - 1 \rightarrow SP$ | | • | • | • | ÷ | ł | | ull Data | PULA | | | | | | $\dashv$ | | $\dashv$ | _† | _ | 7 | - | 32 | 4 | 1 | SP + 1 → SP, Msp → A | • | | | • | ÷ | ł | | | PULB | | | $\neg$ | $\neg \uparrow$ | $\neg$ | - | | $\dashv$ | $\dashv$ | | 1 | 7 | 33 | 4 | 1 | SP + 1 → SP, Msp → B | • | $\rightarrow$ | • | • | ÷ | ļ | | Rotate Left | ROL | | | | | _ | | 69 | 6 | 2 | 79 | 6 | 3 | | ÷ | - | | | | - | - | 6 | ł | | ľ | ROLA | $\vdash$ | + | 1 | | $\dashv$ | - | | -+ | - | -+ | - | - | 49 | 2 | 1 | *) [ | • | _ | : | 1 | (6) | ł | | ļ , | ROLB | | - | - | $\rightarrow$ | - | + | | + | + | $\dashv$ | $\dashv$ | + | 59 | _ | $\ddot{+}$ | b Catherine | • | | 1 | ‡ | (6)<br>(6) | ł | | Rotate Right | ROR | | | $\dashv$ | | _ | -+ | 66 | 6 | 2 | 76 | 6 | 3 | | - | | м | • | | ; | _ | <u></u> | Ļ | | · | RORA | | 寸 | | $\neg$ | | $\dashv$ | | _ | - | | - | + | 46 | 2 | 1 | <u></u> | • | _ | ; | 1 | 6 | 1 | | F | RORB | _ | | $\rightarrow$ | | $\dashv$ | + | - | -+ | $\rightarrow$ | -+ | - | -+ | 56 | $\rightarrow$ | i | R C 67 60 | | - 1 | ; | + | 6 | ┞ | **(1)** HITACHI Condition Code Addressing Modes Boolean/ 3 2 1 0 Operations Mnemonic INDEX EXTEND IMPLIED 4 IMMED. DIRECT Arithmetic Operation zv 1 N С OP OP OP OP ; ; **6** ; • 6 2 78 6 3 ASL Shift Left • • **‡ ‡ 6** 48 2 Arithmetic ASLA • • 1 1 6 1 58 2 1 ASLB ‡ ‡ **6** Double Shift 05 3 ASLD Left, Arithmetic ٠ | ‡ | \$ | 66 | ‡ 6 2 77 ASR Shift Right 47 2 • : : **6** : Arithmetic 1 ASRA • | ‡ | **6** | ‡ 57 2 1 ASRB • R ‡ 6 ‡ 6 2 74 6 3 LSR Shift Right • R ‡ 6 ‡ Logical 44 2 1 ISRA 54 2 1 • R + 6 + LSRB R : 6 : ACC A/ ACC B ٠ Double Shift **04** 3 LSRD Right Logical • ‡ ‡ R • A → M ٠ 3 2 A7 4 2 B7 4 STAA • ‡ ‡ R • Accumulator D7 3 2 E7 4 2 F7 4 3 8 → M STAR • | 1 | R Store Double ED 5 2 FD 5 3 4 2 STD B → M + 1 Accumulator • | 1 | 1 | 1 2 90 A0 4 2 B0 4 3 $A - M \rightarrow A$ 2 3 2 Subtract SUBA • ‡ ‡ ‡ B - M → B CO 2 2 DO 3 2 EO 4 2 FO 4 3 SUBB A : B - M : M + 1 → A : B • | ‡ | ‡ | ‡ 4 3 93 5 2 A3 6 2 B3 6 3 **Double Subtract** SUBD |:|:|: • Subtract 2 $A - B \rightarrow A$ SBA Accumulators • : : : : 3 2 A2 4 2 B2 4 3 A - M - C → A ٠ 2 2 92 SBCA Subtract • : : : : C2 2 2 D2 3 2 E2 4 2 F2 4 3 B - M - C - B With Carry SBCB • ‡ ‡ R • 16 2 1 A → B Transfer TAB • 1 1 R • Accumulators 17 2 1 B → A TBA • ‡ ‡ R R 6D 6 2 7D 6 3 M - 00 Test Zero or TST • t t R R 4D 2 1 A - 00 Minus TSTA • • ; ; A R 5D 2 1 B - 00 **TSTB** Table 7 Accumulator & Memory Instructions (Continued) The Condition Code Register notes are listed after Table 10. ### Direct Addressing In direct addressing, the address of the operand is contained in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in the machine i.e., locations zero through 255. Enhanced execution times are achieved by storing data in these locations. In most configurations, it should be a random access memory. These are two-byte instructions. ## Extended Addressing In extended addressing, the address contained in the second byte of the instruction is used as the higher eight-bits of the address of the operand. The third byte of the instruction is used as the lower eight-bits of the address for the operand. This is an absolute address in memory. These are three-byte instructions. Indexed Addressing In indexed addressing, the address contained in the second byte of the instruction is added to the index register's lowest eight bits in the CPU. The carry is then added to the higher order eight bits of the index register. This result is then used to address memory. The modified address is held in a temporary address register so there is no change to the index register. These are two-byte instructions. ## Implied Addressing In the implied addressing mode the instruction gives the address (i.e., stack pointer, index register, etc.). These are one-byte instructions. ## Relative Addressing In relative addressing, the address contained in the second byte of the instruction is added to the program counter's lowest eight bits plus two. The carry or borrow is then added to the high eight bits. This allows the user to address data within a range of -126 to +129 bytes of the present instruction. These are two-byte instructions. ## HD6801V0, HD6801V5 #### New Instructions In addition to the existing 6800 Instruction Set, the following new instructions are incorporated in the HD6801V Microcomputer. - ABX Adds the 8-bit unsigned accumulator B to the 16-bit X-Register taking into account the possible carry out of the low order byte of the X-Register. - ADDD Adds the double precision ACCD\* to the double precision value M:M+1 and places the results in ACCD. - ASLD Shifts all bits of ACCD one place to the left. Bit 0 is loaded with zero. The C bit is loaded from the most significant bit of ACCD. - LDD Loads the contents of double precision memory location into the double accumulator A:B. The condition codes are set according to the data. - LSRD Shifts all bits of ACCD one place to the right. Bit 15 is loaded with zero. The C bit is loaded from the least significant bit to ACCD. - MUL Multiplies the 8 bits in accumulator A with the 8 bits in accumulator B to obtain a 16-bit unsigned number in A:B, ACCA contains MSB of result. - **PSHX** The contents of the index register is pushed onto the stack at the address contained in the stack pointer. The stack pointer is decremented by 2. - **PULX** The index register is pulled from the stack beginning at the current address contained in the stack pointer +1. The stack pointer is incremented by 2 in total. - STD Stores the contents of double accumulator A:B in memory. The contents of ACCD remain unchanged. - **SUBD** Subtracts the contents of M:M + 1 from the contents of double accumulator AB and places the result in ACCD. - BRN Never branches. If effect, this instruction can be considered a two byte NOP (No operation) requiring three cycles for execution. - CPX Internal processing modified to permit its use with any conditional branch instruction. Table 8 Index Register and Stack Manipulation Instructions | | | | | | | | Ade | dress | ing | Mo | des | | | | | | Boolean/ | ( | | diti<br>Reg | | | ie | |------------------------|----------|----|-----|----|-----|-----|-----|-------|-----|----|-----|----|---|-----|-----|---|------------------------------------------------|---|---|-------------|----|---|----| | Pointer Operations | Mnemonic | IM | меі | D. | DII | REC | T | IN | DE. | × | EX | TN | ) | IMP | LIE | D | Arithmetic Operation | 5 | 4 | 3 | 2 | 1 | 0 | | | | OP | ~ | # | OP | ~ | # | OР | ~ | # | OP | ~ | # | OР | ~ | # | | н | ı | N | z | ٧ | С | | Compare Index Reg | CPX | 8C | 4 | 3 | 9C | 5 | 2 | AC | 6 | 2 | вс | 6 | 3 | | | | X M : M + 1 | • | • | ‡ | ‡ | ‡ | ‡ | | Decrement Index Reg | DEX | | | | | | | | | | | | | 09 | 3 | 1 | X – 1 → X | • | • | • | ‡ | • | • | | Decrement Stack Pntr | DES | 1 | | | | | | | | | | | | 34 | 3 | 1 | SP - 1 → SP | • | • | • | • | • | • | | Increment Index Reg | INX | | | | | | | 1 | 1 | T | | | | 80 | 3 | 1 | X + 1 → X | • | • | • | ‡ | • | • | | Increment Stack Pntr | INS | Ť | | 1 | | | | 1 | | | | | | 31 | 3 | 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 | : | R | • | | Load Stack Pntr | LDS | 8E | 3 | 3 | 9E | 4 | 2 | ΑE | 5 | 2 | ВE | 5 | 3 | | | | M → SPH, (M+1) → SPL | • | • | T | \$ | R | • | | Store Index Reg | STX | T | | | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 | | | | $X_H \rightarrow M, X_L \rightarrow \{M+1\}$ | • | • | 7 | ‡ | R | • | | Store Stack Pntr | STS | | | | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 | | | | $SP_H \rightarrow M, SP_L \rightarrow (M+1)$ | • | • | 7 | 1 | R | • | | Index Reg → Stack Pntr | TXS | T | | | | | | | İ | | | | | 35 | 3 | 1 | X - 1 → SP | • | • | • | • | • | • | | Stack Pntr → Index Reg | TSX | | | | | | | İ | | | | | | 30 | 3 | 1 | SP + 1 → X | • | • | • | • | • | • | | Add | ABX | | | | | T | 1 | | | | | i | | 3A | 3 | 1 | $B + X \rightarrow X$ | • | • | • | • | ٠ | • | | Push Data | PSHX | | | | | | | | | | | | | 3C | 4 | 1 | X <sub>L</sub> → M <sub>sp</sub> , SP – 1 → SP | • | • | • | • | ٠ | • | | | | | | l | | | | | | | | | | | 1 | | X <sub>H</sub> → M <sub>sp</sub> , SP ~ 1 → SP | | | 1 | | | | | Pull Data | PULX | | | | | T | | | Ì | | 1 | | | 38 | 5 | 1 | SP + 1 → SP, M <sub>SP</sub> → X <sub>H</sub> | • | • | • | • | • | • | | | | | | | | | 1 | | | | | | ı | | 1 | 1 | SP + 1 → SP, M <sub>en</sub> → X <sub>1</sub> | | | | | | | The Condition Code Register notes are listed after Table 10. <sup>\*</sup>ACCD is the 16 bit register (A:B) formed by concatenating the A and B accumulators. The A-accumulator is the most significant byte. Table 9 Jump and Branch Instructions | | | | | | | | Add | dressi | ing | Mod | ies | | | | | | | _ c | | | on ( | | e | |-----------------------------|----------|-----|--------|----|--------|----------|-----|----------|-----|-----|-----|----|---|-----|-----|---|------------------------------|-----|---|-----------|----------|--------------|----------| | Operations | Mnemonic | REL | ΔΤΙ | VF | DIF | tEC | т | INI | DE) | < T | EXT | ND | , | IMP | LIE | D | Branch Test | 5 | 4 | 3 | 2 | 1 | 0 | | · | | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | | н | 1 | N | z | V | C | | Branch Always | BRA | 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 | • | • | • | • | • | Ľ | | Branch If = Zero | BEQ | 27 | 3 | 2 | | | | | | | | L | | L | | | Z = 1 | • | • | • | • | • | Ľ | | Branch If > Zero | BG€ | 2C | 3 | 2 | | | | | | | | | | | | | N ⊕ V = 0 | • | • | • | • | • | Ļ | | Branch If > Zero | BGT | 2E | 3 | 2 | | | | | | | | | | | | | Z + (N + V) = 0 | • | • | • | • | · | ľ | | Branch If Higher | ВНІ | 22 | 3 | 2 | | | | | | | | | | | | | C + Z = 0 | • | • | • | • | | Ľ | | Branch If ≤ Zero | BL€ | 2F | 3 | 2 | | | Γ | | | | | I | | | | | 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 ⊕ V = 1 | • | • | • | • | | 4 | | Branch If Minus | BMI | 28 | 3 | 2 | 1 | $\vdash$ | T | <b>!</b> | | Τ- | | | Т | | | | N = 1 | • | • | 1. | • | • | 1 | | Branch If Not Equal | BNE | 26 | 3 | 2 | | | | | | Γ | | | | | | | Z = 0 | • | • | • | • | • | 1 | | Branch If Overflow<br>Clear | BVC | 28 | 3 | 2 | | | | | | | | | | | | | V = 0 | • | • | • | • | • | 4 | | Branch If Overflow Set | BVS | 29 | 3 | 2 | | Т | ⇈ | | | Г | | | I | | | | V = 1 | • | • | • | • | + | + | | Branch If Plus | BPL | 2A | 3 | 2 | 1 - | T | Т | | | Т | | Τ | _ | | | 1 | N = 0 | • | | • | | + | + | | Branch To Subroutine | BSR | 80 | 6 | 2 | 1 | | 1 | | Τ | Т | | T | Т | T | | T | | Ŀ | • | <u> •</u> | Ŀ | ┷ | 4 | | Jump | JMP | + | +- | + | + | +- | T | 6E | 3 | 2 | 7E | 3 | 3 | 1 | Т | 1 | | • | • | • | - | - | - | | Jump To Subroutine | JSR | + | +- | +- | 90 | 5 | 2 | AD | 6 | 2 | BD | 6 | 3 | | T | | | • | • | • | • | • | <u>'</u> | | No Operation | NOP | - | T | 1 | 1 | T | Γ | | | | 1 | | Ī | 01 | 2 | 1 | Advances Prog. Cntr.<br>Only | • | • | • | Т. | • | ' | | Return From Interrupt | RTI | + | $\top$ | + | $\top$ | T | † | | T | | 1 | I | | 38 | 10 | 1 | | | = | = | <u>®</u> | _ | = | | Return From<br>Subroutine | RTS | | | | 1 | | T | | | | | | | 39 | 5 | 1 | | • | • | 1 | + | | | | Software Interrupt | SWI | +- | + | + | +- | 1 | 1 | | 1 | 1 | Т | 1 | Ī | 3F | 12 | 1 | ] | • | _ | | • | <u>' •</u> | | | Wait for Interrupt | WAI | +- | + | 十 | $\top$ | 1 | + | 1- | 1 | Т | T- | T | T | 3E | 9 | 1 | | • | ( | ୭ • | • | • | , | Table 10 Condition Code Register Manipulation Instructions | | | Addre | ssingN | Aodes | | Condition Code Register | | | | | | | |----------------------|----------|---------|--------|-------|-------------------|-------------------------|---|----------------------------------------------|-----------|-------------|------------|--| | Operations | Mnemonic | IMPLIED | | | Boolean Operation | 5 | 4 | 3 | 2 | 1 | 0 | | | Operation. | | OP | ~ | # | _ | н | ı | N | z | V | C | | | Clear Carry | CLC | oc | 2 | 1 | 0 → C | • | • | • | • | • | R | | | Clear Interrupt Mask | CLI | 0E | 2 | 1 | 0 → 1 | • | R | • | • | • | 1. | | | Clear Overflow | CLV | 0A | 2 | 1 | 0 → V | • | • | • | • | R | <b>↓</b> • | | | Set Carry | SEC | OD | 2 | 1 | 1 → C | • | • | • | • | • | S | | | Set Interrupt Mask | SEI | OF | 2 | 1 | 1 → 1 | • | S | • | • | • | ₽• | | | Set Overflow | SEV | OB | 2 | 1 | 1 → V | • | • | Ŀ, | <u> •</u> | <u> S</u> | • | | | Accumulator A → CCR | TAP | 06 | 2 | 1 | A→ CCR | | | <del>_</del> ( | <u> </u> | <del></del> | _ | | | CCR → Accumulator A | TPA | 07 | 2 | 1 | CCR → A | • | • | <u> • </u> | • | 1 • | Ŀ | | Condition Code Register Notes: (Bit set it test is true and cleared otherwise) - (Bit V) N) (All) (Bit I) (Bit C) - Test: Result = 10000000? Test: Result \ 0000000? Test: Pesult \ 00000000? Test: Decimal value of most significant BCD Character greater than nine? (Not cleared if previously set) Test: Operand = 10000000 prior to execution? Test: Operand = 01111111 prior to execution? Test: Set equal to result to N \(\text{\text{\text{\text{\text{equal to result}}}}\) C after shift has occurred. Test: Result less than zero? (Bit 15 = 1) Load Condition Code Resister from Stack. (See Special Operations) - Test: nesurt less train zero? (bit 19 = 1). Load Condition Code Register from Stack, (See Special Operations). Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. Set according to the contents of Accumulator A. Set equal to result of Bit 7 (ACCB). Table 11 Instruction Execution Times in Machine Cycle | | ACCX | lmme-<br>diate | Direct | Ex-<br>tended | In-<br>dexed | lm-<br>plied | Re-<br>lative | | ACCX | Imme-<br>diate | Direct | Ex-<br>tended | In-<br>dexed | lm-<br>plied | Re-<br>lative | |------|------|----------------|--------|---------------|--------------|--------------|---------------|------|------|----------------|--------|---------------|--------------|--------------|---------------| | ABA | • | • | • | • | • | 2 | • | INX | • | • | • | • | • | 3 | • | | ABX | • | • | • | • | • | 3 | • | JMP | • | • | • | 3 | 3 | • | • | | ADC | • | 2 | 3 | 4 | 4 | • | • | JSR | • | • | 5 | 6 | 6 | • | • | | ADD | • | 2 | 3 | 4. | 4 | • | • | LDA | • | 2 | 3 | 4 | 4 | • | • | | ADDD | • | 4 | 5 | 6 | 6 | • | • | LDD | • | 3 | 4 | 5 | 5 | • | • | | AND | • | 2 | 3 | 4 | 4 | • | • | LD\$ | • | 3 | 4 | 5 | 5 | • | • | | ASL | 2 | • | • | 6 | 6 | • | • | LDX | • | 3 | 4 | 5 | 5 | • | • | | ASLD | • | • | • | • | • | 3 | • | LSR | 2 | • | • | 6 | 6 | • | • | | ASR | 2 | • | • | 6 | 6 | • | • | LSRD | • | • | • | • | • | 3 | • | | BCC | • | • | • | • | • | • | 3 | MUL | • | • | • | • | • | 10 | • | | BCS | • | • | • | • | • | • | 3 | NEG | 2 | • | • | 6 | 6 | • | • | | BEQ | • | • | • | • | • | • | 3 | NOP | • | • | • | • | • | 2 | • | | BGE | • | • | • | • | • | • | 3 | ORA | • | 2 | 3 | 4 | 4 | • | • | | BGT | • | • | • | • | • | • | 3 | PSH | 3 | • | • | • | • | • | • | | вні | • | • | • | • | • | • | 3 | PSHX | • | • | • | • | • | 4 | • | | BIT | • | 2 | 3 | 4 | 4 | • | • | PUL | 4 | • | • | • | • | • | • | | BLE | • | • | • | • | • | • | 3 | PULX | • | • | • | • | • | 5 | • | | BLS | • | • | • | • | • | • | 3 | ROL | 2 | • | • | 6 | 6 | • | • | | BLT | • | • | • | • | • | • | 3 | ROR | 2 | • | • | 6 | 6 | • | • | | вмі | • | • | • | • | • | • | 3 | RTI | • | • | • | • | • | 10 | • | | BNE | • | • | • | • | • | • | 3 | RTS | • | • | • | • | • | 5 | • | | BPL | • | • | • | • | • | • | 3 | SBA | • | • | • | • | • | 2 | • | | BRA | • | • | • | • | • | • | 3 | SBC | • | 2 | 3 | 4 | 4 | • | • | | BRN | • | • | • | • | • | • | 3 | SEC | • | • | • | • | • | 2 | • | | BSR | • | • | • | • | • | • | 6 | SEI | • | • | • | • | • | 2 | • | | BVC | • | • | • | • | • | • | 3 | SEV | • | • | • | • | • | 2 | • | | BVS | • | • | • | • | • | • | 3 | STA | • | • | 3 | 4 | 4 | • | • | | CBA | • | • | • | • | • | 2 | • | STD | • | • | 4 | 5 | 5 | • | • | | CLC | • | • | • | • | • | 2 | • | STS | • | • | 4 | 5 | 5 | • | • | | CLI | • | • | • | • | • | 2 | • | STX | • | • | 4 | 5 | 5 | • | • | | CLR | 2 | • | • | 6 | 6 | • | • | SUB | • | 2 | 3 | 4 | 4 | • | • | | CLV | • | • | • | • | • | 2 | • | SUBD | • | 4 | 5 | 6 | 6 | • | • | | CMP | • | 2 | 3 | 4 | 4 | • | • | SWI | • | • | • | • | • | 12 | • | | СОМ | 2 | • | • | 6 | 6 | • | • | TAB | • | • | • | • | • | 2 | • | | CPX | • | 4 | 5 | 6 | 6 | • | • | TAP | • | • | • | • | • | 2 | • | | DAA | • | • | • | • | • | 2 | • | TBA | • | • | • | • | • | 2 | • | | DEC | 2 | • | • | 6 | 6 | • | • | TPA | • | • | • | • | • | 2 | • | | DES | • | • | • | • | • | 3 | • | TST | 2 | • | • | 6 | 6 | • | • | | DEX | • | • | • | • | • | 3 | • | TSX | • | • | • | • | • | 3 | • | | EOR | • | 2 | 3 | 4 | 4 | • | • | TXS | • | • | • | • | • | 3 | • | | INC | 2 | • | • | 6 | 6 | • | • | WAI | • | • | • | • | • | 9 | • | | INC | _ | _ | _ | _ | _ | | _ | | | | | | | | | ## Summary of Cycle by Cycle Operation Table 12 provides a detailed description of the information present on the Address Bus, Data Bus, and the Read/Write line $(R/\overline{W})$ during each cycle for each instruction. This information is useful in comparing actual with expected results during debug of both software and hardware as the control program is executed. The information is categorized in groups according to addressing mode and number of cycles per instruction. (In general, instructions with the same addressing mode and number of cycles execute in the same manner; exceptions are indicated in the table). Table 12 Cycle by Cycle Operation | 2 | 1 2 | Op Code Address | <del>,</del> | | |----------------|--------------------------------------------------|--------------------------------------------------|--------------|----------------------------------| | 2 | | Op Code Address | | | | | 2 | | 1 | Op Code | | | | Op Code Address + 1 | 1 | Operand Data | | 1 | | ! | 1 | | | | | | | | | | | | | | | 3 | 1 | Op Code Address | 1 | Op Code | | _ | 2 | Op Code Address + 1 | 1 | Operand Data (High Order Byte) | | | 3 | Op Code Address + 2 | 1 | Operand Data (Low Order Byte) | | 4 | 1 | Op Code Address | 1 | Op Code | | , | 2 | Op Code Address + 1 | 1 | Operand Data (High Order Byte) | | | 3 | Op Code Address + 2 | 1 | Operand Data (Low Order Byte) | | | 4 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | 1 | | · | | | | | | On Code Address | 1 | Op Code | | 3 | E | _ · · | | Address of Operand | | | _ | j - r | | Operand Data | | | ٠ ، | Address of Operatio | ' | Operana Data | | | | | | | | | <del>├</del> | O- C-d- Address | 1 | Op Code | | 3 | | 1 | - | Destination Address | | | | | - | Data from Accumulator | | <del></del> | | | | Op Code | | 4 | 1 | · · · · · · · · · · · · · · · | 1 | Address of Operand | | | _ | - · · · | 1 . | Operand Data (High Order Byte) | | 1 | | | 1 | Operand Data (Low Order Byte) | | | <del> </del> | + | <u> </u> | | | 4 | 1 | · · | 1 * | Op Code Address of Operand | | | - | | 1 | Register Data (High Order Byte) | | | - | | 1 - | Register Data (Low Order Byte) | | <del> _</del> | + | <del> </del> | -+ | Op Code | | 5 | 1 - | 1 * ' | 1 ' | Address of Operand | | 1 | _ | - * | 1 | Operand Data (High Order Byte) | | | _ | 1 - 7 | 1 . | Operand Data (Low Order Byte) | | | | | 1 . | Low Byte of Restart Vector | | <del></del> | <del> </del> | <del></del> | <del> </del> | Op Code | | 5 | 1 - | 1 -7 | 1 - | Irrelevant Data | | | | } - • | 1 ' | First Subroutine Op Code | | | _ | <b>~</b> | | Return Address (Low Order Byte) | | | 1 | | | Return Address (High Order Byte) | | | | 3 1 2 3 4 1 2 3 4 4 5 5 1 1 2 3 4 5 5 | 2 | 2 | Table 12 Cycle by Cycle Operation (Continued) | Address Mode &<br>Instructions | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |--------------------------------|----------------------------------------|------------|-----------------------------------|-------------|----------------------------------| | NDEXED | | | | | | | JMP | 3 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | ADC EOR | 4 | 1 | Op Code Address | 1 | Op Code | | ADD LDA | | 2 | Op Cade Address + 1 | 1 | Offset | | AND ORA | - | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | BIT SBC | | 4 | Index Register Plus Offset | 1 | Operand Data | | CMP SUB | | | 1 | | , | | STA | 4 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Index Register Plus Offset | 0 | Operand Data | | LDS | 5 | 1 | Op Code Address | 1 | Op Code | | LDX | | 2 | Op Code Address + 1 | 1 | Offset | | LDD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | 255 | | 4 | Index Register Plus Offset | 1 | Operand Data (High Order Byte) | | | | 5 | Index Register Plus Offset + 1 | 1 | Operand Data (Low Order Byte) | | STS | 5 | 1 | Op Code Address | 1 | Op Code | | STX | 5 | 2 | Op Code Address + 1 | 1 | Offset | | STD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | 510 | | 4 | Index Register Plus Offset | 0 | Operand Data (High Order Byte) | | | 1 | 5 | Index Register Plus Offset + 1 | 0 | Operand Data (Figir Order Byte) | | ASL LSR | 6 | 1 | Op Code Address | 1 | Op Code | | ASR NEG | | 2 | Op Code Address + 1 | 1 | Offset | | CLR ROL | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | COM ROR | | 4 | Index Register Plus Offset | 1 | Current Operand Data | | DEC TST* | 1 | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | INC | | 6 | Index Register Plus Offset | Ö | New Operand Data | | CPX | 6 | 1 | Op Code Address | 1 | Op Code | | SUBD | * | 2 | Op Code Address + 1 | i | Offset | | ADDD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | 5 | | 4 | Index Register + Offset | 1 | Operand Data (High Order Byte) | | | | 5 | Index Register + Offset + 1 | i | Operand Data (Low Order Byte) | | | | 6 | Address Bus FFFF | 1. | Low Byte of Restart Vector | | JSR | 6 | 1 | Op Code Address | 1 | Op Code | | | " | 2 | Op Code Address + 1 | i | Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Index Register + Offset | 1 | First Subroutine Op Code | | | | 5 | Stack Pointer | ò | Return Address (Low Order Byte) | | | | 6 | Stack Pointer – 1 | 0 | Return Address (High Order Byte) | | <del></del> | لـــــــــــــــــــــــــــــــــــــ | | yele is "1" level and AP-EEEE DB: | <u> </u> | <del></del> | <sup>\*</sup> In the TST instruction, R/W line of the sixth cycle is "1" level, and AB=FFFF, DB=Low Byte of Reset Vector. Table 12 Cycle by Cycle Operation (Continued) | Address Mode &<br>Instructions | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |--------------------------------|--------|------------|-----------------------------|-------------|---------------------------------------| | XTENDED | | | | | | | JMP | 3 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Jump Address (High Order Byte) | | | | 3 | Op Code Address + 2 | 1 | Jump Address (Low Order Byte) | | ADC EOR | 4 | 1 | Op Code Address | 1 | Op Code | | ADD LDA | | 2 | Op Code Address + 1 | 1 | Address of Operand (High Order Byte) | | AND ORA | | 3 | Op Code Address + 2 | 1 | Address of Operand (Low Order Byte) | | BIT SBC | | 4 | Address of Operand | 1 | Operand Data | | CMP SUB | | | | | | | STA | 4 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Destination Address (High Order Byte) | | | | 3 | Op Code Address + 2 | 1 | Destination Address (Low Order Byte) | | | | 4 | Operand Destination Address | 0 | Data from Accumulator | | LDS | 5 | 1 | Op Code Address | 1 | Op Code | | LDX | | 2 | Op Code Address + 1 | 1 | Address of Operand (High Order Byte) | | LDD | i i | 3 | Op Code Address + 2 | 1 | Address of Operand (Low Order Byte) | | | ļ | 4 | Address of Operand | 1 | Operand Data (High Order Byte) | | | | 5 | Address of Operand + 1 | 1 | Operand Data (Low Order Byte) | | STS | 5 | 1 | Op Code Address | 1 | Op Code | | STX | | 2 | Op Code Address + 1 | 1 | Address of Operand (High Order Byte) | | STD | İ | 3 | Op Code Address + 2 | 1 | Address of Operand (Low Order Byte) | | | | 4 | Address of Operand | 0 | Operand Data (High Order Byte) | | | | 5 | Address of Operand + 1 | 0 | Operand Data (Low Order Byte) | | ASL LSR | 6 | 1 | Op Code Address | 1 | Op Code | | ASR NEG | | 2 | Op Code Address + 1 | 1 | Address of Operand (High Order Byte) | | CLR ROL | 1 | 3 | Op Code Address + 2 | 1 | Address of Operand (Low Order Byte) | | COM ROR | | 4 | Address of Operand | 1 | Current Operand Data | | DEC TST* | | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | INC | | 6 | Address of Operand | 0 | New Operand Data | | CPX | 6 | 1 | Op Code Address | 1 | Op Code | | SUBD | | 2 | Op Code Address + 1 | 1 | Operand Address (High Order Byte) | | ADDD | | 3 | Op Code Address + 2 | 1 | Operand Address (Low Order Byte) | | | | 4 | Operand Address | 1 | Operand Data (High Order Byte) | | | | 5 | Operand Address + 1 | 1 | Operand Data (Low Order Byte) | | | } | 6 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | JSR | 6 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Address of Subroutine (High Order Byt | | | | 3 | Op Code Address + 2 | 1 | Address of Subroutine (Low Order Byt | | | | 4 | Subroutine Starting Address | 1 | Op Code of Next Instruction | | | | 5 | Stack Pointer | 0 | Return Address (Low Order Byte) | | | | 6 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) | <sup>\*</sup> In the TST instruction, R/W line of the sixth cycle is "1" level, and AB = FFFF, DB = Low Byte of Reset Vector. Table 12 Cycle by Cycle Operation (Continued) | Address Mode &<br>Instructions | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |---------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------|---------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------| | IMPLIED | | | | | | | ABA DAA SEC<br>ASL DEC SEI<br>ASR INC SEV<br>CBA LSR TAB<br>CLC NEG TAP<br>CLI NOP TBA<br>CLR ROL TPA<br>CLV ROR TST<br>COM SBA | 2 | 1 2 | Op Code Address<br>Op Code Address + 1 | 1 1 | Op Code Op Code of Next Instruction | | ABX | 3 | 1<br>2<br>3 | Op Code Address Op Code Address + 1 Address Bus FFFF | 1<br>1<br>1 | Op Code<br>Irrelevant Data<br>Low Byte of Restart Vector | | ASLD<br>LSRD | 3 | 1<br>2<br>3 | Op Code Address<br>Op Code Address + 1<br>Address Bus FFFF | 1 1 1 | Op Code<br>Irrelevant Data<br>Low Byte of Restart Vector | | DES<br>INS | 3 | 1<br>2<br>3 | Op Code Address<br>Op Code Address + 1<br>Previous Register Contents | 1 1 1 | Op Code<br>Op Code of Next Instruction<br>Irrelevant Data | | INX<br>DEX | 3 | 1<br>2<br>3 | Op Code Address Op Code Address + 1 Address Bus FFFF | 1 1 1 | Op Code Op Code of Next Instruction Low Byte of Restart Vector | | PSHA<br>PSHB | 3 | 1<br>2<br>3 | Op Code Address Op Code Address + 1 Stack Pointer | 1<br>1<br>0 | Op Code Op Code of Next Instruction Accumulator Data | | TSX | 3 | 1<br>2<br>3 | Op Code Address Op Code Address + 1 Stack Pointer | 1<br>1<br>1 | Op Code Op Code of Next Instruction Irrelevant Data | | TXS | 3 | 1<br>2<br>3 | Op Code Address<br>Op Code Address + 1<br>Address Bus FFFF | 1 1 1 | Op Code Op Code of Next Instruction Low Byte of Restart Vector | | PULA<br>PULB | 4 | 1<br>2<br>3<br>4 | Op Code Address Op Code Address + 1 Stack Pointer Stack Pointer + 1 | 1<br>1<br>1 | Op Code Op Code of Next Instruction Irrelevant Data Operand Data from Stack | | PSHX | 4 | 1<br>2<br>3<br>4 | Op Code Address Op Code Address + 1 Stack Pointer Stack Pointer - 1 | 1<br>1<br>0 | Op Code<br>Irrelevant Data<br>Index Register (Low Order Byte)<br>Index Register (High Order Byte) | | PULX | 5 | 1<br>2<br>3<br>4<br>5 | Op Code Address Op Code Address + 1 Stack Pointer Stack Pointer + 1 Stack Pointer + 2 | 1<br>1<br>1<br>1 | Op Code<br>Irrelevant Data<br>Irrelevant Data<br>Index Register (High Order Byte)<br>Index Register (Low Order Byte) | | RTS | 5 | 1<br>2<br>3<br>4 | Op Code Address Op Code Address + 1 Stack Pointer Stack Pointer + 1 Stack Pointer + 2 | 1 1 1 1 | Op Code Irrelevant Data Irrelevant Data Address of Next Instruction (High Order Byte) Address of Next Instruction (Low Order Byte) | | WAI** | 9 | 1<br>2<br>3<br>4 | Op Code Address<br>Op Code Address + 1<br>Stack Pointer<br>Stack Pointer - 1 | 1<br>1<br>0<br>0 | Op Code<br>Op Code of Next Instruction<br>Return Address (Low Order Byte)<br>Return Address (High Order Byte) | (1) HITACHI 890 Table 12 Cycle by Cycle Operation (Continued) | Address Mode & Instructions | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |-----------------------------|--------|------------|---------------------------|-------------|----------------------------------| | | + | 5 | Stack Pointer – 2 | 0 | Index Register (Low Order Byte) | | WAI** | | 6 | Stack Pointer - 3 | 0 | Index Register (High Order Byte) | | | | 7 | Stack Pointer - 4 | 0 | Contents of Accumulator A | | | | В | Stack Pointer - 5 | 0 | Contents of Accumulator B | | | | 9 | Stack Pointer - 6 | 0 | Contents of Cond. Code Register | | MUL | 10 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Irrelevant Data | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 6 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 7 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | } | 8 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | ļ | 9 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 10 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | 10 | 1 | Op Code Address | 1 | Op Code | | RTI | " | 2 | Op Code Address + 1 | 1 | Irrelevant Data | | | | 3 | Stack Pointer | 1 | Irrelevant Data | | | 1 | 4 | Stack Pointer + 1 | 1 | Contents of Cond. Code Reg. | | | | 1 4 | Stack Content | | from Stack | | | | 5 | Stack Pointer + 2 | 1 | Contents of Accumulator B | | | | ) 5 | Stack Folitter - 2 | | from Stack | | | i | 6 | Stack Pointer + 3 | 1 | Contents of Accumulator A | | | | ٥ | Stack Folinter 13 | | from Stack | | | | ١ ـ | Stack Pointer + 4 | 1 | Index Register from Stack | | | ŀ | 7 | Stack Folliter 14 | | (High Order Byte) | | | - | | Stack Pointer + 5 | 1 | Index Register from Stack | | | | 8 | Stack Polities + 5 | | (Low Order Byte) | | | | | Stack Pointer + 6 | 1 | Next Instruction Address from | | | İ | 9 | Stack Pointer + 6 | | Stack (High Order Byte) | | | 1 | 1 | 1 | 1 | Next Instruction Address from | | | | 10 | Stack Pointer + 7 | | Stack (Low Order Byte) | | 014/1 | 12 | | Op Code Address | 1 | Op Code | | SWI | '2 | 2 | Op Code Address + 1 | 1 | Irrelevant Data | | | | 3 | Stack Pointer | 0 | Return Address (Low Order Byte | | | | 4 | Stack Pointer - 1 | 0 | Return Address (High Order Byte | | | ļ | | Stack Pointer - 2 | 0 | Index-Register (Low Order Byte) | | | İ | 5 | | ő | Index Register (High Order Byte) | | | 1 | 6 | Stack Pointer - 3 | 0 | Contents of Accumulator A | | | i | 7 | Stack Pointer 4 | 0 | Contents of Accumulator B | | | | 8 | Stack Pointer - 5 | 0 | Contents of Cond. Code Register | | | | 9 | Stack Pointer - 6 | 1 | Irrelevant Data | | | | 10 | Stack Pointer — 7 | | Address of Subroutine | | | | 11 | Vector Address FFFA (Hex) | 1 | (High Order Byte) | | | | 1 | | 1 . | Address of Subroutine | | | | 12 | Vector Address FFFB (Hex) | 1 | | | | i | 1 | _ | l | (Low Order Byte) | <sup>\*\*</sup>While the MCU is in the "Wait" state, its bus state will appear as a series of MCU reads of an address which is seven locations less than the original contents of the Stack Pointer. Contrary to the HD6800, none of the ports are driven to the high impedance state by a WAI instruction. Table 12 Cycle by Cycle Operation (Continued) | Address Mode &<br>Instruction | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |-------------------------------|--------|------------|-----------------------------|-------------|----------------------------------| | RELATIVE | | | | | | | BCC BHT BNE | 3 | 1 | Op Code Address | 1 | Op Code | | BCS BLE BPL | | 2 | Op Code Address + 1 | 1 | Branch Offset | | BEQ BLS BRA | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | BGE BLT BVC | İ | ! | | | , | | BGT BMT BVS | | | | | | | BRN | | | | | | | BSR | 6 | 1 | Op Code Address | 1 | Op Code | | | } | 2 | Op Code Address + 1 | 1 | Branch Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Subroutine Starting Address | 1 | Op Code of Next Instruction | | | | 5 | Stack Pointer | 0 | Return Address (Low Order Byte) | | | | 6 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) | ## Summary of Undefined Instruction Operations The HD6801V has 36 undefined instructions. When these are carried out, the contents of Register and Memory in MCU change at random. When the op codes (4E, 5E) are used to execute, the MCU continues to increase the program counter and it will not stop until the Reset signal enters. These op codes are used to test the LSI. Table 13 Op codes Map | | | | | HD6 | 801V MI | CROC | ОМРО | TER | INST | RUCT | IONS | | | | | | | | |--------|------|-----------|------|------|-----------|---------------|---------|------|------|-------------|---------------|------|------|-----------|--------------|--------|------|--------| | | OP | | | | | 0.00 | ACC ACC | _ | | ACCA or SP | | | | ACCB or X | | | | ┨ | | | ODE | | | | | | | IND | EXT | IMM | DIR | IND | EXT | IMM | DIR | IND | EXT | 1 | | | н | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | 1 | | LO | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | 1 | | 0000 | 0 | | SBA | BRA | TSX | NEG | | | | SUB | | | | | | | | 1 | | 0001 | 1 | NOP | CBA | BRN | INS | | | | | | | | CI | MP | | | | $\top$ | | 0010 | 2 | | | вні | PULA (+1) | | | | | SBC | | | | | | | | T | | 0011 | 3 | | | BLS | PULB (+1) | | CC | M | | • SUBD (+2) | | | | • | ADDD (+2) | | | 3 | | 0100 | 4 | LSRD (+1) | | BCC | DES | | AND | | | | | | | | 4 | | | | | 0101 | 5 | ASLD (+1) | | BCS | TXS | | | | | BIT | | | | | | | | 5 | | 0110 | 6 | TAP | TAB | BNE | PSHA | | RC | R | | LDA | | | | | | | 6 | | | 0111 | 7 | TPA | TBA | BEQ | PSHB | | AS | R | | | STA | | | | STA | | | 7 | | 1000 | 8 | INX (+1) | | BVC | PULX (+2) | | AS | iL . | | EOR | | | | | | | | 8 | | 1001 | 9 | DEX (+1) | DAA | BVS | RTS (+2) | | RC | )L | | ADC | | | | | | | | 9 | | 1010 | Α | CLV | | BPL | ABX | | DE | С | | | | | 01 | RA. | | | | A | | 1011 | В | SEV | ABA | BMI | RTI (+7) | | | | | | | | A | OD | | | | В | | 1100 | С | CLC | | BGE | PSHX (+1) | | ŧN | С | | • | CP) | (+2) | | ٠ | LDI | ) (+1) | | С | | 1101 | D | SEC | | BLT | MUL (+7) | TST | | | | BSR<br>(+4) | | | | * (+1) | 5 | TD (+1 | ) | D | | 1110 | E | CLI | | BGT | WAI (+6) | _ ** JMP (-3) | | | | • LDS (+1) | | | | • | • LDX (+1) | | | Е | | 1111 | F | SEI | | BLE | SWI (+9) | | CL | R | | · (+1) | (+1) STS (+1) | | | * (+1) | +1) STX (+1) | | ) | F | | BYTE/C | YCLE | 1/2 | 1/2 | 2/3 | 1/3 | 1/2 | 1/2 | 2/6 | 3/6 | 2/2 | 2/3 | 2/4 | 3/4 | 2/2 | 2/3 | 2/4 | 3/4 | | [NOTES] 1 - 1) Undefined Op codes are marked with . - indicate that the number in parenthesis must be added to the cycle count for that instruction. - 3) The instructions shown below are all 3 bytes and are marked with "\*". Immediate addressing mode of SUBD, CPX, LDS, ADDD, LDD and LDX instructions, and undefined op codes (RF CD CF). - 4) The Op codes (4E, 5E) are 1 byte/∞ cycles instructions, and are marked with "\*\*" (C) HITACHI 892 **(1)** HITACHI Figure 25 HD6801V MCU Single-Chip Dual Processor Configuration Figure 26 HD6801V MCU Expanded Non-Multiplexed Mode Figure 27 HD6801V MCU Expanded Multiplexed Mode ## ■ PRECAUTIONS 894 ## • PRECAUTION CONCERNING COUNTER TIMER (1) Timer Output (P21) After CPU reset, $P_{21}$ is uncertain until the value of the free running counter equals the value of the output compare register or until the free running counter completes a software time-out cycle. (2) Initialization of ICF ICF should be cleared by software after initiating a reset, otherwise ICF may be set if P<sub>21</sub> is "low" after initiating a ## PRECAUTION CONCERNING WRITE-ONLY REGISTER The write-only register cannot be changed like DDR for I/O ports using Read/Modify/Write instructions. (1) The CPU cannot read the write-only register. Procede with Read/Modify/Write instructions as follows: - (i) read the data of specified address; - (ii) modify the data; and - (iii) write the modified data to original address. The Read/Modify/Write instructions cannot be used with the write-only register like DDR. (2) Store instructions can be used for writing to the write-only register. \*Read/Modify/Write instructions-NEG, COM, LSR, ROR, ASR, ASL, ROL, DEC, INC, TST CLR ## **@HITACHI** # ■ PRECAUTION CONCERNING HD6801 SERIES SCI, TIMER STATUS FLAG ## Caution for the HD6801 Family SCI, TIMER Status Flag The flags shown in Table 14 are cleared by reading/writing (flag reset condition 2) the data register corresponding to each flag after reading the status register (flag reset condition 1). To clear the flag correctly, use the following procedure: - 1. Read the status register - 2. Test the flag - 3. Read the data register The SCI, Timer status flag is cleared by reading a "1" for each status flag and then reading the data register. SCI software routines should read the received data after confirming a "1" as the received status flag. Avoid reading dummy data after a "0" for the received status flag. Table 14 Status Flag Reset Conditions | | Status<br>Flag | Flag Reset<br>Condition 1<br>(Status Register) | Flag Reset Condition 2<br>(Data Register) | |-------|----------------|------------------------------------------------|-------------------------------------------| | | ICF | When each flag is | ICR/Read | | TIMER | OCF | "1", | OCR/Read | | | TOF | TRCSR/Read | TC/Read | | | RDRF | When Each flag is | RDR/ | | SCI | ORFE | "1", | Read | | | TDRE | TRCSR/Read | TDR/Write | (b) Bad Example Figure 28 Software polling of SCI-RDRF ## TERMINAL CONDITION DURING RESET, AFTER RESET Table 15 Terminal Condition During Reset, After Reset | C | PU Mode | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |--------------------------------------------------------------|-----------------|---------------|----------|----|------------|------------------|----------|---------------|----------------| | | Port 1 | I<br>Z | ← | - | <b>-</b> | <b>+</b> | - | - | <b>←</b> | | | Port 2 | I<br>Z | +- | - | - | - | <b>←</b> | - | <b>←</b> | | During Reset Port 3 Port 4 SC <sub>1</sub> SC <sub>2</sub> | Port 3 | I<br>Z | + | + | - | + | ←. | <b>←</b> | + | | | -<br>H | + | + | + | - | - | - | ← | | | | SC <sub>1</sub> | I/O<br>H | <b>+</b> | - | <b>←</b> - | H | О<br>Н | 1/O<br>H | H | | | SC <sub>2</sub> | O H | + | +- | - | - | <b>←</b> | - | + | | | Port 1 | l<br>Z | ← | - | + | <b>←</b> | <b>←</b> | + | + | | | Port 2 | Į<br>Z | + | ← | + | - | - | + | <b>←</b> | | After | Port 3 | I/O<br>ABL/DB | <b>←</b> | - | - | Z | I<br>DB | I/O<br>ABL/DB | I<br>Z | | Reset | Port 4 | O<br>ABH | <b>←</b> | + | - | H | - | - | <b>←</b> | | | SC <sub>1</sub> | O<br>AS | - | - | - | i<br>H | IOS | O<br>AS | H | | | SC <sub>2</sub> | O<br>R/W | + | +- | - | <u>0</u><br>0\$3 | O<br>R/W | - | • <del>O</del> | : Input O : Output I/O : Input/Output Upper : Input Condition Lower: Level, Terminal Function H : High Level L : Low Level Z : High Impedance DB : Data Bus ABL : Address Bus Low ABH : Address Bus High AS : Address Strobe R/W : Read/Write IOS : IOS Signal OS3 : OS3 Signal **OHITACHI**