# HD68P05W0 **MCU** (Microcomputer Unit)

The HD68P05W0 is the 8-bit Microcomputer Unit (MCU) which contains a CPU, on-chip clock, RAM, an A/D converter, I/O and two timers. It is designed for the user who needs an economical microcomputer with the proven capabilities of the HD6800-based instruction set. Setting EPROM on the package, this MCU has the same function as the HD6805W1 which has on-chip ROM. It is useful not only for a means of debugging and evaluating the HD6805W1 but also for small-scale-production.

The following EPROMs are available. 4k byte : HN482732A 8k byte : HN482764

- HARDWARE FEATURES
- . 8-Bit Architecture
- 96 Bytes of RAM
- Memory Mapped I/O •
- Internal 8-Bit Timer with 7-Bit Prescaler
- Internal 8-bit Programmable Timer (Timer2) with 7-bit Prescaler
- Vectored interrupts : External, Timer and Software
- 23 I/O Ports + 6 Input Ports (8 Lines Directly Drive LEDs.)
- On-chip 8 bits A/D Converter
- **On-chip Clock Generator**
- Master Reset
- Easy for System Development and Debugging .
- ٠ 5 Vdc Single Supply

#### **SOFTWARE FEATURES**

- . Similar to HD6800 Family
- . Byte Efficient Instruction Set
- Easy to Program
- **Ture Bit Manipulation** ٠
- Bit Test and Branch Instructions
- Versatile Interrupt Function
- Powerful Indexed Addressing for Tables
- Full Set of Conditional Branches
- Memory Usable as Registers/Flags •
- Single Instruction Memory Examine/Change
- 10 Powerful Addressing Modes
- All Addressing Modes Apply to ROM, RAM and I/O
- Compatible Instruction Set with HD6805

#### TYPE OF PRODUCTS

| Type No.  | Bus Timing | EPROM Type No. |
|-----------|------------|----------------|
| HD68P05W0 | 1 MHz      | HN482732A-30   |
| HUGGPUSWU |            | HN482764-3     |

(NOTE) EPROM is not attached to the MCU.

#### PROGRAM DEVELOPMENT SUPPORT TOOLS

- Cross assembler software for use with IBM PCs and compatibles
- In circuit emulator for use with IBM PCs and compatibles



#### PIN ARRANGEMENT



(Top View)

#### CHITACHI 1128 Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

BLOCK DIAGRAM



#### ABSOLUTE MAXIMUM RATINGS

| ltem                         | Symbol            | Value        | Unit |
|------------------------------|-------------------|--------------|------|
| Supply Voltage               | V <sub>cc</sub>   | -0.3 ~ +7.0  | V    |
| Input Voltage (EXCEPT TIMER) | N N               | -0.3 ~ +7.0  | v    |
| Input Voltage (TIMER)        | - V <sub>in</sub> | -0.3 ~ +15.0 | V    |
| Operating Temperature        | T <sub>opr</sub>  | 0 ~ +70      | °C   |
| Storage Temperature          | T <sub>stg</sub>  | -55 ~ +150   | °C   |

(NOTE) This device has an input protection circuit for high quiascent voltage and field, however, be careful not to impress a high input voltage than the insulation maximum value to the high input impedance circuit. To insure normal operation, the following are recommended for  $V_{in}$  and  $V_{out}$ :  $V_{SS} \leq (V_{in} \text{ or } V_{out}) \leq V_{CC}$ 

## ELECTRICAL CHARACTERISTICS

DC CHARACTERISTICS (V<sub>CC</sub> = 5.25V ±0.5V, V<sub>SS</sub> = GND, Ta = 0 ~+70°C, unless otherwise noted.)

| ltem                 | Symbol                                  | Test Condition   | min                                   | typ   | max | Unit            |    |
|----------------------|-----------------------------------------|------------------|---------------------------------------|-------|-----|-----------------|----|
|                      | RES                                     |                  |                                       | 4.0   | -   | V <sub>cc</sub> | V  |
| Input "High" Voltage | $\overline{INT_1}$ , $\overline{INT_2}$ | ]                |                                       | 3.0   | _   | V <sub>cc</sub> | V  |
| mput mga vondge      | All Others                              | ViH              |                                       | 2.0   | -   | V <sub>cc</sub> | v  |
|                      | Timer                                   | 1                |                                       | 2.0   | -   | V <sub>cc</sub> | V  |
| Input "Low" Voltage  | RES                                     |                  |                                       | -0.3  | -   | 0.8             | v  |
|                      | $\overline{INT}_1, \overline{INT}_2$    | V <sub>IL</sub>  |                                       | -0.3  | _   | 0.8             | v  |
|                      | EXTAL                                   |                  |                                       | -0.3  | —   | 0.6             | V  |
|                      | All Others                              |                  |                                       | -0.3  | -   | 0.8             | V  |
| Power Dissipation    |                                         | PD               |                                       | -     | -   | 750             | mW |
| Low Voltage Recover  |                                         | LVR              |                                       | -     | -   | 4.75            | v  |
|                      | TIMER                                   |                  |                                       | -20   | -   | 20              | μA |
| Input Leak Current   | $\overline{INT_1}$ , $\overline{INT_2}$ | 1 <sub>1L</sub>  | V <sub>in</sub> =0.4V∼V <sub>CC</sub> | -50   | -   | 50              | μA |
|                      | EXTAL                                   | ]                |                                       | -1200 | -   | 0               | μA |
| Standby Voltage      | Nonoperation Mode                       | V <sub>SBB</sub> |                                       | 4.0   | 1   | V <sub>cc</sub> | v  |
|                      | Operation Mode                          | V <sub>SB</sub>  |                                       | 4.75  | _   | V <sub>cc</sub> | v  |
| Standby Current      | Nonoperation Mode                       | I <sub>SBB</sub> | V <sub>SBB</sub> =4.0V                |       | _   | 3               | mA |

#### • AC CHARACTERISTICS (V<sub>CC</sub> = 5.25V ±0.5V, V<sub>SS</sub> = GND, Ta = 0 ~ +70°C, unless otherwise noted.)

| Item                                     |                           | Symbol            | Test Condition                                       | min                       | typ | max | Unit |
|------------------------------------------|---------------------------|-------------------|------------------------------------------------------|---------------------------|-----|-----|------|
| Clock Frequency                          |                           | f <sub>cl</sub>   |                                                      | 0.4                       | -   | 4.0 | MHz  |
| Cycle Time                               |                           | t <sub>cyc</sub>  |                                                      | 1.0                       |     | 10  | μs   |
| INT Pulse Width                          |                           | tiwL              |                                                      | t <sub>cγc</sub> +<br>250 | -   | -   | ns   |
| RES Pulse Width                          |                           | tRWL              |                                                      | t <sub>cyc</sub> +<br>250 | -   | -   | ns   |
| TIMER Pulse Width                        |                           | t <sub>TWL</sub>  |                                                      | t <sub>cyc</sub> +<br>250 | -   | -   | ns   |
| Oscillation Start-up Time (Crystal Mode) |                           | tosc              | C <sub>L</sub> =22pF±20%<br>R <sub>S</sub> ≃60Ω max. | -                         | -   | 100 | ms   |
| Delay Time Reset                         |                           | t <sub>RHL</sub>  | External Cap. = 2.2 µF                               | 100                       | -   | -   | ms   |
| Input Capacitance                        | XTAL, V <sub>RH</sub> /Ds | - C <sub>in</sub> | ۱/                                                   | _                         | -   | 35  | pF   |
|                                          | All Others                |                   | V <sub>in</sub> =0V                                  | _                         | -   | 10  | pF   |

O HITACHI
 Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

| RT ELECTRICAL CHAP      |                   | Symbol          | Test Condition               | min  | typ | max             | Unit     |
|-------------------------|-------------------|-----------------|------------------------------|------|-----|-----------------|----------|
| Item                    | <u>,</u> +        | Symbol          | I <sub>OH</sub> = -10 μA     | 3.5  | _   | -               | V        |
|                         | Port A            |                 | $I_{OH} = -100 \mu A$        | 2.4  |     | -               | V        |
|                         |                   | VoH             | $I_{OH} = -200 \mu\text{A}$  | 2.4  | _   | -               | <u>v</u> |
| Output ''High'' Voltage | Port B            | ∙он             | I <sub>OH</sub> = -1 mA      | 1.5  |     |                 | <u>v</u> |
|                         | Port C            |                 | $I_{OH} = -100 \mu A$        | 2.4  | _   |                 | V        |
|                         | Ports A and C     | Vol             | I <sub>OL</sub> = 1.6 mA     | -    |     | 0.5             | V        |
|                         | Port B            |                 | $l_{OL} = 3.2 \text{ mA}$    | _    |     | 0.5             | V        |
| Output "Low" Voltage    |                   |                 | l <sub>oL</sub> = 10 mA      | _    | _   | 1.0             | V        |
|                         |                   | V <sub>IH</sub> |                              | 2.0  | -   | V <sub>cc</sub> | V        |
| Input "High" Voltage    | Ports A, B, C     |                 | +                            | -0.3 | _   | 0.8             | V        |
| Input "Low" Voltage     | and D*            | V <sub>IL</sub> | $V_{in} = 0.8V$              | -500 | +   | +<br>           | μΑ       |
| Input Leak Current      | Port A            |                 | $V_{in} = 2V$                | -300 |     |                 | μA       |
|                         |                   | <b>I</b> IL     | $V_{in} = 0.4V \sim V_{CC}$  | -20  |     | 20              | μA       |
|                         | Ports B, C and D* |                 | V <sub>in</sub> = 0.4V = VCC | 20   |     |                 |          |

#### = 5.25V $\pm 0.5$ V, V<sub>SS</sub> = GND, Ta = 0 $\sim$ +70 $\degree$ C, unless otherwise noted.) í\ r

\* Port D as digital input

# • A/D CONVERTER ELECTRICAL CHARACTERISTICS ( $V_{CC} = 5.25V \pm 0.5V$ , $V_{SS} = AV_{SS} = GMD$ , Ta = 0 ~ +70°C, unless otherwise noted.)

