

USER'S MANUAL

# Hitachi Single-chip Microcomputer H8/300L Series Programming Manual



# Hitachi Single-chip Microcomputer H8/300L Series Programming Manual



ADE-602-040

When using this document, keep the following in mind:

- 1. This document may, wholly or partially, be subject to change without notice.
- 2. All rights are reserved: No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without Hitachi's permission.
- 3. Hitachi will not be held responsible for any damage to the user that may result from accidents or any other reasons during operation of the user's unit according to this document.
- 4. Circuitry and other examples described herein are meant merely to indicate the characteristics and performance of Hitachi's semiconductor products. Hitachi assumes no responsibility for any intellectual property claims or other problems that may result from applications based on the examples described herein.
- 5. No license is granted by implication or otherwise under any patents or other rights of any third party or Hitachi, Ltd.
- 6. MEDICAL APPLICATIONS: Hitachi's products are not authorized for use in MEDICAL APPLICATIONS without the written consent of the appropriate officer of Hitachi's sales company. Such use includes, but is not limited to, use in life support systems. Buyers of Hitachi's products are requested to notify the relevant Hitachi sales offices when planning to use the products in MEDICAL APPLICATIONS.

## Preface

The H8/300L Series of single-chip microcomputers is built around the high-speed H8/300L CPU, with an architecture featuring eight 16-bit (or sixteen 8-bit) general registers and a concise, optimized instruction set.

This manual gives detailed descriptions of the H8/300L instructions. The descriptions apply to all chips in the H8/300L Series. Assembly-language programmers should also read the separate H8/300 Series Cross Assembler User's Manual.

For hardware details, refer to the hardware manual of the specific chip.

# Contents

| Sec | ection 1. CPU 1 |                                                   |    |  |  |  |
|-----|-----------------|---------------------------------------------------|----|--|--|--|
| 1.1 | 1 Overview      |                                                   |    |  |  |  |
|     | 1.1.1 F         | eatures                                           | 1  |  |  |  |
|     | 1.1.2 D         | ata Structure                                     | 2  |  |  |  |
|     | 1.1.3 A         | ddress Space                                      | 4  |  |  |  |
|     | 1.1.4 R         | egister Configuration                             | 5  |  |  |  |
| 1.2 | Registers       | 3                                                 | 6  |  |  |  |
|     | 1.2.1 G         | eneral Registers                                  | 6  |  |  |  |
|     | 1.2.2 C         | ontrol Registers                                  | 6  |  |  |  |
|     | 1.2.3 Ir        | nitial Register Values                            | 7  |  |  |  |
| 1.3 | Instructio      | ons                                               | 8  |  |  |  |
|     | 1.3.1 T         | ypes of Instructions                              | 8  |  |  |  |
|     | 1.3.2 Ir        | nstruction Functions                              | 9  |  |  |  |
|     | 1.3.3 B         | asic Instruction Formats                          | 20 |  |  |  |
|     | 1.3.4 A         | ddressing Modes and Effective Address Calculation | 26 |  |  |  |
|     |                 |                                                   |    |  |  |  |
| Sec | tion 2. I       | nstruction Set                                    | 31 |  |  |  |
| 2.1 | Explanat        | ion Format                                        | 31 |  |  |  |
| 2.2 | Instructio      | ons                                               | 36 |  |  |  |
|     | 2.2.1 (1)       | ADD (add binary) (byte)                           | 36 |  |  |  |
|     | 2.2.1 (2)       | ADD (add binary) (word)                           | 37 |  |  |  |
|     | 2.2.2           | ADDS (add with sign extension)                    | 38 |  |  |  |
|     | 2.2.3           | ADDX (add with extend carry)                      | 39 |  |  |  |
|     | 2.2.4           | AND (AND logical)                                 | 40 |  |  |  |
|     | 2.2.5           | ANDC (AND control register)                       | 41 |  |  |  |
|     | 2.2.6           | BAND (bit AND)                                    | 42 |  |  |  |
|     | 2.2.7           | Bcc (branch conditionally)                        | 43 |  |  |  |
|     | 2.2.8           | BCLR (bit clear)                                  | 46 |  |  |  |
|     | 2.2.9           | BIAND (bit invert AND)                            | 48 |  |  |  |
|     | 2.2.10          | BILD (bit invert load)                            | 49 |  |  |  |
|     | 2.2.11          | BIOR (bit invert inclusive OR)                    | 50 |  |  |  |
|     | 2.2.12          | BIST (bit invert store)                           | 51 |  |  |  |
|     | 2.2.13          | BIXOR (bit invert exclusive OR)                   | 52 |  |  |  |
|     | 2.2.14          | BLD (bit load)                                    | 53 |  |  |  |
|     | 2.2.15          | BNOT (bit NOT)                                    | 54 |  |  |  |

| 2.2.16     | BOR (bit inclusive OR)                 |    |
|------------|----------------------------------------|----|
| 2.2.17     | BSET (bit set)                         |    |
| 2.2.18     | BSR (branch to subroutine)             |    |
| 2.2.19     | BST (bit store)                        | 60 |
| 2.2.20     | BTST (bit test)                        | 61 |
| 2.2.21     | BXOR (bit exclusive OR)                |    |
| 2.2.22 (1) | CMP (compare) (byte)                   |    |
| 2.2.22 (2) | CMP (compare) (word)                   |    |
| 2.2.23     | DAA (decimal adjust add)               |    |
| 2.2.24     | DAS (decimal adjust subtract)          | 68 |
| 2.2.25     | DEC (decrement)                        |    |
| 2.2.26     | DIVXU (divide extend as unsigned)      |    |
| 2.2.27     | EEPMOV (move data to EEPROM)           |    |
| 2.2.28     | INC (increment)                        |    |
| 2.2.29     | JMP (jump)                             |    |
| 2.2.30     | JSR (jump to subroutine)               |    |
| 2.2.31     | LDC (load to control register)         |    |
| 2.2.32 (1) | MOV (move data) (byte)                 |    |
| 2.2.32 (2) | MOV (move data) (word)                 |    |
| 2.2.32 (3) | MOV (move data) (byte)                 |    |
| 2.2.32 (4) | MOV (move data) (word)                 |    |
| 2.2.32 (5) | MOV (move data) (byte)                 |    |
| 2.2.32 (6) | MOV (move data) (word)                 |    |
| 2.2.33     | MULXU (multiply extend as unsigned)    |    |
| 2.2.34     | NEG (negate)                           |    |
| 2.2.35     | NOP (no operation)                     |    |
| 2.2.36     | NOT (NOT = logical complement)         |    |
| 2.2.37     | OR (inclusive OR logical)              |    |
| 2.2.38     | ORC (inclusive OR control register)    |    |
| 2.2.39     | POP (pop data)                         |    |
| 2.2.40     | PUSH (push data)                       |    |
| 2.2.41     | ROTL (rotate left)                     |    |
| 2.2.42     | ROTR (rotate right)                    |    |
| 2.2.43     | ROTXL (rotate with extend carry left)  |    |
| 2.2.44     | ROTXR (rotate with extend carry right) |    |
| 2.2.45     | RTE (return from exception)            |    |
| 2.2.46     | RTS (return from subroutine)           |    |

|     | 2.2.47                                            | SHAL (shift arithmetic left)               | 98  |  |  |
|-----|---------------------------------------------------|--------------------------------------------|-----|--|--|
|     | 2.2.48                                            | SHAR (shift arithmetic right)              | 99  |  |  |
|     | 2.2.49                                            | SHLL (shift logical left)                  | 100 |  |  |
|     | 2.2.50                                            | SHLR (shift logical right)                 | 101 |  |  |
|     | 2.2.51                                            | SLEEP (sleep)                              | 102 |  |  |
|     | 2.2.52                                            | STC (store from control register)          | 103 |  |  |
|     | 2.2.53 (1)                                        | SUB (subtract binary) (byte)               | 104 |  |  |
|     | 2.2.53 (2)                                        | SUB (subtract binary) (word)               | 105 |  |  |
|     | 2.2.54                                            | SUBS (subtract with sign extension)        | 106 |  |  |
|     | 2.2.55                                            | SUBX (subtract with extend carry)          | 107 |  |  |
|     | 2.2.56                                            | XOR (exclusive OR logical)                 | 108 |  |  |
|     | 2.2.57                                            | XORC (exclusive OR control register)       | 109 |  |  |
| 2.3 | Operation                                         | Code Map                                   | 110 |  |  |
| 2.4 | List of Inst                                      | tructions                                  | 112 |  |  |
| 2.5 | Number of                                         | Execution States                           | 119 |  |  |
|     |                                                   |                                            |     |  |  |
| Sec | tion 3. CI                                        | PU Operation States                        | 127 |  |  |
| 3.1 | Program E                                         | xecution State                             | 128 |  |  |
| 3.2 | Exception                                         | Handling States                            | 128 |  |  |
|     | 3.2.1                                             | Types and Priorities of Exception Handling | 128 |  |  |
|     | 3.2.2                                             | Exception Sources and Vector Table         | 129 |  |  |
|     | 3.2.3                                             | Outline of Exception Handling Operation    | 130 |  |  |
| 3.3 | Reset State                                       | 2                                          | 131 |  |  |
| 3.4 | 4 Power-Down State                                |                                            |     |  |  |
|     |                                                   |                                            |     |  |  |
| Sec | tion 4. Ba                                        | asic Operation Timing                      | 133 |  |  |
| 4.1 | 1 On-chip Memory (RAM, ROM)                       |                                            |     |  |  |
| 4.2 | 2 On-chip Peripheral Modules and External Devices |                                            |     |  |  |
|     |                                                   |                                            |     |  |  |
|     |                                                   |                                            |     |  |  |

## Section 1. CPU

## 1.1 Overview

The H8/300L CPU at the heart of the H8/300L Series features 16 general registers of 8 bits each (or 8 registers of 16-bits each), and a concise, optimized instruction set geared to high-speed operation.

## 1.1.1 Features

The H8/300L CPU has the following features.

General register configuration 16 8-bit registers (can be used as 8 16-bit registers)

55 basic instructions

- Multiply and divide instructions
- Powerful bit manipulation instructions

8 addressing modes