|                          | Symbol           | Test Condition               | min  | typ  | max      | Unit     |
|--------------------------|------------------|------------------------------|------|------|----------|----------|
| Item                     | <u> </u>         |                              |      | 5.25 | 5,75     | v        |
| Analog Power Supply      | AVcc             |                              | 4.75 | 5.25 | 5.75     |          |
| Voltage                  |                  |                              | 0    |      | VRH      | V        |
| Analog Input Voltage     | AV <sub>in</sub> |                              | 4.0  |      | Vcc      | v        |
| Reference "High" Voltage | N.               | $4.75V \le V_{CC} \le 5.25V$ |      |      |          | v        |
|                          | VRH              | $5.25V < V_{CC} \le 5.75V$   | 4.0  |      | 5.25     | <b>↓</b> |
| Analog Multiplexer Input |                  |                              | -    | -    | 7.5      | pF       |
| Capacitance              |                  |                              |      |      |          | Bit      |
| Resolution Power         |                  |                              |      | 8    |          |          |
|                          |                  |                              | 76   | 76   | 76       | teve     |
| Conversion Time          |                  |                              | 4    | 4    | 4        | Channel  |
| Input Channels           |                  |                              |      | +    | <u> </u> | +        |
| Absolute Accuracy        |                  | Ta = 25°C                    | -    | -    | ±1.5     | LSB      |



Figure 1 Bus Timing Test Loads

#### HITACHI Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 1131

#### SIGNAL DESCRIPTION

The input and output signals for the MCU, shown in PIN ARRANGEMENT, are described in the following paragraphs.

#### V<sub>CC</sub> and V<sub>SS</sub>

Voltage is supplied to the MCU using these two pins.  $V_{CC}$  is 5.25V ±0.5V.  $V_{SS}$  is the ground connection.

#### • $\overline{INT_1}/\overline{INT_2}$

This pin provides the capability for asynchronously applying an external interrupt to the MCU. Refer to INTERRUPTS for additional information.

#### • XTAL and EXTAL

These pins provide connections for the on-chip clock circuit. A crystal (AT cut, 4MHz maximum) or an external signal can be connected to these pins to provide the internal oscillator with varying degrees of stability. Refer to INTERNAL OSCILLA-TOR for recommendations about these inputs.

#### TIMER

This pin allows an external input to be used to count for the internal timer circuitry. Refer to TIMER 1 and TIMER 2 for additional information about the timer circuitry.

#### RES

This pin allows resetting of the MCU. Refer to RESETS for additional information.

#### NUM

This pin is not for user application and should be connected to  $V_{SS}$ .

#### • I/O Lines (A $_0 \simeq A_7$ , B $_0 \simeq B_7$ , C $_0 \simeq C_6$ )

These 23 lines are arranged into three ports (A, B and C). All lines are programmable as either inputs or outputs under software control of the Data Direction Registers. Refer to INPUT / OUTPUT for additional information.

#### • Input Lines ( $D_0 \sim D_5$ )

These are TTL compatible input lines, in location 0003. These also allow analog inputs to be used for an A/D converter. Refer to INPUT for additional information.

#### V<sub>CC</sub> Standby

 $V_{CC}$  Standby provides power to the standby portion of the RAM and the STBY PWR and RAME bits of the RAM Control Register. Voltage requirements depend on whether the MCU is in a powerup or powerdown state. In the powerup state, the power supply should provide  $V_{CC}$  and must reach  $V_{SB}$  before RES reaches 4.0V. During powerdown,  $V_{CC}$  Standby must remain above  $V_{SBB}$  (min) to sustain the standby RAM and STBY PWR bit. While in powerdown operation, the standby current will not exceed  $I_{SBB}$ .

It is typical to power both  $V_{CC}$  and  $V_{CC}$  Standby from the same source during nomal operation. A diode must be used between them to prevent supplying power to  $V_{CC}$  during power-down operation shown Figure 2.

To sustain the standby RAM during powerdown, the following software or hardware are needed.

(1) Software

When clearing the RAM Enable bit (RAME) which is bit 6 of the RAM Control Register at location \$001F, the RAM is disabled.

 $V_{CC}$  Standby must remain above  $V_{SBB}$  (min). (2) Hardware

When RAME pin is "Low" before powerdown, the RAM is disabled.  $V_{CC}$  Standby must remain above  $V_{SBB}$  (min).



Figure 2 Battery Backup for V<sub>CC</sub> Standby

#### RAME

This pin is used for the external control of the RAM. When it is "Low" before powerdown, the RAM is disabled. If  $V_{CC}$  Standby remains above  $V_{SBB}$  (min), the standby RAM is sustained.

#### • AV<sub>CC</sub>

This pin is used for the power supply of the A/D converter. When high accuracy is required, a different power source from  $V_{CC}$  should be impressed.

Connect to  $V_{CC}$  for all other cases.  $AV_{SS}$  corresponds to  $AV_{CC}$  as a GND terminal.

#### AN<sub>0</sub> ~ AN<sub>3</sub>

These pins allow analog inputs to be used for an A/D converter. These inputs are switched by the internal multiplexer and selected by bit 0 and 1 of the A/D Control Status Register (ADCSR: \$000E).

#### V<sub>BH</sub> and AV<sub>SS</sub>

The input terminal reference voltage for the A/D converter is "High" ( $V_{RH}$ ) or "Low" (AV<sub>SS</sub>). AV<sub>SS</sub> is fixed at 0V.

#### Input Capture (IC)

This pin is used for input of Timer 2 control. in this case, Port  $C_s$  should be configured as input. Refer to TIMER 2 for more details.

#### • Output Compare (OC)

This pin is used for output of Timer 2 when the Output Compare Register is matched with the Timer Data Register 2. In this case, Port C<sub>6</sub> should be configured as an output. Refer to TIMER 2 for more details.

#### REGISTERS

The CPU has five registers available to the programmer, as shown in Figure 3 and explained below.



Figure 3 Programming Model

#### Accumulator (A)

The accumulator is a general purpose 8-bit register used to hold operands and results of arithmetic calculations or data manipulations.

#### Index Register (X)

The index register is an 8-bit register used for the indexed addressing mode and contains an 8-bit address that may be added to an offset value to create an effective address. The index register can also be used for limited calculations or data manipulations when using read/modify/write instructions. When not required by a code sequence being executed, the index register can be used as a temporary storage area.

#### Program Counter (PC)

The program counter is a 13-bit register that contains the address of the next instruction to be executed.

#### Stack Pointer (SP)

The stack pointer is a 13-bit register that contains the address of the next free location on the stack. Initially, the stack pointer is set to location \$007F and is decremented as data is being pushed onto the stack and incremented while data is being pulled from the stack. The seven most significant bits of the stack pointer are permanently set to 0000001. During an MCU reset or reset stack pointer (RSP) instruction, the stack pointer is set to location \$007F. Subroutines and interrupts may be nested down to location \$0041 which allows the programmer to use up to 31 levels of subroutine calls.

#### Condition Code Register (CC)

The condition code register is a 5-bit register in which each bit is used to indicate or flag the results of the instruction just executed. These bits can be individually tested by a program and specific action taken as a result of their state. Each individual condition code register bit is explained below.

#### Half Carry (H)

The half carry bit is used during arithmetic operations (ADD or ADC) to indicate that a carry occurred between bits 3 and 4.

#### Interrupt (I)

This bit is set to mask everything. If an interrupt occurs while this bit is set, it is latched and will be processed as soon as the interrupt bit is reset.

#### Negative (N)

The negative bit is used to indicate that the result of the last arithmetic, logical or data manipulation was negative (bit 7 in a result equal to a logical one).

#### Zero (Z)

Zero is used to indicate that the result of the last arithmetic, logical or data manipulation was zero.

#### Carry/Borrow (C)

Carry/borrow is used to indicate that a carry or borrow out of the arithmetic logic unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions, shifts and rotates.

#### TIMER 1

The MCU timer circuitry is shown in Figure 4. The 8-bit counter, Timer Data Register 1 (TDR1), is loaded under program control and counts down toward zero as soon as the clock input is applied. When the TDR1 reaches zero, the timer interrupt request bit (bit 7) in the Timer Control Register 1 (TCR1) is set. The MCU responds to this interrupt by saving the present CPU state in the stack, fetching the timer 1 interrupt vector from locations \$0FF8 and \$0FF9 and executing the interrupt routine. The timer 1 interrupt can be masked by setting the timer interrupt mask bit (bit 6) in the TCR 1. The interrupt bit (I bit) in the Condition Code Register also prevents a timer 1 interrupt from being processed.

The clock input to the timer 1 can be from an external source applied to the TIMER input pin or it can be the internal  $\phi_2$  signal. When  $\phi_2$  is used as the source, it can be gated by an input applied to the TIMER input pin allowing the user to easily perform pulse-width measurements. The timer 1 continues to count past zero, falling through to \$FF from zero and then continuing the count. Thus, the counter (TDR1) can be read at any time by reading the TDR1. This allows a program to determine the length of time since a timer interrupt has occurred and not disturb the counting process.

At power-up or reset, the prescaler and counter are initialized with all logical ones; the timer 1 interrupt request bit (bit 7) is cleared and the timer 1 interrupt mask bit (bit 6) is set. In order to release the timer 1 interrupt, bit 7 of the TCR 1 must be cleared by software.



Figure 4 Timer Clock

#### • Timer Control Register 1 (TCR1: \$0009)

The Timer Control Register 1 (TCR1: \$0009) can control selection of clock input source and prescaler dividing ratio and timer interrupt.

#### Timer Control Register 1 (TCR1: \$0009)



As shown in Table 1, the selection of the clock input source is ISO and IS1 in the TCR1 (bit 4 and bit 5) and 3 kinds of input are selectable. At reset, internal clock  $\phi_2$  controlled by the TIMER input (bit 4 = 1, bit 5 = 0) is selected.

The prescaler dividing ratio is selected by MS0, MS1, and MS2 in the TCR1 (bit 0, bit 1, bit 2) as shown in Table 2. The dividing ratio is selectable from eight ways ( $\div$ 1,  $\div$ 2,  $\div$ 4,  $\div$ 8,  $\div$ 16,  $\div$ 32,  $\div$ 64,  $\div$ 128). At reset,  $\div$ 1 mode is selected. The prescaler is initialized by writing in the TDR1.

Timer 1 interrupt mask bit (TIM) allows the Timer 1 into interrupt at "0" and masks at "1". Timer 1 interrupt causes Timer 1 interrupt request bit (TIF) to be set. TIF must be cleared by software.

(NOTE) If the MCU Timer1 and Timer2 are not used, the TIMER input pin must be grounded.

Table 1 Selection of Clock Input Source

| TCR1  |       |                                          |  |
|-------|-------|------------------------------------------|--|
| Bit 5 | Bit 4 | Clock Input Source                       |  |
| 0     | 0     | Internal Clock ¢2 *                      |  |
| 0     | 1     | φ <sub>2</sub> Controlled by TIMER Input |  |
| 1     | 0     |                                          |  |
| 1     | 1     | Event Input From TIMER                   |  |

\* The TIMER input pin must be tied to  $V_{CC},$  for uncontrolled  $\phi_2$  clock input,

Table 2 Selection of Prescaler Dividing Ratio

| TCR1  |       |       | Brandlar Dividian Patia  |
|-------|-------|-------|--------------------------|
| Bit 2 | Bit 1 | Bit O | Prescaler Dividing Ratio |
| 0     | 0     | 0     | ÷ 1                      |
| 0     | 0     | 1     | ÷ 2                      |
| 0     | 1     | Q     | ÷ 4                      |
| 0     | 1     | 1     | ÷ 8                      |
| 1     | 0     | 0     | ÷ 16                     |
| 1     | 0     | 1     | ÷ 32                     |
| 1     | 1     | 0     | ÷ 64                     |
| 1     | 1     | 1     | ÷ 128                    |

#### TIMER 2

The HD68P05W0 includes an 8-bit programmable timer (Timer 2) which can not only measure the input waveform but also generate the output waveform. The pulse width for both input and output waveform can be varied from several microseconds to several seconds.

(NOTE) If the MCU Timer1 and Timer2 are not used, the

Timer 2 hardware consists of the followings.

- 8-bit Control Register 2
- 8-bit Status Register 2
- 8-bit Timer Data Register 2
- 8-bit Output Compare Register
- 8-bit Input Capture Register •
- 5-bit Prescaler Control Register
- 7-bit Prescaler 2
- TIMER input pin must be grounded.

Block Diagram of Timer 2 is shown in Fig. 5.



Figure 5 Block Diagram of Timer 2

#### Timer Data Register 2 (TDR2; \$001C) .

The main part of the Timer 2 is the 8-bit Timer Data Register 2 (TDR2) as free-running counter, which is driven by internal clock  $\phi_2$  or the TIMER input and increments the value. The values in the counter is always readable by software.

The Timer Data Register 2 is Read/Write register and is cleared at reset.

#### Output Compare Register (OCR; \$001D)

The Output Compare Register (OCR) is an 8-bit read/write register used to control an output waveform. The contents of this register are always compared with those of the TDR2. When these two contents conform to each other, the flag (OCF) in the Timer Status Register 2 (TSR2) is set and the value of the output level bit (OLVL) in the TCR2 is transferred to Port C<sub>6</sub> (OC).

If Port C<sub>6</sub>'s Data Direction Register (DDR) is "1" (output), this value will appear at Port  $C_6$  (OC). Then the values of OCF and OLVL can be changed for the next compare. The OCR is set to \$FF at reset.

#### Input Capture Register (ICR; \$001E) •

The Input Capture Register (ICR) is an 8-bit read-only register used to store the value of the TDR2 when Port C5 (IC) input transition occurs as defined by the input edge bit (IEDG) of the TCR2.

In order to apply Port C<sub>5</sub> (IC) input to the edge detect circuit, the DDR of Port C5 should be cleared ("0").\*

To ensure an input capture under all condition, Port  $C_5$  (IC) input pulse width should be 2 Enable-cycles at least.

\*The edge detect circuit always senses Port C<sub>5</sub> (IC) even if the DDR is set with Port C<sub>5</sub> output.

#### • Timer Control Register 2 (TCR2; \$001B)

The Timer Control Register 2 (TCR2) consists of an 5-bit register of which all bits can be read and written.

Timer Control Register 2 (TCR2: \$001B)

| 7 | 6 | 5 | 4  | 3    | 2    | 1    | 0    |
|---|---|---|----|------|------|------|------|
|   |   |   | ЮМ | осім | тоім | IEDG | OLVL |

#### **Bit 0 OLVL Output Level**

This bit will appear at Port  $C_6$  when the value in the TDR2 equals the value in the OCR, if the DDR of Port  $C_6$  is set. It is cleared by reset.

#### Bit 1 IEDG Input Edge

This bit determines which level transition of Port C<sub>5</sub> (IC) input will trigger a data store to ICR from the TDR2. When this function is used, it is necessary to clear DDR of Port C<sub>5</sub>. When IEDG = 0, the negative edge triggers ("High" to "Low" transition). When IEDG = 1, the positive edge triggers ("Low" to "High" transition). It is cleared by reset.

#### Bit 2 TOIM Timer Overflow Interrupt Mask

When this bit is cleared, internal interrupt (TOI) is enabled by TOF interrupt but when set, interrupt is inhibited.

#### Bit 3 OCIM Output Compare Interrupt Mask

When this bit is cleared, internal interrupt (OCI) by OCF interrupt occurs. When set, interrupt is inhibited.

#### Bit 4 ICIM Input Capture Interrupt Mask

When this bit is cleared, internal interrupt (ICI) by ICF interrupt occurs. When set, interrupt is inhibited.

#### • Timer Status Register 2 (TSR2: \$001A)

The Timer Status Register 2 (TSR2) is an 8-bit read-only register which indicates that:

- (1) A proper leveltransition has been detected on the input pin with a subsequent transfer of the TDR2 value to the ICR (ICF).
- (2) A match has been found between the TDR2 and the OCR (OCF).

#### (3) The TDR2 is zero (TOF).

Each of the event can generate 3 kinds of internal interrupt request and is controlled by an individual inhibit bits in the TCR2. If the I bit in the Condition Code Register is cleared, priority vectors are generated in response to clearing each interrupt mask bit. Each bit is described below.



#### Bit 5 TOF Timer Overflow Flag

This read-only bit is set when the TDR2 contains \$00. It is cleared by reading the TSR2 followed by reading of the TDR2.

#### Bit 6 OCF Output Compare Flag

This read-only bit is set when a match is found between the OCR and the TDR2. It is cleared by reading the TSR2 and then writing to the OCR.

#### Bit 7 ICF Input Capture Flag

This read-only bit is set to indicate a proper level transition and cleared by reading the TSR2 and then reading the TCR2.

User can write into port  $C_6$  by software.

Accordingly, after port  $C_6$  has output by hardware and is immediately write into by software, simultaneous cyclic pulse control with a short width is easy.

#### Prescaler Control Register 2 (PCR2: \$0019)

The selections of clock input source and prescaler dividing ratio are performed by the Prescaler Control Register 2 (PCR2: \$0019).

#### Prescaler Control Register 2 (PCR2: \$0019)



The selection of clock input source is performed in three different ways by bit 4 and bit 5 of the PCR2, as shown in Table 3. At reset, internal clock  $\phi_2$  controlled by the TIMER input (bit 4 = 1, bit 5 = 0) is selected.

The prescaler dividing ratio is selected by three bits in the PCR2 (bits 0, 1, 2), as shown in Table 4. The dividing ratio can be selected in 8 ways ( $\div$ 1,  $\div$ 2,  $\div$ 4,  $\div$ 8,  $\div$ 16,  $\div$ 32,  $\div$ 64,  $\div$ 128). At reset,  $\div$ 1 (bit 0 = bit 1 = bit 2 = 0) is selected.

When writing into the PCR2, or when writing into the TDR2, prescaler is initialized to \$FF.

Table 3 Selection of Clock Input Source

|                                          | PCR2  |       |
|------------------------------------------|-------|-------|
| Clock Input Source                       | Bit 4 | Bit 5 |
| Internal Clock $\phi_2$ *                | 0     | 0     |
| φ <sub>2</sub> Controlled by TIMER Input | 1     | 0     |
|                                          | 0     | 1     |
| Event Input from TIMER                   | 1     | 1     |

The TIMER input pin must be tied to V<sub>CC</sub>, for uncontrolled \$\phi\_2\$ clock.

## HITACHI Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

Table 4 Selection of Prescaler Dividing Ratio

| PCR2  |       |       | Prescaler Dividing Ratio |  |
|-------|-------|-------|--------------------------|--|
| Bit 2 | Bit 1 | Bit 0 | Prescaler Dividing Natio |  |
| 0     | 0     | 0     | ÷ 1                      |  |
| 0     | 0     | 1     | ÷ 2                      |  |
| 0     | 1     | 0     | ÷ 4                      |  |
| 0     | 1     | 1     | ÷ 8                      |  |
| 1     | 0     | 0     | ÷ 16                     |  |
| 1     | 0     | 1     | ÷ 32                     |  |
| 1     | 1     | 0     | ÷ 64                     |  |
| 1     | 1     | 1     | ÷ 128                    |  |

#### CAUTION

- When executing Branch instructions\* from address \$117 to \$11C, two flags (TOF and ICF) of the Timer Status Register 2 (TSR2) will be occasionally cleared.
  - Cause: These instructions have some dummy read cycles so the TSR2 can be read when executing the instructions.
  - Countermeasure : Don't program branch instructions shown in Table 1 and 3 at address \$117 to \$11C.
- (2) When manipulating or testing the Timer Status Register 2 (TSR2) by Read/Modify/Write instructions\*\*, two flags (TOF and ICF) of the TSR2 will be occasionally cleared.
  - Cause: These instructions have some dummy read cycles so the TSR2 can be read when executing the instructions.
  - Countermeasure: Don't use the instructions shown in Table 1, 2 and 4 for read/write/test operation of the TSR2 flags.