- Register direct (Rn)
- Register indirect (@Rn)
- Register indirect with displacement (@(d:16, Rn))
- Register indirect with post-increment/pre-decrement (@Rn+/@-Rn)
- Absolute address (@aa:8/@aa:16)
- Immediate (#xx:8/#xx:16)
- Program-counter relative (@(d:8, PC))
- Memory indirect (@@aa:8)

64-kbyte address space

High-speed operation

- All frequently used instructions are executed in 2 to 4 states
- High-speed operating frequency: 5 MHz Add/subtract between 8/16-bit registers: 0.4 μs 8 × 8-bit multiply: 2.8 μs 16 ÷ 8-bit divide: 2.8 μs

Low-power operation

• Transition to power-down state using SLEEP instruction

## 1.1.2 Data Structure

The H8/300L CPU can process 1-bit data, 4-bit (packed BCD) data, 8-bit (byte) data, and 16-bit (word) data.

- Bit manipulation instructions operate on 1-bit data specified as bit n (n = 0, 1, 2, ..., 7) in a byte operand.
- All operational instructions except ADDS and SUBS can operate on byte data.
- The MOV.W, ADD.W, SUB.W, CMP.W, ADDS, SUBS, MULXU (8 bits × 8 bits), and DIVXU (16 bits ÷ 8 bits) instructions operate on word data.
- The DAA and DAS instruction perform decimal arithmetic adjustments on byte data in packed BCD form. Each 4-bit of the byte is treated as a decimal digit.

**Data Structure in General Registers:** Data of all the sizes above can be stored in general registers as shown in figure 1-1.

| Data type                                                                                                                 | Register No. | Data format                      |
|---------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------|
| 1-Bit data                                                                                                                | RnH          | 7 0<br>76543210 Don't-care       |
| 1-Bit data                                                                                                                | RnL          | 7 0<br>Don't-care 76543210       |
| Byte data                                                                                                                 | RnH          | 7 0                              |
| Byte data                                                                                                                 | RnL          | 7 0<br>Don't-care                |
| Word data                                                                                                                 | Rn           |                                  |
| 4-Bit BCD data                                                                                                            | RnH          | 7 43 0<br>Upper Lower Don't-care |
| 4-Bit BCD data                                                                                                            | RnL          | 7 43 0<br>Don't-care Upper Lower |
| RnH:Upper 8 bits of General RegisterRnL:Lower 8 bits of General RegisterMSB:Most Significant BitLSB:Least Significant Bit |              |                                  |

Figure 1-1. Register Data Structure

**Data Structure in Memory:** Figure 1-2 shows the structure of data in memory. The H8/300L CPU is able to access word data in memory (MOV.W instruction), but only if the word data starts from an even-numbered address. If an odd address is designated, no address error occurs, but the access is performed starting from the previous even address, with the least significant bit of the address regarded as 0.\* The same applies to instruction codes.

\* Note that the LSIs in the H8/300L Series also contain on-chip peripheral modules for which access in word size is not possible. Details are given in the applicable hardware manual.

| Data type                                                     | Address                     | Data format                   |
|---------------------------------------------------------------|-----------------------------|-------------------------------|
|                                                               |                             | 7 0                           |
| 1-Bit data                                                    | Address n                   | 76543210                      |
| Byte data                                                     | Address n                   |                               |
| Word data                                                     | Even address<br>Odd address | Upper 8 bits     Lower 8 bits |
| Byte data (CCR) on stack                                      | Even address<br>Odd address |                               |
| Word data on stack                                            | Even address<br>Odd address | Upper 8 bits                  |
|                                                               |                             |                               |
| CCR: Condition code register.                                 |                             |                               |
| Note: Word data must begin at an<br>*: Ignored when returned. | even address.               |                               |

Figure 1-2. Memory Data Formats

The stack is always accessed a word at a time. When the CCR is pushed on the stack, two identical copies of the CCR are pushed to make a complete word. When they are returned, the lower byte is ignored.

## 1.1.3 Address Space

The H8/300L CPU supports a 64-Kbyte address space (program code + data). The memory map differs depending on the particular chip in the H8/300L Series and its operating mode. See the applicable hardware manual for details.

## 1.1.4 Register Configuration

Figure 1-3 shows the register configuration of the H8/300L CPU. There are 16 8-bit general registers (R0H, R0L, ..., R7H, R7L), which can also be accessed as eight 16-bit registers (R0 to R7). There are two control registers: the 16-bit program counter (PC) and the 8-bit condition code register (CCR).



Figure 1-3. CPU Registers

## **1.2 Registers**

#### 1.2.1 General Registers

All the general registers can be used as both data registers and address registers. When used as address registers, the general registers are accessed as 16-bit registers (R0 to R7). When used as data registers, they can be accessed as 16-bit registers (R0 to R7), or the high (R0H to R7H) and low (R0L to R7L) bytes can be accessed separately as 8-bit registers. The register length is determined by the instruction.

R7 also functions as the stack pointer, used implicitly by hardware in processing interrupts and subroutine calls. In assembly language, the letters SP can be coded as a synonym for R7. As indicated in figure 1-4, R7 (SP) points to the top of the stack.



Figure 1-4. Stack Pointer

#### **1.2.2 Control Registers**

The CPU has a 16-bit program counter (PC) and an 8-bit condition code register (CCR).

(1) **Program Counter (PC):** This 16-bit register indicates the address of the next instruction the CPU will execute. Instructions are fetched by 16-bit (word) access, so the least significant bit of the PC is ignored (always regarded as 0).

(2) Condition Code Register (CCR): This 8-bit register indicates the internal status of the CPU with an interrupt mask (I) bit and five flag bits: half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags. The two unused bits are available to the user. The bit configuration of the condition code register is shown below.



**Bit 7—Interrupt Mask Bit (I):** When this bit is set to 1, all interrupts except NMI are masked. This bit is set to 1 automatically at the start of interrupt handling.

**Bits 6 and 4—User Bits (U):** These bits can be written and read by software for its own purposes using LDC, STC, ANDC, ORC, and XORC instructions.

**Bit 5—Half-Carry (H):** This bit is used by add, subtract, and compare instructions to indicate a borrow or carry out of bit 3 or bit 11. It is referenced by the decimal adjust instructions.

Bit 3—Negative (N): This bit indicates the value of the most significant bit (sign bit) of the result of an instruction.

Bit 2—Zero (Z): This bit is set to 1 to indicate a zero result and cleared to 0 to indicate a nonzero result.

**Bit 1—Overflow** (V): This bit is set to 1 when an arithmetic overflow occurs, and cleared to 0 at other times.

Bit 0—Carry (C): This bit is used by:

- Add, subtract, and compare instructions, to indicate a carry or borrow at the most significant bit
- Shift and rotate instructions, to store the value shifted out of the most or least significant bit
- Bit manipulation instructions, as a bit accumulator

Note that some instructions involve no flag changes. The flag operations with each instruction are indicated in the individual instruction descriptions that follow in section 2, Instruction Set. CCR is used by LDC, STC, ANDC, ORC, and XORC instructions. The N, Z, V, and C flags are used by the conditional branch instruction (Bcc).

## 1.2.3 Initial Register Values

When the CPU is reset, the program counter (PC) is loaded from the vector table and the interrupt mask bit (I) in CCR is set to 1. The other CCR bits and the general registers are not initialized.

The initial value of the stack pointer (R7) is not fixed. To prevent program crashes the stack pointer should be initialized by software, by the first instruction executed after a reset.

## **1.3 Instructions**

Features:

- The H8/300L CPU has a concise set of 55 instructions.
- A general-register architecture is adopted.
- All instructions are 2 or 4 bytes long.
- Fast multiply/divide instructions and extensive bit manipulation instructions are supported.
- Eight addressing modes are supported.

#### 1.3.1 Types of Instructions

Table 1-1 classifies the H8/300L instructions by type. Section 2, Instruction Set, gives detailed descriptions.

| Function              | Instructions                                | Types |
|-----------------------|---------------------------------------------|-------|
| Data transfer         | MOV, POP*, PUSH*                            | 1     |
| Arithmetic operations | ADD, SUB, ADDX, SUBX, INC, DEC, ADDS, SUBS, | 14    |
|                       | DAA, DAS, MULXU, DIVXU, CMP, NEG            |       |
| Logic operations      | AND, OR, XOR, NOT                           | 4     |
| Shift                 | SHAL, SHAR, SHLL, SHLR, ROTL, ROTR, ROTXL,  | 8     |
|                       | ROTXR                                       |       |
| Bit manipulation      | BSET, BCLR, BNOT, BTST, BAND, BIAND, BOR    | 14    |
|                       | BIOR, BXOR, BIXOR, BLD, BILD, BST, BIST     |       |
| Branch                | Bcc**, JMP, BSR, JSR, RTS                   | 5     |
| System control        | RTE, SLEEP, LDC, STC, ANDC, ORC, XORC, NOP  | 8     |
| Block data transfer   | EEPMOV                                      | 1     |
|                       | Tota                                        | 1 55  |

#### Table 1-1. Instruction Classification

\* POP Rn is equivalent to MOV.W @SP+, Rn.

PUSH Rn is equivalent to MOV.W Rn, @-SP.

\*\* Bcc is a conditional branch instruction in which cc represents a condition.

## **1.3.2 Instruction Functions**

Tables 1-2 to 1-9 give brief descriptions of the instructions in each functional group. The following notation is used.

| Notation                                                                                                                                                                                                                                                                    |                                   |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|--|
| Rd                                                                                                                                                                                                                                                                          | General register (destination)    |  |  |  |
| Rs                                                                                                                                                                                                                                                                          | General register (source)         |  |  |  |
| Rn                                                                                                                                                                                                                                                                          | General register                  |  |  |  |
| (EAd)                                                                                                                                                                                                                                                                       | Destination operand               |  |  |  |
| (EAs)                                                                                                                                                                                                                                                                       | Source operand                    |  |  |  |
| CCR                                                                                                                                                                                                                                                                         | Condition code register           |  |  |  |
| N                                                                                                                                                                                                                                                                           | N (negative) bit of CCR           |  |  |  |
| Ζ                                                                                                                                                                                                                                                                           | Z (zero) bit of CCR               |  |  |  |
| Z<br>V                                                                                                                                                                                                                                                                      | V (overflow) bit of CCR           |  |  |  |
| С                                                                                                                                                                                                                                                                           | C (carry) bit of CCR              |  |  |  |
| PC                                                                                                                                                                                                                                                                          | Program counter                   |  |  |  |
| SP                                                                                                                                                                                                                                                                          | Stack pointer (R7)                |  |  |  |
| #Imm                                                                                                                                                                                                                                                                        | Immediate data                    |  |  |  |
| ор                                                                                                                                                                                                                                                                          | Operation field                   |  |  |  |
| disp                                                                                                                                                                                                                                                                        | Displacement                      |  |  |  |
| +                                                                                                                                                                                                                                                                           | Addition                          |  |  |  |
| _                                                                                                                                                                                                                                                                           | Subtraction                       |  |  |  |
| ×                                                                                                                                                                                                                                                                           | Multiplication                    |  |  |  |
| ÷                                                                                                                                                                                                                                                                           | Division                          |  |  |  |
| ^                                                                                                                                                                                                                                                                           | AND logical                       |  |  |  |
| V                                                                                                                                                                                                                                                                           | OR logical                        |  |  |  |
| $\oplus$                                                                                                                                                                                                                                                                    | Exclusive OR logical              |  |  |  |
| $\begin{array}{c} + \\ \hline - \\ \times \\ \hline + \\ \hline \\ + \\ \sim \\ \hline \\ \\ \hline \\ \hline \\ \hline \\ \\ \\ \hline \\ \\ \\ \\ \hline \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\$ | Move                              |  |  |  |
|                                                                                                                                                                                                                                                                             | Not                               |  |  |  |
| :3, :8,                                                                                                                                                                                                                                                                     | 16 3-bit, 8-bit, or 16-bit length |  |  |  |

## Table 1-2. Data Transfer Instructions

| MOV | B/W | $(E \wedge a) \rightarrow D d \rightarrow (E \wedge d)$             |
|-----|-----|---------------------------------------------------------------------|
|     | •   | $(EAs) \rightarrow Rd, Rs \rightarrow (EAd)$                        |
|     |     | Moves data between two general registers or between a general       |
|     |     | register and memory, or moves immediate data to a general register. |
|     |     | The Rn, @Rn, @(d:16, Rn), @aa:16, #xx:8 or #xx:16, @-Rn, and        |
|     |     | @Rn+ addressing modes are available for byte or word data. The      |
|     |     | @aa:8 addressing mode is available for byte data only.              |
|     |     | The $@-R7$ and $@R7+$ modes require word operands. Do not           |
|     |     | specify byte size for these two modes.                              |
| POP | W   | $(@SP+ \rightarrow Rn)$                                             |
|     |     | Pops a 16-bit general register from the stack.                      |
|     |     | Equivalent to MOV.W @SP+, Rn.                                       |
|     |     | $Rn \rightarrow @-SP$                                               |
|     |     | Pushes a 16-bit general register onto the stack.                    |
|     |     | Equivalent to MOV.W Rn, @-SP.                                       |

\* Size: Operand size

B: Byte

W: Word

#### Instruction Size\* Function $Rd \pm Rs \rightarrow Rd, Rd + \#Imm \rightarrow Rd$ B/W ADD SUB Performs addition or subtraction on data in two general registers, or addition on immediate data and data in a general register. Immediate data cannot be subtracted from data in a general register. Word data can be added or subtracted only when both words are in general registers. В $Rd \pm Rs \pm C \rightarrow Rd, Rd \pm #Imm \pm C \rightarrow Rd$ ADDX SUBX Performs addition or subtraction with carry or borrow on byte data in two general registers, or addition or subtraction on immediate data and data in a general register. INC В $Rd \pm 1 \rightarrow Rd$ DEC Increments or decrements a general register. ADDS W $Rd \pm 1 \rightarrow Rd, Rd \pm 2 \rightarrow Rd$ SUBS Adds or subtracts immediate data to or from data in a general register. The immediate data must be 1 or 2. Rd decimal adjust $\rightarrow$ Rd В DAA DAS Decimal-adjusts (adjusts to packed BCD) an addition or subtraction result in a general register by referring to the condition code register. $Rd \times Rs \rightarrow Rd$ В MULXU Performs 8-bit $\times$ 8-bit unsigned multiplication on data in two general registers, providing a 16-bit result. DIVXU В $Rd \div Rs \rightarrow Rd$ Performs 16-bit ÷ 8-bit unsigned division on data in two general registers, providing an 8-bit quotient and 8-bit remainder. B/W Rd – #Imm CMP Rd - Rs, Compares data in a general register with data in another general register or with immediate data. Word data can be compared only between two general registers. $0 - Rd \rightarrow Rd$ В NEG Obtains the two's complement (arithmetic complement) of data in a general register.

## **Table 1-3.** Arithmetic Instructions

\* Size: Operand size

B: Byte

W: Word

| Table 1-4. | Logic | Operation | Instructions |
|------------|-------|-----------|--------------|
|------------|-------|-----------|--------------|

| Instruction | Size*                                           | Function                                                          |  |  |  |
|-------------|-------------------------------------------------|-------------------------------------------------------------------|--|--|--|
| AND         | В                                               | $Rd \wedge Rs \rightarrow Rd, Rd \wedge \#Imm \rightarrow Rd$     |  |  |  |
|             |                                                 | Performs a logical AND operation on a general register and        |  |  |  |
|             |                                                 | another general register or immediate data.                       |  |  |  |
| OR          | В                                               | $Rd \lor Rs \to Rd, Rd \lor \#Imm \to Rd$                         |  |  |  |
|             |                                                 | Performs a logical OR operation on a general register and another |  |  |  |
|             |                                                 | general register or immediate data.                               |  |  |  |
| XOR         | В                                               | $Rd \oplus Rs \to Rd,  Rd \oplus \#Imm \to Rd$                    |  |  |  |
|             |                                                 | Performs a logical exclusive OR operation on a general register   |  |  |  |
|             | and another general register or immediate data. |                                                                   |  |  |  |
| NOT         | В                                               | $\neg Rd \rightarrow Rd$                                          |  |  |  |
|             |                                                 | Obtains the one's complement (logical complement) of general      |  |  |  |
|             |                                                 | register contents.                                                |  |  |  |
|             |                                                 |                                                                   |  |  |  |

\* Size: Operand size

B: Byte

| Table | 1-5. | Shift | Instructions |
|-------|------|-------|--------------|
|-------|------|-------|--------------|

| Instruction | Size* | Function                                                             |  |
|-------------|-------|----------------------------------------------------------------------|--|
| SHAL        | В     | $Rd shift \rightarrow Rd$                                            |  |
| SHAR        |       | Performs an arithmetic shift operation on general register contents. |  |
| SHLL        | В     | $Rd shift \rightarrow Rd$                                            |  |
| SHLR        | -     | Performs a logical shift operation on general register contents.     |  |
| ROTL        | В     | Rd rotate $\rightarrow$ Rd                                           |  |
| ROTR        |       | Rotates general register contents.                                   |  |
| ROTXL       | В     | Rd rotate through carry $\rightarrow$ Rd                             |  |
| ROTXR       |       | Rotates general register contents through the C (carry) bit.         |  |

\* Size: Operand size

B: Byte

| Instruction | Size* | Function                                                                                                   |
|-------------|-------|------------------------------------------------------------------------------------------------------------|
| BSET        | В     | $1 \rightarrow ( of )$                                                                                     |
|             |       | Sets a specified bit in a general register or memory to 1. The bit is                                      |
|             |       | specified by a bit number, given in 3-bit immediate data or the lower                                      |
|             |       | three bits of a general register.                                                                          |
| BCLR        | В     | $0 \rightarrow (\langle \text{bit-No.} \rangle \text{ of } \langle \text{EAd} \rangle)$                    |
|             |       | Clears a specified bit in a general register or memory to 0. The bit                                       |
|             |       | is specified by a bit number, given in 3-bit immediate data or the lower                                   |
|             |       | three bits of a general register.                                                                          |
| BNOT        | В     | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> (<bit-no.> of <ead>)</ead></bit-no.></ead></bit-no.> |
|             |       | Inverts a specified bit in a general register or memory. The bit is                                        |
|             |       | specified by a bit number, given in 3-bit immediate data or the lower                                      |
|             |       | three bits of a general register.                                                                          |
| BTST        | В     | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z</ead></bit-no.>                                    |
|             |       | Tests a specified bit in a general register or memory and sets or                                          |
|             |       | clears the Z flag accordingly. The bit is specified by a bit number,                                       |
|             |       | given in 3-bit immediate data or the lower three bits of a general                                         |
|             |       | register.                                                                                                  |
| BAND        | В     | $C \land (\langle bit-No. \rangle of \langle EAd \rangle) \rightarrow C$                                   |
|             |       | ANDs the C flag with a specified bit in a general register or                                              |
|             |       | memory.                                                                                                    |
| BIAND       | В     | $C \land [\neg (\langle bit-No. \rangle of \langle EAd \rangle)] \rightarrow C$                            |
|             |       | ANDs the C flag with the inverse of a specified bit in a general                                           |
|             |       | register or memory.                                                                                        |
|             |       | The bit number is specified by 3-bit immediate data.                                                       |
| BOR         | В     | $C \lor (\langle bit-No. \rangle of \langle EAd \rangle) \rightarrow C$                                    |
|             |       | ORs the C flag with a specified bit in a general register or memory.                                       |
| BIOR        | В     | $C \vee [\neg (\langle bit-No. \rangle of \langle EAd \rangle)] \rightarrow C$                             |
|             |       | ORs the C flag with the inverse of a specified bit in a general                                            |
|             |       | register or memory.                                                                                        |
|             |       | The bit number is specified by 3-bit immediate data.                                                       |

## Table 1-6. Bit Manipulation Instructions

| Instruction | Size* | Function                                                                                |
|-------------|-------|-----------------------------------------------------------------------------------------|
| BXOR        | В     | $C \oplus (\langle bit-No. \rangle \text{ of } \langle EAd \rangle) \rightarrow C$      |
|             |       | Exclusive-ORs the C flag with a specified bit in a general register                     |
|             |       | or memory.                                                                              |
| BIXOR       | В     | $C \oplus [\neg(\langle bit-No. \rangle of \langle EAd \rangle)] \rightarrow C$         |
|             |       | Exclusive-ORs the C flag with the inverse of a specified bit in a                       |
|             |       | general register or memory.                                                             |
|             |       | The bit number is specified by 3-bit immediate data.                                    |
| BLD         | В     | $(\langle \text{bit-No.} \rangle \text{ of } \langle \text{EAd} \rangle) \rightarrow C$ |
|             |       | Copies a specified bit in a general register or memory to the C flag.                   |
| BILD        | В     | $\neg$ ( <bit-no.> of <ead>) <math>\rightarrow</math> C</ead></bit-no.>                 |
|             |       | Copies the inverse of a specified bit in a general register or                          |
|             |       | memory to the C flag.                                                                   |
|             |       | The bit number is specified by 3-bit immediate data.                                    |
| BST         | В     | $C \rightarrow (\langle bit-No. \rangle of \langle EAd \rangle)$                        |
|             |       | Copies the C flag to a specified bit in a general register or memory.                   |
| BIST        | В     | $\neg C \rightarrow (\langle bit-No. \rangle of \langle EAd \rangle)$                   |
|             |       | Copies the inverse of the C flag to a specified bit in a general                        |
|             |       | register or memory.                                                                     |
|             |       | The bit number is specified by 3-bit immediate data.                                    |

## Table 1-6. Bit Manipulation Instructions (Cont.)

\* Size: Operand size

B: Byte

| Instruction | Size | Function         |                                                                            |                             |  |  |  |  |  |  |
|-------------|------|------------------|----------------------------------------------------------------------------|-----------------------------|--|--|--|--|--|--|
| Всс         |      | Branches if con  | Branches if condition cc is true. The branching conditions are as follows. |                             |  |  |  |  |  |  |
|             |      | follows.         |                                                                            |                             |  |  |  |  |  |  |
|             |      | Mnemonic         | Description                                                                | Condition                   |  |  |  |  |  |  |
|             |      | BRA (BT)         | Always (True)                                                              | Always                      |  |  |  |  |  |  |
|             |      | BRN (BF)         | Never (False)                                                              | Never                       |  |  |  |  |  |  |
|             |      | BHI              | High                                                                       | $C \lor Z = 0$              |  |  |  |  |  |  |
|             |      | BLS              | Low or Same                                                                | $C \lor Z = 1$              |  |  |  |  |  |  |
|             |      | BCC (BHS)        | Carry Clear                                                                | C = 0                       |  |  |  |  |  |  |
|             |      |                  | (High or Same)                                                             |                             |  |  |  |  |  |  |
|             |      | BCS (BLO)        | Carry Set (Low)                                                            | C = 1                       |  |  |  |  |  |  |
|             |      | BNE              | Not Equal                                                                  | $\mathbf{Z} = 0$            |  |  |  |  |  |  |
|             |      | BEQ              | Equal                                                                      | Z = 1                       |  |  |  |  |  |  |
|             |      | BVC              | Overflow Clear                                                             | V = 0                       |  |  |  |  |  |  |
|             |      | BVS              | Overflow Set                                                               | V = 1                       |  |  |  |  |  |  |
|             |      | BPL              | Plus                                                                       | N = 0                       |  |  |  |  |  |  |
|             |      | BMI              | Minus                                                                      | N = 1                       |  |  |  |  |  |  |
|             |      | BGE              | Greater or Equal                                                           | $N \oplus V = 0$            |  |  |  |  |  |  |
|             |      | BLT              | Less Than                                                                  | $N \oplus V = 1$            |  |  |  |  |  |  |
|             |      | BGT              | Greater Than                                                               | $Z \lor (N \oplus V) = 0$   |  |  |  |  |  |  |
|             |      | BLE              | Less or Equal                                                              | $Z \lor (N \oplus V) = 1$   |  |  |  |  |  |  |
|             |      |                  | 1                                                                          | 11                          |  |  |  |  |  |  |
| JMP         |      |                  | ditionally to a specified a                                                |                             |  |  |  |  |  |  |
| BSR         |      |                  | ibroutine at a specified di                                                | splacement from the current |  |  |  |  |  |  |
|             |      | address.         |                                                                            |                             |  |  |  |  |  |  |
| JSR         |      |                  | ibroutine at a specified ad                                                | ldress.                     |  |  |  |  |  |  |
| RTS         |      | Returns from a s | Returns from a subroutine.                                                 |                             |  |  |  |  |  |  |

## **Table 1-7. Branching Instructions**

| Instruction | Size* | Function                                                            |
|-------------|-------|---------------------------------------------------------------------|
| RTE         |       | Returns from an exception handling routine.                         |
| SLEEP       |       | Causes a transition to power-down state.                            |
| LDC         | В     | $Rs \rightarrow CCR, \#Imm \rightarrow CCR$                         |
|             |       | Moves immediate data or general register contents to the condition  |
|             |       | code register.                                                      |
| STC         | В     | $CCR \rightarrow Rd$                                                |
|             |       | Copies the condition code register to a specified general register. |
| ANDC        | В     | $CCR \land \#Imm \rightarrow CCR$                                   |
|             |       | Logically ANDs the condition code register with immediate data.     |
| ORC         | В     | $CCR \lor \#Imm \rightarrow CCR$                                    |
|             |       | Logically ORs the condition code register with immediate data.      |
| XORC        | В     | $CCR \oplus \#Imm \rightarrow CCR$                                  |
|             |       | Logically exclusive-ORs the condition code register with immediate  |
|             |       | data.                                                               |
| NOP         |       | $PC + 2 \rightarrow PC$                                             |
|             |       | Only increments the program counter.                                |

## Table 1-8. System Control Instructions

\* Size: Operand size

B: Byte

## Table 1-9. Block Data Transfer Instruction

| Instruction | Size | Function                                                                  |
|-------------|------|---------------------------------------------------------------------------|
| EEPMOV      |      | if $R4L \neq 0$ then                                                      |
|             |      | repeat $@R5+ \rightarrow @R6+$                                            |
|             |      | $R4L - 1 \rightarrow R4L$                                                 |
|             |      | until $R4L = 0$                                                           |
|             |      | else next;                                                                |
|             |      | Moves a data block according to parameters set in general registers       |
|             |      | R4L, R5, and R6.                                                          |
|             |      | R4L: size of block (bytes)                                                |
|             |      | R5: starting source address                                               |
|             |      | R6: starting destination address                                          |
|             |      | Execution of the next instruction starts as soon as the block transfer is |
|             |      | completed.                                                                |
|             |      | This instruction is for writing to the large-capacity EEPROM provided     |
|             |      | on chip with some models in the H8/300L Series. For details see the       |
|             |      | applicable hardware manual.                                               |

**Notes on Bit Manipulation Instructions:** BSET, BCLR, BNOT, BST, and BIST are readmodify-write instructions. They read a byte of data, modify one bit in the byte, then write the byte back. Care is required when these instructions are applied to registers with write-only bits and to the I/O port registers.

| Se                                                             | equence                                          | Operation                                                  |  |  |  |  |  |
|----------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------|--|--|--|--|--|
| 1                                                              | Read Read one data byte at the specified address |                                                            |  |  |  |  |  |
| 2                                                              | Modify                                           | Modify one bit in the data byte                            |  |  |  |  |  |
| 3 Write Write the modified data byte back to the specified add |                                                  | Write the modified data byte back to the specified address |  |  |  |  |  |

**Example 1:** BCLR is executed to clear bit 0 in port control register 4 (PCR4) under the following conditions.

| P47:       | Input pin, Low   |
|------------|------------------|
| P46:       | Input pin, High  |
| P45 – P40: | Output pins, Low |

The intended purpose of this BCLR instruction is to switch P40 from output to input.

### **Before Execution of BCLR Instruction**

|              | P47   | P46   | P45    | <b>P4</b> 4 | P43    | P42    | P41    | P40    |
|--------------|-------|-------|--------|-------------|--------|--------|--------|--------|
| Input/output | Input | Input | Output | Output      | Output | Output | Output | Output |
| Pin state    | Low   | High  | Low    | Low         | Low    | Low    | Low    | Low    |
| PCR4         | 0     | 0     | 1      | 1           | 1      | 1      | 1      | 1      |
| PDR4         | 1     | 0     | 0      | 0           | 0      | 0      | 0      | 0      |

## **Execution of BCLR Instruction**

BCLR #0 @PCR4 ; clear bit 0 in PCR4

## After Execution of BCLR Instruction

|              | P47    | P46    | P45    | P44    | P43    | P42    | P41    | P40   |
|--------------|--------|--------|--------|--------|--------|--------|--------|-------|
| Input/output | Output | Input |
| Pin state    | Low    | High   | Low    | Low    | Low    | Low    | Low    | High  |
| PCR4         | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 0     |
| PDR4         | 1      | 0      | 0      | 0      | 0      | 0      | 0      | 0     |

**Explanation:** To execute the BCLR instruction, the CPU begins by reading PCR4. Since PCR4 is a write-only register, it is read as H'FF, even though its true value is H'3F.

Next the CPU clears bit 0 of the read data, changing the value to H'FE.

Finally, the CPU writes this value (H'FE) back to PCR4 to complete the BCLR instruction.

As a result, bit 0 in PCR4 is cleared to 0, making P40 an input pin. In addition, bits 7 and 6 in PCR4 are set to 1, making P47 and P46 output pins.

**Example 2:** BSET is executed to set bit 0 in the port 4 port data register (PDR4) under the following conditions.

P47: Input pin, Low

P46: Input pin, High

P45 – P40: Output pins, Low

The intended purpose of this BSET instruction is to switch the output level at P40 from Low to High.

#### **Before Execution of BSET Instruction**

|              | P47   | P46   | P45    | P44    | P43    | P42    | P41    | P40    |
|--------------|-------|-------|--------|--------|--------|--------|--------|--------|
| Input/output | Input | Input | Output | Output | Output | Output | Output | Output |
| Pin state    | Low   | High  | Low    | Low    | Low    | Low    | Low    | Low    |
| PCR4         | 0     | 0     | 1      | 1      | 1      | 1      | 1      | 1      |
| PDR4         | 1     | 0     | 0      | 0      | 0      | 0      | 0      | 0      |

## **Execution of BSET Instruction**

BSET #0 @PDR4 ; set bit 0 in port 4 port data register

#### After Execution of BSET Instruction

|              | P47   | P46   | P45    | P44    | P43    | P42    | P41    | P40    |
|--------------|-------|-------|--------|--------|--------|--------|--------|--------|
| Input/output | Input | Input | Output | Output | Output | Output | Output | Output |
| Pin state    | Low   | High  | Low    | Low    | Low    | Low    | Low    | High   |
| PCR4         | 0     | 0     | 1      | 1      | 1      | 1      | 1      | 1      |
| PDR4         | 0     | 1     | 0      | 0      | 0      | 0      | 0      | 1      |

**Explanation:** To execute the BSET instruction, the CPU begins by reading port 4. Since P47 and P46 are input pins, the CPU reads the level of these pins directly, not the value in the port data register. It reads P47 as Low (0) and P46 as High (1).

Since P45 to P40 are output pins, for these pins the CPU reads the value in PDR4. The CPU therefore reads the value of port 4 as H'40, although the actual value in PDR4 is H'80.

Next the CPU sets bit 0 of the read data to 1, changing the value to H'41.

Finally, the CPU writes this value (H'41) back to PDR4 to complete the BSET instruction.

As a result, bit 0 in PDR4 is set to 0, switching pin P40 to High output. However, bits 7 and 6 in PDR4 change their values.

## **1.3.3 Basic Instruction Formats**

(1) Format of Data Transfer Instructions

Figure 1-5 shows the format used for data transfer instructions.

| 15 8 7 0                                         | MOV                                               |
|--------------------------------------------------|---------------------------------------------------|
| op r <sub>m</sub> r <sub>n</sub>                 | $Rm \rightarrow Rn$                               |
| 15 8 7 0                                         |                                                   |
| op r <sub>m</sub> r <sub>n</sub>                 | $Rn \rightarrow @Rm$ , or $@Rm \rightarrow Rn$    |
| 15 8 7 0                                         |                                                   |
| op r <sub>m</sub> r <sub>n</sub>                 | @(d:16, Rm) $\rightarrow$ Rn, or                  |
| disp.                                            | $Rn \rightarrow @(d:16, Rm)$                      |
| 15 8 7 0                                         |                                                   |
| op r <sub>m</sub> r <sub>n</sub>                 | @Rm+ $\rightarrow$ Rn, or Rn $\rightarrow$ @-Rm   |
| 15 8 7 0                                         |                                                   |
| op r <sub>n</sub> abs.                           | @aa:8 $\rightarrow$ Rn, or Rn $\rightarrow$ @aa:8 |
| 15 8 7 0                                         |                                                   |
| op r <sub>n</sub>                                | @aa:16 $\rightarrow$ Rn, or                       |
| abs.                                             | $Rn \rightarrow @aa:16$                           |
| 15 8 7 0                                         |                                                   |
| op r <sub>n</sub> IMM                            | #xx:8 → Rn                                        |
|                                                  |                                                   |
| 15 8 7 0                                         |                                                   |
| op r <sub>n</sub>                                | #xx:16 → Rn                                       |
| IMM                                              |                                                   |
| 15 8 7 0                                         |                                                   |
| op r <sub>n</sub>                                | POP, PUSH                                         |
|                                                  |                                                   |
| Notation                                         |                                                   |
| op: Operation field                              |                                                   |
| r <sub>m</sub> , r <sub>n</sub> : Register field |                                                   |
| disp: Displacement                               |                                                   |
| abs.: Absolute address                           |                                                   |
| IMM: Immediate data                              |                                                   |

Figure 1-5. Instruction Format of Data Transfer Instructions

(2) Format of Arithmetic, Logic Operation, and Shift Instructions

Figure 1-6 shows the format used for arithmetic, logic operation, and shift instructions.

| 15                                        |                  | 8 | 7   |    | 0 |                            |
|-------------------------------------------|------------------|---|-----|----|---|----------------------------|
|                                           | ор               |   | ۲m  | rn |   | ADD, SUB, CMP (Rm)         |
|                                           |                  |   |     |    |   | ADDX, SUBX (Rm)            |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
|                                           | ор               |   |     | ٢n |   | ADDS, SUBS, INC, DEC, DAA, |
|                                           |                  |   |     |    |   | DAS, NEG, NOT              |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
|                                           | ор               |   |     | rn |   | MULXU, DIVXU               |
|                                           |                  |   |     |    |   |                            |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
| ор                                        | rn               |   | IMN | Λ  |   | ADD, ADDX, SUBX, CMP       |
|                                           |                  |   |     |    |   | (#xx:8)                    |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
|                                           | ор               |   | rm  | rn |   | AND, OR, XOR (Rm)          |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
| ор                                        | r <sub>n</sub>   | Ť | IMN | Λ  | Ť | AND, OR, XOR (#xx:8)       |
| L                                         |                  |   |     |    | J |                            |
| 15                                        |                  | 8 | 7   |    | 0 |                            |
|                                           | ор               |   |     | rn |   | SHAL, SHAR, SHLL, SHLR,    |
|                                           |                  |   |     |    |   | ROTL, ROTR, ROTXL, ROTXR   |
|                                           |                  |   |     |    |   |                            |
| Notation                                  | On another first |   |     |    |   |                            |
| op:                                       | Operation field  |   |     |    |   |                            |
| r <sub>m</sub> , r <sub>n</sub> :<br>IMM: | Register field   |   |     |    |   |                            |
|                                           | initieulate uato | а |     |    |   |                            |
|                                           |                  |   |     |    |   |                            |

Figure 1-6. Instruction Format of Arithmetic, Logic, and Shift Instructions

## (3) Format of Bit Manipulation Instructions

Figure 1-7 shows the format used for bit manipulation instructions.

| 15            | 8                                  | 7   |                       | 0              | BSET, BCLR, BNOT, BTST          |
|---------------|------------------------------------|-----|-----------------------|----------------|---------------------------------|
| r             | <br>op                             |     | IMM                   |                |                                 |
|               | OP                                 |     | IIVIIVI               | r <sub>n</sub> | Operand: register direct (Rn)   |
|               |                                    |     |                       |                | Bit No.: immediate (#xx:3)      |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               | ор                                 |     | r <sub>m</sub>        | r <sub>n</sub> | Operand: register direct (Rn)   |
|               |                                    |     |                       |                | Bit No .: register direct (Rm)  |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               | ор                                 | Т   | r <sub>n</sub>        | 0000           | Operand: register indirect (@Rn |
|               | ор                                 | -   | IMM                   | 0000           | Bit No.: immediate (#xx:3)      |
|               |                                    |     |                       |                |                                 |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               | ор                                 | T   | rn                    | 0000           | Operand: register indirect (@Rn |
|               | ор                                 |     | r <sub>m</sub>        | 0000           | Bit No.: register direct (Rm)   |
|               |                                    |     |                       |                |                                 |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               | ор                                 |     |                       | abs.           | Operand: absolute (@aa:8)       |
| ,             | ор                                 |     | IMM                   | 0000           | Bit No.: immediate (#xx:3)      |
|               | _                                  |     |                       | _              |                                 |
| 15            |                                    | 7   |                       | 0              |                                 |
|               | op                                 |     |                       | abs.           | Operand: absolute (@aa:8)       |
|               | ор                                 |     | r <sub>m</sub>        | 0000           | Bit No.: register direct (Rm)   |
|               |                                    |     |                       |                |                                 |
| 15            | 8                                  | 7   |                       | 0              | BAND, BOR, BXOR, BLD, BST       |
|               | ор                                 |     | IMM                   | r <sub>n</sub> | Operand: register direct (Rn)   |
|               |                                    |     |                       |                | Bit No.: immediate (#xx:3)      |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               |                                    | T T | r                     |                | Operand: register indirect (@Rn |
|               | op<br>op                           |     | r <sub>n</sub><br>IMM | 0000           |                                 |
|               |                                    |     |                       | 0000           | Bit No.: immediate (#xx:3)      |
| 15            | 8                                  | 7   |                       | 0              |                                 |
|               | ор                                 | Τ   | at                    | DS.            | Operand: absolute (@aa:8)       |
|               | ор                                 |     | IMM                   | 0000           | Bit No .: immediate (#xx:3)     |
| Matellar      |                                    |     |                       |                | 、 <i>、 、</i>                    |
| Notation      |                                    |     |                       |                |                                 |
| op:           | Operation field                    |     |                       |                |                                 |
| rm, rn:       | Register field                     |     |                       |                |                                 |
|               | بممتداء امم مقررا ممما ٨           | ~   |                       |                |                                 |
| abs.:<br>IMM: | Absolute address<br>Immediate data | 5   |                       |                |                                 |



| 15                           | 8                | 7              | 0    | BIAND, BIOR, BIXOR, BILD, BIS   |
|------------------------------|------------------|----------------|------|---------------------------------|
|                              |                  | IMM            | rn   | Operand: register direct (Rn)   |
| ·····                        |                  |                |      | Bit No.: immediate (#xx:3)      |
| 15                           | 8                | 7              | 0    |                                 |
|                              | ор               | r <sub>n</sub> | 0000 | Operand: register indirect (@Ri |
|                              | ор               | IMM            | 0000 | Bit No.: immediate (#xx:3)      |
| 15                           | 8                | 7              | 0    |                                 |
|                              | ор               | а              | bs.  | Operand: absolute (@aa:8)       |
|                              | ор               | IMM            | 0000 | Bit No.: immediate (#xx:3)      |
|                              |                  |                |      |                                 |
| lotation                     | า                |                |      |                                 |
| p:                           | Operation field  |                |      |                                 |
|                              | Register field   |                |      |                                 |
| m, rn:                       |                  |                |      |                                 |
| m, r <sub>n</sub> :<br>abs.: | Absolute address |                |      |                                 |



(4) Format of Branching Instructions

Figure 1-8 shows the format used for branching instructions.

| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|----------------|-----------------|-----|-----|----------------|----|-----|---|--------------|
| ор             | , CC            |     |     | disp           | ). |     |   | Bcc          |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                | ор              |     |     | r <sub>m</sub> | 0  | 00  | 0 | JMP (@Rm)    |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                |                 | 0   |     |                |    |     |   | JMP (@aa:16) |
|                |                 | ab  | S.  |                |    |     |   |              |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                | ор              |     |     | abs            | 5. |     |   | JMP (@@aa:8) |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                | ор              |     |     | dis            | p. |     |   | BSR          |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                | ор              | -   |     | r <sub>m</sub> | 0  | 0 0 | 0 | JSR (@Rm)    |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
|                |                 | op  |     |                |    |     |   | JSR (@aa:16) |
|                |                 | ab  |     |                |    |     |   | , ,          |
| 15             |                 | 8   | 7   |                |    |     | 0 |              |
| -              | ор              |     |     | abs            |    |     |   | JSR (@@aa:8) |
| 15             |                 | 8   | 7 · |                |    |     | 0 |              |
|                |                 |     | p   |                |    |     |   | RTS          |
|                |                 |     |     |                |    |     |   |              |
| lotatior       | n               |     |     |                |    |     |   |              |
| p:             | Operation field |     |     |                |    |     |   |              |
| c:             | Condition field |     |     |                |    |     |   |              |
| m <sup>:</sup> | Register field  |     |     |                |    |     |   |              |
| isp.:          | Displacement    |     |     |                |    |     |   |              |
| bs.:           | Absolute addre  | ess |     |                |    |     |   |              |

**Figure 1-8. Instruction Format of Branching Instructions** 

### (5) Format of System Control Instructions

Figure 1-9 shows the format used for system control instructions.



## Figure 1-9. Instruction Format of System Control Instructions

(6) Format of Block Data Transfer Instruction

Figure 1-10 shows the format used for the block data transfer instruction.



## Figure 1-10. Instruction Format of Block Data Transfer Instruction

## 1.3.4 Addressing Modes and Effective Address Calculation

Table 1-10 lists the eight addressing modes and their assembly-language notation. Each instruction can use a specific subset of these addressing modes.

Arithmetic, logic, and shift instructions use register direct addressing (1). The ADD.B, ADDX, SUBX, CMP.B, AND, OR, and XOR instructions can also use immediate addressing (6).

The MOV instruction uses all the addressing modes except program-counter relative (7) and memory indirect (8).

Bit manipulation instructions use register direct (1), register indirect (2), or absolute (5) addressing to identify a byte operand and 3-bit immediate addressing to identify a bit within the byte. The BSET, BCLR, BNOT, and BTST instructions can also use register direct addressing (1) to identify the bit.

| No. | Mode                                       | Notation             |
|-----|--------------------------------------------|----------------------|
| (1) | Register direct                            | Rn                   |
| (2) | Register indirect                          | @Rn                  |
| (3) | Register indirect with 16-bit displacement | @(d:16, Rn)          |
| (4) | Register indirect with post-increment      | @Rn+                 |
|     | Register indirect with pre-decrement       | @-Rn                 |
| (5) | Absolute address (8 or 16 bits)            | @aa:8, @aa:16        |
| (6) | Immediate (3-, 8-, or 16-bit data)         | #xx:3, #xx:8, #xx:16 |
| (7) | PC-relative (8-bit displacement)           | @(d:8, PC)           |
| (8) | Memory indirect                            | @@aa:8               |
|     |                                            |                      |

## Table 1-10. Addressing Modes

(1) Register Direct—Rn: The register field of the instruction specifies an 8- or 16-bit general register containing the operand. In most cases the general register is accessed as an 8-bit register. Only the MOV.W, ADD.W, SUB.W, CMP.W, ADDS, SUBS, MULXU (8 bits  $\times$  8 bits), and DIVXU (16 bits  $\div$  8 bits) instructions have 16-bit operands.

(2) **Register indirect—@Rn:** The register field of the instruction specifies a 16-bit general register containing the address of the operand.

(3) Register Indirect with Displacement—@(d:16, Rn): This mode, which is used only in MOV instructions, is similar to register indirect but the instruction has a second word (bytes 3 and 4) which is added to the contents of the specified general register to obtain the operand address. For the MOV.W instruction, the resulting address must be even.

## (4) Register Indirect with Post-Increment or Pre-Decrement—@Rn+ or @-Rn:

• Register indirect with post-increment—@Rn+

The @Rn+ mode is used with MOV instructions that load registers from memory. It is similar to the register indirect mode, but the 16-bit general register specified in the register field of the instruction is incremented after the operand is accessed. The size of the increment is 1 or 2 depending on the size of the operand: 1 for a byte operand; 2 for a word operand. For a word operand, the original contents of the 16-bit general register must be even.

• Register indirect with pre-decrement-@-Rn

The @-Rn mode is used with MOV instructions that store register contents to memory. It is similar to the register indirect mode, but the 16-bit general register specified in the register field of the instruction is decremented before the operand is accessed. The size of the decrement is 1 or 2 depending on the size of the operand: 1 for a byte operand; 2 for a word operand. For a word operand, the original contents of the 16-bit general register must be even.

(5) Absolute Address—@aa:8 or @aa:16: The instruction specifies the absolute address of the operand in memory. The @aa:8 mode uses an 8-bit absolute address of the form H'FFxx. The upper 8 bits are assumed to be 1, so the possible address range is H'FF00 to H'FFFF (65280 to 65535). The MOV.B, MOV.W, JMP, and JSR instructions can use 16-bit absolute addresses.

(6) Immediate—#xx:8 or #xx:16: The instruction contains an 8-bit operand in its second byte, or a 16-bit operand in its third and fourth bytes. Only MOV.W instructions can contain 16-bit immediate values.

The ADDS and SUBS instructions implicitly contain the value 1 or 2 as immediate data. Some bit manipulation instructions contain 3-bit immediate data (#xx:3) in the second or fourth byte of the instruction, specifying a bit number. (7) **PC-Relative—@(d:8, PC):** This mode is used to generate branch addresses in the Bcc and BSR instructions. An 8-bit value in byte 2 of the instruction code is added as a sign-extended value to the program counter contents. The result must be an even number. The possible branching range is -126 to +128 bytes (-63 to +64 words) from the current address.

(8) Memory Indirect—@@aa:8: This mode can be used by the JMP and JSR instructions. The second byte of the instruction code specifies an 8-bit absolute address from H'0000 to H'00FF (0 to 255). Note that the initial part of the area from H'0000 to H'00FF contains the exception vector table. See the applicable hardware manual for details. The word located at this address contains the branch address.

If an odd address is specified as a branch destination or as the operand address of a MOV.W instruction, the least significant bit is regarded as 0, causing word access to be performed at the address preceding the specified address. See the memory data structure description in section 1.1.2, Data Structure.

### **Effective Address Calculation**

Table 1-11 explains how the effective address is calculated in each addressing mode.

| Table 1-11. Effective Address Calculation (1) |  |
|-----------------------------------------------|--|
|-----------------------------------------------|--|





### Table 1-11. Effective Address Calculation (2)



#### Table 1-11. Effective Address Calculation (3)

reg, regm, regn: General register op: Operation field disp: Displacement abs: Absolute address IMM: Immediate data

# Section 2. Instruction Set

# **2.1 Explanation Format**

Section 2 gives full descriptions of all the H8/300L Series instructions, presenting them in alphabetic order. Each instruction is explained in a table like the following:

| ADD (add binary) (byte)     | ADD                                                                                      |  |  |  |  |  |  |  |
|-----------------------------|------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation                   | Condition Code                                                                           |  |  |  |  |  |  |  |
| $Rd + (EAs) \rightarrow Rd$ |                                                                                          |  |  |  |  |  |  |  |
| Assembly-Language Format    | $[] - ] \downarrow ] - ] \downarrow ] \downarrow ] \downarrow ] \downarrow ] \downarrow$ |  |  |  |  |  |  |  |
| ADD.B <eas>, Rd</eas>       | I: Previous value remains unchanged.                                                     |  |  |  |  |  |  |  |
| Operand Size                | H: Set to 1 when there is a carry from bit 3;<br>otherwise cleared to 0.                 |  |  |  |  |  |  |  |
| Byte                        | N: Set to 1 when the result is negative;<br>otherwise cleared to 0.                      |  |  |  |  |  |  |  |
|                             | Z: Set to 1 when the result is zero;<br>otherwise cleared to 0.                          |  |  |  |  |  |  |  |
|                             | V: Set to 1 when an overflow occurs;<br>otherwise cleared to 0.                          |  |  |  |  |  |  |  |
|                             | C: Set to 1 when there is a carry from bit 7; otherwise cleared to 0.                    |  |  |  |  |  |  |  |

# Description

This instruction adds the source operand to the contents of an 8-bit general register and places the result in the general register .

| Addressing      | Mnem. | Operands  |       | No. of |     |      |          |          |        |
|-----------------|-------|-----------|-------|--------|-----|------|----------|----------|--------|
| mode            |       |           | 1st b | oyte   | 2nd | byte | 3rd byte | 4th byte | states |
| Immediate       | ADD.B | #xx:8, Rd | 8     | rd     | IN  | М    |          |          | 2      |
| Register direct | ADD.B | Rs, Rd    | 0     | 8      | rs  | rd   |          |          | 2      |

The parts of the table are explained below.

Name: The full and mnemonic names of the instruction are given at the top of the page.

| Symbol         | Meaning                                                                             |
|----------------|-------------------------------------------------------------------------------------|
| Rd             | General register (destination)*                                                     |
| Rs             | General register (source)*                                                          |
| Rn             | General register*                                                                   |
| <ead></ead>    | Destination operand                                                                 |
| <eas></eas>    | Source operand                                                                      |
| PC             | Program counter                                                                     |
| SP             | Stack pointer                                                                       |
| CCR            | Condition code register                                                             |
| N              | N (negative) flag of CCR                                                            |
| Z              | Z (zero) flag of CCR                                                                |
| V              | V (overflow) flag of CCR                                                            |
| С              | C (carry) flag of CCR                                                               |
| disp           | Displacement                                                                        |
| $\rightarrow$  | Transfer from left operand to right operand; or state transition from left state to |
|                | right state.                                                                        |
| +              | Addition                                                                            |
|                | Subtraction                                                                         |
| ×              | Multiplication                                                                      |
| ÷              | Division                                                                            |
| ^              | AND logical                                                                         |
| <sup>i</sup> v | OR logical                                                                          |
| $\oplus$       | Exclusive OR logical                                                                |
| -              | Inverse logic (logical complement)                                                  |
| ()<>           | Contents of operand effective address                                               |

Operation: The instruction is described in symbolic notation. The following symbols are used.

\* General registers are either 8 bits (R0H/R0L - R7H/R7L) or 16 bits (R0 - R7).

# Assembly-Language Format:

| The assembly-language coding of | ADD. B <b><eas></eas></b> , <b>Rd</b> |
|---------------------------------|---------------------------------------|
| the instruction is given. An    | Mnemonic Size Source Destination      |
| example is:                     |                                       |

The operand size is indicated by the letter B (byte) or W (word). Some instructions have restrictions on the size of operands they handle.

The abbreviation EAs or EAd (effective address of source or destination) is used for operands that permit more than one addressing mode. The H8/300L CPU supports the following eight addressing modes. The method of calculating effective addresses is explained in section 1.3.4, Addressing Modes and Effective Address Calculation, above.

| Notation     | Addressing Mode                                     |
|--------------|-----------------------------------------------------|
| Rn           | Register direct                                     |
| @Rn          | Register indirect                                   |
| @(d:16, Rn)  | Register indirect with displacement                 |
| @Rn+/@ -Rn   | Register indirect with post-increment/pre-decrement |
| @aa:8/@aa:16 | Absolute address                                    |
| #xx:8/#xx:16 | Immediate                                           |
| @(d:8, PC)   | Program-counter relative                            |
| @@aa:8       | Memory indirect                                     |

**Operand size:** Word or byte. Byte size is indicated for bit-manipulation instructions because these instructions access a full byte in order to read or write one bit.

**Condition code:** The effect of instruction execution on the flag bits in CCR is indicated. The following notation is used:

| Symbo | l Meaning                                                       |
|-------|-----------------------------------------------------------------|
| \$    | The flag is altered according to the result of the instruction. |
| 0     | The flag is cleared to "0."                                     |
|       | The flag is not changed.                                        |
| *     | Not fixed; the flag is left in an unpredictable state.          |

Description: The action of the instruction is described in detail.

**Instruction Formats:** Each possible format of the instruction is shown explicitly, indicating the addressing mode, the object code, and the number of states required for execution when the instruction and its operands are located in on-chip memory. The following symbols are used:

| Symbol     | Meaning                                                                              |
|------------|--------------------------------------------------------------------------------------|
| Imm.       | Immediate data (3, 8, or 16 bits)                                                    |
| abs.       | An absolute address (8 bits or 16 bits)                                              |
| disp.      | Displacement (8 bits or 16 bits)                                                     |
| rs, rd, rn | General register number (3 bits or 4 bits) The s, d, and n correspond to the letters |
|            | in the operand notation.                                                             |

**Register Designation:** 16-bit general registers are indicated by a 3-bit  $r_s$ , rd, or  $r_n$  value. 8-bit registers are indicated by a 4-bit  $r_s$ , rd, or  $r_n$  value. Address registers used in the @Rn, @(disp:16, Rn), @Rn+, and @-Rn addressing modes are always 16-bit registers. Data registers are 8-bit or 16-bit registers depending on the size of the operand. For 8-bit registers, the lower three bits of  $r_s$ , rd, or  $r_n$  give the register number. The most significant bit is 1 if the lower byte of the register is used, or 0 if the upper byte is used. Registers are thus indicated as follows:

| er | 8-Bit registers |                                                                                                                                                           |                                                                                                                                                                                                                                                   |
|----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | rs, rd, or rn   | Register                                                                                                                                                  |                                                                                                                                                                                                                                                   |
|    | 0000            | R0H                                                                                                                                                       |                                                                                                                                                                                                                                                   |
| R0 | 0001            | R1H                                                                                                                                                       |                                                                                                                                                                                                                                                   |
| R1 | :               | :                                                                                                                                                         |                                                                                                                                                                                                                                                   |
| :  | 0111            | R7H                                                                                                                                                       |                                                                                                                                                                                                                                                   |
| R7 | $1\ 0\ 0\ 0$    | ROL                                                                                                                                                       |                                                                                                                                                                                                                                                   |
|    | 1001            | R1L                                                                                                                                                       |                                                                                                                                                                                                                                                   |
|    | :               | :                                                                                                                                                         |                                                                                                                                                                                                                                                   |
|    | 1111            | R7L                                                                                                                                                       |                                                                                                                                                                                                                                                   |
|    | R1<br>:         | rs, rd, or rn           0000           R0         0001           R1         :           :         0111           R7         1000           1001         : | rs, rd, or rn         Register           0000         R0H           R0         0001         R1H           R1         :         :           :         01111         R7H           R7         1000         R0L           1001         R1L         : |

**Bit Data Access:** Bit data are accessed as the n-th bit of a byte operand in a general register or memory. The bit number is given by 3-bit immediate data, or by a value in a general register. When a bit number is specified in a general register, only the lower three bits of the register are significant. Two examples are shown below.



The addressing mode and operand size apply to the register or memory byte containing the bit.

**Number of States Required for Execution:** The number of states indicated is the number required when the instruction and any memory operands are located in on-chip ROM or RAM. If the instruction or an operand is located in external memory or the on-chip register field, additional states are required for each access. See section 2.5, Number of Execution States.

| 2.2.1 (1) ADD (add binary) (byte) |                                                                                                                                                                                                                                                                                                                 | ADD              |  |  |  |  |  |  |  |  |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|--|--|--|--|--|--|
| Operation                         | Condition Code                                                                                                                                                                                                                                                                                                  |                  |  |  |  |  |  |  |  |  |
| $Rd + (EAs) \rightarrow Rd$       | I H N Z                                                                                                                                                                                                                                                                                                         | <u>v c</u>       |  |  |  |  |  |  |  |  |
| Assembly-Language Format          | - <u>      ↓   ↓   ↓</u>                                                                                                                                                                                                                                                                                        | ↓ ↓ ↓            |  |  |  |  |  |  |  |  |
| ADD.B <eas>, Rd</eas>             | I: Previous value remains u                                                                                                                                                                                                                                                                                     | nchanged.        |  |  |  |  |  |  |  |  |
| Operand Size                      | <ul> <li>H: Set to 1 when there is a carry from bit 3; otherwise cleared to 0.</li> <li>N: Set to 1 when the result is negative; otherwise cleared to 0.</li> <li>Z: Set to 1 when the result is zero; otherwise cleared to 0.</li> <li>V: Set to 1 when an overflow occurs; otherwise cleared to 0.</li> </ul> |                  |  |  |  |  |  |  |  |  |
| Byte                              |                                                                                                                                                                                                                                                                                                                 |                  |  |  |  |  |  |  |  |  |
|                                   |                                                                                                                                                                                                                                                                                                                 |                  |  |  |  |  |  |  |  |  |
|                                   |                                                                                                                                                                                                                                                                                                                 |                  |  |  |  |  |  |  |  |  |
|                                   | C: Set to 1 when there is a ca<br>otherwise cleared to 0.                                                                                                                                                                                                                                                       | arry from bit 7; |  |  |  |  |  |  |  |  |

# Description

This instruction adds the source operand to the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Mnom  | Onerende  |             | No. of |          |    |          |          |        |
|-----------------|-------|-----------|-------------|--------|----------|----|----------|----------|--------|
| mode            | Mnem. | Operands  | 1st byte 2r |        | 2nd byte |    | 3rd byte | 4th byte | states |
| Immediate       | ADD.B | #xx:8, Rd | 8           | rd     | IM       | M  |          |          | 2      |
| Register direct | ADD.B | Rs, Rd    | 0           | 8      | rs       | rd |          |          | 2      |

# Operation

 $Rd + Rs \rightarrow Rd$ 

# Assembly-Language Format

ADD.W Rs, Rd

# **Operand Size**

Word

|    |       |        | \$     |        | \$     | \$     | \$    | \$    |
|----|-------|--------|--------|--------|--------|--------|-------|-------|
|    |       |        |        |        | _      |        |       |       |
| I: | Prev  | ious   | valu   | e ren  | nains  | unc    | hang  | ed.   |
| H: | Set t | :o 1 v | vhen   | there  | e is a | carr   | y fro | m bit |
|    | 11; c | other  | wise   | clear  | ed to  | o 0.   |       |       |
| N: | Set t | :o 1 v | vhen   | the r  | esul   | t is n | egati | ve;   |
|    | othe  | rwise  | e clea | ared t | io 0.  |        |       |       |
| Z: | Set t | :o 1 v | vhen   | the r  | esul   | t is z | ero;  |       |
|    | othe  | rwise  | e clea | ared t | :o 0.  |        |       |       |
| V: | Set t | :o 1 v | vhen   | an o   | verfl  | ow c   | occur | s;    |
|    | othe  | rwise  | e clea | ared t | o 0.   |        |       |       |
| C: | Set t | to 1 v | vhen   | there  | e is a | carr   | y fro | m bit |

**Condition Code** 

I

Η

N Z

15; otherwise cleared to 0.

# Description

This instruction adds word data in two general registers and places the result in the second general register.

# **Instruction Formats and Number of Execution States**

| Addressing      | Mnem.  | Operands  |          | Instructi | on code  |          | No. of |
|-----------------|--------|-----------|----------|-----------|----------|----------|--------|
| mode            | winem. | Operatios | 1st byte | 2nd byte  | 3rd byte | 4th byte | states |
| Register direct | ADD.W  | Rs, Rd    | 0 9      | 0 rs 0 rd |          |          | 2      |

С

V

# Operation

 $Rd + 1 \rightarrow Rd$  $Rd + 2 \rightarrow Rd$ 

#### Assembly-Language Format

ADDS #1, Rd ADDS #2, Rd

### **Operand Size**

Word



- I: Previous value remains unchanged.
- H: Previous value remains unchanged.

N: Previous value remains unchanged.

- Z: Previous value remains unchanged.
- V: Previous value remains unchanged.

C: Previous value remains unchanged.

# Description

This instruction adds the immediate value 1 or 2 to word data in a general register. Unlike the ADD instruction, it does not affect the condition code flags.

# **Instruction Formats and Number of Execution States**

| Addressing      | Mnem.  | Operands |       |     |     | Instruc | tion code |          | No. of |
|-----------------|--------|----------|-------|-----|-----|---------|-----------|----------|--------|
| mode            | winem. | Operanus | 1st b | yte | 2nc | l byte  | 3rd byte  | 4th byte | states |
| Register direct | ADDS   | #1, Rd   | 0     | В   | 0   | 0 rd    |           |          | 2      |
| Register direct | ADDS   | #2, Rd   | 0     | В   | 8   | 0 rd    |           |          | 2      |

Note: This instruction cannot access byte-size data.

# 2.2.3 ADDX (add with extend carry)

# Operation

 $Rd + (EAs) + C \rightarrow Rd$ 

# Assembly-Language Format

ADDX <EAs>, Rd

# **Operand Size**

Byte

|   |    | Ι     |       | Η      |        | Ν      | Ζ       | V     | С     |    |
|---|----|-------|-------|--------|--------|--------|---------|-------|-------|----|
| - |    |       |       | \$     |        | \$     | \$      | \$    | \$    |    |
|   |    |       |       |        |        |        |         |       |       |    |
|   | I: | Prev  | ious  | valu   | e rem  | ains   | unch    | nango | ed.   |    |
| - | H: | Set t | o 1 i | f ther | e is a | a car  | ry fro  | om b  | it 3; |    |
|   |    | othe  | rwise | e clea | ared t | o 0.   |         |       |       |    |
|   | N: | Set t | o 1 v | vhen   | the r  | esult  | t is ne | egati | ve;   |    |
|   |    | othe  | rwise | e clea | ared t | o 0.   |         |       |       |    |
|   | Z: | Set t | o 1 v | vhen   | the r  | esult  | t is ze | ero;  |       |    |
|   |    | othe  | rwise | e clea | ared t | o 0.   |         |       |       |    |
|   | V: | Set t | o 1 v | vhen   | an o   | verfl  | ow o    | ccur  | s;    |    |
|   |    | othe  | rwise | e clea | ared t | o 0.   |         |       |       |    |
|   | C: | Set t | o 1 v | vhen   | there  | e is a | carr    | y fro | m bit | 7; |
|   |    | othe  | rwise | e clea | ared t | o 0.   |         |       |       |    |
|   |    |       |       |        |        |        |         |       |       |    |

**Condition Code** 

# Description

This instruction adds the source operand and carry flag to the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Mnem.    | Operande  |       |     | Ir  | nstruc | tion code |          | No. of |
|-----------------|----------|-----------|-------|-----|-----|--------|-----------|----------|--------|
| mode            | Millern. | Operands  | 1st b | yte | 2nd | byte   | 3rd byte  | 4th byte | states |
| Immediate       | ADDX     | #xx:8, Rd | 9     | rd  | IN  | IM     |           |          | 2      |
| Register direct | ADDX     | Rs, Rd    | 0     | Е   | rs  | rd     |           |          | 2      |

### 2.2.4 AND (AND logical)

### Operation

 $\mathrm{Rd} \wedge (\mathrm{EAs}) \rightarrow \mathrm{Rd}$ 

# Assembly-Language Format

AND <EAs>, Rd

# **Operand Size**

Byte

|   | Co | nditi | on C  | ode    |        |       |         |       |     |
|---|----|-------|-------|--------|--------|-------|---------|-------|-----|
|   |    | I     |       | Н      |        | N     | Z       | v     | C   |
|   |    |       |       |        |        | \$    | \$      | 0     |     |
|   |    |       |       |        |        |       |         |       |     |
|   | I: | Prev  | ious  | valu   | e rem  | nains | uncl    | hang  | ed. |
| _ | H: | Prev  | ious  | valu   | e rem  | nains | uncl    | nang  | ed. |
|   | N: | Set t | o 1 v | vhen   | the r  | esul  | t is n  | egati | ve; |
|   |    | othe  | rwise | clea   | ared t | o 0.  |         |       |     |
|   | Z: | Set t | o 1 v | yhen   | the r  | esul  | t is ze | ero;  |     |
|   |    | othe  | rwise | e clea | red t  | o 0.  |         |       |     |
|   | V: | Clea  | red t | o 0.   |        |       |         |       |     |
|   | C: | Prev  | ious  | valu   | e rem  | nains | uncl    | nang  | ed. |

# Description

This instruction ANDs the source operand with the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Mnem.  | Operands  |       |     | In    | struct | ion code |          | No. of |
|-----------------|--------|-----------|-------|-----|-------|--------|----------|----------|--------|
| mode            | winem. | Operatios | 1st b | yte | 2nd I | byte   | 3rd byte | 4th byte | states |
| Immediate       | AND    | #xx:8, Rd | E     | rd  | IM    | М      |          |          | 2      |
| Register direct | AND    | Rs, Rd    | 1     | 6   | rs    | rd     |          |          | 2      |

# 2.2.5 ANDC (AND control register)

# Operation

 $CCR \land \#IMM \rightarrow CCR$ 

# Assembly-Language Format

ANDC #xx:8, CCR

# **Operand Size**

Byte

| Condition | Code |   |   |
|-----------|------|---|---|
| I         | н    | N | 7 |

#### 

I: ANDed with bit 7 of the immediate data.

- H: ANDed with bit 5 of the immediate data.
- N: ANDed with bit 3 of the immediate data.
- Z: ANDed with bit 2 of the immediate data.
- V: ANDed with bit 1 of the immediate data.
- C: ANDed with bit 0 of the immediate data.

# Description

This instruction ANDs the condition code register (CCR) with immediate data and places the result in the condition code register. Bits 6 and 4 are ANDed as well as the flag bits. No interrupt requests are accepted immediately after this instruction. All interrupts, including the nonmaskable interrupt (NMI), are deferred until after the next instruction.

| Addressing | Mnem.  | Operands   |       |     | Instructi | on code  |          | No. of |
|------------|--------|------------|-------|-----|-----------|----------|----------|--------|
| mode       | winem. | Operanus   | 1st b | yte | 2nd byte  | 3rd byte | 4th byte | states |
| Immediate  | ANDC   | #xx:8, CCR | 0     | 6   | IMM       |          |          | 2      |

#### 2.2.6 BAND (bit AND)

### Operation

 $C \land (\langle Bit No. \rangle of \langle EAd \rangle) \rightarrow C$ 

### Assembly-Language Format

BAND #xx:3, <EAd>

# **Operand Size**

Byte



**BAND** 

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Previous value remains unchanged.
- Z: Previous value remains unchanged.
- V: Previous value remains unchanged.
- C: ANDed with the specified bit.

### Description

This instruction ANDs a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.

 $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

Instruction Formats and Number of Execution States

| Addressing        | Mnem.     | Operands    |       |      | Ins   | structi | on cod | е    |       |      | No. of |
|-------------------|-----------|-------------|-------|------|-------|---------|--------|------|-------|------|--------|
| mode              | Millerii. | Operands    | 1st t | oyte | 2nd b | oyte    | 3rd b  | oyte | 4th t | oyte | states |
| Register direct   | BAND      | #xx:3, Rd   | 7     | 6    | 0 IMM | rd      | 4      |      |       |      | 2      |
| Register indirect | BAND      | #xx:3,@Rd   | 7     | С    | 0 rd  | 0       | 7      | 6    | 0 IMM | 0    | 6      |
| Absolute address  | BAND      | #xx:3,@aa:8 | 7     | E    | a     | os      | 7      | 6    | 0 імм | 0    | 6      |

# 2.2.7 Bcc (branch conditionally)

#### Operation

If cc then

 $PC + d:8 \rightarrow PC$ 

else next;

# Assembly-Language Format

 $\stackrel{\text{Bcc d:8}}{\longrightarrow} \text{Condition code field}$ 

(For mnemonics, see the table on the next page.)

### **Operand Size**

0





- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Previous value remains unchanged.
- Z: Previous value remains unchanged.
- V: Previous value remains unchanged.
- C: Previous value remains unchanged.

### Description

If the specified condition is false, this instruction does nothing; the next instruction is executed. If the specified condition is true, a signed displacement is added to the address of the next instruction and execution branches to the resulting address.

The displacement is a signed 8-bit value which must be even. The branch destination address can be located in the range -126 to +128 bytes from the address of the Bcc instruction. The applicable conditions and their mnemonics are given below.

| Mnemonic  | cc Field | Description                   | Condition                 | Meaning                                    |
|-----------|----------|-------------------------------|---------------------------|--------------------------------------------|
| BRA (BT)  | 0000     | Always (True)                 | Always true               |                                            |
| BRN (BF)  | 0001     | Never (False)                 | Never                     |                                            |
| BHI       | 0010     | High                          | $C \lor Z = 0$            | X > Y (Unsigned)                           |
| BLS       | 0011     | Low or Same                   | $C \lor Z = 1$            | $X \le Y$ (Unsigned)                       |
| BCC (BHS) | 0100     | Carry Clear<br>(High or Same) | C = 0                     | $X \ge Y$ (Unsigned)                       |
| BCS (BLO) | 0101     | Carry Set (Low)               | C = 1                     | X < Y (Unsigned)                           |
| BNE       | 0110     | Not Equal                     | Z = 0                     | $X \neq Y$ (Signed or                      |
| BEQ       | 0111     | Equal                         | Z = 1                     | unsigned)<br>X = Y (Signed or<br>unsigned) |
| BVC       | 1000     | Overflow Clear                | V = 0                     |                                            |
| BVS       | 1001     | Overflow Set                  | V = 1                     |                                            |
| BPL       | 1010     | Plus                          | N = 0                     |                                            |
| BMI       | 1011     | Minus                         | N = 1                     |                                            |
| BGE       | 1100     | Greater or Equal              | $N \oplus V = 0$          | $X \ge Y$ (Signed)                         |
| BLT       | 1101     | Less Than                     | $N \oplus V = 1$          | X < Y (Signed)                             |
| BGT       | 1110     | Greater Than                  | $Z \lor (N \oplus V) = 0$ | X > Y (Signed)                             |
| BLE       | 1111     | Less or Equal                 | $Z \lor (N \oplus V) = 1$ | $X \le Y$ (Signed)                         |
|           |          |                               |                           |                                            |

BT, BF, BHS, and BLO are synonyms for BRA, BRN, BCC, and BCS, respectively.

| Adressing   |           |          |       |      | Instructio | on code  |          | No . of |
|-------------|-----------|----------|-------|------|------------|----------|----------|---------|
| mode        | Mnem.     | Operands | 1st b | oyte | 2nd byte   | 3rd byte | 4th byte | states  |
| PC relative | BRA (BT)  | d:8      | 4     | 0    | disp.      |          |          | 4       |
| PC relative | BRN (BF)  | d:8      | 4     | 1    | disp.      |          |          | 4       |
| PC relative | вні       | d:8      | 4     | 2    | disp.      |          |          | 4       |
| PC relative | BLS       | d:8      | 4     | 3    | disp.      |          |          | 4       |
| PC relative | BCC (BHS) | d:8      | 4     | 4    | disp.      |          |          | 4       |
| PC relative | BCS (BLO) | d:8      | 4     | 5    | disp.      |          |          | 4       |
| PC relative | BNE       | d:8      | 4     | 6    | disp.      |          |          | 4       |
| PC relative | BEQ       | d:8      | 4     | 7    | disp.      |          |          | 4       |
| PC relative | BVC       | d:8      | 4     | 8    | disp.      |          |          | 4       |
| PC relative | BVS       | d:8      | 4     | 9    | disp.      |          |          | 4       |
| PC relative | BPL       | d:8      | 4     | Α    | disp.      |          |          | 4       |
| PC relative | BMI       | d:8      | 4     | В    | disp.      |          |          | 4       |
| PC relative | BGE       | d:8      | 4     | С    | disp.      |          |          | 4       |
| PC relative | BLT       | d:8      | 4     | D    | disp.      |          |          | 4       |
| PC relative | BGT       | d:8      | 4     | E    | disp.      |          |          | 4       |
| PC relative | BLE       | d:8      | 4     | F    | disp.      |          |          | 4       |

# **Instruction Formats and Number of Execution States**

\* The branch address must be even.

| Operation                                                        | Condition Code                       |
|------------------------------------------------------------------|--------------------------------------|
| $0 \rightarrow (\langle Bit No. \rangle of \langle EAd \rangle)$ | I H N Z V C                          |
| Assembly-Language Format                                         |                                      |
| BCLR #xx:3, <ead></ead>                                          | I: Previous value remains unchanged. |
| BCLR Rn, <ead></ead>                                             | H: Previous value remains unchanged. |
|                                                                  | N: Previous value remains unchanged. |
| Operand Size                                                     | Z: Previous value remains unchanged. |
| Byte                                                             | V: Previous value remains unchanged. |
| 2,0                                                              | C: Previous value remains unchanged. |

# Description

This instruction clears a specified bit in the destination operand to 0. The bit number can be specified by 3-bit immediate data, or by the lower three bits of an 8-bit general register. The destination operand can be located in a general register or memory.

The specified bit is not tested before being cleared. The condition code flags are not altered.

 $\text{Bit No.} \qquad \begin{array}{c} \text{#xx:3 or Rn} \\ \text{Bit No.} \\ \text{ZEAd} > * \rightarrow \text{Byte data in register or memory} \\ \end{array}$ 

| Addressing        | Mnem.    | Operands    |          |   | Ir    | nstructi | on coc   | le |       |      | No. of |  |
|-------------------|----------|-------------|----------|---|-------|----------|----------|----|-------|------|--------|--|
| mode              | Milleni. | Operands    | 1st byte |   | 2nd   | byte     | 3rd byte |    | 4th I | oyte | states |  |
| Register direct   | BCLR     | #xx:3, Rd   | 7        | 2 | 0 IMM | rd       |          |    |       |      | 2      |  |
| Register indirect | BCLR     | #xx:3,@Rd   | 7        | D | 0 rd  | 0        | 7        | 2  | 0 імм | 0    | 8      |  |
| Absolute address  | BCLR     | #xx:3,@aa:8 | 7        | F | al    | os       | 7        | 2  | 0 IMM | 0    | 8      |  |
| Register direct   | BCLR     | Rn, Rd      | 6        | 2 | rn    | rd       |          |    |       |      | 2      |  |
| Register indirect | BCLR     | Rn, @Rd     | 7        | D | 0 rd  | 0        | 6        | 2  | rn    | 0    | 8      |  |
| Absolute address  | BCLR     | Rn, @aa:8   | 7        | F | ab    | S        | 6        | 2  | rn    | 0    | 8      |  |

#### 2.2.9 BIAND (bit invert AND)

### Operation

 $C \land [\neg (\langle Bit No. \rangle of \langle EAd \rangle)] \rightarrow C$ 

### Assembly-Language Format

BIAND #xx:3, <EAd>

# **Operand Size**

Byte

| Co     | nditi | on C  | Code |        |       |      |       |        |    |
|--------|-------|-------|------|--------|-------|------|-------|--------|----|
|        | Ι     |       | Н    |        | N     | Ζ    | V     | С      |    |
|        |       |       |      |        |       |      |       | \$     |    |
|        |       |       |      |        |       |      |       |        |    |
| 1:     | Prev  | nous  | valu | e ren  | nains | unc  | hang  | ed.    |    |
| <br>H: | Prev  | ious  | valu | e ren  | nains | unc  | hang  | ed.    |    |
| N:     | Prev  | ious  | valu | e ren  | nains | uncl | hang  | ed.    |    |
| Z:     | Prev  | ious  | valu | e ren  | nains | unc  | hang  | ed.    |    |
| V:     | Prev  | ious  | valu | e ren  | nains | unc  | hang  | ed.    |    |
| C:     | ANI   | Ded y | with | the ir | ivers | e of | the s | pecifi | ed |
|        | bit.  |       |      |        |       |      |       |        |    |

## Description

This instruction ANDs the inverse of a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.  $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

### Instruction Formats and Number of Execution States

| Addressing        | Mnem. Operands |             |          |   | Instructio | on code  |          | No. of |  |
|-------------------|----------------|-------------|----------|---|------------|----------|----------|--------|--|
| mode              | Milletti.      | Operands    | 1st byte |   | 2nd byte   | 3rd byte | 4th byte | states |  |
| Register direct   | BIAND          | #xx:3, Rd   | 7        | 6 | 1 IMM rd   |          |          | 2      |  |
| Register indirect | BIAND          | #xx:3,@Rd   | 7        | С | 0 rd 0     | 7 6      | 1 IMM 0  | 6      |  |
| Absolute address  | BIAND          | #xx:3,@aa:8 | 7        | E | abs        | 7 6      | 1 IMM 0  | 6      |  |

# 2.2.10 BILD (bit invert load)

# Operation

 $\neg$  (<Bit No.> of <EAd>)  $\rightarrow$  C

# Assembly-Language Format

BILD #xx:3, <EAd>

# **Operand Size**

Byte



C: Loaded with the inverse of the specified bit.

# Description

This instruction loads the inverse of a specified bit into the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.

 $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

**Instruction Formats and Number of Execution States** 

| Addressing        | Maam  | Operanda    |          | In | struction | code     |   |      |          |     |   | No. of |  |
|-------------------|-------|-------------|----------|----|-----------|----------|---|------|----------|-----|---|--------|--|
| mode              | Mnem. | Operands    | 1st byte |    | 2nd b     | 2nd byte |   | oyte | 4th byte |     |   | states |  |
| Register direct   | BILD  | #xx:3, Rd   | 7        | 7  | 1 IMM     | rd       |   |      |          |     |   | 2      |  |
| Register indirect | BILD  | #xx:3,@Rd   | 7        | C  | 0 rd      | 0        | 7 | 7    | 1        | ІММ | 0 | 6      |  |
| Absolute address  | BILD  | #xx:3,@aa:8 | 7        | E  | at        | os       | 7 | 7    | 1        | ІММ | 0 | 6      |  |

#### 2.2.11 BIOR (bit invert inclusive OR) **BIOR Condition Code** Operation $C \lor [\neg (\langle Bit No. \rangle of \langle EAd \rangle)] \rightarrow C$ I Η Assembly-Language Format BIOR #xx:3, <EAd> I: Previous value remains unchanged. H: Previous value remains unchanged. **Operand Size** N: Previous value remains unchanged. Byte Z: Previous value remains unchanged. V: Previous value remains unchanged. C: ORed with the inverse of the specified bit.

# Description

This instruction ORs the inverse of a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

 $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

# **Instruction Formats and Number of Execution States**

| Addressing        | Mnem.     | m. Operands - |          |   | Inst     | ructio | n cod    | e |          |     |   | No. of |  |
|-------------------|-----------|---------------|----------|---|----------|--------|----------|---|----------|-----|---|--------|--|
| mode              | Millerii. | Operatios     | 1st byte |   | 2nd byte |        | 3rd byte |   | 4th byte |     |   | states |  |
| Register direct   | BIOR      | #xx:3, Rd     | 7        | 4 | 1 IMM    | rd     |          |   |          |     |   | 2      |  |
| Register indirect | BIOR      | #xx:3,@Rd     | 7        | С | 0 rd     | 0      | 7        | 4 | 1        | ІММ | 0 | 6      |  |
| Absolute address  | BIOR      | #xx:3,@aa:8   | 7        | E | ab       | s      | 7        | 4 | 1        | ІММ | 0 | 6      |  |

### 2.2.12 BIST (bit invert store)

### Operation

 $\neg$  C  $\rightarrow$  (<Bit No.> of <EAd>)

# Assembly-Language Format BIST #xx:3, <EAd>

# **Operand Size**

Byte



- Z: Previous value remains unchanged.
- V: Previous value remains unchanged.
- C: Previous value remains unchanged.

# Description

This instruction stores the inverse of the carry flag to a specified bit location in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.

 $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The values of the unspecified bits are not changed.

# **Instruction Formats and Number of Execution States**

| Addressing        | Mnem.   | Operando    |          |   | Ins   | tructio  | on cod | e    |          |     | No. of |  |
|-------------------|---------|-------------|----------|---|-------|----------|--------|------|----------|-----|--------|--|
| mode              | minern. | Operands    | 1st byte |   | 2nd b | 2nd byte |        | oyte | 4th byte |     | states |  |
| Register direct   | BIST    | #xx:3, Rd   | 6        | 7 | 1 IMM | rd       |        |      |          |     | 2      |  |
| Register indirect | BIST    | #xx:3,@Rd   | 7        | D | 0 rd  | 0        | 6      | 7    | 1 IM     | М 0 | 8      |  |
| Absolute address  | BIST    | #xx:3,@aa:8 | 7        | F | ab    | s        | 6      | 7    | 1 IM     | м 0 | 8      |  |

| 2.2.13 BIXOR (bit invert exclusive OR)                                                            | BIXOR                                     |
|---------------------------------------------------------------------------------------------------|-------------------------------------------|
| Operation                                                                                         | Condition Code                            |
| $C \oplus [\neg (\langle Bit \text{ No.} \rangle \text{ of } \langle EAd \rangle)] \rightarrow C$ | I H N Z V C                               |
| Assembly-Language Format                                                                          |                                           |
| BIXOR #xx:3, <ead></ead>                                                                          | I: Previous value remains unchanged.      |
|                                                                                                   | H: Previous value remains unchanged.      |
| Operand Size                                                                                      | N: Previous value remains unchanged.      |
| Byte                                                                                              | Z: Previous value remains unchanged.      |
|                                                                                                   | V: Previous value remains unchanged.      |
|                                                                                                   | C: Exclusive-ORed with the inverse of the |
|                                                                                                   | specified bit.                            |

#### Description

This instruction exclusive-ORs the inverse of a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.

 $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

**Instruction Formats and Number of Execution States** 

| Addressing        | Mnom      | Inem. Operands - |          | Instruction code |          |    |          |   |          |     |     |        |  |
|-------------------|-----------|------------------|----------|------------------|----------|----|----------|---|----------|-----|-----|--------|--|
| mode              | Millerii. | Operanus         | 1st byte |                  | 2nd byte |    | 3rd byte |   | 4th byte |     | yte | states |  |
| Register direct   | BIXOR     | #xx:3, Rd        | 7        | 5                | 1 IMM    | rd |          |   |          |     |     | 2      |  |
| Register indirect | BIXOR     | #xx:3,@Rd        | 7        | C                | 0 rd     | 0  | 7        | 5 | 1        | ΙММ | 0   | 6      |  |
| Absolute address  | BIXOR     | #xx:3,@aa:8      | 7        | ¦Ε               | at       | s  | 7        | 5 | 1        | IMM | 0   | 6      |  |

### 2.2.14 BLD (bit load)

# Operation

 $(<\!\!Bit \text{ No.> of } <\!\!EAd\!\!>) \rightarrow C$ 

# Assembly-Language Format

# BLD #xx:3, <EAd>

# **Operand Size**

Byte



BLD

H: Previous value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Loaded with the specified bit.

# Description

This instruction loads a specified bit into the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.



The value of the specified bit is not changed.

# **Instruction Formats and Number of Execution States**

| Addressing        | Mnem. | Operanda    |          |    | Ins      | tructio | n cod    | e |          |    |     | No. of |  |
|-------------------|-------|-------------|----------|----|----------|---------|----------|---|----------|----|-----|--------|--|
| mode              | mnem. | Operands    | 1st byte |    | 2nd byte |         | 3rd byte |   | 4th byte |    | yte | states |  |
| Register direct   | BLD   | #xx:3, Rd   | 7        | 7  | 0 IMM    | rd      |          |   |          |    |     | 2      |  |
| Register indirect | BLD   | #xx:3,@Rd   | 7        | c  | 0 rd     | 0       | 7        | 7 | 01       | MM | 0   | 6      |  |
| Absolute address  | BLD   | #xx:3,@aa:8 | 7        | ¦Ε | ab       | S       | 7        | 7 | 0        | MM | 0   | 6      |  |

#### 2.2.15 BNOT (bit NOT) **BNOT Condition Code** Operation $\neg$ (<Bit No.> of <EAd>) Ι $\rightarrow$ (<Bit No.> of <EAd>) **Assembly-Language Format** I: Previous value remains unchanged. BNOT #xx:3, <EAd> H: Previous value remains unchanged. BNOT Rn, <EAd> N: Previous value remains unchanged. Z: Previous value remains unchanged. **Operand Size** V: Previous value remains unchanged. Byte C: Previous value remains unchanged.

#### Description

This instruction inverts a specified bit in a general register or memory location. The bit number is specified by 3-bit immediate data, or by the lower three-bits of a general register. The operation is shown schematically below.

#xx:3 or Rn

<≁Invert

7

The bit is not tested before being inverted. The condition code flags are not altered.

# **BNOT** (bit NOT)

| Addressing        | Mnem.  | Operands    |       |          | In    | structio | n code   | Э |       |      | No. of |  |
|-------------------|--------|-------------|-------|----------|-------|----------|----------|---|-------|------|--------|--|
| mode              | winem. | Operatios   | 1st b | 1st byte |       | byte     | 3rd byte |   | 4th I | oyte | states |  |
| Register direct   | BNOT   | #xx:3, Rd   | 7     | 1        | 0 IMM | rd       |          |   |       |      | 2      |  |
| Register indirect | BNOT   | #xx:3,@Rd   | 7     | D        | 0 rd  | 0        | 7        | 1 | 0 IMM | 0    | 8      |  |
| Absolute address  | BNOT   | #xx:3,@aa:8 | 7     | F        | a     | bs       | 7        | 1 | 0 IMM | 0    | 8      |  |
| Register direct   | BNOT   | Rn, Rd      | 6     | 1        | rn    | rd       |          |   |       |      | 2      |  |
| Register indirect | BNOT   | Rn, @Rd     | 7     | D        | 0 rd  | 0        | 6        | 1 | m     | 0    | 8      |  |
| Absolute address  | BNOT   | Rn, @aa:8   | 7     | F        | at    | os       | 6        | 1 | m     | 0    | 8      |  |

#### 2.2.16 BOR (bit inclusive OR) BOR **Condition** Code Operation $C \lor (\langle Bit No. \rangle of \langle EAd \rangle) \rightarrow C$ T Η N Assembly-Language Format BOR #xx:3, <EAd> I: Previous value remains unchanged. H: Previous value remains unchanged. **Operand Size** N: Previous value remains unchanged. Byte Z: Previous value remains unchanged. V: Previous value remains unchanged. C: ORed with the specified bit.

### Description

This instruction ORs a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.

 $\langle EAd \rangle^* \rightarrow$  Byte data in register or memory



The value of the specified bit is not changed.

**Instruction Formats and Number of Execution States** 

| Addressing        | ssing Mnem. |             |          |   | Instructio | n code   |          | No. of |  |
|-------------------|-------------|-------------|----------|---|------------|----------|----------|--------|--|
| mode              | winem.      | Operands    | 1st byte |   | 2nd byte   | 3rd byte | 4th byte | states |  |
| Register direct   | BOR         | #xx:3, Rd   | 7        | 4 | 0 IMM rd   |          |          | 2      |  |
| Register indirect | BOR         | #xx:3,@Rd   | 7        | С | 0 rd 0     | 7 4      |          | 6      |  |
| Absolute address  | BOR         | #xx:3,@aa:8 | 7        | E | abs        | 7 4      |          | 6      |  |

#### 2.2.17 BSET (bit set)

# Operation

 $1 \rightarrow (\langle Bit No. \rangle of \langle EAd \rangle)$ 

#### Assembly-Language Format

BSET #xx:3,<EAd> BSET Rn,<EAd>

# **Operand Size**

Byte



11. Fievious value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Previous value remains unchanged.

#### Description

This instruction sets a specified bit in the destination operand to 1. The bit number can be specified by 3-bit immediate data, or by the lower three-bits of an 8-bit general register. The destination operand can be located in a general register or memory.

The specified bit is not tested before being cleared. The condition code flags are not altered.

<EAd>\* $\rightarrow$  Byte data in register or memory

\* Register direct, register indirect, or absolute addressing.





1

# **BSET** (bit set)

| Addressing<br>mode | Mnem.   | Operands    |          | No. of |          |    |          |   |       |      |        |
|--------------------|---------|-------------|----------|--------|----------|----|----------|---|-------|------|--------|
|                    | Minern. | Operands    | 1st byte |        | 2nd byte |    | 3rd byte |   | 4th t | oyte | states |
| Register direct    | BSET    | #xx:3, Rd   | 7        | 0      | о імм    | rd |          |   |       |      | 2      |
| Register indirect  | BSET    | #xx:3,@Rd   | 7        | D      | 0 rd     | 0  | 7        | 0 | 0 IMM | 0    | 8      |
| Absolute address   | BSET    | #xx:3,@aa:8 | 7        | F      | al       | bs | 7        | 0 | 0 IMM | 0    | 8      |
| Register direct    | BSET    | Rn, Rd      | 6        | 0      | rn       | rd |          |   |       |      | 2      |
| Register indirect  | BSET    | Rn, @Rd     | 7        | D      | 0 rd     | 0  | 6        | 0 | rn    | 0    | 8      |
| Absolute address   | BSET    | Rn, @aa:8   | 7        | F      | ab       | S  | 6        | 0 | rn    | 0    | 8      |

### 2.2.18 BSR (branch to subroutine)

# Operation $PC \rightarrow @-SP$

 $PC + d:8 \rightarrow PC$ 

Assembly-Language Format BSR d:8

# **Operand Size**

Condition Code I H N Z V C \_\_\_\_\_\_

I: Previous value remains unchanged.

H: Previous value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Previous value remains unchanged.

# Description

This instruction pushes the program counter (PC) value onto the stack, then adds a specified displacement to the program counter value and branches to the resulting address. The program counter value used is the address of the instruction following the BSR instruction.

The displacement is a signed 8-bit value which must be even. The possible branching range is -126 to +128 bytes from the address of the BSR instruction.

| Addressing<br>mode | Mnem.  | Operands |       | No. of |          |          |          |        |  |   |
|--------------------|--------|----------|-------|--------|----------|----------|----------|--------|--|---|
|                    | winem. | Operanus | 1st b | yte    | 2nd byte | 3rd byte | 4th byte | states |  |   |
| PC-relative        | BSR    | d:8      | 5 5   |        | 5 5      |          | disp     |        |  | 6 |

### 2.2.19 BST (bit store)

#### Operation

 $C \rightarrow (\langle Bit No. \rangle of \langle EAd \rangle)$ 

# **Assembly-Language Format**

BST #xx:3, <EAd>

# **Operand Size**

Byte



C: Previous value remains unchanged.

# Description

This instruction stores the carry flag to a specified flag location in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

Bit No.  $\langle EAd \rangle^* \rightarrow Byte data in register or memory$ 



# Instruction Formats and Number of Execution States

| Addressing<br>mode | Mnem.          | Operanda    |      | No. of |       |       |      |   |       |      |        |   |
|--------------------|----------------|-------------|------|--------|-------|-------|------|---|-------|------|--------|---|
|                    | Mnem. Operands | 1st         | byte | 2nd b  | yte   | 3rd b | oyte |   | 4th b | oyte | states |   |
| Register direct    | BST            | #xx:3, Rd   | 6    | 7      | 0 IMM | rd    |      |   |       |      |        | 2 |
| Register indirect  | BST            | #xx:3,@Rd   | 7    | D      | 0 rd  | 0     | 6    | 7 | 0     | ІММ  | 0      | 8 |
| Absolute address   | BST            | #xx:3,@aa:8 | 7    | F      | abs   |       | 6    | 7 | 0     | ІММ  | 0      | 8 |

### 2.2.20 BTST (bit test)

### Operation

 $\neg \ (<\!\!\text{Bit No.}\!\!> \!\text{of } <\!\!\!\text{EAd}\!\!>) \rightarrow Z$ 

# Assembly-Language Format

BTST #xx:3, <EAd> BTST Rn, <EAd>

# **Operand Size**

Byte



BTST

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Previous value remains unchanged.
- Z: Set to 1 when the specified bit is zero; otherwise cleared to 0.
- V: Previous value remains unchanged.
- C: Previous value remains unchanged.

# Description

This instruction tests a specified bit in a general register or memory location and sets or clears the Zero flag accordingly. The bit number can be specified by 3-bit immediate data, or by the lower three bits of an 8-bit general register. The operation is shown schematically below.

\*x:3 or RnBit No.  $^7$  $\downarrow$ Test

The value of the specified bit is not altered.

| Addressing<br>mode | Mnem.  | Operands    | Instruction code |                   |       |    |   | е        |       | No. of |        |
|--------------------|--------|-------------|------------------|-------------------|-------|----|---|----------|-------|--------|--------|
|                    | winem. | Operanus    | 1st I            | 1st byte 2nd byte |       |    |   | 3rd byte |       | oyte   | states |
| Register direct    | BTST   | #xx:3, Rd   | 7                | 3                 | о імм | rd |   |          |       |        | 2      |
| Register indirect  | BTST   | #xx:3,@Rd   | 7                | С                 | 0 rd  | 0  | 7 | 3        | 0 імм | 0      | 6      |
| Absolute address   | BTST   | #xx:3,@aa:8 | 7                | Е                 | a     | bs | 7 | 3        | 0 імм | 0      | 6      |
| Register direct    | BTST   | Rn, Rd      | 6                | 3                 | rn    | rd |   |          |       |        | 2      |
| Register indirect  | BTST   | Rn, @Rd     | 7                | С                 | 0 rd  | 0  | 6 | 3        | m     | 0      | 6      |
| Absolute address   | BTST   | Rn, @aa:8   | 7                | E                 | at    | os | 6 | 3        | m     | 0      | 6      |

# 2.2.21 BXOR (bit exclusive OR)

### Operation

 $C \oplus (\langle Bit No. \rangle of \langle EAd \rangle) \rightarrow C$ 

# Assembly-Language Format

BXOR #xx:3, <EAd>

# **Operand Size**

Byte



I: Previous value remains unchanged.

H: Previous value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Exclusive-ORed with the specified bit.

# Description

This instruction exclusive-ORs a specified bit with the carry flag and places the result in the carry flag. The specified bit can be located in a general register or memory. The bit number is specified by 3-bit immediate data. The operation is shown schematically below.

 $Ad>* \rightarrow Byte data in register or memory$ 



The value of the specified bit is not changed.

# Instruction Formats and Number of Execution States

| Addressing<br>mode | Mnem.           | Operands    |       | No. of |       |      |       |      |   |       |      |        |
|--------------------|-----------------|-------------|-------|--------|-------|------|-------|------|---|-------|------|--------|
|                    | Milem. Operands | Operands    | 1st I | oyte   | 2nd b | oyte | 3rd b | oyte |   | 4th b | oyte | states |
| Register direct    | BXOR            | #xx:3, Rd   | 7     | 5      | 0 IMM | rd   |       |      |   |       |      | 2      |
| Register indirect  | BXOR            | #xx:3,@Rd   | 7     | С      | 0 rd  | 0    | 7     | 5    | 0 | IMM   | 0    | 6      |
| Absolute address   | BXOR            | #xx:3,@aa:8 | 7     | E      | abs   |      | 7     | 5    | 0 | IMM   | 0    | 6      |

### 2.2.22 (1) CMP (compare) (byte)

# Operation

Rd – (EAs); set condition code

#### Assembly-Language Format

CMP.B <EAs>, Rd

# **Operand Size**

Byte

# Ι Η Ν Ζ Î Î ſ I: Previous value remains unchanged. H: Set to 1 when there is a borrow from bit 3; otherwise cleared to 0. N: Set to 1 when the result is negative; otherwise cleared to 0. Z: Set to 1 when the result is zero; otherwise cleared to 0. V: Set to 1 when an overflow occurs; otherwise cleared to 0. C: Set to 1 when there is a borrow from bit 7; otherwise cleared to 0.

### Description

This instruction subtracts an 8-bit source register or immediate data from an 8-bit destination register and sets the condition code flags according to the result. The destination register is not altered.

### **Instruction Formats and Number of Execution States**

| Addressing Mnem. | Mnem. Operands |          | Instruction code |    |     |      |                   |  |        |  |
|------------------|----------------|----------|------------------|----|-----|------|-------------------|--|--------|--|
| mode             | Millern.       | Operanus | 1st byte 2       |    | 2nd | byte | 3rd byte 4th byte |  | states |  |
| Immediate        | CMP.B          | #xx:8,Rd | A                | rd | IMM |      |                   |  | 2      |  |
| Register direct  | CMP.B          | Rs, Rd   | 1                | С  | rs  | rd   |                   |  | 2      |  |

# **Condition Code**

# Operation

Rd-Rs; set condition code

### **Assembly-Language Format**

CMP.W Rs, Rd

# **Operand Size**

Word

# **Condition Code**



- I: Previous value remains unchanged.
- H: Set to 1 when there is a borrow from bit 11; otherwise cleared to 0.
- N: Set to 1 when the result is negative; otherwise cleared to 0.
- Z: Set to 1 when the result is zero; otherwise cleared to 0.
- V: Set to 1 when an overflow occurs; otherwise cleared to 0.
- C: Set to 1 when there is a borrow from bit 15; otherwise cleared to 0.

# Description

This instruction subtracts a source register from a destination register and sets the condition code flags according to the result. The destination register is not altered.

| Addressing Mnem. | Operands |          | Instruction code |           |          |          |        |  |
|------------------|----------|----------|------------------|-----------|----------|----------|--------|--|
| mode             | winem.   | Operanus | 1st byte         | 2nd byte  | 3rd byte | 4th byte | states |  |
| Register direct  | CMP.W    | Rs, Rd   | 1 D              | 0 rs 0 rd |          |          | 2      |  |

# 2.2.23 DAA (decimal adjust add)

# Operation

Rd (decimal adjust)  $\rightarrow$  Rd

# Assembly-Language Format

DAA Rd

# **Operand Size**

Byte

|    | I                      | H<br>* | <u> </u> | N<br>\$ | Z<br>\$ | V<br>* | C<br>¢   |
|----|------------------------|--------|----------|---------|---------|--------|----------|
|    | Previous<br>Unpredic   |        |          | nains   | uncł    | nange  | ed.      |
| N: | Set to 1 v<br>negative |        |          | 5       |         |        | is       |
| Z: | Set to 1 votherwis     |        |          | 5       | ted re  | esult  | is zero; |

**Condition Code** 

- V: Unpredictable.
- C: Set to 1 when there is a carry from bit 7; otherwise left unchanged.

### Description

When the result of an addition operation performed by the ADD.B or ADDX instruction on 4bit BCD data is contained in an 8-bit general register and the carry and half-carry flags, the DAA instruction adjusts the result by adding H'00, H'06, H'60, or H'66 to the general register according to the table below.

Valid results are not assured if this instruction is executed under conditions other than those stated above.

|        | Status befor | e adjustmer | nt           | Value | Resulting |
|--------|--------------|-------------|--------------|-------|-----------|
| C flag | Upper nibble | H flag      | Lower nibble | added | C flag    |
| 0      | 0 - 9        | 0           | 0 - 9        | H'00  | 0         |
| 0      | 0 - 8        | 0           | A – F        | H'06  | 0         |
| 0      | 0 - 9        | 1           | 0 - 3        | H'06  | 0         |
| 0      | A - F        | 0           | 0 - 9        | H'60  | 1         |
| 0      | 9 – F        | 0           | A – F        | H'66  | 1         |
| 0      | A - F        | 1           | 0 - 3        | H'66  | 1         |
| 1      | 0 - 2        | 0           | 0 - 9        | H'60  | 1         |
| 1      | 0 - 2        | 0           | A – F        | H'66  | 1         |
| 1      | 0 - 3        | 1           | 0 - 3        | H'66  | 1         |
|        | I            |             |              |       |           |

# DAA (decimal adjust add)

| Addressing      | Mnem. Operands |          | Instruction code |     |       |      |          |          |        |  |
|-----------------|----------------|----------|------------------|-----|-------|------|----------|----------|--------|--|
| mode            | winem.         | Operanus | 1st b            | yte | 2nd b | oyte | 3rd byte | 4th byte | states |  |
| Register direct | DAA            | Rd       | 0                | F   | 0     | rd   |          |          | 2      |  |

#### 2.2.24 DAS (decimal adjust subtract) DAS Operation **Condition Code** Rd (decimal adjust) $\rightarrow$ Rd Ι Η Ν Ζ \* \$ Ĵ **Assembly-Language Format** DAS Rd I: Previous value remains unchanged. H: Unpredictable. **Operand Size** N: Set to 1 when the adjusted result is Byte negative; otherwise cleared to 0. Z: Set to 1 when the adjusted result is zero; otherwise cleared to 0. V: Unpredictable. C: Previous value remains unchanged.

# Description

When the result of a subtraction operation performed by the SUB.B, SUBX, or NEG instruction on 4-bit BCD data is contained in an 8-bit general register and the carry and half-carry flags, the DAA instruction adjusts the result by adding H'00, H'FA, H'A0, or H'9A to the general register according to the table below.

Valid results are not assured if this instruction is executed under conditions other than those stated above.

|        | Status befor | e adjustme | nt           | Value | Resulting |
|--------|--------------|------------|--------------|-------|-----------|
| C flag | Upper nibble | H flag     | Lower nibble | added | C flag    |
| 0      | 0-9          | 0          | 0-9          | H'00  | 0         |
| 0      | 0 - 8        | 1          | 6 – F        | H'FA  | 0         |
| 1      | 7 - F        | 0          | 0-9          | H'A0  | 1         |
| 1      | 6 – F        | 1          | 6 – F        | H'9A  | 1         |
|        |              |            |              |       |           |

# DAS (decimal adjust subtract)

| Addressing      | Mnem. Operands |          | Instruction code |          |          |          |        |  |  |
|-----------------|----------------|----------|------------------|----------|----------|----------|--------|--|--|
| mode            |                | Operanus | 1st byte         | 2nd byte | 3rd byte | 4th byte | states |  |  |
| Register direct | DAS            | Rd       | 1   F            | 0 rd     |          |          | 2      |  |  |

### 2.2.25 DEC (decrement)

# Operation

 $Rd - 1 \rightarrow Rd$ 

# Assembly-Language Format

# **Operand Size**

Byte



**Condition Code** 

C: Previous value remains unchanged.

# Description

This instruction decrements an 8-bit general register and places the result in the general register.

| Addressing Mnem. | Operands |          | No. of   |          |          |          |        |
|------------------|----------|----------|----------|----------|----------|----------|--------|
| mode             | winem.   | Operanus | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
| Register direct  | DEC      | Rd       | 1 A      | 0 rd     |          |          | 2      |

# 2.2.26 DIVXU (divide extend as unsigned)

### Operation

 $Rd \div Rs \to Rd$ 

# Assembly-Language Format

DIVXU Rs, Rd

# **Operand Size**

Byte





- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the divisor is negative; otherwise cleared to 0.
- Z: Cleared to 0 when divisor  $\neq$  0; otherwise not guaranteed.
- V: Previous value remains unchanged.
- C: Previous value remains unchanged.

# Description

This instruction divides a 16-bit general register by an 8-bit general register and places the result in the 16-bit general register. The quotient is placed in the lower byte. The remainder is placed in the upper byte. The operation is shown schematically below.



Valid results (Rd, N, Z) are not assured if division by zero is attempted or an overflow occurs. Division by zero is indicated in the Zero flag. Overflow can be avoided by the coding shown on the next page.

| Addressing Mnem. | Operands |           | Instruction code |      |     |      |          |          |               |  |
|------------------|----------|-----------|------------------|------|-----|------|----------|----------|---------------|--|
| mode             | winem.   | Operatios | 1st              | byte | 2nd | byte | 3rd byte | 4th byte | No. of states |  |
| Register direct  | DIVXU    | Rs, Rd    | 5                | 1    | rs  | 0 rd |          |          | 14            |  |

DIVXU

### Note: DIVXU Overflow

Since the DIVXU instruction performs 16-bit  $\div$  8-bit  $\rightarrow$  8-bit division, an overflow will occur if the divisor byte is equal to or less than the upper byte of the dividend. For example, H'FFFF  $\div$  H'01  $\rightarrow$  H'FFFF causes an overflow. (The quotient has more than 8 bits.) Overflows can be avoided by using a subprogram like the following. A work register is

required.



| 2.2.27 EEPMOV (move data to EEPROM) | EEPMOV                               |
|-------------------------------------|--------------------------------------|
| Operation                           | Condition Code                       |
| if $R4L \neq 0$ then                | I H N Z V C                          |
| repeat $@R5+ \rightarrow @R6+$      |                                      |
| $R4L - 1 \rightarrow R4L$           |                                      |
| until $R4L = 0$                     |                                      |
| else next;                          | I: Previous value remains unchanged. |
|                                     | H: Previous value remains unchanged. |
| Assembly-Language Format            | N: Previous value remains unchanged. |
| EEPMOV                              | Z: Previous value remains unchanged. |
|                                     | V: Previous value remains unchanged. |
| Operand Size                        | C: Previous value remains unchanged. |
|                                     |                                      |

This instruction moves a block of data from the memory location specified in general register R5 to the memory location specified in general register R6. General register R4L gives the byte length of the block.

Data are transferred a byte at a time. After each byte transfer, R5 and R6 are incremented and R4L is decremented. When R4L reaches 0, the transfer ends and the next instruction is executed. No interrupt requests are accepted during the data transfer.

At the end of this instruction, R4L contains H'00. R5 and R6 contain the last transfer address +1.

The memory locations specified by general registers R5 and R6 are read before the block transfer is performed.

# **Instruction Formats and Number of Execution States**

| Addressing Mnem. | Mnom   | Operands  |          |   | Ir       | No. of |          |   |          |   |        |
|------------------|--------|-----------|----------|---|----------|--------|----------|---|----------|---|--------|
| mode             | Minem. | Operatios | 1st byte |   | 2nd byte |        | 3rd byte |   | 4th byte |   | states |
|                  | EEPMOV |           | 7        | в | 5        | С      | 5        | 9 | 8        | F | 9+4n*  |

\* n is the initial value in R4L ( $0 \le n \le 255$ ). Although n bytes of data are transferred, memory is accessed 2(n+1) times, requiring 4(n+1) states.

#### 2.2.28 INC (increment) **Condition Code** Operation $Rd + 1 \rightarrow Rd$ I Η N Ζ \$ 1 Î Assembly-Language Format INC Rd I: Previous value remains unchanged. **Operand Size** H: Previous value remains unchanged. N: Set to 1 when the result is negative; Byte otherwise cleared to 0. Z: Set to 1 when the result is zero; otherwise cleared to 0.

- V: Set to 1 when an overflow occurs (the previous value in Rd was H'7F); otherwise cleared to 0.
- C: Previous value remains unchanged.

### Description

This instruction increments an 8-bit general register and places the result in the general register.

| Addressing Mnem. | Operands |          | No. of |     |     |      |          |          |        |  |
|------------------|----------|----------|--------|-----|-----|------|----------|----------|--------|--|
| mode             | winem.   | Operands | 1st b  | yte | 2nd | byte | 3rd byte | 4th byte | states |  |
| Register direct  | INC      | Rd       | 0      | А   | 0   | rd   |          |          | 2      |  |

| 2.2.29 JMP (jump)        | JMP                                  |
|--------------------------|--------------------------------------|
| Operation                | Condition Code                       |
| $(EAd) \rightarrow PC$   | I H N Z V C                          |
| Assembly-Language Format |                                      |
| JMP <b><ea></ea></b>     |                                      |
|                          | I: Previous value remains unchanged. |
| Operand Size             | H: Previous value remains unchanged. |
|                          | N: Previous value remains unchanged. |
|                          | Z: Previous value remains unchanged. |
|                          | V: Previous value remains unchanged. |
|                          | C: Previous value remains unchanged. |

This instruction branches unconditionally to a specified destination address. The destination address must be even.

| Addressing        | Mnem. O        | Operands |          | Instruction code |          |    |          |          |        |  |  |
|-------------------|----------------|----------|----------|------------------|----------|----|----------|----------|--------|--|--|
| mode              | Minem. Operand |          | 1st byte |                  | 2nd byte |    | 3rd byte | 4th byte | states |  |  |
| Register indirect | JMP            | @Rn      | 5        | 9                | 0 rn     | 0  |          |          | 4      |  |  |
| Absolute address  | JMP            | @aa:16   | 5        | Α                | 0        | 0  | a        | abs.     | 6      |  |  |
| Memory indirect   | JMP            | @@aa:8   | 5        | В                | ab       | S. |          |          | 8      |  |  |

### 2.2.30 JSR (Jump to subroutine)

### Operation

 $PC \rightarrow @-SP$ 

 $(EAd) \rightarrow PC$ 

# Assembly-Language Format

JSR <EA>

### **Operand Size**



I: Previous value remains unchanged.

H: Previous value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Previous value remains unchanged.

### Description

This instruction pushes the program counter onto the stack, then branches to a specified destination address. The program counter value pushed on the stack is the address of the instruction following the JSR instruction. The destination address must be even.

| Addressing Mnem.  |     |        |          | Instruction code |          |    |          |          |        |  |  |
|-------------------|-----|--------|----------|------------------|----------|----|----------|----------|--------|--|--|
| mode              |     |        | 1st byte |                  | 2nd byte |    | 3rd byte | 4th byte | states |  |  |
| Register indirect | JSR | @Rn    | 5        | D                | 0 rn     | 0  |          |          | 6      |  |  |
| Absolute address  | JSR | @aa:16 | 5        | Е                | 0        | 0  | é        | abs.     | 8      |  |  |
| Memory indirect   | JSR | @@aa:8 | 5        | F                | ab       | S. |          |          | 8      |  |  |

### 2.2.31 LDC (load to control register)

# Operation

 $(EAs) \rightarrow CCR$ 

### Assembly-Language Format

LDC <EAs>, CCR

# **Operand Size**

Byte

| Co | nditi | on C | Code |         |    |    |    |
|----|-------|------|------|---------|----|----|----|
|    | Ι     |      | Н    | Ν       | Z  | V  | С  |
|    | ¢     | ¢    | \$   | \$<br>¢ | \$ | \$ | \$ |

I: Loaded from the source operand.

H: Loaded from the source operand.

N: Loaded from the source operand.

Z: Loaded from the source operand.

V: Loaded from the source operand.

C: Loaded from the source operand.

# Description

This instruction loads the source operand contents into the condition code register (CCR). Bits 4 and 6 are loaded as well as the flag bits.

No interrupt requests are accepted immediately after this instruction. All interrupts are deferred until after the next instruction.

| Addressing      | Mnem.    | oom Operande |       | Instruction code |     |      |          |          |        |  |  |
|-----------------|----------|--------------|-------|------------------|-----|------|----------|----------|--------|--|--|
| mode            | Minerii. | Operands     | 1st b | yte              | 2nd | byte | 3rd byte | 4th byte | states |  |  |
| Immediate       | LDC      | #xx:8, CCR   | 0     | 7                |     | ММ   |          |          | 2      |  |  |
| Register direct | LDC      | Rs, CCR      | 0     | 3                | 0   | rs   |          |          | 2      |  |  |

# 2.2.32 (1) MOV (move data) (byte)

# MOV

# Operation

 $Rs \rightarrow Rd$ 

### **Assembly-Language Format**

MOV.B Rs, Rd

### **Operand Size**

Byte

| Condition | Code |
|-----------|------|
|-----------|------|

| Ι | Η | <br>N             | Ζ | V | С |
|---|---|-------------------|---|---|---|
|   |   | <br>$\Rightarrow$ | € | 0 |   |

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the data value is negative; otherwise cleared to 0.
- Z: Set to 1 when the data value is zero; otherwise cleared to 0.
- V: Cleared to 0.
- C: Previous value remains unchanged.

# Description

This instruction moves one byte of data from a source register to a destination register and sets condition code flags according to the data value.

| Addressing      | Mnem. Operands |           |          | No. of   |          |          |        |
|-----------------|----------------|-----------|----------|----------|----------|----------|--------|
| mode            | winem.         | Operatios | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
| Register direct | MOV.B          | Rs, Rd    | 0 C      | rs rd    |          |          | 2      |

| 2.2.32 (2) MOV (move data) (word)        | MOV                                                                                                                                                                                                                                        |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                                | Condition Code                                                                                                                                                                                                                             |
| $Rs \rightarrow Rd$                      | $- \begin{array}{c c} I & H & N & Z & V & C \\ \hline - & - & - & \uparrow & \uparrow & 0 & - \end{array}$                                                                                                                                 |
| Assembly-Language Format<br>MOV.W Rs, Rd | <ul><li>I: Previous value remains unchanged.</li><li>H: Previous value remains unchanged.</li></ul>                                                                                                                                        |
| <b>Operand Size</b><br>Word              | <ul> <li>N: Set to 1 when the data value is negative; otherwise cleared to 0.</li> <li>Z: Set to 1 when the data value is zero; otherwise cleared to 0.</li> <li>V: Cleared to 0.</li> <li>C: Previous value remains unchanged.</li> </ul> |

This instruction moves one word of data from a source register to a destination register and sets condition code flags according to the data value.

| Addressing      | Mnem.  | Operands  |          | Instruction code |           |          |          |        |  |  |
|-----------------|--------|-----------|----------|------------------|-----------|----------|----------|--------|--|--|
| mode            | winem. | Operatios | 1st byte |                  | 2nd byte  | 3rd byte | 4th byte | states |  |  |
| Register direct | MOV.W  | Rs, Rd    | 0        | D                | 0 rs 0 rd |          |          | 2      |  |  |

### 2.2.32 (3) MOV (move data) (byte)

### Operation

 $(EAs) \rightarrow Rd$ 

# Assembly-Language Format

MOV.B <EAs>, Rd

# **Operand Size**

Byte



- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the data value is negative; otherwise cleared to 0.
- Z: Set to 1 when the data value is zero; otherwise cleared to 0.
- V: Cleared to 0.
- C: Previous value remains unchanged.

### Description

This instruction moves one byte of data from a source operand to a destination register and sets condition code flags according to the data value.

The MOV.B @R7+, Rd instruction should never be used, because it leaves an odd value in the stack pointer. See section 3.2.3 for details.

| Addressing                            | Mnem.     | Operando      |          |    | No. of   |    |          |          |        |
|---------------------------------------|-----------|---------------|----------|----|----------|----|----------|----------|--------|
| mode                                  | Millerit. | Operands      | 1st byte |    | 2nd byte |    | 3rd byte | 4th byte | states |
| Immediate                             | MOV.B     | #xx:8, Rd     | F        | rd | IN       | 1M |          |          | 2      |
| Register indirect                     | MOV.B     | @RS, Rd       | 6        | 8  | 0 rs     | rd |          |          | 4      |
| Register indirect with displacement   | MOV.B     | @(d:16,Rs),Rd | 6        | E  | 0 rs     | rd |          | disp.    | 6      |
| Register indirect with post-increment | MOV.B     | @Rs+, Rd      | 6        | с  | 0 rs     | rd |          |          | 6      |
| Absolute address                      | MOV.B     | @aa:8, Rd     | 2        | rd | at       | os |          |          | 4      |
| Absolute address                      | MOV.B     | @aa:16, Rd    | 6        | A. | 0        | rd |          | abs.     | 6      |

| 2.2.32 (4) MOV (move data) (word) | MOV                                                                     |
|-----------------------------------|-------------------------------------------------------------------------|
| Operation                         | Condition Code                                                          |
| $(EAs) \rightarrow Rd$            | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                   |
| Assembly-Language Format          |                                                                         |
| MOV.W <eas>, Rd</eas>             | I: Previous value remains unchanged.                                    |
| Operand Size                      | - H: Previous value remains unchanged.                                  |
| Word                              | N: Set to 1 when the data value is negative;<br>otherwise cleared to 0. |
|                                   | Z: Set to 1 when the data value is zero; otherwise cleared to 0.        |
|                                   | V: Cleared to 0.                                                        |
|                                   | C: Previous value remains unchanged.                                    |

This instruction moves one word of data from a source operand to a destination register and sets condition code flags according to the data value.

If the source operand is in memory, it must be located at an even address.

MOV.W @R7+, Rd is identical in machine language to POP.W Rd.

Note that the LSIs in the H8/300L Series contain on-chip peripheral modules for which access in word size is not possible. Details are given in the applicable hardware manual.

| Instruction Formats and Number of Execution State | Instruction | Formats and | 1 Number of | 'Execution State |
|---------------------------------------------------|-------------|-------------|-------------|------------------|
|---------------------------------------------------|-------------|-------------|-------------|------------------|

| Addressing                            | Mnem.  | Operands      |       | Instruction code |      |    |    |          |          |        |
|---------------------------------------|--------|---------------|-------|------------------|------|----|----|----------|----------|--------|
| mode                                  | whiem. |               | 1st b | yte              | 2nd  | by | te | 3rd byte | 4th byte | states |
| Immediate                             | MOV.W  | #xx:16, Rd    | 7     | 9                | 0    | 0  | rd | ІММ      |          | 4      |
| Register indirect                     | MOV.W  | @RS, Rd       | 6     | 9                | 0 rs | 0  | rd |          |          | 4      |
| Register indirect with displacement   | MOV.W  | @(d:16,Rs),Rd | 6     | F                | 0 rs | 0  | rd |          | disp.    | 6      |
| Register indirect with post-increment | MOV.W  | @Rs+, Rd      | 6     | D                | 0 rs | 0  | rd |          |          | 6      |
| Absolute address                      | MOV.W  | @aa:16, Rd    | 6     | В                | 0    | 0  | rd |          | abs.     | 6      |

| 2.2.32 (5) MOV (move data) (byte) | MOV                                         |  |  |  |  |  |  |  |  |
|-----------------------------------|---------------------------------------------|--|--|--|--|--|--|--|--|
| Operation                         | Condition Code                              |  |  |  |  |  |  |  |  |
| $Rs \rightarrow (EAd)$            | I H N Z V C                                 |  |  |  |  |  |  |  |  |
| ·                                 |                                             |  |  |  |  |  |  |  |  |
| Assembly-Language Format          |                                             |  |  |  |  |  |  |  |  |
| MOV.B Rs, <ead></ead>             | I: Previous value remains unchanged.        |  |  |  |  |  |  |  |  |
|                                   | H: Previous value remains unchanged.        |  |  |  |  |  |  |  |  |
| Operand Size                      | N: Set to 1 when the data value is negative |  |  |  |  |  |  |  |  |
| Byte                              | otherwise cleared to 0.                     |  |  |  |  |  |  |  |  |
|                                   | Z: Set to 1 when the data value is zero;    |  |  |  |  |  |  |  |  |
|                                   | otherwise cleared to 0.                     |  |  |  |  |  |  |  |  |
|                                   | V: Cleared to 0.                            |  |  |  |  |  |  |  |  |
|                                   | C: Previous value remains unchanged.        |  |  |  |  |  |  |  |  |

This instruction moves one byte of data from a source register to memory and sets condition code flags according to the data value.

The MOV.B Rs, @-R7 instruction should never be used, because it leaves an odd value in the stack pointer. See section 3.2.3 for details.

The instruction MOV.B RnH, @-Rn or MOV.B RnL, @-Rn decrements register Rn, then moves the upper or lower byte of the decremented result to memory.

| Addressing                           | Mnem, Operands |                   |       | No. of |   |      |      |          |          |        |
|--------------------------------------|----------------|-------------------|-------|--------|---|------|------|----------|----------|--------|
| mode                                 | when.          | Operands          | 1st b | yte    | 2 | nd t | oyte | 3rd byte | 4th byte | states |
| Register indirect                    | MOV.B          | Rs, @Rd           | 6     | 8      | 1 | rd   | rs   |          |          | 4      |
| Register indirect with displacement  | MOV.B          | Rs,<br>@(d:16,Rd) | 6     | E      | 1 | rd   | rs   |          | disp.    | 6      |
| Register indirect with pre-decrement | MOV.B          | Rs, @-Rd          | 6     | с      | 1 | rd   | rs   |          |          | 6      |
| Absolute address                     | MOV.B          | Rs,@aa:8          | 3     | rs     |   | ab   | s    |          |          | 4      |
| Absolute address                     | MOV.B          | Rs,@aa:16         | 6     | Α      | 8 | 3    | rs   |          | abs.     | 6      |

### 2.2.32 (6) MOV (move data) (word)

### Operation

 $Rs \rightarrow (EAd)$ 

# Assembly-Language Format

MOV.W Rs, <EAd>

# **Operand Size**

Word

# Condition Code

| Ι | Н    | Ν      | Ζ  | V | С |
|---|------|--------|----|---|---|
| _ | <br> | <br>\$ | \$ | 0 |   |

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the data value is negative; otherwise cleared to 0.
- Z: Set to 1 when the data value is zero; otherwise cleared to 0.
- V: Cleared to 0.
- C: Previous value remains unchanged.

# Description

This instruction moves one word of data from a general register to memory and sets condition code flags according to the data value.

The destination address in memory must be even.

MOV.W Rs, @-R7 is identical in machine language to PUSH.W Rs.

The instruction MOV.W Rn, @-Rn decrements register Rn by 2, then moves the decremented result to memory.

Note that the LSIs in the H8/300L Series contain on-chip peripheral modules for which access in word size is not possible. Details are given in the applicable hardware manual.

| Addressing                           | Mnem. Operands |                    |       | Instruction code |           |                   |        |  |  |  |
|--------------------------------------|----------------|--------------------|-------|------------------|-----------|-------------------|--------|--|--|--|
| mode                                 |                |                    | 1st b | yte              | 2nd byte  | 3rd byte 4th byte | states |  |  |  |
| Register indirect                    | MOV.W          | Rs, @Rd            | 6     | 9                | 1 rd 0 rs |                   | 4      |  |  |  |
| Register indirect with displacement  | MOV.W          | Rs,<br>@(d:16, Rd) | 6     | F                | 1 rd 0 rs | disp.             | 6      |  |  |  |
| Register indirect with pre-decrement | MOV.W          | Rs, @-Rd           | 6     | D                | 1 rd 0 rs |                   | 6      |  |  |  |
| Absolute address                     | MOV.W          | Rs, @aa:16         | 6     | В                | 8 0 rs    | abs.              | 6      |  |  |  |

| 2.2.33 MULXU (multiply extend as unsign | MULXU                                |               |  |  |  |  |  |  |  |
|-----------------------------------------|--------------------------------------|---------------|--|--|--|--|--|--|--|
| Operation                               | <b>Condition Code</b>                |               |  |  |  |  |  |  |  |
| $Rd \times Rs \rightarrow Rd$           | I H N                                | ZVC           |  |  |  |  |  |  |  |
|                                         |                                      |               |  |  |  |  |  |  |  |
| Assembly-Language Format                |                                      | - <b>I</b>    |  |  |  |  |  |  |  |
| MULXU Rs, Rd                            | I: Previous value remains unchanged. |               |  |  |  |  |  |  |  |
|                                         | H: Previous value remains unchanged. |               |  |  |  |  |  |  |  |
|                                         | N: Previous value remains unchanged. |               |  |  |  |  |  |  |  |
| Operand Size                            | Z: Previous value remains unchanged. |               |  |  |  |  |  |  |  |
| Byte                                    | V: Previous value remain             | s unchanged.  |  |  |  |  |  |  |  |
|                                         | C: Previous value remain             | is unchanged. |  |  |  |  |  |  |  |

This instruction performs 8-bit  $\times$  8-bit  $\rightarrow$  16-bit multiplication. It multiplies a destination register by a source register and places the result in the destination register. The source register is an 8-bit register. The destination register is a 16-bit register containing the data to be multiplied in the lower byte. (The upper byte is ignored). The result is placed in both bytes of the destination register. The operation is shown schematically below.



The multiplier can occupy either the upper or lower byte of the source register.

| Addressing      | Mnem.  | Operands    |       | Instruction code |     |        |          |          |        |  |
|-----------------|--------|-------------|-------|------------------|-----|--------|----------|----------|--------|--|
| mode            | winem. | m. Operands | 1st b | yte              | 2nc | l byte | 3rd byte | 4th byte | states |  |
| Register direct | MULXU  | Rs, Rd      | 5     | 0                | rs  | 0 rd   |          |          | 14     |  |

| 2.2.34 NEG (negate)                       | NEG                                                    |  |  |  |  |  |
|-------------------------------------------|--------------------------------------------------------|--|--|--|--|--|
| Operation                                 | Condition Code                                         |  |  |  |  |  |
| $0 - \mathrm{Rd} \rightarrow \mathrm{Rd}$ | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ |  |  |  |  |  |
| Assembly-Language Format                  |                                                        |  |  |  |  |  |
| NEG Rd                                    | I: Previous value remains unchanged.                   |  |  |  |  |  |
|                                           | H: Set to 1 when there is a borrow from bit            |  |  |  |  |  |
| Operand Size                              | 3; otherwise cleared to 0.                             |  |  |  |  |  |
| Byte                                      | N: Set to 1 when the result is negative;               |  |  |  |  |  |
|                                           | otherwise cleared to 0.                                |  |  |  |  |  |
|                                           | Z: Set to 1 when the result is zero;                   |  |  |  |  |  |
|                                           | otherwise cleared to 0.                                |  |  |  |  |  |
|                                           | V: Set to 1 when an overflow occurs (the               |  |  |  |  |  |
|                                           | previous contents of the destination                   |  |  |  |  |  |
|                                           | register was H'80); otherwise cleared to               |  |  |  |  |  |
|                                           | 0.                                                     |  |  |  |  |  |
|                                           | C: Set to 1 when there is a borrow from bit            |  |  |  |  |  |
|                                           | 7 (the previous contents of the                        |  |  |  |  |  |
|                                           | destination register was not H'00);                    |  |  |  |  |  |
|                                           | otherwise cleared to 0.                                |  |  |  |  |  |

This instruction replaces the contents of an 8-bit general register with its two's complement (subtracts the register contents from H'00).

If the original contents of the destination register was H'80, the register value remains H'80 and the overflow flag is set.

|     | Addressing Mnem. |                  | Operands |     | No. of |      |          |          |        |   |
|-----|------------------|------------------|----------|-----|--------|------|----------|----------|--------|---|
| × . | mode             | Mileni. Operands | 1st b    | yte | 2nd    | byte | 3rd byte | 4th byte | states |   |
|     | Register direct  | NEG              | Rd       | 1   | 7      | 8    | rd       |          |        | 2 |

### 2.2.35 NOP (no operation)

### Operation

 $PC + 2 \rightarrow PC$ 

# Assembly-Language Format

NOP

# **Operand Size**

 I
 H
 N
 Z
 V
 C

 I
 Previous value remains unchanged.

 H:
 Previous value remains unchanged.

N: Previous value remains unchanged.

Z: Previous value remains unchanged.

V: Previous value remains unchanged.

C: Previous value remains unchanged.

# Description

This instruction only increments the program counter, causing the next instruction to be executed. The internal state of the CPU does not change.

# **Instruction Formats and Number of Execution States**

| Addressing<br>mode | Mnem. Operands |           | No. of   |          |          |          |        |
|--------------------|----------------|-----------|----------|----------|----------|----------|--------|
|                    |                | Operatios | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
|                    | NOP            |           | 0 0      | 0 0      |          |          | 2      |

# Condition Code

### 2.2.36 NOT (NOT = logical complement)

### NOT

# Operation

 $\neg \operatorname{Rd} \rightarrow \operatorname{Rd}$ 

# Assembly-Language Format

NOT  $\mathbf{R}\mathbf{d}$ 

# **Operand Size**

Byte



| Ι | Η    | Ν      | Ζ  | V | С |
|---|------|--------|----|---|---|
|   | <br> | <br>\$ | \$ | 0 |   |

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the result is negative; otherwise cleared to 0.
- Z: Set to 1 when the result is zero; otherwise cleared to 0.
- V: Cleared to 0.
- C: Previous value remains unchanged.

# Description

This instruction replaces the contents of an 8-bit general register with its one's complement (subtracts the register contents from H'FF).

| Addressing      | Mnem.  | Operands  |          |   | Ir       | nstructi | on code  |          | No. of |
|-----------------|--------|-----------|----------|---|----------|----------|----------|----------|--------|
| mode            | winem. | Operatios | 1st byte |   | 2nd byte |          | 3rd byte | 4th byte | states |
| Register direct | NOT    | Rd        | 1        | 7 | 0        | rd       |          |          | 2      |

### 2.2.37 OR (inclusive OR logical)

# Operation

 $Rd \lor (EAs) \rightarrow Rd$ 

### Assembly-Language Format

OR <EAs>, Rd

# **Operand Size**

Byte

# **Condition Code**

| Ι |   | Η | N     | Ζ  | V | С |
|---|---|---|-------|----|---|---|
| _ | _ |   | <br>€ | \$ | 0 |   |

- I: Previous value remains unchanged.
- H: Previous value remains unchanged.
- N: Set to 1 when the result is negative; otherwise cleared to 0.
- Z: Set to 1 when the result is zero; otherwise cleared to 0.
- V: Cleared to 0.
- C: Previous value remains unchanged.

# Description

This instruction ORs the source operand with the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Mnom     | Mnem. Operands |          | Instruction code |          |    |          |          |        |
|-----------------|----------|----------------|----------|------------------|----------|----|----------|----------|--------|
| mode            | Millern. | Operanus       | 1st byte |                  | 2nd byte |    | 3rd byte | 4th byte | states |
| Immediate       | OR       | #xx:8, Rd      | С        | rd               | IN       | IM |          |          | 2      |
| Register direct | OR       | Rs, Rd         | 1        | 4                | rs       | rd |          |          | 2      |

# 2.2.38 ORC (inclusive OR control register)

# Operation

 $CCR \lor \#IMM \rightarrow CCR$ 

# Assembly-Language Format ORC #xx:8, CCR

# **Operand Size**

Byte

|    | Ι    |        | Н       |      | N      | Z   | V     | C     |
|----|------|--------|---------|------|--------|-----|-------|-------|
|    | €    | \$     | \$      | \$   | \$     | \$  | \$    | \$    |
| I: | ORec | l with | n bit   | 7 of | the in | nme | diate | data. |
| H: | ORec | l with | n bit   | 5 of | the in | nme | diate | data. |
| N: | ORec | l with | n bit   | 3 of | the in | nme | diate | data. |
| Z: | ORec | l witl | n bit i | 2 of | the in | nme | diate | data. |
| V: | ORed | l witl | n bit   | 1 of | the in | nme | diate | data. |
| C: | ORed | l with | n bit   | 0 of | the in | nme | diate | data. |

**Condition Code** 

# Description

This instruction ORs the condition code register (CCR) with immediate data and places the result in the condition code register. Bits 6 and 4 are ORed as well as the flag bits. No interrupt requests are accepted immediately after this instruction. All interrupts are deferred until after the next instruction.

| Addressing | Mnom    | Mnem. Operands |          | Instruction code |          |          |          |        |  |  |
|------------|---------|----------------|----------|------------------|----------|----------|----------|--------|--|--|
| mode       | WITETT. | Operanus       | 1st byte |                  | 2nd byte | 3rd byte | 4th byte | states |  |  |
| Immediate  | ORC     | #xx:8, CCR     | 0        | 4                | IMM      |          |          | 2      |  |  |

| 2.2.39 POP (pop data)    | РОР                                                                  |
|--------------------------|----------------------------------------------------------------------|
| Operation                | Condition Code                                                       |
| $(@SP+ \rightarrow Rn)$  | + + + + + + + + + + + + + + + + + +                                  |
| Assembly-Language Format |                                                                      |
| POP Rn                   | I: Previous value remains unchanged.                                 |
| Operand Size             | H: Previous value remains unchanged.                                 |
| Word                     | N: Set to 1 when the data value is negative; otherwise cleared to 0. |
|                          | Z: Set to 1 when the data value is zero; otherwise cleared to 0.     |
|                          | V: Cleared to 0.                                                     |
|                          | C: Previous value remains unchanged.                                 |

This instruction pops data from the stack to a 16-bit general register and sets condition code flags according to the data value.

POP.W Rn is identical in machine language to MOV.W @SP+, Rn.

| Addressing | Mnem.   | Operands  |          | No. of   |          |          |        |
|------------|---------|-----------|----------|----------|----------|----------|--------|
| mode       | WITETT. | Operatios | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
|            | POP     | Rd        | 6 D      | 7 0 rn   |          |          | 6      |

| 2.2.40 PUSH (push data)  | PUSH                                                                                                                              |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Operation                | Condition Code                                                                                                                    |
| $Rn \rightarrow @-SP$    | $ \qquad $ |
| Assembly-Language Format |                                                                                                                                   |
| PUSH Rn                  |                                                                                                                                   |
|                          | I: Previous value remains unchanged.                                                                                              |
| Operand Size             | H: Previous value remains unchanged.                                                                                              |
| Word                     | N: Set to 1 when the data value is negative; otherwise cleared to 0.                                                              |
|                          | Z: Set to 1 when the data value is zero;                                                                                          |
|                          | otherwise cleared to 0.                                                                                                           |
|                          | V: Cleared to 0.                                                                                                                  |
|                          | C: Previous value remains unchanged.                                                                                              |

This instruction pushes data from a 16-bit general register onto the stack and sets condition code flags according to the data value.

PUSH.W Rn is identical in machine language to MOV.W Rn, @-SP.

| Addressing | Mnem.   | Operands |          | No. of   |          |          |        |
|------------|---------|----------|----------|----------|----------|----------|--------|
| mode       | WINEIN. | Operands | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
|            | PUSH    | Rs       | 6 D      | F 0 rn   |          |          | 6      |

| 2.2.41 ROTL (rotate left)          | ROTL                                                                                                                                     |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                          | Condition Code                                                                                                                           |
| Rd (rotated left) $\rightarrow$ Rd | $- \qquad \qquad$ |
| Assembly-Language Format           |                                                                                                                                          |
| ROTL Rd                            |                                                                                                                                          |
|                                    | I: Previous value remains unchanged.                                                                                                     |
| Operand Size                       | H: Previous value remains unchanged.                                                                                                     |
| Byte                               | N: Set to 1 when the result is negative;                                                                                                 |
| •                                  | otherwise cleared to 0.                                                                                                                  |
|                                    | Z: Set to 1 when the result is zero;                                                                                                     |
|                                    | otherwise cleared to 0.                                                                                                                  |
|                                    | V: Cleared to 0.                                                                                                                         |
|                                    | C: Receives the previous value in bit 7.                                                                                                 |

This instruction rotates an 8-bit general register one bit to the left. The most significant bit is rotated to the least significant bit, and also copied to the carry flag.

The operation is shown schematically below.



| Addressing      | Mnem.  | Operands  | Instruction code |   |          |    |          |          | No. of |
|-----------------|--------|-----------|------------------|---|----------|----|----------|----------|--------|
| mode            | winem. | Operatios | 1st byte         |   | 2nd byte |    | 3rd byte | 4th byte | states |
| Register direct | ROTL   | Rd        | 1                | 2 | 8        | rd |          |          | 2      |

# 2.2.42 ROTR (rotate right)

### ROTR

| Operation                           | Condition Code                                                                                                                                                              |  |  |  |  |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Rd (rotated right) $\rightarrow$ Rd | $\begin{array}{c c} I & H & N & Z & V & C \\ \hline \hline$ |  |  |  |  |  |
| Assembly-Language Format            |                                                                                                                                                                             |  |  |  |  |  |
| ROTR Rd                             |                                                                                                                                                                             |  |  |  |  |  |
|                                     | I: Previous value remains unchanged.                                                                                                                                        |  |  |  |  |  |
| Operand Size                        | H: Previous value remains unchanged.                                                                                                                                        |  |  |  |  |  |
| Byte                                | N: Set to 1 when the result is negative; otherwise cleared to 0.                                                                                                            |  |  |  |  |  |
|                                     | Z: Set to 1 when the result is zero;<br>otherwise cleared to 0.                                                                                                             |  |  |  |  |  |
|                                     | V: Cleared to 0.                                                                                                                                                            |  |  |  |  |  |
|                                     | C: Receives the previous value in bit 0.                                                                                                                                    |  |  |  |  |  |

# Description

This instruction rotates an 8-bit general register one bit to the right. The least significant bit is rotated to the most significant bit, and also copied to the carry flag.

The operation is shown schematically below.



| Addressing<br>mode Mne | Mnom   | Operanda         |       |     | Ins   | structi | on code  |          | No. of |
|------------------------|--------|------------------|-------|-----|-------|---------|----------|----------|--------|
|                        | winem. | Mnem.   Operands | 1st b | yte | 2nd l | oyte    | 3rd byte | 4th byte | states |
| Register direct        | ROTR   | Rd               | 1     | 3   | 8     | rd      |          |          | 2      |

#### 2.2.43 ROTXL (rotate with extend carry left) ROTXL **Condition Code** Operation Rd (rotated with carry left) $\rightarrow$ Rd Ι Η N Ζ Î ↑ 0 Assembly-Language Format ROTXL Rd I: Previous value remains unchanged. H: Previous value remains unchanged. **Operand Size** N: Set to 1 when the result is negative; Byte otherwise cleared to 0. Z: Set to 1 when the result is zero; otherwise cleared to 0. V: Cleared to 0. C: Receives the previous value in bit 7.

# Description

This instruction rotates an 8-bit general register one bit to the left through the carry flag. The carry flag is rotated into the least significant bit of the register. The most significant bit rotates into the carry flag.

The operation is shown schematically below.



| Addressing Mnem. | Mnom     | Operande |      |          | In | structi  | on code  |        | No. of |
|------------------|----------|----------|------|----------|----|----------|----------|--------|--------|
|                  | Operands | 1st      | byte | 2nd byte |    | 3rd byte | 4th byte | states |        |
| Register direct  | ROTXL    | Rd       | 1    | 2        | 0  | rd       |          |        | 2      |

# 2.2.44 ROTXR (rotate with extend carry right)

# Operation

Rd (rotated with carry right)  $\rightarrow$  Rd

# Assembly-Language Format

ROTXR  $\mathbf{R}\mathbf{d}$ 

# **Operand Size**

Byte

|   | CU | nunt  |                                   | out    |       |       |       |       |     |  |  |
|---|----|-------|-----------------------------------|--------|-------|-------|-------|-------|-----|--|--|
| d |    | Ι     |                                   | Н      |       | Ν     | Ζ     | V     | С   |  |  |
|   |    |       |                                   |        |       | \$    | \$    | 0     | \$  |  |  |
|   |    |       |                                   |        |       |       |       |       |     |  |  |
|   | I: | Prev  | ious                              | value  | e rem | ains  | uncł  | nange | ed. |  |  |
|   | H: | Prev  | Previous value remains unchanged. |        |       |       |       |       |     |  |  |
|   | N: | Set t | o 1 v                             | vhen   | the r | esult | is ne | egati | ve; |  |  |
|   |    | othe  | rwise                             | e clea | red t | o 0.  |       |       |     |  |  |
|   | Z: | Set t | o 1 v                             | vhen   | the r | esult | is ze | ero;  |     |  |  |
|   |    | othe  | rwise                             | e clea | red t | o 0.  |       |       |     |  |  |
|   | V: | Clea  | red t                             | o 0.   |       |       |       |       |     |  |  |

**Condition Code** 

C: Receives the previous value in bit 0.

ROTXR

# Description

This instruction rotates an 8-bit general register one bit to the right through the carry flag. The least significant bit is rotated into the carry flag. The carry flag rotates into the most significant bit.

The operation is shown schematically below.



| Addressing<br>mode Mr | Mnem.  | Operands | Instruction code |          |          |          | No. of |  |
|-----------------------|--------|----------|------------------|----------|----------|----------|--------|--|
|                       | winem. |          | 1st byte         | 2nd byte | 3rd byte | 4th byte | states |  |
| Register direct       | ROTXR  | Rd       | 1 3              | 0 rd     |          |          | 2      |  |

| 2.2.45 RTE (return from exception) | RTE                                   |
|------------------------------------|---------------------------------------|
| Operation                          | Condition Code                        |
| $@$ SP+ $\rightarrow$ CCR          | I H N Z V C                           |
| $@SP+ \rightarrow PC$              | 1     1     1     1     1     1     1 |
| Assembly-Language Format           | -                                     |
| RTE                                | I: Restored from stack.               |
|                                    | H: Restored from stack.               |
| Operand Size                       | N: Restored from stack.               |
|                                    | Z: Restored from stack.               |
|                                    | V: Restored from stack.               |
|                                    | C: Restored from stack.               |
|                                    |                                       |

This instruction returns from an exception-handling routine. It pops the condition code register (CCR) and program counter (PC) from the stack. Program execution continues from the address restored to the program counter.

The CCR and PC contents at the time of execution of this instruction are lost.

The CCR is one byte in size, but it is popped from the stack as a word (in which the lower 8 bits are ignored). This instruction therefore adds 4 to the value of the stack pointer (R7).

| Addressing<br>mode | Mnem. | Operands | Instruction code |       |      |          |          |        | No. of |
|--------------------|-------|----------|------------------|-------|------|----------|----------|--------|--------|
|                    |       | 1st t    | oyte             | 2nd b | oyte | 3rd byte | 4th byte | states |        |
|                    | RTE   |          | 5                | 6     | 7    | 0        |          |        | 10     |

### 2.2.46 RTS (return from subroutine)

### **Condition Code** Operation $@SP+ \rightarrow PC$ I Η Ν Ζ **Assembly-Language Format** RTS I: Previous value remains unchanged. H: Previous value remains unchanged. **Operand Size** N: Previous value remains unchanged. Z: Previous value remains unchanged. V: Previous value remains unchanged. C: Previous value remains unchanged.

### Description

This instruction returns from a subroutine. It pops the program counter (PC) from the stack. Program execution continues from the address restored to the program counter. The PC contents at the time of execution of this instruction are lost.

| Addressing<br>mode M | Mnem. | Operands |          | Instructi | on code  |        | No. of |
|----------------------|-------|----------|----------|-----------|----------|--------|--------|
|                      |       | 1st byte | 2nd byte | 3rd byte  | 4th byte | states |        |
|                      | RTS   |          | 5 4      | 7 0       |          |        | 8      |

| 2.2.47 SHAL (shift arithmetic left)            | SHAL                                                                                                                                     |  |  |  |  |  |  |  |
|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation                                      | Condition Code                                                                                                                           |  |  |  |  |  |  |  |
| Rd (shifted arithmetic left ) $\rightarrow$ Rd | I H N Z V C                                                                                                                              |  |  |  |  |  |  |  |
| Assembly-Language Format                       | $- \qquad \qquad$ |  |  |  |  |  |  |  |
| SHAL Rd                                        |                                                                                                                                          |  |  |  |  |  |  |  |
|                                                | I: Previous value remains unchanged.                                                                                                     |  |  |  |  |  |  |  |
| Operand Size                                   | H: Previous value remains unchanged.                                                                                                     |  |  |  |  |  |  |  |
| Byte                                           | N: Set to 1 when the result is negative;<br>otherwise cleared to 0.                                                                      |  |  |  |  |  |  |  |
|                                                | Z: Set to 1 when the result is zero;                                                                                                     |  |  |  |  |  |  |  |
|                                                | otherwise cleared to 0.                                                                                                                  |  |  |  |  |  |  |  |
|                                                | V: Set to 1 when an overflow occurs; otherwise cleared to 0.                                                                             |  |  |  |  |  |  |  |
|                                                | C: Receives the previous value in bit 7.                                                                                                 |  |  |  |  |  |  |  |

This instruction shifts an 8-bit general register one bit to the left. The most significant bit shifts into the carry flag, and the least significant bit is cleared to 0.

The operation is shown schematically below.



The SHAL instruction is identical to the SHLL instruction except for its effect on the overflow (V) flag.

| Addressing<br>mode Mnem | Mnom   | Operande |          | Instruction code |          |          |        |
|-------------------------|--------|----------|----------|------------------|----------|----------|--------|
|                         | winem. |          | 1st byte | 2nd byte         | 3rd byte | 4th byte | states |
| Register direct         | SHAL   | Rd       | 1 0      | 8 rd             |          |          | 2      |

| 2.2.48 SHAR (shift arithmetic right)            | SHAR                                                                                         |  |  |  |  |  |  |  |
|-------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation                                       | Condition Code                                                                               |  |  |  |  |  |  |  |
| Rd (shifted arithmetic right ) $\rightarrow$ Rd | I H N Z V C                                                                                  |  |  |  |  |  |  |  |
| Assembly-Language Format                        | $- \qquad - \qquad - \qquad - \qquad - \qquad - \qquad - \qquad + \qquad + \qquad + \qquad $ |  |  |  |  |  |  |  |
| SHAR Rd                                         |                                                                                              |  |  |  |  |  |  |  |
|                                                 | I: Previous value remains unchanged.                                                         |  |  |  |  |  |  |  |
| Operand Size                                    | H: Previous value remains unchanged.                                                         |  |  |  |  |  |  |  |
| Byte                                            | N: Set to 1 when the result is negative;<br>otherwise cleared to 0.                          |  |  |  |  |  |  |  |
|                                                 | Z: Set to 1 when the result is zero;                                                         |  |  |  |  |  |  |  |
|                                                 | otherwise cleared to 0.                                                                      |  |  |  |  |  |  |  |
|                                                 | V: Cleared to 0.                                                                             |  |  |  |  |  |  |  |
|                                                 | C: Receives the previous value in bit 0.                                                     |  |  |  |  |  |  |  |

This instruction shifts an 8-bit general register one bit to the right. The most significant bit remains unchanged. The sign of the result does not change. The least significant bit shifts into the carry flag.

The operation is shown schematically below.



| Addressing<br>mode Mnem | Mnom   | Operands |          | Instructi | on code  |          | No. of |
|-------------------------|--------|----------|----------|-----------|----------|----------|--------|
|                         | winem. | Operands | 1st byte | 2nd byte  | 3rd byte | 4th byte | states |
| Register direct         | SHAR   | Rd       | 1 1      | 8 rd      |          |          | 2      |

| 2.2.49 SHLL (shift logical left)            | SHLL                                                                                                                                     |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                                   | Condition Code                                                                                                                           |
| Rd (shifted logical left ) $\rightarrow$ Rd | $- \qquad \qquad$ |
| Assembly-Language Format                    |                                                                                                                                          |
| SHLL Rd                                     |                                                                                                                                          |
|                                             | I: Previous value remains unchanged.                                                                                                     |
| Operand Size                                | H: Previous value remains unchanged.                                                                                                     |
| Byte                                        | N: Set to 1 when the result is negative;<br>otherwise cleared to 0.                                                                      |
|                                             | Z: Set to 1 when the result is zero; otherwise cleared to 0.                                                                             |
|                                             | V: Cleared to 0.                                                                                                                         |
|                                             | C: Receives the previous value in bit 0.                                                                                                 |

# Description

This instruction shifts an 8-bit general register one bit to the left. The least significant bit is cleared to 0. The most significant bit shifts into the carry flag.

The operation is shown schematically below.



The SHLL instruction is identical to the SHAL instruction except for its effect on the overflow (V) flag.

| Addressing      | Mnom  | Operando |          | Instructi | on code  |          | No. of |
|-----------------|-------|----------|----------|-----------|----------|----------|--------|
| mode            | Mnem. | Operands | 1st byte | 2nd byte  | 3rd byte | 4th byte | states |
| Register direct | SHLL  | Rd       | 1 0      | 0 rd      |          |          | 2      |

| 2.2.50 SHLR (shift logical right)            | SHLR                                                                |
|----------------------------------------------|---------------------------------------------------------------------|
| Operation                                    | Condition Code                                                      |
| Rd (shifted logical right ) $\rightarrow$ Rd |                                                                     |
| Assembly-Language Format                     | + + + 0 + +                                                         |
| SHLR Rd                                      |                                                                     |
|                                              | I: Previous value remains unchanged.                                |
| Operand Size                                 | H: Previous value remains unchanged.                                |
| Byte                                         | N: Set to 1 when the result is negative;<br>otherwise cleared to 0. |
|                                              | Z: Set to 1 when the result is zero;                                |
|                                              | otherwise cleared to 0.                                             |
|                                              | V: Cleared to 0.                                                    |
|                                              | C: Receives the previous value in bit 0.                            |

# Description

This instruction shifts an 8-bit general register one bit to the right. The most significant bit is cleared to 0. The least significant bit shifts into the carry flag.

The operation is shown schematically below.



| Addressing      | e Mnom |          |          | Instruction code |          |          |        |  |
|-----------------|--------|----------|----------|------------------|----------|----------|--------|--|
| mode            | winem. | Operands | 1st byte | 2nd byte         | 3rd byte | 4th byte | states |  |
| Register direct | SHLR   | Rd       | 1 1      | 0 rd             |          |          | 2      |  |

# 2.2.51 SLEEP (sleep)SLEEPOperationCondition CodeProgram execution state $\rightarrow$ power-<br/>down modeIHNZVCIHNZVCIINZVCIINZVCIINZVCIINZVCIIPrevious value remains unchanged.ISLEEPIPrevious value remains unchanged.HOperand SizeNPrevious value remains unchanged.IPrevious value remains unchanged.ZPrevious value remains unchanged.VPrevious value remains unchanged.VPrevious value remains unchanged.

C: Previous value remains unchanged.

## Description

When the SLEEP instruction is executed, the CPU enters a power-down mode. Its internal state remains unchanged, but the CPU stops executing instructions and waits for an exception-handling request (interrupt or reset). When it receives an exception-handling request, the CPU exits the power-down mode and begins the exception-handling sequence.

If the interrupt mask (I) bit is set to 1, the power-down mode can be released only by a nonmaskable interrupt (NMI) or reset.

For information about the power-down modes, see the applicable hardware manual.

| Addressing | Mnem. Operands |            | Operands |          |          |          | No. of |
|------------|----------------|------------|----------|----------|----------|----------|--------|
| mode       | winem.         | Operations | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
|            | SLEEP          |            | 0 1      | 8 0      |          |          | 2      |

| 2.2.52 STC (store from control register) | STC                                  |
|------------------------------------------|--------------------------------------|
| Operation                                | Condition Code                       |
| $CCR \rightarrow Rd$                     | I H N Z V C                          |
| Assembly-Language Format                 |                                      |
| STC CCR, Rd                              |                                      |
|                                          | I: Previous value remains unchanged. |
| Operand Size                             | H: Previous value remains unchanged. |
| Byte                                     | N: Previous value remains unchanged. |
| 2                                        | Z: Previous value remains unchanged. |
|                                          | V: Previous value remains unchanged. |
|                                          | C: Previous value remains unchanged. |

# Description

This instruction copies the condition code register (CCR) to a specified general register. Bits 6 and 4 are copied as well as the flag bits.

| Addressing      | Mnom  | Operando |          | No. of   |          |          |        |
|-----------------|-------|----------|----------|----------|----------|----------|--------|
| mode            | Mnem. | Operands | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
| Register direct | STC   | CCR, Rd  | 0 2      | 0 rd     |          |          | 2      |

### 2.2.53 (1) SUB (subtract binary) (byte)

# Operation

 $Rd - Rs \rightarrow Rd$ 

### Assembly-Language Format

SUB.B Rs, Rd

# **Operand Size**

Byte

|    | _I       | Η        |        | Ν     | Z                 | V     | С   |
|----|----------|----------|--------|-------|-------------------|-------|-----|
|    |          | - 1      |        | \$    | $\Leftrightarrow$ | ↕     | \$  |
|    |          |          |        |       |                   |       |     |
| I: | Previo   | us value | e rem  | ains  | unc               | hang  | ed. |
| H: | Set to   | 1 when   | there  | is a  | borr              | ow f  | rom |
|    | bit 3; c | otherwis | e cle  | ared  | to 0              | •     |     |
| N: | Set to   | 1 when   | the r  | esul  | t is n            | egati | ve; |
|    | otherw   | ise clea | red to | o 0.  |                   |       |     |
| Z: | Set to 2 | 1 when   | the r  | esult | t is ze           | ero;  |     |
|    | otherw   | ise clea | red to | o 0.  |                   |       |     |
| V: | Set to 2 | 1 when   | an ov  | verfl | ow o              | occur | s;  |
|    | otherw   | ise clea | red to | o 0.  |                   |       |     |
| C: | Set to 2 | 1 when   | there  | is a  | borr              | ow f  | rom |
|    | bit 7; o | otherwis | e cle  | ared  | to 0              | •     |     |

### Description

This instruction subtracts an 8-bit source register from an 8-bit destination register and places the result in the destination register.

Only register direct addressing is supported. To subtract immediate data it is necessary to use the SUBX.B instruction, first setting the zero flag to 1 and clearing the carry flag to 0.

The following codings can also be used to subtract nonzero immediate data.

| (1) | ORC  | #H'05,  | CCR    | (2) | ADD  | #(0 – Imn | n), Rd |
|-----|------|---------|--------|-----|------|-----------|--------|
|     | SUBX | #(Imm – | 1), Rd |     | XORC | #H'01,    | CCR    |

**Instruction Formats and Number of Execution States** 

| Addressing Mnem. |        | Operands  |          | No. of   |          |          |        |
|------------------|--------|-----------|----------|----------|----------|----------|--------|
| mode             | winem. | Operatios | 1st byte | 2nd byte | 3rd byte | 4th byte | states |
| Register direct  | SUB.B  | Rs, Rd    | 1 8      | rs rd    |          |          | 2      |

| Ι | Η      | N     | Z. | V  | С  |
|---|--------|-------|----|----|----|
|   | <br>\$ | <br>↕ | \$ | \$ | \$ |

**SUB** 

| 2.2.53 (2) SUB (subtract binary) (word) | SUB                                                                                                                                                       |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                               | Condition Code                                                                                                                                            |
| $Rd - Rs \rightarrow Rd$                | I H N Z V C                                                                                                                                               |
| Assembly-Language Format                | $\lfloor - \rfloor - \lfloor \downarrow \rfloor - \lfloor \downarrow \rfloor \downarrow \rfloor \downarrow \rfloor \downarrow \rfloor \downarrow \rfloor$ |
| SUB.W Rs, Rd                            |                                                                                                                                                           |
|                                         | I: Previous value remains unchanged.                                                                                                                      |
| Operand Size                            | H: Set to 1 when there is a borrow from                                                                                                                   |
| Word                                    | bit 11; otherwise cleared to 0.                                                                                                                           |
|                                         | N: Set to 1 when the result is negative;<br>otherwise cleared to 0.                                                                                       |
|                                         | Z: Set to 1 when the result is zero; otherwise cleared to 0.                                                                                              |
|                                         | V: Set to 1 when an overflow occurs; otherwise cleared to 0.                                                                                              |
|                                         | C: Set to 1 when there is a borrow from                                                                                                                   |
|                                         | bit 15; otherwise cleared to 0.                                                                                                                           |

# Description

This instruction subtracts a 16-bit source register from a 16-bit destination register and places the result in the destination register.

| Addressing      | Mnem.  | Operands |          | Instructio | on code  |          | No. of |
|-----------------|--------|----------|----------|------------|----------|----------|--------|
| mode            | winem. | Operands | 1st byte | 2nd byte   | 3rd byte | 4th byte | states |
| Register direct | SUB.W  | Rs, Rd   | 1 9      | 0 rs 0 rd  |          |          | 2      |

| 2.2.54 SUBS (subtract with sign extension) | SUBS                                 |
|--------------------------------------------|--------------------------------------|
| Operation                                  | Condition Code                       |
| $Rd - 1 \rightarrow Rd$                    | I H N Z V C                          |
| $Rd - 2 \rightarrow Rd$                    |                                      |
| Assembly-Language Format                   |                                      |
| SUBS #1, Rd                                | I: Previous value remains unchanged. |
| SUBS #2, Rd                                | H: Previous value remains unchanged. |
|                                            | N: Previous value remains unchanged. |
| Operand Size                               | Z: Previous value remains unchanged. |
| Word                                       | V: Previous value remains unchanged. |
|                                            | C: Previous value remains unchanged. |

# Description

This instruction subtracts the immediate value 1 or 2 from word data in a general register. Unlike the SUB instruction, it does not affect the condition code flags.

The SUBS instruction does not permit byte operands.

| Addressing      | Mnem.  | Operands  |       |     | 1   | nstructio | on code  |          | No. of |
|-----------------|--------|-----------|-------|-----|-----|-----------|----------|----------|--------|
| mode            | winem. | Operatios | 1st b | yte | 2nd | byte      | 3rd byte | 4th byte | states |
| Register direct | SUBS   | #1, Rd    | 1     | В   | 0   | 0 rd      |          |          | 2      |
| Register direct | SUBS   | #2, Rd    | 1     | В   | 8   | 0 rd      |          |          | 2      |

## 2.2.55 SUBX (subtract with extend carry)

### Operation

 $Rd - (EAs) - C \rightarrow Rd$ 

# Assembly-Language Format SUBX <EAs>, Rd

# **Operand Size**

Byte

# **Condition Code**

| Ι | Η      | Ν      | Ζ  | V  | С  |
|---|--------|--------|----|----|----|
|   | <br>\$ | <br>\$ | \$ | \$ | \$ |

- I: Previous value remains unchanged.
- H: Set to 1 if there is a borrow from bit 3; otherwise cleared to 0.
- N: Set to 1 when the result is negative; otherwise cleared to 0.
- Z: Previous value remains unchanged when the result is zero; otherwise cleared to 0.
- V: Set to 1 when an overflow occurs; otherwise cleared to 0.
- C: Set to 1 when there is a borrow from bit 7; otherwise cleared to 0.

# Description

This instruction subtracts the source operand and carry flag from the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Maam  | Operands Instr |       | structi | on code |      | No. of   |          |        |
|-----------------|-------|----------------|-------|---------|---------|------|----------|----------|--------|
| mode            | Mnem. | Operanus       | 1st b | yte     | 2nd t   | oyte | 3rd byte | 4th byte | states |
| Immediate       | SUBX  | #xx:8, Rd      | В     | rd      | 11      | MM   |          |          | 2      |
| Register direct | SUBX  | Rs, Rd         | 1     | E       | rs      | rd   |          |          | 2      |

### 2.2.56 XOR (exclusive OR logical) XOR **Condition Code** Operation $Rd \oplus (EAs) \rightarrow Rd$ Η Ν Ι Ζ Î Î Assembly-Language Format XOR <EAs>, Rd I: Previous value remains unchanged. H: Previous value remains unchanged. **Operand Size** N: Set to 1 when the result is negative; Byte otherwise cleared to 0. Z: Set to 1 when the result is zero; otherwise cleared to 0. V: Cleared to 0. C: Previous value remains unchanged.

### Description

This instruction exclusive-ORs the source operand with the contents of an 8-bit general register and places the result in the general register.

| Addressing      | Mnem.  | Operands  |          | Instructi | on code  |          | No. of |
|-----------------|--------|-----------|----------|-----------|----------|----------|--------|
| mode            | winem. | Operanus  | 1st byte | 2nd byte  | 3rd byte | 4th byte | states |
| Immediate       | XOR    | #xx:8, Rd | D rd     | IMM       |          |          | 2      |
| Register direct | XOR    | Rs, Rd    | 1 5      | rs rd     |          |          | 2      |

# 2.2.57 XORC (exclusive OR control register)

| Operation                                   | Condition Code                                      |
|---------------------------------------------|-----------------------------------------------------|
| $CCR \oplus \#IMM \rightarrow CCR$          | I H N Z V C                                         |
| Assembly-Language Format<br>XORC #xx:8, CCR |                                                     |
| AURC #XX.0, CCK                             | I: Exclusive-ORed with bit 7 of the                 |
| Operand Size                                | immediate data.                                     |
| Byte                                        | H: Exclusive-ORed with bit 5 of the immediate data. |
|                                             | N: Exclusive-ORed with bit 3 of the immediate data. |
|                                             | Z: Exclusive-ORed with bit 2 of the immediate data. |
|                                             | V: Exclusive-ORed with bit 1 of the immediate data. |
|                                             | C: Exclusive-ORed with bit 0 of the immediate data. |

### Description

This instruction exclusive-ORs the condition code register (CCR) with immediate data and places the result in the condition code register. Bits 6 and 4 are exclusive-ORed as well as the flag bits.

No interrupt requests are accepted immediately after this instruction. All interrupts, including the nonmaskable interrupt (NMI), are deferred until after the next instruction.

| Addressing | Mnem.  | Operando   |          | Instructi | on code  |          | No. of |
|------------|--------|------------|----------|-----------|----------|----------|--------|
| mode       | winem. | Operands   | 1st byte | 2nd byte  | 3rd byte | 4th byte | states |
| Immediate  | XORC   | #xx:8, CCR | 0 5      | IMM       |          |          | 2      |

# 2.3 Operation Code Map

Table 2-1 shows the operation code map for instructions of the H8/300L CPU. Only the first byte (bits 15 to 8 of the first word) of the instruction code is indicated here.

- Indicates that the most significant bit of the 2nd byte (bit 7 of 1st word of instruction code) is 0.

 Indicates that the most significant bit of the 2nd byte (bit 7 of 1st word of instruction code) is 1.

 Table 2-1.
 Operation Code Map

| LO | 0     | 1            | 2       | 3        | 4   | 5    | 6    | 7           | 8   | 9   | A       | В      | с   | D           | E             | F   |
|----|-------|--------------|---------|----------|-----|------|------|-------------|-----|-----|---------|--------|-----|-------------|---------------|-----|
| 0  | NOP   | SLEEP        | STC     | LDC      | ORC | XORC | ANDC | LDC         | AI  | DD  | INC     | ADDS   | M   | ov          | ADDX          | DAA |
| 1  | SHLL  | SHLR<br>SHAR |         | ROTXR    | OR  | XOR  | AND  | NOT<br>NEG  | SI  | UB  | DEC     | SUBS   | с   | MP          | SUBX          | DAS |
| 2  |       | •            | <b></b> | <b>2</b> |     |      |      |             |     |     | <b></b> |        |     |             |               |     |
| 3  |       |              |         |          |     |      |      | M           | VO  |     |         |        |     |             |               |     |
| 4  | BRA   | BRN          | BHI     | BLS      | BCC | BCS  | BNE  | BEQ         | BVC | BVS | BPL     | BMI    | BGE | BLT         | BGT           | BLE |
| 5  | MULXU | DIVXU        |         |          | RTS | BSR  | RTE  |             |     |     | JMP     |        |     |             | JSR           |     |
| 6  | DOLT  | DNOT         |         | BTST     |     |      |      | BST<br>BIST |     |     |         | м      | ov* |             |               |     |
| 7  | BSET  | BNOT         | BCLR    | BISI     | BOR | BXOR | BAND | BLD<br>BILD |     | моу |         | EEPMOV | Bit | manipulatio | on instructio | ons |
| 8  |       |              |         |          |     |      |      | AI          | סכ  |     |         | ·      |     |             |               |     |
| 9  |       |              |         |          |     |      |      | AD          | DX  |     |         |        |     |             |               |     |
| A  |       |              |         |          |     |      |      | CI          | MP  |     |         |        |     |             |               |     |
| В  |       |              |         |          |     |      |      | SL          | IBX |     |         |        |     |             |               |     |
| с  |       |              |         |          |     |      | _    | С           | R   |     |         |        |     |             |               |     |
| D  |       |              |         |          |     |      |      | X           | OR  |     |         |        |     |             |               |     |
| E  |       |              |         |          |     |      |      | AI          | ND  |     |         |        |     |             |               |     |
| F  |       |              |         |          |     |      |      | M           | ov  |     |         |        |     |             |               |     |

Note: The PUSH and POP instructions are equivalent in machine language to the MOV instruction. See the descriptions of individual instructions in section 2.2, Instructions, for details.

# 2.4 List of Instructions

# Table 2-2. List of Instructions (1)

|                       |      |                                                            | Ir       |   |     |             | •         |          | de a<br>n (B |      | s)      |   |    |       |      |     |    |             |
|-----------------------|------|------------------------------------------------------------|----------|---|-----|-------------|-----------|----------|--------------|------|---------|---|----|-------|------|-----|----|-------------|
|                       | Size |                                                            | #xx:8/16 | _ | @Rn | @(d:16, Rn) | @-Rn/@Rn+ | @aa:8/16 | @(d:8, PC)   | @@aa | plied   | c | on | ditie | on ( | Coc | le | of States * |
| Mnemonic              | ŝ    | Operation                                                  | ¥        | R | 0   | 0           | Ó         | 0        | 0            | 0    | <u></u> | 1 | Н  | Ν     | Ζ    | ۷   | С  | ŝ           |
| MOV.B #xx:8, Rd       | В    | #xx:8 → Rd8                                                | 2        |   |     |             |           |          |              |      |         | _ |    | \$    | \$   | 0   | _  | 2           |
| MOV.B Rs, Rd          | В    | $Rs8 \rightarrow Rd8$                                      |          | 2 |     |             |           |          |              |      |         | - | -  | \$    | \$   | 0   | _  | 2           |
| MOV.B @Rs, Rd         | В    | @Rs16 → Rd8                                                |          |   | 2   |             |           |          |              |      |         | _ |    | \$    | \$   | 0   | _  | 4           |
| MOV.B @(d:16, Rs), Rd | В    | $@(d:16, Rs16) \rightarrow Rd8$                            |          |   |     | 4           |           |          |              |      |         | - | —  | \$    | \$   | 0   |    | 6           |
| MOV.B @Rs+, Rd        | В    | @Rs16 → Rd8<br>Rs16+1 → Rs16                               |          |   |     |             | 2         |          |              |      |         | - |    | \$    | \$   | 0   | -  | 6           |
| MOV.B @aa:8, Rd       | в    | @aa:8 → Rd8                                                |          |   |     |             |           | 2        |              |      |         | _ | _  | \$    | \$   | 0   | —  | 4           |
| MOV.B @aa:16, Rd      | В    | @aa:16 → Rd8                                               |          |   |     |             |           | 4        |              |      |         | - |    | \$    | \$   | 0   |    | 6           |
| MOV.B Rs, @Rd         | В    | Rs8 → @Rd16                                                |          |   | 2   |             |           |          |              |      |         |   |    | \$    | \$   | 0   | -  | 4           |
| MOV.B Rs, @(d:16, Rd) | В    | $Rs8 \rightarrow @(d:16, Rd16)$                            |          |   |     | 4           |           |          |              |      |         |   | -  | \$    | \$   | 0   |    | 6           |
| MOV.B Rs, @-Rd        | В    | Rd16–1 → Rd16<br>Rs8 → @Rd16                               |          |   |     |             | 2         |          |              |      |         | - | —  | \$    | \$   | 0   | -  | 6           |
| MOV.B Rs, @aa:8       | в    | Rs8 → @aa:8                                                |          |   |     |             |           | 2        |              |      |         | _ |    | \$    | \$   | 0   | _  | 4           |
| MOV.B Rs, @aa:16      | В    | Rs8 → @aa:16                                               |          |   |     |             |           | 4        |              |      |         | — |    | \$    | \$   | 0   | _  | 6           |
| MOV.W #xx:16, Rd      | W    | #xx:16 → Rd                                                | 4        |   |     |             |           |          |              |      |         | - | -  | \$    | \$   | 0   |    | 4           |
| MOV.W Rs, Rd          | w    | $Rs16 \rightarrow Rd16$                                    |          | 2 |     |             |           |          |              |      |         | _ |    | \$    | \$   | 0   |    | 2           |
| MOV.W @Rs, Rd         | w    | @Rs16 → Rd16                                               |          |   | 2   |             |           |          |              |      |         | - | _  | \$    | \$   | 0   | -  | 4           |
| MOV.W @(d:16, Rs), Rd | W    | $@(d:16, Rs16) \rightarrow Rd16$                           |          |   |     | 4           |           |          |              |      |         | - |    | \$    | \$   | 0   | _  | 6           |
| MOV.W @Rs+, Rd        | w    | @Rs16 → Rd16<br>Rs16+2 → Rs16                              |          |   |     |             | 2         |          |              |      |         | - | —  | \$    | \$   | 0   |    | 6           |
| MOV.W @aa:16, Rd      | W    | @aa:16 → Rd16                                              |          |   |     |             |           | 4        |              |      |         | — |    | \$    | ↕    | 0   | -  | 6           |
| MOV.W Rs, @Rd         | w    | $Rs16 \rightarrow @Rd16$                                   |          |   | 2   |             |           |          |              |      |         | — | —  | \$    | \$   | 0   | —  | 4           |
| MOV.W Rs, @(d:16, Rd) | W    | $Rs16 \rightarrow @(d:16, Rd16)$                           |          |   |     | 4           |           |          |              |      |         |   |    | \$    | \$   | 0   | —  | 6           |
| MOV.W Rs, @-Rd        | w    | Rd16–2 → Rd16<br>Rs16 → @Rd16                              |          |   |     |             | 2         |          |              |      |         | - | -  | \$    | \$   | 0   | -  | 6           |
| MOV.W Rs, @aa:16      | W    | Rs16 → @aa:16                                              |          |   |     |             |           | 4        |              |      |         |   | —  | \$    | \$   | 0   | _  | 6           |
| POP Rd                | w    | $\begin{array}{l} @SP \to Rd16 \\ SP+2 \to SP \end{array}$ |          |   |     |             | 2         |          |              |      |         | _ | -  | \$    | \$   | 0   | -  | 6           |
| PUSH Rs               | W    | $SP-2 \rightarrow SP$<br>Rs16 $\rightarrow @SP$            |          |   |     |             | 2         |          |              |      |         |   |    | \$    | \$   | 0   |    | 6           |

# Table 2-2. List of Instructions (2)

|                  |      |                                                       | in       |    |     |             | ng I<br>Ler |          |            |      | s)      |   |    |       |      |     |    |                |
|------------------|------|-------------------------------------------------------|----------|----|-----|-------------|-------------|----------|------------|------|---------|---|----|-------|------|-----|----|----------------|
|                  | Size |                                                       | #xx:8/16 | ſ  | @Rn | @(d:16, Rn) | @-Rn/@Rn+   | @aa:8/16 | @(d:8, PC) | ගුඔය | Implied | c | on | ditie | on ( | Cod | le | o. of States * |
| Mnemonic         | Si   | Operation                                             | ¥        | Rn | 0   | 0           | 0           | 0        | 0          | 0    | E       | I | Η  | Ν     | Ζ    | ۷   | С  | Ŝ              |
| ADD.B #xx:8, Rd  | В    | $Rd8+#xx:8 \rightarrow Rd8$                           | 2        |    |     |             |             |          |            |      |         |   | \$ | \$    | \$   | \$  | \$ | 2              |
| ADD.B Rs, Rd     | В    | $Rd8+Rs8 \rightarrow Rd8$                             |          | 2  |     |             |             |          |            |      |         | _ | \$ | \$    | \$   | \$  | \$ | 2              |
| ADD.W Rs, Rd     | W    | $Rd16+Rs16 \rightarrow Rd16$                          |          | 2  |     |             |             |          |            |      |         | — | 1  | \$    | \$   | \$  | \$ | 2              |
| ADDX.B #xx:8, Rd | В    | $Rd8+#xx:8+C \rightarrow Rd8$                         | 2        |    |     |             |             |          |            |      |         | — | ⊅  | \$    | 2    | \$  | \$ | 2              |
| ADDX.B Rs, Rd    | В    | $Rd8+Rs8+C \rightarrow Rd8$                           |          | 2  |     |             |             |          |            |      |         | — | \$ | \$    | 2    | \$  | \$ | 2              |
| ADDS.W #1, Rd    | w    | $Rd16+1 \rightarrow Rd16$                             |          | 2  |     |             |             |          |            |      |         | — |    |       |      | _   | —  | 2              |
| ADDS.W #2, Rd    | w    | $Rd16+2 \rightarrow Rd16$                             |          | 2  |     |             |             |          |            |      |         | — |    |       |      | _   | —  | 2              |
| INC.B Rd         | В    | $Rd8+1 \rightarrow Rd8$                               |          | 2  |     |             |             |          |            |      |         | — |    | \$    | \$   | \$  | —  | 2              |
| DAA.B Rd         | В    | Rd8 decimal-adjust $\rightarrow$ Rd8                  |          | 2  |     |             |             |          |            |      |         |   | *  | \$    | \$   | *   | 3  | 2              |
| SUB.B Rs, Rd     | В    | $Rd8-Rs8 \rightarrow Rd8$                             |          | 2  |     |             |             |          |            |      |         | _ | \$ | \$    | \$   | \$  | \$ | 2              |
| SUB.W Rs, Rd     | W    | $Rd16-Rs16 \rightarrow Rd16$                          |          | 2  |     |             |             |          |            |      |         | _ | 1  | \$    | \$   | \$  | \$ | 2              |
| SUBX.B #xx:8, Rd | В    | Rd8–#xx:8–C $\rightarrow$ Rd8                         | 2        |    |     |             |             |          |            |      |         |   | \$ | \$    | 2    | \$  | \$ | 2              |
| SUBX.B Rs, Rd    | В    | $Rd8-Rs8-C \rightarrow Rd8$                           |          | 2  |     |             |             |          |            |      |         |   | \$ | \$    | 2    | \$  | \$ | 2              |
| SUBS.W #1, Rd    | W    | Rd16–1 → Rd16                                         |          | 2  |     |             |             |          |            |      |         |   |    |       |      | _   | _  | 2              |
| SUBS.W #2, Rd    | W    | Rd16–2 → Rd16                                         |          | 2  |     |             |             |          |            |      |         |   | —  |       |      |     | _  | 2              |
| DEC.B Rd         | В    | $Rd8-1 \rightarrow Rd8$                               |          | 2  |     |             |             |          |            |      |         | _ | _  | \$    | \$   | \$  |    | 2              |
| DAS.B Rd         | в    | Rd8 decimal-adjust $\rightarrow$ Rd8                  |          | 2  |     |             |             |          |            |      |         |   | *  | \$    | \$   | *   | _  | 2              |
| NEG.B Rd         | В    | $0-\text{Rd} \rightarrow \text{Rd}$                   |          | 2  |     |             |             |          |            |      |         |   | \$ | \$    | \$   | \$  | \$ | 2              |
| CMP.B #xx:8, Rd  | В    | Rd8–#xx:8                                             | 2        |    |     |             |             |          |            |      |         | _ | \$ | \$    | \$   | \$  | \$ | 2              |
| CMP.B Rs, Rd     | В    | Rd8–Rs8                                               |          | 2  |     |             |             |          |            |      |         |   | \$ | \$    | \$   | \$  | \$ | 2              |
| CMP.W Rs, Rd     | w    | Rd16-Rs16                                             |          | 2  |     |             |             |          |            |      |         | _ | 1  | \$    | \$   | \$  | \$ | 2              |
| MULXU.B Rs, Rd   | В    | $Rd8 \times Rs8 \rightarrow Rd16$                     |          | 2  |     |             |             |          |            |      |         |   |    |       |      | _   | —  | 14             |
| DIVXU.B Rs, Rd   | В    | Rd16÷Rs8 → Rd16<br>(RdH: remainder,<br>RdL: quotient) |          | 2  |     |             |             |          |            |      |         |   |    | 6     | 6    |     |    | 14             |
| AND.B #xx:8, Rd  | В    | $Rd8^{x:8} \rightarrow Rd8$                           | 2        |    |     |             |             |          |            |      |         |   | _  | \$    | \$   | 0   | _  | 2              |
| AND.B Rs, Rd     | В    | Rd8∧Rs8 → Rd8                                         |          | 2  |     |             |             |          |            |      |         |   |    | \$    | \$   | 0   |    | 2              |
| OR.B #xx:8, Rd   | В    | Rd8∨#xx:8 → Rd8                                       | 2        |    |     |             |             |          |            |      |         | _ | _  | \$    | \$   | 0   | _  | 2              |
| OR.B Rs, Rd      | в    | Rd8∨Rs8 → Rd8                                         |          | 2  |     |             |             |          |            |      |         | _ |    | \$    | \$   | 0   | _  | 2              |
| XOR.B #xx:8, Rd  | В    | Rd8⊕#xx:8 → Rd8                                       | 2        |    |     |             |             |          |            |      |         |   |    | \$    | \$   | 0   |    | 2              |
| XOR.B Rs, Rd     | в    | $Rd8 \oplus Rs8 \rightarrow Rd8$                      |          | 2  |     |             |             |          |            |      |         | _ | _  | \$    | \$   | 0   |    | 2              |
| NOT.B Rd         | в    | $\overline{Rd} \to Rd$                                |          | 2  |     |             |             |          |            |      |         | — |    | \$    | \$   | 0   |    | 2              |

# Table 2-2. List of Instructions (3)

|                   |      |                                                                                                                                                      | Addressing Mode and<br>Instruction Length (Bytes)                                          |   |   |   |   |   |   | s)     |   |    |   |    |    |    |                 |   |
|-------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|---|---|---|---|---|---|--------|---|----|---|----|----|----|-----------------|---|
|                   | Size |                                                                                                                                                      | #xx:8/16<br>Rn<br>@Rn<br>@Rn/@Rn+<br>@aa:8/16<br>@aa:8/16<br>@(d:8, PC)<br>@@aa<br>Implied |   |   |   |   |   |   | nplied |   | on |   |    |    |    | No. of States * |   |
| Mnemonic          |      | Operation                                                                                                                                            | ŧ                                                                                          |   | Ø | 0 | 0 | ଞ | 0 | 0      | Ľ | 1  | н | N  | Z  | ۷  | С               |   |
| SHAL.B Rd         | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | \$ | \$ | \$ | \$              | 2 |
| SHAR.B Rd         | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | \$ | \$ | 0  | \$              | 2 |
| SHLL.B Rd         | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | \$ | \$ | 0  | \$              | 2 |
| SHLR.B Rd         | В    | $0 \rightarrow \qquad \qquad$ |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | 0  | \$ | 0  | \$              | 2 |
| ROTXL.B Rd        | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | \$ | \$ | 0  | \$              | 2 |
| ROTXR.B Rd        | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   | • |   |        |   |    |   | \$ | \$ | 0  | \$              | 2 |
| ROTL.B Rd         | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | \$ | \$ | 0  | \$              | 2 |
| ROTR.B Rd         | В    |                                                                                                                                                      |                                                                                            | 2 |   |   |   |   |   |        |   | _  |   | \$ | \$ | 0  | \$              | 2 |
| BSET #xx:3, Rd    | в    | (#xx:3 of Rd8) ← 1                                                                                                                                   |                                                                                            | 2 |   |   |   |   |   |        |   |    |   | _  | —  | —  | _               | 2 |
| BSET #xx:3, @Rd   | В    | (#xx:3 of @Rd16) ← 1                                                                                                                                 |                                                                                            |   | 4 |   |   |   |   |        |   |    | _ |    |    |    |                 | 8 |
| BSET #xx:3, @aa:8 | В    | (#xx:3 of @aa:8) ← 1                                                                                                                                 |                                                                                            |   |   |   |   | 4 |   |        |   | _  |   | _  |    | —  | —               | 8 |
| BSET Rn, Rd       | В    | (Rn8 of Rd8) ← 1                                                                                                                                     |                                                                                            | 2 |   |   |   |   |   |        |   |    |   |    |    | —  |                 | 2 |
| BSET Rn, @Rd      | В    | (Rn8 of @Rd16) ← 1                                                                                                                                   |                                                                                            |   | 4 |   |   |   |   |        |   | _  | _ |    | _  | _  |                 | 8 |
| BSET Rn, @aa:8    | В    | (Rn8 of @aa:8) ← 1                                                                                                                                   |                                                                                            |   |   |   |   | 4 |   |        |   |    | - | —  | _  | —  | _               | 8 |

# Table 2-2. List of Instructions (4)

|                   | T    |                                                       | Ir            |   |     |             | ng I<br>Ler |          |            |       | s)      |   |    |   |    |     |    |                |
|-------------------|------|-------------------------------------------------------|---------------|---|-----|-------------|-------------|----------|------------|-------|---------|---|----|---|----|-----|----|----------------|
|                   | Size |                                                       | #xx:8/16      | E | @Rn | @(d:16, Rn) | @-Rn/@Rn+   | @aa:8/16 | @(d:8, PC) | ගුළුය | Implied | c | on |   |    | Cod | le | o. of States * |
| Mnemonic          | 0.   | Operation                                             | <del>\$</del> | 뗦 | 0   | 0           | 0           | 0        | 0          | 0     | 느       | 1 | Н  | Ν | Z  | ۷   | С  | Ŝ              |
| BCLR #xx:3, Rd    | В    | (#xx:3 of Rd8) ← 0                                    | ļ             | 2 |     |             |             |          |            |       |         |   |    | _ |    | _   | _  | 2              |
| BCLR #xx:3, @Rd   | В    | (#xx:3 of @Rd16) ← 0                                  |               |   | 4   |             |             |          |            |       |         |   |    |   | -  |     | _  | 8              |
| BCLR #xx:3, @aa:8 | В    | (#xx:3 of @aa:8) ← 0                                  |               |   |     |             |             | 4        |            |       |         |   | -  |   | -  |     | _  | 8              |
| BCLR Rn, Rd       | В    | (Rn8 of Rd8) ← 0                                      |               | 2 |     |             |             |          |            |       |         | _ | _  | _ |    | -   | _  | 2              |
| BCLR Rn, @Rd      | В    | (Rn8 of @Rd16) ← 0                                    |               |   | 4   |             |             |          |            |       |         | - |    | _ | -  | _   | _  | 8              |
| BCLR Rn, @aa:8    | В    | (Rn8 of @aa:8) ← 0                                    |               |   |     |             |             | 4        |            |       |         |   |    | _ |    | —   |    | 8              |
| BNOT #xx:3, Rd    | В    | (#xx:3 of Rd8) ←<br>(#xx:3 of Rd8)                    |               | 2 |     |             |             |          |            |       |         |   |    |   |    | —   | —  | 2              |
| BNOT #xx:3, @Rd   | В    | (#xx:3 of @Rd16) ←<br>(#xx:3 of @Rd16)                |               |   | 4   |             |             |          |            |       |         | — |    | _ |    | —   |    | 8              |
| BNOT #xx:3, @aa:8 | В    | (#xx:3 of @aa:8) ←<br>(#xx:3 of @aa:8)                |               |   |     |             |             | 4        |            |       |         | — | —  |   |    |     | —  | 8              |
| BNOT Rn, Rd       | В    | (Rn8 of Rd8) ←<br>(Rn8 of Rd8)                        |               | 2 |     |             |             |          |            |       |         |   |    |   | —  |     | -  | 2              |
| BNOT Rn, @Rd      | В    | (Rn8 of @Rd16) ←<br>(Rn8 of @Rd16)                    |               |   | 4   |             |             |          |            |       |         | — |    |   |    | _   | -  | 8              |
| BNOT Rn, @aa:8    | В    | (Rn8 of @aa:8) ←<br>(Rn8 of @aa:8)                    |               |   |     |             |             | 4        |            |       |         | — | —  |   |    | -   | -  | 8              |
| BTST #xx:3, Rd    | В    | $(\overline{\#xx:3 \text{ of } Rd8}) \rightarrow Z$   |               | 2 |     |             |             |          |            |       |         |   |    | — | \$ | _   |    | 2              |
| BTST #xx:3, @Rd   | В    | $(\overline{\#xx:3 \text{ of } @Rd16}) \rightarrow Z$ |               |   | 4   |             |             |          |            |       |         | _ |    |   | \$ |     |    | 6              |
| BTST #xx:3, @aa:8 | В    | $(\overline{\#xx:3 \text{ of } @aa:8}) \rightarrow Z$ |               |   |     |             |             | 4        |            |       |         |   |    |   | \$ | _   | -  | 6              |
| BTST Rn, Rd       | В    | $(\overline{Rn8 \text{ of } Rd8}) \rightarrow Z$      |               | 2 |     |             |             |          |            |       |         |   | —  | — | \$ |     | _  | 2              |
| BTST Rn, @Rd      | В    | $(\overline{Rn8 \text{ of } @Rd16}) \rightarrow Z$    |               |   | 4   |             |             |          |            |       |         | _ |    |   | \$ |     | —  | 6              |
| BTST Rn, @aa:8    | В    | (Rn8 of @aa:8) $\rightarrow$ Z                        |               |   |     |             |             | 4        |            |       |         |   |    |   | \$ |     | —  | 6              |
| BLD #xx:3, Rd     | В    | (#xx:3 of Rd8) $\rightarrow$ C                        |               | 2 |     |             |             |          |            |       |         | — |    |   |    |     | \$ | 2              |
| BLD #xx:3, @Rd    | В    | (#xx:3 of @Rd16) $\rightarrow$ C                      |               |   | 4   |             |             |          |            |       |         |   | _  |   |    |     | \$ | 6              |
| BLD #xx:3, @aa:8  | В    | (#xx:3 of @aa:8) $\rightarrow$ C                      |               |   |     |             |             | 4        |            |       |         |   |    |   |    |     | \$ | 6              |
| BILD #xx:3, Rd    | В    | $(\overline{\#xx:3 \text{ of } Rd8}) \rightarrow C$   |               | 2 |     |             |             |          |            |       |         | — |    |   |    |     | \$ | 2              |
| BILD #xx:3, @Rd   | В    | $(\overline{\#xx:3 \text{ of } @Rd16}) \rightarrow C$ |               |   | 4   |             |             |          |            |       |         |   | _  |   |    |     | \$ | 6              |
| BILD #xx:3, @aa:8 | В    | $(\overline{\#xx:3 \text{ of } @aa:8}) \rightarrow C$ |               |   |     |             |             | 4        |            |       |         |   | —  |   |    | —   | \$ | 6              |
| BST #xx:3, Rd     | в    | $C \rightarrow (\#xx:3 \text{ of } Rd8)$              |               | 2 |     |             |             |          |            |       |         |   |    |   | —  |     |    | 2              |
| BST #xx:3, @Rd    | В    | $C \rightarrow (\#xx:3 \text{ of } @Rd16)$            |               |   | 4   |             |             |          |            |       |         |   | _  | _ |    |     |    | 8              |
| BST #xx:3, @aa:8  | В    | $C \rightarrow (\#xx:3 \text{ of } @aa:8)$            |               |   |     |             |             | 4        |            |       |         |   |    |   |    | —   |    | 8              |

# Table 2-2. List of Instructions (5)

|                    |      | _                                   |                                        | Ir       |   |     |             | ng l<br>Ler |          |            |       | s)      |   |    |       |      |     |    |               |
|--------------------|------|-------------------------------------|----------------------------------------|----------|---|-----|-------------|-------------|----------|------------|-------|---------|---|----|-------|------|-----|----|---------------|
|                    | ze   |                                     | Branching                              | #xx:8/16 | _ | @Rn | @(d:16, Rn) | @-Rn/@Rn+   | @aa:8/16 | @(d:8, PC) | ලැබිය | Implied | С | on | ditie | on ( | Cod | le | . of States * |
| Mnemonic           | Size | Operation                           | Condition                              | ¥        | Я | 0   | ø           | 0           | Ö        | 0          | ø     | <u></u> | I | Н  | Ν     | Z    | ۷   | С  | Ŝ             |
| BIST #xx:3, Rd     | В    | $\overline{C} \rightarrow (\#xx:3)$ | of Rd8)                                |          | 2 |     |             |             |          |            |       |         | _ |    | _     | —    | _   | _  | 2             |
| BIST #xx:3, @Rd    | В    | $\overline{C} \rightarrow (\#xx:3)$ | of @Rd16)                              |          |   | 4   |             |             |          |            |       |         | _ |    | _     | _    | -   | -  | 8             |
| BIST #xx:3, @aa:8  | В    | $\overline{C} \rightarrow (\#xx:3)$ | of @aa:8)                              |          |   |     |             |             | 4        |            |       |         | — |    | —     |      |     | _  | 8             |
| BAND #xx:3, Rd     | В    | C∧(#xx:3 of                         | $Rd8) \rightarrow C$                   |          | 2 |     |             |             |          |            |       |         | - | _  | —     |      | _   | \$ | 2             |
| BAND #xx:3, @Rd    | В    | C∧(#xx:3 of                         | $($ Rd16 $) \rightarrow C$             |          |   | 4   |             |             |          |            |       |         |   | _  |       |      | _   | \$ | 6             |
| BAND #xx:3, @aa:8  | В    | C∧(#xx:3 of                         | @aa:8) → C                             |          |   |     |             |             | 4        |            |       |         |   |    | —     | _    |     | \$ | 6             |
| BIAND #xx:3, Rd    | В    | C∧( <del>#</del> xx:3 of            | $\overline{Rd8}) \rightarrow C$        |          | 2 |     |             |             |          |            |       |         | — |    | —     |      |     | \$ | 2             |
| BIAND #xx:3, @Rd   | В    | C∧(#xx:3 of                         | $(@Rd16) \rightarrow C$                |          |   | 4   |             |             |          |            |       |         | — |    |       |      | -   | \$ | 6             |
| BIAND #xx:3, @aa:8 | В    | C∧( <del>#xx:3</del> of             | @aa:8) → C                             |          |   |     |             |             | 4        |            |       |         | _ |    |       | —    |     | \$ | 6             |
| BOR #xx:3, Rd      | В    | C∨(#xx:3 of                         | $Rd8) \rightarrow C$                   |          | 2 |     |             |             |          |            |       |         |   |    |       |      |     | \$ | 2             |
| BOR #xx:3, @Rd     | В    | C∨(#xx:3 of                         | $(MRd16) \rightarrow C$                |          |   | 4   |             |             |          |            |       |         |   | _  |       |      |     | \$ | 6             |
| BOR #xx:3, @aa:8   | в    | C∨(#xx:3 of                         | @aa:8) → C                             |          |   |     |             |             | 4        |            |       |         | — |    |       |      |     | \$ | 6             |
| BIOR #xx:3, Rd     | в    | C∨( <b>#</b> xx:3 of                | $Rd8) \rightarrow C$                   |          | 2 |     |             |             |          |            |       |         | — |    |       | —    |     | \$ | 2             |
| BIOR #xx:3, @Rd    | В    | C∨( <del>#xx:3 of</del>             | (2000000000000000000000000000000000000 |          |   | 4   |             |             |          |            |       |         | _ | I  | l     |      |     | \$ | 6             |
| BIOR #xx:3, @aa:8  | В    | C∨( <del>#xx:3 of</del>             | $\overline{(aa:8)} \rightarrow C$      |          |   |     |             |             | 4        |            |       |         |   |    | -     |      |     | \$ | 6             |
| BXOR #xx:3, Rd     | В    | C⊕(#xx:3 of                         | Rd8) $\rightarrow$ C                   |          | 2 |     |             |             |          |            |       |         |   |    |       |      |     | \$ | 2             |
| BXOR #xx:3, @Rd    | В    | C⊕(#xx:3 of                         | @Rd16) → C                             |          |   | 4   |             |             |          |            |       |         |   | -  |       | _    |     | \$ | 6             |
| BXOR #xx:3, @aa:8  | В    | C⊕(#xx:3 of                         | @aa:8) → C                             |          |   |     |             |             | 4        |            |       |         |   | _  | —     |      | _   | \$ | 6             |
| BIXOR #xx:3, Rd    | В    | C⊕( <del>#xx:3 of</del>             | Rd8) → C                               |          | 2 |     |             |             |          |            |       |         | _ |    | _     |      |     | \$ | 2             |
| BIXOR #xx:3, @Rd   | в    | C⊕( <del>#xx:3 of</del>             | @Rd16) → C                             |          |   | 4   |             |             |          |            |       |         | _ | _  |       |      | _   | \$ | 6             |
| BIXOR #xx:3, @aa:8 | в    | C⊕( <del>#xx:3 of</del>             | @aa:8) → C                             |          |   |     |             |             | 4        |            |       |         | - | -  | -     | -    |     | \$ | 6             |
| BRA d:8 (BT d:8)   |      | $PC \leftarrow PC+d$                | :8                                     |          |   |     |             |             |          | 2          |       |         |   | -  | _     |      | _   | _  | 4             |
| BRN d:8 (BF d:8)   |      | $PC \leftarrow PC+2$                |                                        |          |   |     |             |             |          | 2          |       |         | _ | -  | _     |      |     |    | 4             |
| BHI d:8            |      | if condition                        | C∨Z = 0                                |          |   |     |             |             |          | 2          |       |         | _ | -  |       |      |     |    | 4             |
| BLS d:8            |      | is true then $PC \leftarrow$        | C∨Z = 1                                |          |   |     |             |             |          | 2          |       |         | _ |    |       |      |     |    | 4             |
| BCC d:8 (BHS d:8)  |      | PC+d:8                              | C = 0                                  |          |   |     |             |             |          | 2          |       |         | _ | -  | -     |      | _   |    | 4             |
| BCS d:8 (BLO d:8)  | _    | else next;                          | C = 1                                  |          |   |     |             |             |          | 2          |       |         | _ |    | _     | —    |     |    | 4             |
| BNE d:8            |      |                                     | Z = 0                                  |          |   |     |             |             |          | 2          |       |         |   | _  | _     |      |     |    | 4             |
| BEQ d:8            |      |                                     | Z = 1                                  |          |   |     |             |             |          | 2          |       |         |   | _  | _     |      |     |    | 4             |
| BVC d:8            | _    | V = 0                               |                                        |          |   |     |             |             |          | 2          |       |         | _ | _  | _     |      | _   |    | 4             |
| BVS d:8            |      |                                     | V = 1                                  |          |   |     |             |             |          | 2          |       |         | _ | _  | _     |      |     |    | 4             |

# Table 2-2. List of Instructions (6)

|                 |      |                                                                                                                     |                           | Ir       |   |     |             | ng l<br>Ler |          |            |       | s)      |    |    |       |      |     |    |               |
|-----------------|------|---------------------------------------------------------------------------------------------------------------------|---------------------------|----------|---|-----|-------------|-------------|----------|------------|-------|---------|----|----|-------|------|-----|----|---------------|
|                 | e    |                                                                                                                     | Branching                 | #xx:8/16 |   | Ľ   | @(d:16, Rn) | @-Rn/@Rn+   | @aa:8/16 | @(d:8, PC) | ඟු ඔය | Implied | c  | on | ditio | on ( | Cod | le | . of States * |
| Mnemonic        | Size | Operation                                                                                                           | Condition                 | Q#       | 쎮 | @Rn | ø           | Q           | <b>@</b> | ø          | ø     | Ē       | I  | Н  | Ν     | Z    | ۷   | С  | Ŝ             |
| BPL d:8         |      | if condition                                                                                                        | N = 0                     |          |   |     |             |             |          | 2          |       |         |    |    |       |      |     | _  | 4             |
| BMI d:8         |      | is true then<br>PC ←                                                                                                | N = 1                     |          |   |     |             |             |          | 2          |       |         |    |    | —     |      | —   | _  | 4             |
| BGE d:8         |      | PC+d:8                                                                                                              | N⊕V = 0                   |          |   |     |             |             |          | 2          |       |         |    | —  |       | —    |     | -  | 4             |
| BLT d:8         |      | else next;                                                                                                          | N⊕V = 1                   |          |   |     |             |             |          | 2          |       |         | _  |    | -     |      | —   | —  | 4             |
| BGT d:8         |      |                                                                                                                     | Z∨(N⊕V) = 0               |          |   |     |             |             |          | 2          |       |         | _  |    | _     |      | _   | _  | 4             |
| BLE d:8         |      |                                                                                                                     | $Z \lor (N \oplus V) = 1$ |          |   |     |             |             |          | 2          |       |         |    |    | _     |      | —   |    | 4             |
| JMP @Rn         |      | PC ← Rn16                                                                                                           |                           |          |   | 2   |             |             |          |            |       |         |    | -  |       |      |     | -  | 4             |
| JMP @aa:16      | _    | PC ← aa:16                                                                                                          |                           |          |   |     |             |             | 4        |            |       |         |    | _  |       | _    | _   | _  | 6             |
| JMP @@aa:8      | _    | PC ← @aa:                                                                                                           | 8                         |          |   |     |             |             |          |            | 2     |         |    | —  |       | _    |     | -  | 8             |
| BSR d:8         |      | $SP-2 \rightarrow SP$<br>PC $\rightarrow @SP$<br>PC $\leftarrow$ PC+d                                               | :8                        |          |   |     |             |             |          | 2          |       |         |    | _  |       | _    |     | _  | 6             |
| JSR @Rn         |      | $SP-2 \rightarrow SP$<br>PC $\rightarrow @SP$<br>PC $\leftarrow Rn16$                                               |                           |          |   | 2   |             |             |          |            |       |         | -  |    |       |      |     | -  | 6             |
| JSR @aa:16      |      | $SP-2 \rightarrow SP$<br>PC $\rightarrow @SP$<br>PC $\leftarrow aa:16$                                              |                           |          |   |     |             |             | 4        |            |       |         |    |    |       |      | —   | -  | 8             |
| JSR @@aa:8      |      | $SP-2 \rightarrow SP$<br>PC $\rightarrow @SP$<br>PC $\leftarrow @aa:$                                               | 8                         |          |   |     |             |             |          |            | 2     |         |    |    |       | _    |     | -  | 8             |
| RTS             |      | $PC \leftarrow @SP$<br>$SP+2 \rightarrow SP$                                                                        |                           |          |   |     |             |             |          |            |       | 2       |    | _  |       |      |     | -  | 8             |
| RTE             |      | $\begin{array}{l} CCR \leftarrow @S \\ SP+2 \rightarrow SP \\ PC \leftarrow @SP \\ SP+2 \rightarrow SP \end{array}$ | P                         |          |   |     |             |             |          |            |       | 2       | \$ | \$ | \$    | \$   | \$  | \$ | 10            |
| SLEEP           |      | Transit to sle                                                                                                      | ep mode.                  |          |   |     |             |             |          |            |       | 2       |    |    |       |      | -   |    | 2             |
| LDC #xx:8, CCR  | В    | $#xx:8 \rightarrow CC$                                                                                              | R                         | 2        |   |     |             |             |          |            |       |         | \$ | ≎  | \$    | \$   | \$  | \$ | 2             |
| LDC Rs, CCR     | В    | $Rs8 \rightarrow CCR$                                                                                               |                           |          | 2 |     |             |             |          |            |       |         | \$ | \$ | \$    | \$   | \$  | \$ | 2             |
| STC CCR, Rd     | В    | $CCR \rightarrow Rd8$                                                                                               |                           |          | 2 |     |             |             |          |            |       |         | _  |    | _     |      |     |    | 2             |
| ANDC #xx:8, CCR | в    | CCR^#xx:8                                                                                                           | $\rightarrow$ CCR         | 2        |   |     |             |             |          |            |       |         | \$ | \$ | \$    | \$   | \$  | \$ | 2             |
| ORC #xx:8, CCR  | В    | CCRv#xx:8                                                                                                           | $\rightarrow$ CCR         | 2        |   |     |             |             |          |            |       |         | ¢  | \$ | ¢     | \$   | \$  | \$ | 2             |

### Table 2-2. List of Instructions (7)

|                 |      |                                                                                                        |          | Addressing Mode and<br>Instruction Length (Bytes) |     |             |   |          |            |       |          |    |     |      |      |     |    |               |
|-----------------|------|--------------------------------------------------------------------------------------------------------|----------|---------------------------------------------------|-----|-------------|---|----------|------------|-------|----------|----|-----|------|------|-----|----|---------------|
|                 | e    |                                                                                                        | #xx:8/16 |                                                   | ĥ   | @(d:16, Rn) |   | @aa:8/16 | @(d:8, PC) | ලැබිය | Implied  | c  | con | diti | on ( | Cod | le | . of States * |
| Mnemonic        | Size | Operation                                                                                              | ¥        | 뚭                                                 | @Rn | Q           | ø | Ö        | ø          | ø     | <u>E</u> | 1  | н   | N    | Z    | ۷   | С  | Ŝ             |
| XORC #xx:8, CCR | В    | $CCR \oplus \#xx:8 \rightarrow CCR$                                                                    | 2        |                                                   |     |             |   |          |            |       |          | \$ | \$  | \$   | \$   | \$  | \$ | 2             |
| NOP             |      | $PC \leftarrow PC+2$                                                                                   |          |                                                   |     |             |   |          |            |       | 2        | —  | —   | _    | —    | —   | _  | 2             |
| EEPMOV          |      | if R4L ≠ 0<br>Repeat @R5 → @R6<br>R5+1 → R5<br>R6+1 → R6<br>R4L-1 → R4L<br>Until R4L = 0<br>else next; |          |                                                   |     |             |   |          |            |       | 4        |    |     |      |      |     |    | 4             |

Notes: \* The number of execution states indicated here assumes that the operation code and operand data are in on-chip memory. For other cases, refer to section 2.5, Number of Execution States.

① Set to 1 when there is a carry or borrow at bit 11; otherwise cleared to 0.

② When the result is 0, the previous value remains unchanged; otherwise cleared to 0.

③ Set to 1 when there is a carry in the adjusted result; otherwise the previous value remains unchanged.

The number of execution states is 4n + 9, with n being the value set in R4L.

Set to 1 when the divisor is negative; otherwise cleared to 0.

⑤ Set to 1 when the divisor is 0; otherwise cleared to 0.

# 2.5 Number of Execution States

The tables here can be used to calculate the number of states required for instruction execution. Table 2-3 indicates the number of states required for each cycle (instruction fetch, branch address read, stack operation, byte data access, word data access, internal operation). Table 2-4 indicates the number of cycles of each type occurring in each instruction. The total number of states required for execution of an instruction can be calculated from these two tables as follows:

Execution states =  $I \times SI + J \times SJ + K \times SK + L \times SL + M \times SM + N \times SN$ 

- **Examples:** When instruction is fetched from on-chip ROM, and an on-chip RAM is accessed.
- 1. BSET #0, @FF00

From table 2-4: I = L = 2, J = K = M = N = 0From table 2-3: SI = 2, SL = 2Number of states required for execution =  $2 \times 2 + 2 \times 2 = 8$ 

When instruction is fetched from on-chip ROM, branch address is read from on-chip ROM, and on-chip RAM is used for stack area.

2. JSR @@ 30

From table 2-4: I = 2, J = K = 1, L = M = N = 0From table 2-3: SI = SJ = SK = 2Number of states required for execution =  $2 \times 2 + 1 \times 2 + 1 \times 2 = 8$ 

# Table 2-3. Number of States Taken by Each Cycle in Instruction Execution

| Execution Status    |    | Α              | ccess Location                   |
|---------------------|----|----------------|----------------------------------|
| (instruction cycle) |    | On-Chip Memory | <b>On-Chip Peripheral Module</b> |
| Instruction fetch   | SI |                |                                  |
| Branch address read | SJ |                |                                  |
| Stack operation     | Sк | 2              |                                  |
| Byte data access    | Sl |                | 2 or 3*                          |
| Word data access    | Sм |                |                                  |
| Internal operation  | SN |                | 1                                |

\* Depends on which on-chip module is accessed. See the applicable hardware manual for details.

| Instruction | Mnemonic          | Instruction<br>Fetch | Branch<br>Addr. Read | Stack<br>Operation |   | Word Data<br>Access | Internal<br>Operation |
|-------------|-------------------|----------------------|----------------------|--------------------|---|---------------------|-----------------------|
|             |                   | I                    | J                    | К                  | L | М                   | N                     |
| ADD         | ADD.B #xx:8, Rd   | 1                    |                      |                    |   |                     |                       |
|             | ADD.B Rs, Rd      | 1                    |                      |                    |   |                     |                       |
|             | ADD.W Rs, Rd      | 1                    |                      |                    |   |                     |                       |
| ADDS        | ADDS.W #1/2, Rd   | 1                    |                      |                    |   |                     |                       |
| ADDX        | ADDX.B #xx:8, Rd  | 1                    |                      |                    |   |                     |                       |
|             | ADDX.B Rs, Rd     | 1                    |                      |                    |   |                     |                       |
| AND         | AND.B #xx:8, Rd   | 1                    |                      |                    |   |                     |                       |
|             | AND.B Rs, Rd      | 1                    |                      |                    |   |                     |                       |
| ANDC        | ANDC #xx:8, CCR   | 1                    |                      |                    |   |                     |                       |
| BAND        | BAND #xx:3, Rd    | 1                    |                      |                    |   |                     |                       |
|             | BAND #xx:3, @Rd   | 2                    |                      |                    | 1 |                     |                       |
|             | BAND #xx:3, @aa:8 | 2                    |                      |                    | 1 |                     |                       |
| Bcc         | BRA d:8 (BT d:8)  | 2                    |                      |                    |   |                     |                       |
|             | BRN d:8 (BF d:8)  | 2                    |                      |                    |   |                     |                       |
|             | BHI d:8           | 2                    |                      |                    |   |                     |                       |
|             | BLS d:8           | 2                    |                      |                    |   |                     |                       |
|             | BCC d:8 (BHS d:8) | 2                    |                      |                    |   |                     |                       |
|             | BCS d:8 (BLO d:8) | 2                    |                      |                    |   |                     |                       |
|             | BNE d:8           | 2                    |                      |                    |   |                     |                       |
|             | BEQ d:8           | 2                    |                      |                    |   |                     |                       |
|             | BVC d:8           | 2                    |                      |                    |   |                     |                       |
|             | BVS d:8           | 2                    |                      |                    |   |                     |                       |
|             | BPL d:8           | 2                    |                      |                    |   |                     |                       |
|             | BMI d:8           | 2                    |                      |                    |   |                     |                       |
|             | BGE d:8           | 2                    |                      |                    |   |                     |                       |
|             | BLT d:8           | 2                    |                      |                    |   |                     |                       |
|             | BGT d:8           | 2                    |                      |                    |   |                     |                       |
|             | BLE d:8           | 2                    |                      | -                  |   |                     |                       |
| BCLR        | BCLR #xx:3, Rd    | 1                    |                      |                    |   |                     |                       |
|             | BCLR #xx:3, @Rd   | 2                    |                      |                    | 2 |                     |                       |
|             | BCLR #xx:3, @aa:8 | 2                    |                      |                    | 2 |                     |                       |
|             | BCLR Rn, Rd       | 1                    |                      |                    |   |                     |                       |

 Table 2-4.
 Number of Cycles in Each Instruction

| Instruction | Mnemonic           | Instruction<br>Fetch | Branch<br>Addr. Read |   | Byte Data<br>Access | Word Data<br>Access | Internal<br>Operation |
|-------------|--------------------|----------------------|----------------------|---|---------------------|---------------------|-----------------------|
|             |                    | I                    | J                    | К | L                   | М                   | N                     |
| BCLR        | BCLR Rn, @Rd       | 2                    |                      |   | 2                   |                     |                       |
|             | BCLR Rn, @aa:8     | 2                    |                      |   | 2                   |                     |                       |
| BIAND       | BIAND #xx:3, Rd    | 1                    |                      |   |                     |                     |                       |
|             | BIAND #xx:3, @Rd   | 2                    |                      |   | 1                   |                     |                       |
|             | BIAND #xx:3, @aa:8 | 2                    |                      |   | 1                   |                     |                       |
| BILD        | BILD #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BILD #xx:3, @Rd    | 2                    |                      |   | • 1                 |                     |                       |
|             | BILD #xx:3, @aa:8  | 2                    |                      |   | 1                   |                     |                       |
| BIOR        | BIOR #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BIOR #xx:3, @Rd    | 2                    |                      |   | 1                   |                     |                       |
|             | BIOR #xx:3, @aa:8  | 2                    |                      |   | 1                   |                     |                       |
| BIST        | BIST #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BIST #xx:3, @Rd    | 2                    |                      |   | 2                   |                     |                       |
|             | BIST #xx:3, @aa:8  | 2                    |                      |   | 2                   |                     |                       |
| BIXOR       | BIXOR #xx:3, Rd    | 1                    |                      |   |                     |                     |                       |
|             | BIXOR #xx:3, @Rd   | 2                    |                      |   | 1                   |                     |                       |
|             | BIXOR #xx:3, @aa:8 | 2                    |                      |   | 1                   |                     |                       |
| BLD         | BLD #xx:3, Rd      | 1                    |                      |   |                     |                     |                       |
|             | BLD #xx:3, @Rd     | 2                    |                      |   | 1                   |                     |                       |
|             | BLD #xx:3, @aa:8   | 2                    |                      |   | 1                   |                     |                       |
| BNOT        | BNOT #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BNOT #xx:3, @Rd    | 2                    |                      |   | 2                   |                     |                       |
|             | BNOT #xx:3, @aa:8  | 2                    |                      |   | 2                   |                     |                       |
|             | BNOT Rn, Rd        | 1                    |                      |   |                     |                     |                       |
|             | BNOT Rn, @Rd       | 2                    |                      |   | 2                   |                     |                       |
|             | BNOT Rn, @aa:8     | 2                    |                      |   | 2                   |                     |                       |
| BOR         | BOR #xx:3, Rd      | 1                    |                      |   |                     |                     |                       |
|             | BOR #xx:3, @Rd     | 2                    |                      |   | 1                   |                     |                       |
|             | BOR #xx:3, @aa:8   | 2                    |                      |   | 1                   |                     |                       |
| BSET        | BSET #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BSET #xx:3, @Rd    | 2                    |                      |   | 2                   |                     |                       |
|             | BSET #xx:3, @aa:8  | 2                    |                      |   | 2                   |                     |                       |
|             | BSET Rn, Rd        | 1                    |                      |   |                     |                     |                       |
|             | BSET Rn, @Rd       | 2                    |                      |   | 2                   |                     |                       |

| Instruction | Mnemonic          | Instruction<br>Fetch | Branch<br>Addr. Read |   | Byte Data<br>Access | Word Data<br>Access | Internal<br>Operation |
|-------------|-------------------|----------------------|----------------------|---|---------------------|---------------------|-----------------------|
|             |                   | I                    | J                    | К | L                   | М                   | N                     |
| BSET        | BSET Rn, @aa:8    | 2                    |                      |   | 2                   |                     |                       |
| BSR         | BSR d:8           | 2                    |                      | 1 |                     |                     |                       |
| BST         | BST #xx:3, Rd     | 1                    |                      |   |                     |                     |                       |
|             | BST #xx:3, @Rd    | 2                    |                      |   | 2                   |                     |                       |
|             | BST #xx:3, @aa:8  | 2                    |                      |   | 2                   |                     |                       |
| BTST        | BTST #xx:3, Rd    | 1                    |                      |   |                     |                     |                       |
|             | BTST #xx:3, @Rd   | 2                    |                      |   | 1                   |                     |                       |
|             | BTST #xx:3, @aa:8 | 2                    |                      |   | 1                   |                     |                       |
|             | BTST Rn, Rd       | 1                    |                      |   |                     |                     |                       |
|             | BTST Rn, @Rd      | 2                    |                      |   | 1                   |                     |                       |
|             | BTST Rn, @aa:8    | 2                    |                      |   | 1                   |                     |                       |
| BXOR        | BXOR #xx:3, Rd    | 1                    |                      |   |                     |                     |                       |
|             | BXOR #xx:3, @Rd   | 2                    |                      |   | 1                   |                     |                       |
|             | BXOR #xx:3, @aa:8 | 2                    |                      |   | 1                   |                     |                       |
| CMP         | CMP. B #xx:8, Rd  | 1                    |                      |   |                     |                     |                       |
|             | CMP. B Rs, Rd     | 1                    |                      |   |                     |                     |                       |
|             | CMP.W Rs, Rd      | 1                    |                      |   |                     |                     |                       |
| DAA         | DAA.B Rd          | 1                    |                      |   |                     |                     |                       |
| DAS         | DAS.B Rd          | 1                    |                      |   |                     |                     |                       |
| DEC         | DEC.B Rd          | 1                    |                      |   |                     |                     |                       |
| DIVXU       | DIVXU.B Rs, Rd    | 1                    |                      |   |                     |                     | 12                    |
| EEPMOV      | EEPMOV            | 2                    |                      |   | 2n+2*               |                     | 1                     |
| INC         | INC.B Rd          | 1                    |                      |   |                     |                     |                       |
| JMP         | JMP @Rn           | 2                    |                      |   |                     |                     |                       |
|             | JMP @aa:16        | 2                    |                      |   |                     |                     | 2                     |
|             | JMP @@aa:8        | 2                    | 1                    |   |                     |                     | 2                     |
| JSR         | JSR @Rn           | 2                    |                      | 1 |                     |                     |                       |
|             | JSR @aa:16        | 2                    |                      | 1 |                     |                     | 2                     |
|             | JSR @@aa:8        | 2                    | 1                    | 1 |                     |                     |                       |
| LDC         | LDC #xx:8, CCR    | 1                    |                      |   |                     |                     |                       |
|             | LDC Rs, CCR       | 1                    |                      |   |                     |                     |                       |
| MOV         | MOV.B #xx:8, Rd   | 1                    |                      |   |                     |                     |                       |
|             | MOV.B Rs, Rd      | 1                    |                      |   |                     |                     |                       |
|             | MOV.B @Rs, Rd     | 1                    |                      |   | 1                   |                     |                       |

| Instruction | Mnemonic              | Instruction<br>Fetch | Branch<br>Addr. Read | Stack<br>Operation | Byte Data<br>Access | Word Data<br>Access | Internal<br>Operation |
|-------------|-----------------------|----------------------|----------------------|--------------------|---------------------|---------------------|-----------------------|
|             |                       | Ι                    | J                    | К                  | L                   | М                   | N                     |
| MOV         | MOV.B @(d:16, Rs), Rd | 2                    |                      |                    | 1                   |                     |                       |
|             | MOV.B @Rs+, Rd        | 1                    |                      |                    | 1                   |                     | 2                     |
|             | MOV.B @aa:8, Rd       | 1                    |                      |                    | 1                   |                     |                       |
|             | MOV.B @aa:16, Rd      | 2                    |                      |                    | 1                   |                     |                       |
|             | MOV.B Rs, @Rd         | 1                    |                      |                    | 1                   |                     |                       |
|             | MOV.B Rs, @(d:16, Rd) | 2                    |                      |                    | 1                   |                     |                       |
|             | MOV.B Rs, @–Rd        | 1                    |                      |                    | 1                   |                     | 2                     |
|             | MOV.B Rs, @aa:8       | 1                    |                      |                    | 1                   |                     |                       |
|             | MOV.B Rs, @aa:16      | 2                    |                      |                    | 1                   |                     |                       |
|             | MOV.W #xx:16, Rd      | 2                    |                      |                    |                     |                     |                       |
|             | MOV.W Rs, Rd          | 1                    |                      |                    |                     |                     |                       |
|             | MOV.W @Rs, Rd         | 1                    |                      |                    |                     | 1                   |                       |
|             | MOV.W @(d:16, Rs), Rd | 2                    |                      |                    |                     | 1                   |                       |
|             | MOV.W @Rs+, Rd        | 1                    |                      |                    |                     | 1                   | 2                     |
|             | MOV.W @aa:16, Rd      | 2                    |                      |                    |                     | 1                   |                       |
|             | MOV.W Rs, @Rd         | 1 .                  |                      |                    |                     | 1                   |                       |
|             | MOV.W Rs, @(d:16, Rd) | 2                    |                      |                    |                     | 1                   |                       |
|             | MOV.W Rs, @-Rd        | 1                    |                      |                    |                     | 1                   | 2                     |
|             | MOV.W Rs, @aa:16      | 2                    |                      |                    |                     | 1                   |                       |
| MULXU       | MULXU.B Rs, Rd        | 1                    |                      |                    |                     |                     | 12                    |
| NEG         | NEG.B Rd              | 1                    |                      |                    |                     |                     |                       |
| NOP         | NOP                   | 1                    |                      |                    |                     |                     |                       |
| NOT         | NOT.B Rd              | 1                    |                      |                    |                     |                     |                       |
| OR          | OR.B #xx:8, Rd        | 1                    |                      |                    |                     |                     |                       |
|             | OR.B Rs, Rd           | 1                    |                      |                    |                     |                     |                       |
| ORC         | ORC #xx:8, CCR        | 1                    |                      |                    |                     |                     |                       |
| POP         | POP Rd                | 1                    |                      | 1                  |                     |                     | 2                     |
| PUSH        | PUSH Rs               | 1                    |                      | 1                  |                     |                     | 2                     |
| ROTL        | ROTL.B Rd             | 1                    |                      |                    |                     |                     |                       |
| ROTR        | ROTR.B Rd             | 1                    |                      |                    |                     |                     |                       |
| ROTXL       | ROTXL.B Rd            | 1                    |                      |                    |                     |                     |                       |
| ROTXR       | ROTXR.B Rd            | 1                    |                      |                    |                     |                     |                       |
| RTE         | RTE                   | 2                    |                      | 2                  |                     |                     | 2                     |
| RTS         | RTS                   | 2                    |                      | 1                  |                     |                     | 2                     |

| Instruction | Mnemonic         | Instruction<br>Fetch | Branch<br>Addr. Read | Stack<br>Operation | Byte Data<br>Access |   | Internal<br>Operation |
|-------------|------------------|----------------------|----------------------|--------------------|---------------------|---|-----------------------|
|             |                  | Ι                    | J                    | K                  | L                   | М | N                     |
| SHLL        | SHLL.B Rd        | 1                    |                      |                    |                     |   |                       |
| SHAL        | SHAL.B Rd        | 1                    |                      |                    |                     |   |                       |
| SHAR        | SHAR.B Rd        | 1                    |                      |                    |                     |   |                       |
| SHLR        | SHLR.B Rd        | 1                    |                      |                    |                     |   |                       |
| SLEEP       | SLEEP            | 1                    |                      |                    |                     |   |                       |
| STC         | STC CCR, Rd      | 1                    |                      |                    |                     |   |                       |
| SUB         | SUB.B Rs, Rd     | 1                    |                      |                    |                     |   |                       |
|             | SUB.W Rs, Rd     | 1                    |                      |                    |                     |   |                       |
| SUBS        | SUBS.W #1/2, Rd  | 1                    |                      |                    |                     |   |                       |
| SUBX        | SUBX.B #xx:8, Rd | 1                    |                      |                    |                     |   |                       |
|             | SUBX.B Rs, Rd    | 1                    |                      |                    |                     |   |                       |
| XOR         | XOR.B #xx:8, Rd  | 1                    |                      |                    |                     |   |                       |
|             | XOR.B Rs, Rd     | 1                    |                      |                    |                     |   |                       |
| XORC        | XORC #xx:8, CCR  | 1                    |                      |                    |                     |   |                       |

\* n: Initial value in R4L. The source and destination operands are accessed n + 1 times each.

# Section 3. CPU Operation States

There are three CPU operation states, namely, program execution state, power-down state, and exception-handling state. In power-down state there are sleep mode, standby mode, and watch mode. These operation states are shown in figure 3-1. Figure 3-2 shows the state transitions. For further details please refer to the applicable hardware manual.



Figure 3-1. CPU Operation States



Figure 3-2. State Transitions

# **3.1 Program Execution State**

In program execution state the CPU executes program instructions in sequence.

# **3.2 Exception Handling States**

Exception-handling states are transient states occurring when exception handling is raised by a reset or interrupt, and the CPU changes its normal processing flow, branching to a start address acquired from a vector table. In exception handling caused by an interrupt, PC and CCR values are saved to the stack, with reference made to a stack pointer (R7).

# 3.2.1 Types and Priorities of Exception Handling

Exception handling includes processing of reset exceptions and of interrupts. Table 3-1 summarizes the factors causing each kind of exception, and their priorities. Reset exception handling has the highest priority.

# Table 3-1. Types of Exception Handling and Priorities

|          |                         |                    | Timing for start of                                  |
|----------|-------------------------|--------------------|------------------------------------------------------|
| Priority | <b>Exception source</b> | Detection timing   | exception handling                                   |
| High     | Reset                   | Clock-synchronous  | Reset exception handling starts as                   |
| <b>A</b> |                         |                    | soon as $\overline{\text{RES}}$ pin changes from low |
|          |                         |                    | to high.                                             |
|          | Interrupt               | End of instruction | When an interrupt request is made,                   |
|          |                         | execution*         | interrupt exception handling starts                  |
|          |                         |                    | after execution of the present                       |
| Low      |                         |                    | instruction is completed.                            |

\* Interrupt detection is not made upon completion of ANDC, ORC, XORC, and LDC instruction execution, nor upon completion of reset exception handling.

# 3.2.2 Exception Sources and Vector Table

The factors causing exception handling can be classified as in figure 3-3.

For details of exception handling, the vector numbers of each source, and the vector addresses, see the applicable hardware manual.



Figure 3-3. Classification of Exception Sources

### 3.2.3 Outline of Exception Handling Operation

A reset has the highest priority of all exception handling. After the  $\overline{\text{RES}}$  pin goes to low level putting the CPU in reset state, the  $\overline{\text{RES}}$  pin is then put at high level, and reset exception handling is started at the point when the reset conditions are met. For details on reset conditions refer to the applicable hardware manual. When reset exception handling is started, the CPU gets a start address from the exception handling vector table, and starts executing the exception handling routine from that address. During execution of this routine and immediately after, all interrupts including NMI are masked.

When interrupt exception handling is started, the CPU refers to the stack pointer (R7) and pushes the PC and CCR contents to the stack. The CCR I bit is then set to 1, a start address is acquired from the exception handling vector table, and the interrupt exception handling routine is executed from this address. The stack state in this case is as shown in figure 3-4.



Figure 3-4. Stack State after Completion of Interrupt Exception Handling

# 3.3 Reset State

When the  $\overline{\text{RES}}$  pin goes to low level, all processing stops and the system goes to reset state. The I bit of the condition code register (CCR) is set, masking all interrupts.

After the  $\overline{\text{RES}}$  pin is changed externally from low to high level, reset exception handling starts at the point when the reset conditions are met. For details on reset conditions refer to the applicable hardware manual.

# 3.4 Power-Down State

In power-down state the CPU operation is stopped, reducing power consumption. For details see the applicable hardware manual.

# Section 4. Basic Operation Timing

CPU operation is synchronized by a clock ( $\phi$ ). The period from the rising edge of  $\phi$  to the next rising edge is called one state. A memory cycle or bus cycle consists of two or three states. For details on access to on-chip memory and to on-chip peripheral modules see the applicable hardware manual.

# 4.1 On-chip Memory (RAM, ROM)

Two-state access is employed for high-speed access to on-chip memory. The data bus width is 16 bits, <u>allowing access in byte or word size</u>. Figure 4-1 shows the on-chip memory access cycle.



Figure 4-1. On-Chip Memory Access Cycle

# 4.2 On-chip Peripheral Modules and External Devices

On-chip peripheral modules are accessed in two or three states. The data bus width is 8 bits, so access is made in byte size only. Access to word data or instruction codes is not possible. Figure 4-2 shows the on-chip peripheral module access cycle.



Figure 4-2. On-Chip Peripheral Module Access Cycle

# H8/300L Series Programming Manual

Publication Date: 1st Edition, December 1991 Published by: Semiconductor and IC Div. Hitachi, Ltd. Edited by: Application Engineering Dept. Hitachi Microcomputer System Ltd. Copyright © Hitachi, Ltd., 1991. All rights reserved. Printed in Japan.

# HITACHI, LTD. SEMICONDUCTOR AND INTEGRATED CIRCUITS DIVISION SALES OFFICE

### **HEAD QUARTERS**

Semiconductor & IC Div. Karukozaka MN Bldg., 2-1, Ageba-cho, Shinjuku-ku, Tokyo 162, Japan Tel: Tokyo (03) 3266-9376 Fax: (03) 3235-2375

# USA

### Headquarters

Hitachi America, Ltd. Semiconductor & IC Div. 2000 Sierra Point Parkway Brisbane, CA. 94005-1819 Tel: 415-589-8300 Fax: 415-583-4207

### **Northwest Regional Office**

1900 McCarthy Boulevard Milpitas, CA. 95131 Tel: 408-954-8100 Fax: 408-954-0499

### Southwest Regional Office

18300 Von Karman Avenue, Suite 730 Irvine, CA. 92715 Tel: 714-553-8500 Fax: 714-553-8561

## South Central Regional Office

2 Lincoln Centre, Suite 865 5420 LBJ Freeway Dallas, TX. 75240 Tel: 214-991-4510 Fax: 214-991-6151

### **Mid Atlantic Regional Office**

1700 Galloping Hill Road Kenilworth, NJ. 07033 Tel: 201-245-6400 Fax: 201-245-6071

### North Central Regional Office

500 Park Boulevard, Suite 415 Itasca, IL. 60143 Tel: 312-773-4864 Fax: 312-773-9006

### Northeast Regional Office

77 Bedford St. Burlington, MA. 01803 Tel: 617-229-2150 Fax: 617-229-6554

### **Automotive Regional Office**

6 Parklane Boulevard, Suite 558 Dearborn, MI. 48126 Tel: 313-271-4410 Fax: 313-271-5707

### EUROPE (CE) Headquarters

Hitachi Europe GmbH Electronic Components Div. Central Europe Headquarters Hans-Pinsel-Straße 10A 8013 Haar bei München, F. R. Germany Tel: 089-46140 Fax: 089-463068

### **Branch Office**

Hitachi Europe GmbH Electronic Components Div. Central Europe Headquarters Breslauer Straße 6 4040 Neuss 1, F. R. Germany Tel: 02101-15027 to 9 Fax: 02101-10513

Hitachi Europe GmbH Electronic Components Div. Central Europe Headquarters Verkaufsbüro Stuttgart Fabrikstraße 17 7024 Filderstadt 4, F. R. Germany Tel: 0711-772011 Fax: 0711-7775116

Hitachi Europe GmbH Electronic Components Div. Bureau de représentation en France Immeuble "Les Gemeaux" 2, Rue Antoine Etex F-94020 Creteil Cedex, France Tel: 1-43394500 Fax: 1-43398493

Hitachi Europe GmbH Electronic Components Div. 00158 Roma Via Pescosolido, 154, Italy Tel: 06-4510146, 4510147 Fax: 06-4510148 Hitachi Europe GmbH Electronic Components Div. Via L. Rizzo 8 I-20151 Milano, Italy Tel: 02-33404180 Fax: 02-33404152

### EUROPE (NE) Headquarters

Hitachi Europe Ltd. Electronic Components Div. Northern Europe Headquarters Whitebrook Park Lower Cookham Road Maidenhead Berkshire SL6 8YA, United Kingdom Tel: 0628-585000 Fax: 0628-778322

### **Branch Office**

Hitachi Europe Ltd. Electronic Components Div. Northern Europe Headquarters Haukadalsgatan 10 Box 1062, S-164 21 Kista, Sweden Tel: 08-751-0035 Fax: 08-751-5073

# ASIA

Headquarters Hitachi Asia Pte. Ltd. 78 Shenton Way #11-01 Singapore 0207 Tel: 221-6131, 7355 Fax: 225-4225, 221-4474

### **Branch Office**

Hitachi Asia Pte. Ltd. Taipei Branch Office 9 th Fl. –1 No.64, Tun–Hwa N. Road Taipei Financial Center Taipei, Taiwan Tel: 02-741-4021 to 6 Fax: 02-752-1567

# ASIA(HK)

### Headquarters

Hitachi Asia (Hong Kong) Ltd. Unit 706, North Tower, World Finance Centre, Harbour City Canton Road, Tsimshatsui, Kowloon Hong Kong Tel: 852-7359218 Fax: 852-7306071

### **Branch Office**

Hitachi Asia (Hong Kong) Ltd. Seoul Branch Office 18 Floor Kukje Center Building 191, 2-Ka, Hanggang–Ro Yongsan-Ku, Seoul, Korea Tel: 796-3115, 3647 to 8 Fax: 796-2145

Hitachi Asia (Hong Kong) Ltd. Beijing Office Room 1412, Beijing Fortune Building, 5 Dong San Huan Bei-lu, Chaoyang District, Beijing People's Republic of China Tel: 501-4351-4 Fax: 501-4350