| * | Branch instructions |               |                 |
|---|---------------------|---------------|-----------------|
|   | Bit Test & Branch   | (\$00 - \$0F) | in Table 5-(1)  |
|   | Branch              | (\$20 ~ \$2F) | in Table 5-(4)/ |
|   | (2                  | SAD /         |                 |

\*\* Read/Modify/Write instructions (Bit Test & Branch (SOO ~ SOF) in Table 5-(1) Bit Set/Clear (S1O ~ S1F) in Table 5-(2) Memory Manipulation (S3O ~ S3F) in Table 5-(3)

Table 5 Instruction Inhibited to Operate the TSR2

(1) Bit Test and Branch Instruction

| Mnemonic        | Op Code  | ≓ Bγtes | # Cycles |
|-----------------|----------|---------|----------|
| BRSET n (n=0~7) | 2 · n    | 3       | 10       |
| BRCLRn (n=0~7)  | 01+2 · n | 3       | 10       |

(2) Bit Set/Clear Instruction

| Mnemonic       | Op Code  | # Bytes | # Cycles |
|----------------|----------|---------|----------|
| BSET n (n=0~7) | 10+2 · n | 2       | 7        |
| BCLRn (n=0~7)  | 11+2 · n | 2       | 7        |

(3) Read/Modify/Write Instruction

| Mnemonic | Op Code | # Bytes | # Cycles |
|----------|---------|---------|----------|
| INC      | 3C      | 2       | 6        |
| DEC      | 3A      | 2       | 6        |
| CLR      | 3F      | 2       | 6        |
| COM      | 33      | 2       | 6        |
| NEG      | 30      | 2       | 6        |
| ROL      | 39      | 2       | 6        |
| ROR      | 36      | 2       | 6        |
| LSL      | 38      | 2       | 6        |
| LSR      | 34      | 2       | 6        |
| ASR      | 37      | 2       | 6        |
| ASL      | 38      | 2       | 6        |
| TST      | 3D      | 2       | 6        |

#### (4) Branch Instruction

| Mnemonic | Op Code | # Bγtes | # Cycles |
|----------|---------|---------|----------|
| BRA      | 20      | 2       | 4        |
| BRN      | 21      | 2       | 4        |
| вні      | 22      | 2       | 4        |
| BLS      | 23      | 2       | 4        |
| BCC      | 24      | 2       | 4        |
| (BHS)    | 24      | 2       | 4        |
| BCS      | 25      | 2       | 4        |
| (BLO)    | 25      | 2       | 4        |
| BNE      | 26      | 2       | 4        |
| BEQ      | 27      | 2       | 4        |
| внсс     | 28      | 2       | 4        |
| BHCS     | 29      | 2       | 4        |
| BPL      | 2A      | 2       | 4        |
| BMI      | 2B      | 2       | 4        |
| BMC      | 2C      | 2       | 4        |
| BMS      | 2D      | 2       | 4        |
| BIL      | 2E      | 2       | 4        |
| він      | 2F      | 2       | 4        |
| BSR      | AD      | 2       | 8        |

#### RESETS

The MCU can be reset two ways; by initial power-up and by the external reset input (RES), see Figure 6. All the I/O ports are initialized to input mode (DDRs are cleared) during reset.

During power-up, a minimum 100 milliseconds is needed before allowing the RES input to go "High". This time allows the internal crystal oscillator to stabilize. Connecting a capacitor to the RES input, as shown in Figure 7, typically provides

sufficient delay.



Figure 6 Power Up and Reset Timing



Figure 7 Power Up Reset Delay Circuit

#### INTERNAL OSCILLATOR

The internal oscillator circuit is designed to interface with a crystal (AT cut, 4 MHz max.) which is sufficient to drive it with various stability. As shown in Figure 8, a 22 pF capacitor is required from EXTAL to ground. Crystal specifications are given in Figure 9. Alternatively, EXTAL may be driven with a duty cycle of 50% with XTAL connected to ground.



External Clock



#### Figure 8 Internal Oscillator Options



C₀ = 7 pF max. f = 4 MHz (C₁ ≈22pF±20%)

 $R_S = 60 \Omega$  max.

Figure 9 Crystal parameters

#### INTERRUPTS

The MCU can be interrupted in seven different ways: through external interrupt input pin ( $\overline{INT}_1$  and  $\overline{INT}_2$ ), internal timer interrupt request (Timer 1, ICI, OCI and OFI) and a software interrupt instruction (SWI).  $\overline{INT}_2$  and Timer 1 are generated by the same vector address. When interrupt occurs, processing of the program is suspended, the present CPU state is pushed onto the stack. Figure 10 shows interrupt stacking order. Moreover, the interrupt mask bit (I) of the Condition Code Register is set and the external routine priority address is achieved from the special external vector address. After that, the external interrupt routine is executed. The interrupt Table 6 Interrupt Priorities

|                  | Interrupt                 | Priority | Vector Address                                     |
|------------------|---------------------------|----------|----------------------------------------------------|
|                  | RES                       | 1        | \$0FFE, \$0FFF                                     |
|                  | SWI                       | 2        | \$0FFC, \$0FFD                                     |
| A1 1             | INT                       | 3        | \$OFFA, \$OFFB                                     |
| 4k bytes<br>type | Timer/INT <sub>2</sub>    | 4        | \$0FF8, \$0FF9                                     |
| ()pe             | ICI                       | 5        | \$0FF6, \$0FF7                                     |
|                  | OCI                       | 6        | \$0FF4, \$0FF5                                     |
|                  | OFI                       | 7        | \$0FF2, \$0FF3                                     |
|                  | Interrupt                 | Priority | Vector Address                                     |
|                  | RES                       | 1        | \$1FFE, \$1FFF                                     |
|                  | I RES                     |          | φικες,φικκε                                        |
|                  | SWI                       | 2        | \$1FFC, \$1FFD                                     |
| <b>0</b> 1       |                           | 2        |                                                    |
| 8k bytes         | SWI                       | -        | \$1FFC, \$1FFD                                     |
| 8k bytes<br>type | SWI<br>INT,               | 3        | \$1FFC, \$1FFD<br>\$1FFA, \$1FFB                   |
|                  | SWI<br>INT,<br>Timer/INT, | 3        | \$1FFC, \$1FFD<br>\$1FFA, \$1FFB<br>\$1FF8, \$1FF9 |

service routines normally end with a return from interrupt (RTI) instruction which allows the CPU to resume processing of the program prior to the interrupt. The priority interrupts are shown in Table 6 with the vector address that contains the starting address of the appropriate interrupt routine. The interrupt sequence is shown as a flowchart in Figure 11.

Note that the Vector Address when using the 8k byte type EPROM is different from the 4k byte type EPROM.

1138



\* For subroutine calls, only PCH and PCL are stacked.

Figure 10 Interrupt Stacking Order



Figure 11 Interrupt Flowchart

#### Miscellaneous Register (MR: \$000A)

The vector address generated by the external interrupt  $(INT_2)$  is the same as that of TIMER1 as shown in Table 6. The miscellaneous register (MR) controls the  $INT_2$  interrupt.



Bit 7 (IRF) of the MR is used as an  $INT_2$  interrupt request flag.  $INT_2$  interrupt occurs at the  $INT_2$  negative edge, and IRF is set.  $INT_2$  interrupt or not can be proved by checking IRF by software in the interrupt routine of the vector address (\$FF8, \$FF9). IRF should be reset by software (BCLR instruction).

Bit 6 (IM) of the MR is an  $\overline{INT_2}$  interrupt mask bit. When IM is set,  $\overline{INT_2}$  interrupt is disabled.  $\overline{INT_2}$  interrupt is also disabled by bit (I) of the Condition Code Register (CC) like other interrupts.

IRF is available for both read and write. However, IRF is

not writable by software. Therefore,  $\overline{INT}_2$  interrupt cannot be requested by software. At reset, IRF is cleared and IM is set.

#### INPUT/OUTPUT

There are 23 input/output pins. All pins are controlled by the Data Direction Register and both input and output are programmable. When programmed as output, the latched output data is readable as input data, regardless of the logic levels at the output pin due to output loading (See Figure 12.) When Port B is programmed for output, it is capable of sinking 10 mA on each pin (Vol max. = 1V). Furthermore, Port A is CMOS compatible as output. Ports B and C are CMOS compatible as inputs. Some examples of the Port connections are shown in Figure 13.

Port Cs and C6 are also used for Timer 2.

When Port  $C_5$  is used as Timer 2 Input Capture (IC), Port  $C_5$ 's DDR should be cleared (Port  $C_5$  as input) and bit 4 (ICIM) in the Timer Control Register 2 (TCR2) should be cleared too. The Input Capture Register (ICR) stores the TDR2 when a Port  $C_5$  input transition occures as defined by bit 1 (IDEG) of the TCR2.

When Port C<sub>6</sub> is used as Timer 2 Output Compare (OC), Port C<sub>6</sub>'s DDR should be set (Port C<sub>6</sub> as output). When the Output Compare Register (OCR) matches the TDR2, bit 0 (OLVL) in the TCR2 is set and OLVL will appear at Port C<sub>6</sub>. Port C<sub>6</sub> is writable by software. But the writing by software is unavailable when a match between the TDR2 and the OCR is found at the same time.



Figure 12 Typical Port I/O Circuitry



Port A Programmed as output(s), driving CMOS and TTL Load directly.



Port B Programmed as output(s), driving LED(s) directly. (c)



#### INPUT

Port D is usable as either TTL compatible inputs or a 4-channel input for an A/D converter. Fig. 14 shows port D logic configuration.

The Port D register at location \$003 stores TTL compatible inputs. When using as analog inputs for an A/D converter, refer to "A/D CONVERTER".

#### A/D CONVERTER

The HD68P05W0 has an internal 8 bit A/D converter. The A/D converter, shown in Figure 15, includes 4 analog inputs



Port B Programmed as output(s), driving Darlington base directly.



Port C Programmed as output(s), driving CMOS load(s), using external pull-up resistors. (d)

 $(AN_0 \text{ to } AN_3)$ , the Result Register (ADRR) and the Control Status Register (ADCSR).

#### CAUTION

The MCU has circuitry to protect the inputs against damage due to high static voltages or electric field; however, the design of the input circuitry for the A/D converter, AN<sub>0</sub> ~ AN<sub>3</sub>, V<sub>RH</sub> and AV<sub>CC</sub>, does not offer the same level of protection. Precautions should be taken to avoid applications of any voltage higher than maximum-rated voltage or handled in any environment producing high-static voltages.



Figure 15 A/D Converter Block Diagram

Downloaded from Elcodis.com electronic components distributor

#### Analog Input (AN<sub>0</sub> to AN<sub>3</sub>)

Analog inputs  $AN_0$  to  $AN_3$  accept analog voltages of 0V to 5V. The resolution is 8 bits (256 divisions) with a conversion time of 76  $\mu$ s at 1 MHz. Analog conversion starts selecting analog inputs by bit 0 and bit 1 of the ADCSR analog input. Since the CPU is not required during conversion, other user programs can be executed.

Table 7 Analog Input Selection

| AD    | CSR   | Analog Input Signal |
|-------|-------|---------------------|
| Bit 1 | Bit O | Analog mput Signal  |
| 0     | 0     | ANo                 |
| 0     | 1     | AN 1                |
| 1     | 0     | AN <sub>2</sub>     |
| 1     | 1     | AN <sub>3</sub>     |

#### A/D Control Status Register (ADCSR: \$000E)

The Control Status Register (ADCSR) is used to select analog input pin and confirm A/D conversion termination. An analog input pin is selected by bit 0 and bit 1 as shown in Table 7.

A/D conversion begins when the data is written into bit 0 and bit 1 of the ADCSR. When A/D conversion ends, bit 7 (CEND) is set. Bit 7 is reset after the ADRR is read. Even if bit 7 is set, A/D conversion execution still continues. To end the A/D conversion, the A/D Result Register (ADRR) stores the most current value. During A/D conversion execution, new data is written into the ADCSR selecting the input channel and the A/D conversion execution at that time is suspended. CEND is reset and new A/D conversion begins.

#### • A/D Result Register (ADRR: \$000F)

When the A/D conversion ends, the result is set in the A/D Result Register (\$000F). When CEND of the ADCSR is set, converted result is obtained by reading the ADRR. Furthermore, CEND is cleared.

#### STANDBY RAM

The portion from \$020 to \$027 of the RAM can be used for the standby RAM.

When using the standby RAM, V<sub>CC</sub> Standby should remain above V<sub>SBB</sub> (min) during powerdown. Consequently, power is provided only to the standby RAM and STBY PWR bit of the RAM Control Register. 8 byte RAM is sustained with small power dissipation. The RAM including the standby RAM is controlled by the RAM Control Register (RCR) or RAME pin.



Figure 16 Standby RAM

#### RAM Control Register (RCR: \$001F)

This register at location 01F gives the status information about the RAM. When RAM Enable bit (RAME) is "0", the RAM is disabled. When V<sub>CC</sub> Standby is greater than V<sub>SBB</sub>, Standby Power bit (STBY PWR) is set and the standby RAM is sustained during powerdown.

RAM Control Register (RCR: \$001F)



#### Bit 6 RAM Enable

RAME bit is set or cleared by either software or hardware. When the MCU is reset, RAME bit is set and the RAM is enabled. If RAME bit is cleared, the user can neither read nor write the RAM.

When the RAM is disabled (logic "0"), the RAM address is invalid.

#### Bit 7 Standby Power

STBY PWR bit is cleared whenever  $V_{CC}$  standby decreases below  $V_{SBB}$  (min). This bit is a read/write status bit that the user can read. When this bit is set, it indicates that the standby power is applied and data in the standby RAM is valid.

#### RAME Signal

RAME bit in the RCR can be cleared when RAME pin goes "Low" by hardware (RAM is disabled). To make standby mode by hardware, set RAME pin "Low" during V<sub>CC</sub> Standby remains above V<sub>SBB</sub> (min) and powerdown sequence should be as shown in Fig. 17.

When RAME pin gets "Low" in the powerup state. RAME bit of the RCR is cleared and the RAM is disabled. During powerdown, RAME bit is sustained by  $V_{CC}$  Standby. When RAME pin gets "High" in the powerup state. RAME bit of the RCR is set and the RAM is enabled.

RAME pin can be used to control the RAM externally without software.



Figure 17 RAM Control Signal (RAME)

#### BIT MANIPULATION

The MCU has the ability to set or clear any single RAM or input/output port (except the data direction registers) with a single instruction (BSET and BCLR). Any bit in the page zero read only memory can be tested by using the BRSET and

1142

Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

BRCLR instructions, and the program branches as a result of its state. This capability to work with any bit in RAM, ROM or I/O allows the user to have individual flags in RAM or to handle single I/O bits as control lines. The example in Figure 18 shows the usefulness of the bit manipulation and test instructions. Assume that bit 0 of port A is connected to a zero crossing detector circuit and that bit 1 of port A is connected to the trigger of a TRIAC which powers the controlled hardware.

This program, which uses only seven bytes of ROM provides turn-on of the TRIAC within 14 microseconds of the zero crossing. The timer is also incorporated to provide turn-on at some later time which permits pulse-width modulation of the controlled power.



Figure 18 Bit Manipulation Example

#### ADDRESSING MODES

The MCU has ten addressing modes available for use by the programmer. These modes are explained and illustrated briefly in the following paragraphs.

#### Immediate

Refer to Figure 19. The immediate addressing mode accesses constants which do not change during program execution. Such instructions are two bytes long. The effective address (EA) is the PC and the operand is fetched from the byte following the opcode.

#### Direct

Refer to Figure 20. In direct addressing, the address of the operand is contained in the secondbyte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in memory. All RAM space, I/O registers and 128 bytes of ROM are located in page zero to take advantage of this efficient memory addressing mode.

#### Extended

Refer to Figure 21. Extended addressing is used to reference any location in memory space. The EA is the contents of the two bytes following the opcode. Extended addressing instructions are three bytes long.

#### • Relative

Refer to Figure 22. The relative addressing mode applies only

to the branch instructions. In this mode the contents of the byte following the opcode is added to the program counter when the branch is taken. EA = (PC) + 2 + Rel. Rel is the contents of the location following the instruction opcode with bit 7 being the sign bit. If the branch is not taken, Rel = 0, when a branch takes place, the program goes to somewhere within the range of +129 bytes to -127 bytes of the present instruction. These instructions are two bytes long.

#### Indexed (No Offset)

Refer to Figure 23. This mode of addressing accesses the lowest 256 bytes of memory. These instructions are one byte long and their EA is the contents of the index register.

#### Indexed (8-bit Offset)

Refer to Figure 24. The EA is calculated by adding the contents of the byte following the opcode to the contents of the index register. In this mode, 511 low memory locations are accessable. These instructions occupy two bytes.

#### Indexed (16-bit Offset)

Refer to Figure 25. This addressing mode calculates the EA by adding the contents of the two bytes following the opcode to the index register. Thus, the entire memory space may be accessed. Instructions which use this addressing mode are three bytes long.

#### Bit Set/Clear

Refer to Figure 26. This mode of addressing applies to instructions which can set or clear any bit on page zero. The lower three bits in the opcode specify the bit to be set or cleared while the byte following the opcode specifies the address in page zero.

#### Bit Test and Branch

Refer to Figure 27. This mode of addressing applies to instructions which can test any bit in the first 256 locations (\$0000 through \$00FF) and branch to any location relative to the PC. The byte to be tested is addressed by the byte following the opcode. The individual bit within that byte to be tested is addressed by the lower three bits of the opcode. The third byte is the relative address to be added to the program counter if the branch condition is met. These instructions are three bytes long. The value of the bit to be tested is written to the carry bit in the condition code register.

#### Implied

Refer to Figure 28. The implied mode of addressing has no EA. All of the information necessary to execute an instruction is contained in the opcode. Direct operations on the accumulator and the index register are included in this mode of addressing. In addition, control instructions such as SWI and RTI belong to this group. All implied addressing instructions are one byte long.



Figure 19 Immediate Addressing Example



Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300











Figure 23 Indexed (No Offset) Addressing Example



1146 Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300



Figure 25 Indexed (16-Bit Offset) Addressing Example



Figure 26 Bit Set/Clear Addressing Example







Figure 28 Implied Addressing Example

 Image: Mitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

#### INSTRUCTION SET

The MCU has a set of 59 basic instructions. These instructions can be divided into five different types; register/memory, read/modify/write, branch, bit manipulation and control. Each instruction is briefly explained below. All of the instructions within a given type are presented in individual tables.

#### Register/Memory Instructions

Most of these instructions use two operands. One operand is either the accumulator or the index register. The other operand is obtained from memory by using one of the addressing modes. The jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operand. Refer to Table 8.

#### Read/Modify/Write Instructions

These instructions read a memory location or a register, modify or test its contents and write the modified value back to the memory or register. The TST instruction for test of negative or zero is an exception to the read/modify/write instructions since it does not perform the write. Refer to Table 9.

#### • Branch Instructions

The branch instructions cause a branch from a program when a certain condition is met. Refer to Table 10.

#### • Bit Manipulation Instructions

These instructions are used on any bit in the first 256 bytes of the memory. One group either sets or clears. The other group performs the bit test and branch operations. Refer to Table 11.

#### Control Instructions

The control instructions control the MCU operations during program execution. Refer to Table 12.

#### Alphabetical Listing

The complete instruction set is given in alphabetical order in Table 13.

#### Opcode Map

Table 14 is an opcode map for the instructions used on the MCU.

| Instructions    |
|-----------------|
| Register/Memory |
| Table 8         |

|                                                                      |          | 1    |           |        |      |        |        |          | 4        | Addressing Modes | ng Mod  | es                     |        |           |                           |          |       |                            |        |
|----------------------------------------------------------------------|----------|------|-----------|--------|------|--------|--------|----------|----------|------------------|---------|------------------------|--------|-----------|---------------------------|----------|-------|----------------------------|--------|
| Function                                                             | Mnemonic | -    | Immediate | te     |      | Direct |        | Ē        | Extended | _                | - Z     | Indexed<br>(No Offset) | -      | 1<br>(8-B | Indexed<br>(8-Bit Offset) | t        | 116-1 | Indexed<br>(16-Bit Offset) | (16    |
|                                                                      |          |      |           |        | ð    |        | #      | do       |          | #                | d       |                        |        |           |                           | <u> </u> | g     | #                          | #      |
|                                                                      |          | Code | Bytes     | Cycles | Code | Bytes  | Cycles | Code     | Bytes    | Cycles           | Code    | Bytes (                | Cycles | Code      | Bytes (                   | Cycles   | Code  | Bytes (                    | Cycles |
| Load A from Memory                                                   | LDA      | A6   | 2         | 2      | BG   | 2      | 4      | C6       | e        | 5                | F6      | -                      | 4      | E6        | 2                         | ъ        | D6    | m                          | 9      |
| Load X from Memory                                                   | LDX      | AE   | 2         | 2      | BE   | 2      | 4      | СE       | m        | 2<br>C           | ш<br>Ц  | -                      | 4      | Ш         | 2                         | ъ        | DE    | m                          | 9      |
| Store A in Memory                                                    | STA      |      | i         |        | 87   | 2      | ഹ      | C        | e        | 9                | F7      | -                      | ъ      | E7        | 2                         | 9        | 07    | m                          | 1      |
| Store X in Memory                                                    | STX      | I    | ļ         |        | ШШ   | 2      | ъ      | Ч        | e        | 9                | Ŀ       | +                      | ъ      | Ш         | 2                         | 9        | DF    | m                          | ~      |
| Add Memory to A                                                      | ADD      | AB   | 2         | 2      | 88   | 2      | 4      | 89       | с        | 2                | FB      | -                      | 4      | EB        | 2                         | <u>د</u> | DB    | e<br>M                     | 9      |
| Add Memory and<br>Carry to A                                         | ADC      | A9   | 5         | 2      | B9   | 2      | 4      | 60       | ю        | ى<br>ع           | F9      | -                      | 4      | 63        | 2                         | 2        | 60    | m                          | 9      |
| Subtract Memory                                                      | SUB      | AO   | 2         | 2      | BO   | 2      | 4      | 8        | m        | 2                | F0      | -                      | 4      | Ë         | 2                         | ъ        | 00    | m                          | 9      |
| Subtract Memory from<br>A with Borrow                                | SBC      | A2   | 7         | 2      | 82   | 7      | 4      | C        | m        | 2                | F2      | ! -                    | 4      | E2        | 5                         | 2        | D2    | m                          | 9      |
| AND Memory to A                                                      | AND      | A4   | 2         | 2      | B4   | 2      | ব      | 64<br>0  | с        | ъ                | ۳4<br>4 | ¦ –                    | 4      | E4        | 5                         | 2        | D4    | e                          | 9      |
| <b>OR Memory with A</b>                                              | ORA      | AA   | 2         | 2      | ΒA   | 2      | 4      | CA       | ю        | 5                | FA      | -                      | 4      | EA        | 2                         | ъ        | DA    | с<br>С                     | 9      |
| Exclusive OR Memory<br>with A                                        | EOR      | A8   | 2         | 2      | 88   | 2      | 4      | 89       | m        | ۍ<br>م           | 8°<br>L | _                      | ব      | E8        | 2                         | 2        | D8    | m                          | 9      |
| Arithmetic Compare A<br>with Memory                                  | CMP      | A1   | 2         | 2      | 81   | 5      | 4      | ច        | m        | പ                | Ē       | +<br>                  | 4      | -<br>-    | 2                         | പ        | 10    | e                          | 9      |
| Arithmetic Compare X<br>with Memory                                  | СРХ      | A3   | 2         | 2      | 83   | 5      | 4      | ß        | 3        | <u>م</u>         | F3      | -                      | 4      | E3        | 2                         | ъ.       | D3    | m                          | 9      |
| Bit Test Memory with A<br>(Logical Compare)                          | віт      | A5   | 2         | 2      | B5   | 2      | 4      | C5       | m        | ഹ                | E5      | -                      | ব      | ES        | 5                         | 2        | D5    | <i>т</i>                   | 9      |
| Jump Unconditional                                                   | ЧМГ      | 1    | 1         | I      | BC   | 2      | e      | <u>ဗ</u> | с        | 4                | FC      | -                      | ę      | цС        | 2                         | 4        | ы     | m                          | 5      |
| Jump to Subroutine                                                   | JSR      |      | I         | Ι      | BD   | 2      | 7      | 9        | ъ        | 8                | Ð       | -                      | 7      | ED        | 2                         | 8        | DD    | e                          | 6      |
| Symbols:<br>Op : Operation Abbreviation<br># : Instruction Statement |          |      |           |        |      |        |        |          |          |                  |         |                        |        |           |                           |          | :     |                            |        |

1150

Downloaded from **Elcodis.com** electronic components distributor

## HD68P05W0

Table 9 Read/Modify/Write Instructions

| <b>@</b> HITACHI                                                                                           |      |  |
|------------------------------------------------------------------------------------------------------------|------|--|
| Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 | 1151 |  |

| Downloaded from Elcodis.com electronic components distributor | Downloaded from | Elcodis.com | electronic | components | distributor |
|---------------------------------------------------------------|-----------------|-------------|------------|------------|-------------|
|---------------------------------------------------------------|-----------------|-------------|------------|------------|-------------|

|                                                                     |            |          |             |        |      |             |        | Addr | Addressing Modes | lodes        |            |                        |        |          |                           |        |
|---------------------------------------------------------------------|------------|----------|-------------|--------|------|-------------|--------|------|------------------|--------------|------------|------------------------|--------|----------|---------------------------|--------|
| Function                                                            | Mnemonic   | <u> </u> | Implied (A) | 2      | 1    | Implied (X) | x      |      | Direct           |              | - <u>z</u> | Indexed<br>(No Offset) |        | 1<br>8-E | Indexed<br>(8-Bit Offset) | et)    |
|                                                                     |            | g        | #           | #      | ð    | #           | #      | ð    | #                | #            | ð          | #                      |        |          | #                         | #      |
|                                                                     |            | Code     | Bytes       | Cycles | Code | Bytes       | Cycles | Code | Bytes            | Bytes Cycles | ð          | Bytes                  | Cycles | Code     | Bytes                     | Cycles |
| Increment                                                           | INC        | 4<br>4   | -           | 4      | 50   | •           | 4      | 3C   | 2                | 9            | 7C         | -                      | 9      | ပ္ပ      | 2                         | 2      |
| Decrement                                                           | DEC        | 4A       | -           | 4      | 5A   | 1           | 4      | ЗA   | 2                | 9            | ٦A         | -                      | 9      | 6A       | 2                         | ~      |
| Clear                                                               | CLR        | 4F       | -           | 4      | 5F   | -           | 4      | ЗF   | 2                | 9            | γF         | -                      | 9      | 6F       | 2                         | ~      |
| Complement                                                          | coM        | 43       | -           | 4      | 53   | -           | 4      | 33   | 2                | 9            | 73         | -                      | 9      | 63       | 2                         | ~      |
| Negate<br>(2's Complement)                                          | NEG        | 40       | -           | 4      | 20   | -           | 4      | 30   | 2                | ų            | 70         | -                      | 9      | 60       | 2                         | ~      |
| Rotate Left Thru Carry                                              | ROL        | 49       | -           | 4      | 59   | -           | 4      | 39   | 2                | 9            | 79         | -                      | 9      | 69       | 2                         | ~      |
| Rotate Right Thru Carry                                             | ROR        | 46       | -           | 4      | 56   | -           | 4      | 36   | 2                | 9            | 76         | -                      | 9      | 99       | 2                         | ~      |
| Logical Shift Left                                                  | LSL<br>LSL | 48       | -           | 4      | 58   |             | 4      | 38   | 2                | 6            | 78         | -                      | 9      | 68       | 2                         | 7      |
| Logical Shift Right                                                 | LSR        | 44       | -           | 4      | 2    | -           | 4      | 34   | 2                | 9            | 74         | -                      | 6      | 64       | 2                         | 2      |
| Arithmetic Shift Right                                              | ASR        | 47       | -           | 4      | 57   | -           | 4      | 37   | 2                | 9            | 77         | -                      | 9      | 67       | 2                         | ~      |
| Arithmetic Shift Left                                               | ASL        | 48       | -           | 4      | 58   | -           | 4      | 38   | 2                | 9            | 78         | -                      | 9      | 68       | 2                         | ~      |
| Test for Negative or<br>Zero                                        | TST        | 4D       | -           | 4      | 5D   | -           | 4      | 30   | 2                | 9            | 02         | -                      | 9      | 60       | 2                         | 2      |
| Symbols:<br>Op: Operation Abbreviation<br># : Instruction Statement |            |          |             |        |      |             |        |      |                  |              |            |                        |        |          |                           |        |

## HD68P05W0

|                                       |          | Rela       | tive Addressing | Mode        |
|---------------------------------------|----------|------------|-----------------|-------------|
| Function                              | Mnemonic | Op<br>Code | #<br>Bytes      | #<br>Cycles |
| Branch Always                         | BRA      | 20         | 2               | 4           |
| Branch Never                          | BRN      | 21         | 2               | 4           |
| Branch IF Higher                      | ВНІ      | 22         | 2               | 4           |
| Branch IF Lower or Same               | BLS      | 23         | 2               | 4           |
| Branch IF Carry Clear                 | BCC      | 24         | 2               | 4           |
| (Branch IF Higher or Same)            | (BHS)    | 24         | 2               | 4           |
| Branch IF Carry Set                   | BCS      | 25         | 2               | 4           |
| (Branch IF Lower)                     | (BLO)    | 25         | 2               | 4           |
| Branch IF Not Equal                   | BNE      | 26         | 2               | 4           |
| Branch IF Equal                       | BEQ      | 27         | 2               | 4           |
| Branch IF Half Carry Clear            | BHCC     | 28         | 2               | 4           |
| Branch IF Half Carry Set              | BHCS     | 29         | 2               | 4           |
| Branch IF Plus                        | BPL      | 2A         | 2               | 4           |
| Branch IF Minus                       | BMI      | 2B         | 2               | 4           |
| Branch IF Interrupt Mask Bit is Clear | BMC      | 2C         | 2               | 4           |
| Branch IF Interrupt Mask Bit is Set   | BMS      | 2D         | 2               | 4           |
| Branch IF Interrupt Line is Low       | BIL      | 2E         | 2               | 4           |
| Branch IF Interrupt Line is High      | BIH      | 2F         | 2               | 4           |
| Branch to Subroutine                  | BSR      | AD         | 2               | 8           |

Table 10 Branch Instructions

Symbols: Op: Operation Abbreviation #: Instruction Statement

Table 11 Bit Manipulation Instructions

|                                       |                 | Addressing Modes |               |             |                     |            |             |  |  |  |  |  |
|---------------------------------------|-----------------|------------------|---------------|-------------|---------------------|------------|-------------|--|--|--|--|--|
| Branch IF Bit n is clear<br>Set Bit n | Mnemonic        | E                | Bit Set/Clear |             | Bit Test and Branch |            |             |  |  |  |  |  |
|                                       |                 | Op<br>Code       | #<br>Bytes    | #<br>Cycles | Op<br>Code          | #<br>Bytes | #<br>Cycles |  |  |  |  |  |
| Branch IF Bit n is set                | BRSET n (n≠0 7) | _                | _             | _           | <b>2•</b> n         | 3          | 10          |  |  |  |  |  |
| Branch IF Bit n is clear              | BRCLR n (n=07)  | _                | -             | -           | 01+2•n              | 3          | 10          |  |  |  |  |  |
| Set Bit n                             | BSET n (n=0 7)  | 10+2•n           | 2             | 7           | -                   | -          | -           |  |  |  |  |  |
| Clear bit n                           | BCLR n (n=0 7)  | 11+2•n           | 2             | 7           | -                   | -          | -           |  |  |  |  |  |

Symbols: Op: Operation Abbreviation #: Instruction Statement

Table 12 Control Instructions

|                          |          |            | Implied    |             |  |  |  |  |  |
|--------------------------|----------|------------|------------|-------------|--|--|--|--|--|
| Function                 | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles |  |  |  |  |  |
| Transfer A to X          | ТАХ      | 97         | 1          | 2           |  |  |  |  |  |
| Transfer X to A          | ТХА      | 9F         | 1          | 2           |  |  |  |  |  |
| Set Carry Bit            | SEC      | 99         | 1          | 2           |  |  |  |  |  |
| Clear Carry Bit          | CLC      | 98         | 1          | 2           |  |  |  |  |  |
| Set Interrupt Mask Bit   | SEI      | 9B         | 1          | 2           |  |  |  |  |  |
| Clear Interrupt Mask Bit | CLI      | 9A         | 1          | 2           |  |  |  |  |  |
| Software Interrupt       | SWI      | 83         | 1          | 11          |  |  |  |  |  |
| Return from Subroutine   | RTS      | 81         | 1          | 6           |  |  |  |  |  |
| Return from Interrupt    | RTI      | 80         | 1          | 9           |  |  |  |  |  |
| Reset Stack Pointer      | RSP      | 9C         | 1          | 2           |  |  |  |  |  |
| No-Operation             | NOP      | 9D         | 1          | 2           |  |  |  |  |  |

Symbols: Op: Operation Abbreviation #: Instruction Statement

|          | 1          | <u> </u>       | Cod           | e<br>T                                |                |                           |                                              |                                       |                      |                         |            |     |             |                   |              |
|----------|------------|----------------|---------------|---------------------------------------|----------------|---------------------------|----------------------------------------------|---------------------------------------|----------------------|-------------------------|------------|-----|-------------|-------------------|--------------|
| Mnemonic | Implied    | Imme-<br>diate | Direct        | Ex-<br>tended                         | Re-<br>lative  | Indexed<br>(No<br>Offset) | Indexed<br>(8 Bits)                          | Indexed<br>(16 Bits)                  | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н          | 1   | N           | z                 | с            |
| ADC      |            | ×              | ×             | ×                                     |                | x                         | x                                            | ×                                     |                      | i                       |            | ٠   | $\wedge$    | <u> </u>          | Λ            |
| ADD      | +          | x              | x             | ×                                     | ļ              | ×                         | ×                                            | ×                                     |                      |                         | $  \wedge$ | •   | $\land$     | $\land$           |              |
| AND      | 1          | ×              | * ×           | ×                                     |                | x                         | x                                            | ×                                     | •                    | i<br>i                  | •          | •   | $\wedge$    | $\land$           | •            |
| ASL      | ×          |                | ×             |                                       |                | ×                         | x                                            | :<br>+                                |                      | •                       | •          | •   | $\land$     | $  \wedge$        | $\uparrow$   |
| ASR      | ×          | • ·            | x             |                                       |                | ×                         | ×                                            | · · · · · ·                           |                      | ļ                       | •          | •   | Λ           | <u> </u>          | $\downarrow$ |
| BCC      | 1          | ;              | 1             | +                                     | x              |                           | I<br>•                                       | +                                     | ·                    |                         | •          | •   | •           | •                 | •            |
| BCLR     | •          |                |               | 1                                     | :              |                           | !                                            | +                                     | ×                    | ;<br>                   | •          | •   | •           | •                 | •            |
| BCS      |            | 1              |               | <u> </u>                              | ×              | 1                         |                                              | ļ                                     | <u>.</u>             | <u>+</u>                | •          | •   | •           | •                 | •            |
| BEQ      |            |                |               | +                                     | ×              | 1                         |                                              |                                       |                      | · · · · · · ·           | •          | •   | •           | •                 | •            |
| BHCC     |            | <u> -</u>      |               | <u>+</u>                              | ×              | -                         |                                              |                                       | -                    | 1                       | •          | •   | •           | •                 | •            |
| BHCS     | +          |                | +             | + ·                                   | ×              | <i>*</i>                  |                                              |                                       |                      |                         | •          | •   | •           | •                 | •            |
|          |            |                | -+ · ·        | + ·                                   |                | •                         |                                              |                                       |                      |                         | •          | •   | ٠           | •                 | •            |
| BHI      |            |                |               | <b>;</b>                              | x              | ····                      | · • • • • • • • • • • • • • • • • • • •      | · · · · · · · · · · · · · · · · · · · | †                    |                         | ٠          | ٠   | ٠           | •                 | •            |
| BHS      |            |                |               | ÷                                     | x              |                           | +                                            | +                                     |                      |                         | •          | •   | •           | •                 |              |
| BIH      |            | <u> </u>       |               | +                                     | + - <u>-</u> - | ÷                         | +                                            |                                       |                      |                         | •          | •   | •           | •                 | •            |
| BIL      |            | 1              |               | +                                     | ·              | ×                         | ×                                            | ×                                     | +                    |                         | •          | •   |             |                   |              |
| BIT      |            | <u>×</u>       | ×             | +×                                    |                | <b>^</b>                  | <u>                                     </u> | +                                     | •                    | +                       |            | •   | •           | •                 |              |
| BLO      |            |                | <u> </u>      |                                       | ×              |                           | +                                            | +                                     |                      |                         | -          | •   | •           | •                 |              |
| BLS      |            |                |               | · · · · · · · · · · · · · · · · · · · | ×              |                           |                                              |                                       | -+                   |                         | •          | •   | •           | •                 | -            |
| BMC      |            |                |               | <u> </u>                              | ×              | ·<br>                     |                                              |                                       |                      |                         |            | •   |             | •                 | +            |
| BMI      |            |                | 1             | ·                                     | ×              |                           |                                              |                                       |                      | <u> </u>                |            | +   | +           | +                 | +            |
| BMS      |            | <br>           |               |                                       | ×              |                           |                                              |                                       | ·                    | i<br>                   | •          | •   | •           | •                 | +            |
| BNE      |            |                |               |                                       | ×              |                           |                                              | ·<br>                                 | +                    |                         | •          | •   | •           | •                 | -+-          |
| BPL      |            |                |               | 1                                     | ×              |                           |                                              |                                       | i                    | ,<br>                   | •          | •   | •           | •                 | -            |
| BRA      |            |                | 1             | i                                     | ×              |                           |                                              | _i                                    | _ <b>_</b>           |                         | •          | •   | •           | •                 |              |
| BRN      |            | 1              |               |                                       | ×              |                           |                                              |                                       | .i                   |                         | •          | •   | •           | •                 | 4            |
| BRCLR    |            |                |               | 1 -                                   |                |                           |                                              |                                       |                      | x                       | •          | •   | •           | •                 |              |
| BRSET    |            |                | +             |                                       |                |                           |                                              |                                       |                      | ×                       | •          | •   | •           | •                 | -            |
| BSET     |            |                |               |                                       | 1              |                           |                                              |                                       | ×                    |                         | •          | •   | •           | •                 | -            |
| BSR      |            | -+             |               |                                       | ×              |                           |                                              | .i                                    |                      | - i                     | •          | •   | •           | •                 |              |
| CLC      | ×          |                |               |                                       |                |                           |                                              |                                       | =                    |                         | •          | •   | •           | •                 |              |
| CLI      | ×          |                | -             |                                       | 1              | 1                         |                                              |                                       | -                    |                         | •          | 0   | •           | •                 | -            |
|          | x          |                | - ·   · · · · |                                       |                | ×                         | ×                                            |                                       |                      |                         | •          | •   | 0           | 1                 | _            |
| CMP      |            | ×              | ×             | ×                                     |                | X                         | ×                                            | ×                                     |                      |                         | •          | •   |             | $\Lambda$         | <u> </u>     |
|          | ×          |                | ×             | +                                     |                | ×                         | ×                                            | 1                                     |                      |                         | •          | •   | ^           | $\sqrt{}$         | $\backslash$ |
| COM      | _ <u>_</u> | ×              |               | ×                                     |                | ×                         | ×                                            | ×                                     |                      |                         | •          | •   | · /         | $\setminus \land$ |              |
| CPX      | ×          |                | x             |                                       |                | ×                         | ×                                            |                                       | - <b>-</b>           |                         | •          | •   |             |                   |              |
| DEC      | ····       |                |               | ×                                     | +-             | ×                         | ×                                            | ×                                     |                      |                         | •          | •   | · ^         |                   |              |
| EOR      |            | ×              | ··· •         | ^                                     |                | ×                         | ×                                            |                                       |                      |                         | •          | •   |             |                   |              |
| INC      | ×          |                | x             | -                                     |                | ×                         | x                                            | ×                                     | •                    |                         | •          |     | •           | •                 | ,†           |
| JMP      |            |                | ×             | ×                                     |                |                           | x                                            | x                                     | -                    |                         | •          |     |             | •                 | ,†           |
| JSR      |            |                | ×             | ×                                     |                | ×                         |                                              | ×                                     |                      |                         |            | -   |             |                   | $(\dagger$   |
| LDA      |            | ×              | ×             | ×                                     | _ <u>_</u>     |                           | ×                                            |                                       |                      |                         |            | _+_ | _+ <u> </u> |                   | -            |
| LDX      |            | ×              | ×             | ×                                     |                | ×                         | ×                                            | ×                                     |                      |                         | _1_        |     | <u> </u>    | •                 | <u>· 1</u>   |

Table 13 Instruction Set

Condition Code Symbols. H Half Carry (From Bit 3) I Interrupt Mask N Negative (Sign Bit)

N Z Zero C ∧

.

Carry Borrow Test and Set if True, Cleared Otherwise Not Affected

(to be continued)

| Mnemonic |         | Addressing Modes |        |               |               |                           |                     |                                       |                      |                         |   |   |          |          |   |
|----------|---------|------------------|--------|---------------|---------------|---------------------------|---------------------|---------------------------------------|----------------------|-------------------------|---|---|----------|----------|---|
|          | Implied | Imme-<br>diate   | Direct | Ex-<br>tended | Re-<br>lative | Indexed<br>(No<br>Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits)                  | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н | I | N        | z        | 0 |
| LSL      | ×       |                  | ×      |               |               | x                         | ×                   |                                       |                      |                         | ٠ | • | Λ        | $\land$  | 7 |
| LSR      | x       |                  | ×      |               |               | x                         | ×                   |                                       |                      |                         | ٠ | • | 0        | $\land$  | 1 |
| NEG      | x       |                  | x      |               |               | ×                         | ×                   |                                       |                      |                         | ٠ | ٠ | Λ        | Λ        | 1 |
| NOP      | x       |                  |        |               |               |                           |                     |                                       |                      |                         | ٠ | • | •        | •        | • |
| ORA      |         | x                | ×      | x             |               | x                         | ×                   | x                                     |                      |                         | • | • | Λ        | $\land$  |   |
| ROL      | x       |                  | x      |               |               | x                         | x                   | · · · · · · · · · · · · · · · · · · · |                      |                         | ٠ | • |          | Ι Λ      | 1 |
| ROR      | ĸ       |                  | x      |               |               | x                         | x                   |                                       | ··· ·                |                         | ٠ | • | Λ        | , ^      | 1 |
| RSP      | x       |                  |        |               |               |                           | · · ·               |                                       |                      |                         | ٠ | • | •        | •        | ļ |
| RTI      | x       |                  |        |               |               |                           |                     |                                       |                      |                         | ? | ? | ?        | ?        | 2 |
| RTS      | x       |                  |        |               |               |                           |                     |                                       |                      |                         | • | • | •        | •        |   |
| SBC      |         | ×                | ×      | ×             |               | ×                         | ×                   | x                                     |                      |                         | ٠ | • | Λ        |          | 7 |
| SEC      | ×       |                  |        |               |               |                           |                     |                                       |                      |                         | • | • | ٠        | •        | 1 |
| SEI      | x       |                  |        |               |               |                           |                     |                                       |                      |                         | ٠ | 1 | •        | •        |   |
| STA      | † †     |                  | x      | ×             |               | ×                         | ×                   | x                                     |                      |                         | ٠ | • | Λ        | $\wedge$ |   |
| STX      | 1       |                  | x      | ×             |               | x                         | ×                   | x                                     |                      |                         | ٠ | ٠ | Λ        | $\wedge$ |   |
| SUB      | + +<br> | ×                | x      | x             |               | ×                         | ×                   | x                                     |                      |                         | ٠ | • | Λ        | Λ        | 7 |
| SWI      | ×       |                  |        |               |               | <u> </u>                  |                     |                                       |                      |                         | ٠ | 1 | ٠        | •        |   |
| TAX      | x       |                  |        |               |               |                           | 1                   |                                       |                      |                         | ٠ | • | ٠        | ٠        | • |
| TST      | ×       |                  | x      |               |               | ×                         | x                   |                                       |                      |                         | ٠ | • | $\wedge$ | $\wedge$ | • |
| ТХА      | x       |                  |        |               |               | ·                         |                     |                                       |                      |                         | • | • | •        | •        |   |

Table 13 Instruction Set

Condition Code Symbols: H Half Carry (From Bit 3) I Interrupt Mask N Negative (Sign Bit)

N Z

Zero

Carry/Borrow Test and Set if True, Cleared Otherwise Not Affected C () ?

Load CC Register From Stack

|   | Bit Manip        | pulation      | Brnch | h Read/Modify/Write |     |       |     |     |      | itro       | Register/Memory |         |         |     |     |     |       |      |
|---|------------------|---------------|-------|---------------------|-----|-------|-----|-----|------|------------|-----------------|---------|---------|-----|-----|-----|-------|------|
|   | Test &<br>Branch | Set/<br>Clear | Rel   | DIR                 | A   | x     | X1  | ,xo | IMP  | IMP        | імм             | DIR     | EXT     | ,X2 | ,X1 | ,x0 |       |      |
|   | 0                | 1             | 2     | 3                   | 4   | 5     | 6   | 7   | 8    | 9          | A               | B       | C       | D   | E   | F   | ] + [ | HIGI |
| 0 | BRSETO           | BSETO         | BRA   |                     |     | NEQ   |     |     | RTI* | <u> </u>   |                 |         |         | SUB | •   |     | 0     | _    |
| 1 | BRCLRO           | BCLRO         | BRN   |                     |     | -     |     |     | RTS* | - 1        | :               |         |         | CMP |     |     | 1     | -    |
| 2 | BRSET1           | BSET1         | вні   |                     |     |       |     |     |      | -          | ;               |         |         | SBC |     |     | 2     | -    |
| 3 | BRCLR1           | BCLRI         | BLS   |                     | СОМ |       |     |     |      | i –        |                 |         |         | 3   | Ľ   |     |       |      |
| 4 | BR\$ET2          | BSET2         | BCC   |                     |     | LSR   |     |     | -    | , <u> </u> | 1               |         |         | AND |     |     | 4     | 0    |
| 5 | BRCLR2           | BCLR2         | BCS   |                     |     | -     |     |     | _    |            | Ī               |         |         | BIT |     |     | 5     | w    |
| 6 | BRSET3           | BSET3         | BNE   |                     |     | ROR   |     |     | - 1  | . –        | 1               |         |         | LDA |     |     | 6     |      |
| 7 | BRCLR3           | BCLR3         | BEQ   |                     |     | ASR   |     |     |      | TAX        | -               | STA(+1) |         |     |     |     |       | -    |
| 8 | BRSET4           | BSET4         | внсс  |                     |     | LSL/A | SL  |     | -    | CLC        |                 | EOR     |         |     |     |     |       |      |
| 9 | BRCLR4           | BCLR4         | BHCS  |                     |     | ROL   |     |     | ~    | SEC        |                 | ADC     |         |     |     |     |       |      |
| А | BRSET5           | BSET5         | BPL   |                     |     | DEC   |     |     |      | CLI        | -               |         |         | A   |     |     |       |      |
| В | BRCLR5           | BCLR5         | BMI   |                     |     | -     |     |     | -    | SEI        | ]               | ADD     |         |     |     |     |       | •    |
| с | BRSET6           | BSET6         | BMC   |                     | INC |       |     |     |      | RSP        | -               |         | JMP(-1) |     |     |     |       |      |
| D | BRCLR6           | BCLR6         | BMS   |                     |     | TST   |     |     | -    | NOP        | BSR*            | JSR(+3) |         |     |     |     |       |      |
| Е | BRSET7           | BSET7         | BIL   |                     |     |       |     |     |      |            | <u> </u>        | LDX     |         |     |     |     |       |      |
| F | BRCLR7           | BCLR7         | ខាអ   |                     |     | CLR   |     |     | -    | TXA        | ] - ]           |         | STX(+1) |     |     |     |       |      |
|   | 3/10             | 2/7           | 2/4   | 2/6                 | 1/4 | 1/4   | 2/7 | 1/6 | 1/*  | 1/2        | 2/2             | 2/4     | 3/5     | 3/6 | 2/5 | 1/4 |       |      |

[NOTE] 1. Undefined opcodes are marked with "-".
 2. The number at the bottom of each column denotes the number of bytes and the number of cycles required (Bytes/Cycles). Mnemonics followed by a "•" require a different number of cycles as follows: RTI 9 RTS 6 SWI 11 BSR 8
 3. ( ) indicates that the number in parenthesis must be added to the cycle count for that instruction.



#### Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300

#### HD68P05W0 USED FOR HD6805W1

The HD6805W1 provides mask option of the internal oscillator and low voltage inhibit, while the HD68P05W0 provides only crystal option and without low voltage inhibit function.

The address from \$0F7A to \$0FF1 cannot be used for user program because the self test program of the HD6805W1 (onchip ROM version) is located at these addresses.

In order to be pin compatible with the HD6805W1, the address of the HD68P05W0's ROM must be located at \$0080 – \$0FFF. Memory addresses \$1000 to \$1FFF should not be usable.



Figure 30 MCU Memory Structure (For 8k bytes)

 CAUTION – This 8k bytes type should not be used debugging on-chip ROM of the HD6805W1.

#### PRECAUTION TO USE EPROM ON THE PACKAGE 8-BIT SINGLE-CHIP MICROCOMPUTER

As this microcomputer takes a special packaging type with pin sockets on its surface, pay attention to the followings;

- Do not apply higher electro-static voltage or serge voltage etc. than maximum rating, or it may cause permanent damage to the device.
- (2) There are 28 pin sockets on its surface. When using 32k



Let the index-side four pins open. When using 24 pin EPROM, match its index and insert it into lower 24 pin sockets.

EPROM (24 pins), let the index-side four pins open.

- (3) When assembling this LSI into user's system products as well as the mask ROM type 8-bit single-chip microcomputer, pay attention to the followings to keep the good ohmic contact between EPROM pins and pin sockets.
  - (a) When soldering on a printe, circuit board, etc., keep its condition under 250°C within 10 seconds. Over-time/ temperature may cause the bonding solder of socket pins to meet and the sockets may drop.
  - (b) Keep out detergent or coater from the pin sockets at aft-solder flux removal or board coating. The flux or coater may make pin socket contactivity worse.
  - (c) Avoid the permanent use of this LSI under the evervibratory place and system.
  - (d) Repeating insertion/removal of EPROMs may damage the contactivity of the pin sockets, so it is recommended to assemble new ones to your system products.
  - Ask our sales agent about anything unclear.