## Section 1 CPU

### 1.1 Overview

The H8S/2600 CPU and the H8S/2000 CPU are high-speed central processing units with a common an internal 32-bit architecture. Each CPU is upward-compatible with the H8/300 and H8/300H CPUs. The H8S/2600 CPU and H8S/2000 CPU have sixteen 16-bit general registers, can address a 4-Gbyte linear address space, and are ideal for realtime control.

### 1.1.1 Features

The H8S/2600 CPU and H8S/2000 CPU have the following features.

- Upward-compatible with $\mathrm{H} 8 / 300$ and $\mathrm{H} 8 / 300 \mathrm{H}$ CPUs
- Can execute H8/300 and H8/300H object programs
- General-register architecture
- Sixteen 16-bit general registers (also usable as sixteen 8-bit registers or eight 32-bit registers)
- Sixty-nine basic instructions (H8S/2000 CPU has sixty-five)
- 8/16/32-bit arithmetic and logic instructions
- Multiply and divide instructions
- Powerful bit-manipulation instructions
- Multiply-and-accumulate instruction (H8S/2600 CPU only)
- Eight addressing modes
- Register direct [Rn]
— Register indirect [@ERn]
— Register indirect with displacement [@(d:16,ERn) or @(d:32,ERn)]
— Register indirect with post-increment or pre-decrement [@ERn+ or @-ERn]
— Absolute address [@aa:8, @aa:16, @aa:24, or @aa:32]
— Immediate [\#xx:8, \#xx:16, or \#xx:32]
— Program-counter relative [@(d:8,PC) or @(d:16,PC)]
— Memory indirect [@@aa:8]
- 4-Gbyte address space
- Program: 16 Mbytes
- Data: 4 Gbytes
- High-speed operation
- All frequently-used instructions execute in one or two states
- Maximum clock frequency:
$20 \mathrm{MHz}^{*}$
— 8/16/32-bit register-register add/subtract: 50 ns
- $8 \times 8$-bit register-register multiply: $\quad 150 \mathrm{~ns}$ (H8S/2000 CPU: 600 ns )
- $16 \div 8$-bit register-register divide: 600 ns
- $16 \times 16$-bit register-register multiply: 200 ns (H8S/2000 CPU: 1000 ns )
- $32 \div 16$-bit register-register divide: $\quad 1000 \mathrm{~ns}$
- Two CPU operating modes
- Normal mode
- Advanced mode
- Power-down modes
- Transition to power-down state by SLEEP instruction
- CPU clock speed selection

Note: * The maximum operating frequency and instruction execution time differ depending on the product.

### 1.1.2 Differences between H8S/2600 CPU and H8S/2000 CPU

Differences between the $\mathrm{H} 8 \mathrm{~S} / 2600 \mathrm{CPU}$ and the $\mathrm{H} 8 \mathrm{~S} / 2000 \mathrm{CPU}$ are as follows.

- Register configuration
- The MAC register is supported only by the H8S/2600 CPU .

For details, see section 1.4, Register Configuration.

- Basic instructions
- The MAC, CLRMAC, LDMAC, and STMAC instructions are supported only by the H8S/2600 CPU.
For details, see section 1.6, Instruction Set, and Section 2, Instruction Descriptions.
- Number of states required for execution
- The number of states required for execution of the MULXU and MULXS instructions. For details, see section 2.6, Number of States Required for Execution.

In addition, there may be defferences in address spaces, EXR register functions, power-down states, and so on. For details, refer to the relevant microcontroller hardware manual.

### 1.1.3 Differences from H8/300 CPU

In comparison with the $\mathrm{H} 8 / 300 \mathrm{CPU}$, the $\mathrm{H} 8 \mathrm{~S} / 2600 \mathrm{CPU}$ and $\mathrm{H} 8 \mathrm{~S} / 2000 \mathrm{CPU}$ have the following enhancements.

- More general registers and control registers
- Eight 16-bit registers, one 8-bit and two 32-bit control registers have been added.
- Expanded address space
- Normal mode supports the same 64-kbyte address space as the H8/300 CPU .
- Advanced mode supports a maximum 4-Gbyte address space.
- Enhanced addressing
- The addressing modes have been enhanced to make effective use of the 4-Gbyte address space.
- Enhanced instructions
- Addressing modes of bit-manipulation instructions have been enhanced.
- Signed multiply and divide instructions have been added.
- A multiply-and-accumulate instruction has been added. (H8S/2600CPU only)
- Two-bit shift and rotate instructions have been added.
- Instructions for saving and restoring multiple registers have been added.
- A test and set instruction has been added.
- Higher speed
- Basic instructions execute twice as fast.


### 1.1.4 Differences from $\mathrm{H} 8 / 300 \mathrm{H} \mathbf{C P U}$

In comparison with the $\mathrm{H} 8 / 300 \mathrm{H} \mathrm{CPU}$, the $\mathrm{H} 8 \mathrm{~S} / 2600 \mathrm{CPU}$ and $\mathrm{H} 8 \mathrm{~S} / 2000 \mathrm{CPU}$ have the following enhancements.

- Additional control register
- One 8-bit and two 32-bit control registers have been added.
- Expanded address space
- Advanced mode supports a maximum 4-Gbyte data address space.
- Enhanced instructions
- Addressing modes of bit-manipulation instructions have been enhanced.
- A multiply-and-accumulate instruction has been added (H8S/2600 CPU only).
- Two-bit shift and rotate instructions have been added.
- Instructions for saving and restoring multiple registers have been added.
- A test and set instruction has been added.
- Higher speed
- Basic instructions execute twice as fast.


### 1.2 CPU Operating Modes

Like the $\mathrm{H} 8 / 300 \mathrm{H}$ CPU, the $\mathrm{H} 8 \mathrm{~S} / 2600 \mathrm{CPU}$ has two operating modes: normal and advanced. Normal mode supports a maximum 64-kbyte address space. Advanced mode supports a maximum 4-Gbyte total address space, of which up to 16 Mbytes can be used for program code and up to 4 Gbytes for data. The mode is selected with the mode pins of the microcontroller. For further information, refer to the relevant microcontroller hardware manual.


## Figure 1.1 CPU Operating Modes

## (1) Normal Mode

The exception vector table and stack have the same structure as in the $\mathrm{H} 8 / 300 \mathrm{CPU}$.
Address Space: A maximum address space of 64 kbytes can be accessed, as in the H8/300 CPU .
Extended Registers (En): The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16 -bit segments of 32 -bit registers. When En is used as a 16 -bit register it can contain any value, even when the corresponding general register (R0 to R7) is used as an address register. If the general register is referenced in the register indirect addressing mode with pre-decrement ( $@-\mathrm{Rn}$ ) or post-increment ( $@ \mathrm{Rn}+$ ) and a carry or borrow occurs, however, the value in the corresponding extended register will be affected.

Instruction Set: All additional instructions and addressing modes not found in the H8/300 CPU can be used. Only the lower 16 bits of effective addresses (EA) are valid.

Exception Vector Table and Memory Indirect Branch Addresses: In normal mode the top area starting at $\mathrm{H}^{\prime} 0000$ is allocated to the exception vector table. One branch address is stored per 16 bits (figure 1.2). The exception vector table differs depending on the microcontroller. Refer to the relevant microcontroller hardware manual for further information.


Figure 1.2 Exception Vector Table (Normal Mode)
The memory indirect addressing mode (@@aa:8) employed in the JMP and JSR instructions uses an 8-bit absolute address included in the instruction code to specify a memory operand that contains a branch address. In normal mode the operand is a 16-bit word operand, providing a 16-bit branch address. Branch addresses can be stored in the top area from $\mathrm{H}^{\prime} 0000$ to $\mathrm{H}^{\prime} 00 \mathrm{FF}$. Note that this area is also used for the exception vector table.

Stack Structure: When the program counter ( PC ) is pushed onto the stack in a subroutine call, and the PC, condition-code register (CCR), and extended control register (EXR) are pushed onto the stack in exception handling, they are stored as shown in figure 1.3. When EXR is invalid, it is not pushed onto the stack. For details, see the relevant hardware manual.

(a) Subroutine Branch

(b) Exception Handling

Notes: 1. When EXR is not used it is not stored on the stack.
2. SP when EXR is not used.
3. Ignored on return.

## Figure 1.3 Stack Structure in Normal Mode

## (2) Advanced Mode

In advanced mode the data address space is larger than for the $\mathrm{H} 8 / 300 \mathrm{H}$ CPU .
Address Space: The 4-Gbyte maximum address space provides linear access to a maximum 16 Mbytes of program code and maximum 4 Gbytes of data.

Extended Registers (En): The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit segments of 32 -bit registers or address registers.

Instruction Set: All instructions and addressing modes can be used.

Exception Vector Table and Memory Indirect Branch Addresses: In advanced mode the top area starting at $\mathrm{H}^{\prime} 00000000$ is allocated to the exception vector table in units of 32 bits. In each 32 bits, the upper 8 bits are ignored and a branch address is stored in the lower 24 bits (figure 1.4). The exception vector table differs depending on the microcontroller. Refer to the relevant microcontroller hardware manual for further information.


Figure 1.4 Exception Vector Table (Advanced Mode)
The memory indirect addressing mode (@@aa:8) employed in the JMP and JSR instructions uses an 8 -bit absolute address included in the instruction code to specify a memory operand that contains a branch address. In advanced mode the operand is a 32 -bit longword operand, providing a 32-bit branch address. The upper 8 bits of these 32 bits are a reserved area that is regarded as $\mathrm{H}^{\prime} 00$. Branch addresses can be stored in the top area from $\mathrm{H}^{\prime} 00000000$ to $\mathrm{H}^{\prime} 000000 \mathrm{FF}$. Note that this area is also used for the exception vector table.

Stack Structure: In advanced mode, when the program counter ( PC ) is pushed onto the stack in a subroutine call, and the PC, condition-code register (CCR), and extended control register (EXR) are pushed onto the stack in exception handling, they are stored as shown in figure 1.5 . When EXR is invalid, it is not pushed onto the stack. For details, see the relevant hardware manual.

(a) Subroutine Branch

(b) Exception Handling

Notes: 1. When EXR is not used it is not stored on the stack.
2. SP when EXR is not used.
3. Ignored on return.

Figure 1.5 Stack Structure in Advanced Mode

### 1.4 Register Configuration

### 1.4.1 Overview

The CPUs have the internal registers shown in figure 1.7. There are two types of registers: general registers and control registers. The H8S/2000 CPU does not support the MAC register.

General Registers (Rn) and Extended Registers (En)

|  | 07 |  | 07 | 0 |
| :---: | :---: | :---: | :---: | :---: |
| ER0 | E0 | ROH | ROL |  |
| ER1 | E1 | R1H | R1L |  |
| ER2 | E2 | R2H | R2L |  |
| ER3 | E3 | R3H | R3L |  |
| ER4 | E4 | R4H | R4L |  |
| ER5 | E5 | R5H | R5L |  |
| ER6 | E6 | R6H | R6L |  |
| ER7 (SP) | E7 | R7H | R7L |  |

## Control Registers (CR)






Legend:
SP: Stack pointer
H: Half-carry flag
PC: Program counter
EXR: Extended control register
T: Trace bit
U. User bit

I2 to IO: Interrupt mask bits
Negative lag
Z: Zero flag
CCR: Condition-code register
V: Overflow flag
I: Interrupt mask bit
C: $\quad$ Carry flag
UI: User bit or interrupt mask bit
MAC: Multiply-accumulate register

Figure 1.7 CPU Registers

### 1.4.2 General Registers

The CPUs have eight 32 -bit general registers. These general registers are all functionally alike and can be used as both address registers and data registers. When a general register is used as a data register, it can be accessed as a 32 -bit, 16 -bit, or 8 -bit register. When the general registers are used as 32-bit registers or address registers, they are designated by the letters ER (ER0 to ER7).

The ER registers divide into 16-bit general registers designated by the letters E (E0 to E7) and R (R0 to R7). These registers are functionally equivalent, providing a maximum sixteen 16-bit registers. The E registers (E0 to E7) are also referred to as extended registers.

The R registers divide into 8 -bit general registers designated by the letters $\mathrm{RH}(\mathrm{R} 0 \mathrm{H}$ to R 7 H ) and RL (R0L to R7L). These registers are functionally equivalent, providing a maximum sixteen 8 -bit registers.

Figure 1.8 illustrates the usage of the general registers. The usage of each register can be selected independently.


Figure 1.8 Usage of General Registers
General register ER7 has the function of stack pointer (SP) in addition to its general-register function, and is used implicitly in exception handling and subroutine calls. Figure 1.9 shows the stack.


Figure 1.9 Stack

### 1.4.3 Control Registers

The control registers are the 24-bit program counter (PC), 8-bit extended control register (EXR), 8 -bit condition-code register (CCR), and 64-bit multiply-accumulate register (MAC: H8S/2600 CPU only).
(1) Program Counter (PC)

This 24-bit counter indicates the address of the next instruction the CPU will execute. The length of all CPU instructions is 16 bits (one word) or a multiple of 16 bits, so the least significant PC bit is ignored. When an instruction is fetched, the least significant PC bit is regarded as 0 .

## (2) Extended Control Register (EXR)

This 8 -bit register contains the trace bit (T) and three interrupt mask bits (I2 to I0).
Bit 7-Trace Bit (T): Selects trace mode. When this bit is cleared to 0 , instructions are executed in sequence. When this bit is set to 1 , a trace exception is generated each time an instruction is executed.

Bits 6 to 3-Reserved: These bits are reserved, always read as 1 .
Bits 2 to 0-Interrupt Mask Bits (I2 to I0): These bits designate the interrupt mask level (0 to 7). For details refer to the relevant microcontroller hardware manual.

Operations can be performed on the EXR bits by the LDC, STC, ANDC, ORC, and XORC instructions. All interrupts, including NMI, are disabled for three states after one of these instructions is executed, except for STC.

## (3) Condition-Code Register (CCR)

This 8-bit register contains internal CPU status information, including an interrupt mask bit (I) and half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags.

Bit 7-Interrupt Mask Bit (I): Masks interrupts other than NMI when set to 1 . (NMI is accepted regardless of the I bit setting.) The I bit is set to 1 by hardware at the start of an exceptionhandling sequence.

Bit 6-User Bit or Interrupt Mask Bit (UI): Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions. This bit can also be used as an interrupt mask bit. For details refer to the relevant microcontroller hardware manual.

Bit 5-Half-Carry Flag (H): When the ADD.B, ADDX.B, SUB.B, SUBX.B, CMP.B, or NEG.B instruction is executed, this flag is set to 1 if there is a carry or borrow at bit 3 , and cleared to 0 otherwise. When the ADD.W, SUB.W, CMP.W, or NEG.W instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 11 , and cleared to 0 otherwise. When the ADD.L, SUB.L, CMP.L, or NEG.L instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 27, and cleared to 0 otherwise.

Bit 4-User Bit (U): Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions.

Bit 3-Negative Flag (N): Stores the value of the most significant bit (sign bit) of data.
Bit 2-Zero Flag (Z): Set to 1 to indicate zero data, and cleared to 0 to indicate non-zero data.
Bit 1—Overflow Flag (V): Set to 1 when an arithmetic overflow occurs, and cleared to 0 at other times.

Bit 0-Carry Flag (C): Set to 1 when a carry occurs, and cleared to 0 otherwise. Used by:

- Add instructions, to indicate a carry
- Subtract instructions, to indicate a borrow
- Shift and rotate instructions, to store the value shifted out of the end bit

The carry flag is also used as a bit accumulator by bit manipulation instructions.

### 1.5.2 Memory Data Formats

Figure 1.11 shows the data formats in memory. The CPU can access word data and longword data in memory, but word or longword data must begin at an even address. If an attempt is made to access word or longword data at an odd address, no address error occurs but the least significant bit of the address is regarded as 0 , so the access starts at the preceding address. This also applies to instruction fetches.


Figure 1.11 Memory Data Formats
When the stack pointer (ER7) is used as an address register to access the stack, the operand size should be word size or longword size.

### 1.6 Instruction Set

### 1.6.1 Overview

The H8S/2600 CPU has 69types of instructions, while the H8S/2000 CPU has 65 types. The instructions are classified by function as shown in table 1.1. For a detailed description of each instruction, see section 2.2, Instruction Descriptions.

Table 1.1 Instruction Classification

| Function | Instructions | Size | Types |
| :---: | :---: | :---: | :---: |
| Data transfer | MOV | BWL | 5 |
|  | POP*2, PUSH ${ }^{* 2}$ | WL |  |
|  | LDM, STM | L |  |
|  | MOVFPE, MOVTPE | B |  |
| Arithmetic operations | ADD, SUB, CMP, NEG | BWL | 19 |
|  | ADDX, SUBX, DAA, DAS | B |  |
|  | INC, DEC | BWL |  |
|  | ADDS, SUBS | L |  |
|  | MULXU, DIVXU, MULXS, DIVXS | BW |  |
|  | EXTU, EXTS | WL |  |
|  | TAS*4 | B |  |
|  | MAC, LDMAC, STMAC, CLRMAC*1 | - | $4^{* 1}$ |
| Logic operations | AND, OR, XOR, NOT | BWL | 4 |
| Shift | SHAL, SHAR, SHLL, SHLR, ROTL, ROTR, ROTXL, ROTXR | BWL | 8 |
| Bit manipulation | BSET, BCLR, BNOT, BTST, BLD, BILD, BST, BIST, BAND, BIAND, BOR, BIOR, BXOR, BIXOR | B | 14 |
| Branch | Bcc*3, JMP, BSR, JSR, RTS | - | 5 |
| System control | TRAPA, RTE, SLEEP, LDC, STC, ANDC, ORC, XORC, NOP | - | 9 |
| Block data transfer | EEPMOV | - | 1 |

Legend: B: Byte size
W: Word size
L: Longword size
Notes: 1. The MAC, LDMAC, STMAC, and CLRMAC instructions are supported only by the H8S/2600 CPU.
2. POP.W Rn and PUSH.W Rn are identical to MOV.W @SP+, Rn and MOV.W Rn, @-SP. POP.L ERn and PUSH.L ERn are identical to MOV.L @SP+, ERn and MOV.L ERn, @-SP.
3. Bcc is the generic designation of a conditional branch instruction.
4. Only register ERO, ER1, ER4, or ER5 should be used when using the TAS instruction.

### 1.6.2 Instructions and Addressing Modes

Table 1.2 indicates the combinations of instructions and addressing modes that the H8S/2600 CPU and $\mathrm{H} 8 \mathrm{~S} / 2000 \mathrm{CPU}$ can use.

Table 1.2 Combinations of Instructions and Addressing Modes


B: Byte
L: Longword
Notes: 1. Supported only by the H8S/2600 CPU
Notes: 1. Supported only by the H8S/2600 CPU
2. Only register ERO, ER1, ER4, or ER5 should be used when using the TAS instruction.

### 1.6.3 Table of Instructions Classified by Function

Table 1.3 summarizes the instructions in each functional category. The notation used in table 1.3 is defined next.

## Operation Notation

| Rd | General register (destination)* |
| :---: | :---: |
| Rs | General register (source)* |
| Rn | General register* |
| ERn | General register (32-bit register) |
| MAC | Multiply-accumulate register (32-bit register) |
| (EAd) | Destination operand |
| (EAs) | Source operand |
| EXR | Extended control register |
| CCR | Condition-code register |
| N | N (negative) flag in CCR |
| Z | Z (zero) flag in CCR |
| V | $\checkmark$ (overflow) flag in CCR |
| C | C (carry) flag in CCR |
| PC | Program counter |
| SP | Stack pointer |
| \#IMM | Immediate data |
| disp | Displacement |
| + | Addition |
| - | Subtraction |
| $\times$ | Multiplication |
| $\div$ | Division |
| $\wedge$ | Logical AND |
| $v$ | Logical OR |
| $\oplus$ | Logical exclusive OR |
| $\rightarrow$ | Move |
| $\checkmark$ | Logical not (logical complement) |
| :8/:16/:24/:32 | 8-, 16-, 24-, or 32-bit length |
| Note: * General registers include 8-bit registers (R0H to R7H, R0L to R7L), 16-bit registers (R0 <br>  to R7, E0 to E7), and 32-bit registers (ER0 to ER7).  |  |

Table 1.3 Instructions Classified by Function

| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| Data transfer | MOV | B/W/L | (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. |
|  | MOVFPE | B | (EAs) $\rightarrow$ Rd |
|  |  |  | Moves external memory contents (addressed by @aa:16) to a general register in synchronization with an E clock. |
|  | MOVTPE | B | $\mathrm{Rs} \rightarrow$ (EAs) |
|  |  |  | Moves general register contents to an external memory location (addressed by @aa:16) in synchronization with an E clock. |
|  | POP | W/L | $@$ SP+ $\rightarrow$ Rn |
|  |  |  | Pops a register from the stack. POP.W Rn is identical to MOV.W @SP+, Rn. POP.L ERn is identical to MOV.L @SP+, ERn. |
|  | PUSH | W/L | Rn $\rightarrow$ @-SP |
|  |  |  | Pushes a register onto the stack. PUSH.W Rn is identical to MOV.W Rn, @-SP. PUSH.L ERn is identical to MOV.L ERn, @-SP. |
|  | LDM | L | @SP+ $\rightarrow$ Rn (register list) |
|  |  |  | Pops two or more general registers from the stack. |
|  | STM | L | Rn (register list) $\rightarrow$ @-SP |
|  |  |  | Pushes two or more general registers onto the stack. |


| Type | Instruction | Size*1 | Function |
| :---: | :---: | :---: | :---: |
| Arithmetic operations | $\begin{aligned} & \hline \text { ADD } \\ & \text { SUB } \end{aligned}$ | B/W/L | $R d \pm R s \rightarrow R d, \quad R d \pm \# I M M \rightarrow R d$ <br> Performs addition or subtraction on data in two general registers, or on immediate data and data in a general register. (Immediate byte data cannot be subtracted from byte data in a general register. Use the SUBX or ADD instruction.) |
|  | $\begin{aligned} & \hline \text { ADDX } \\ & \text { SUBX } \end{aligned}$ | B | $R d \pm R s \pm C \rightarrow R d, \quad R d \pm \# I M M \pm C \rightarrow R d$ <br> Performs addition or subtraction with carry or borrow on byte data in two general registers, or on immediate data and data in a general register. |
|  | $\begin{aligned} & \text { INC } \\ & \text { DEC } \end{aligned}$ | B/W/L | $\mathrm{Rd} \pm 1 \rightarrow \mathrm{Rd}, \quad \mathrm{Rd} \pm 2 \rightarrow \mathrm{Rd}$ <br> Increments or decrements a general register by 1 or 2. (Byte operands can be incremented or decremented by 1 only.) |
|  | ADDS SUBS | L | $R d \pm 1 \rightarrow R d, \quad R d \pm 2 \rightarrow R d, \quad R d \pm 4 \rightarrow R d$ <br> Adds or subtracts the value 1, 2 , or 4 to or from data in a 32-bit register. |
|  | DAA | B | Rd decimal adjust $\rightarrow$ Rd |
|  | DAS |  | Decimal-adjusts an addition or subtraction result in a general register by referring to the CCR to produce 4bit BCD data. |
|  | MULXU | B/W | $\mathrm{Rd} \times \mathrm{Rs} \rightarrow \mathrm{Rd}$ <br> Performs unsigned multiplication on data in two general registers: either 8 bits $\times 8$ bits $\rightarrow 16$ bits or 16 bits $\times$ 16 bits $\rightarrow 32$ bits. |
|  | MULXS | B/W | $\mathrm{Rd} \times \mathrm{Rs} \rightarrow \mathrm{Rd}$ <br> Performs signed multiplication on data in two general registers: either 8 bits $\times 8$ bits $\rightarrow 16$ bits or 16 bits $\times$ 16 bits $\rightarrow 32$ bits. |
|  | DIVXU | B/W | $\mathrm{Rd} \div \mathrm{Rs} \rightarrow \mathrm{Rd}$ <br> Performs unsigned division on data in two general registers: either 16 bits $\div 8$ bits $\rightarrow 8$-bit quotient and 8 -bit remainder or 32 bits $\div 16$ bits $\rightarrow 16$-bit quotient and 16-bit remainder. |
|  | DIVXS | B/W | $\mathrm{Rd} \div \mathrm{Rs} \rightarrow \mathrm{Rd}$ <br> Performs signed division on data in two general registers: either 16 bits $\div 8$ bits $\rightarrow 8$-bit quotient and 8 -bit remainder or 32 bits $\div 16$ bits $\rightarrow 16$-bit quotient and 16-bit remainder. |


| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| Arithmetic operations | CMP | B/W/L | Rd-Rs, Rd-\#IMM <br> Compares data in a general register with data in another general register or with immediate data, and sets CCR bits according to the result. |
|  | NEG | B/W/L | $0-R d \rightarrow R d$ <br> Takes the two's complement (arithmetic complement) of data in a general register. |
|  | EXTU | W/L | $\mathrm{Rd} \text { (zero extension) } \rightarrow \mathrm{Rd}$ <br> Extends the lower 8 bits of a 16-bit register to word size, or the lower 16 bits of a 32-bit register to longword size, by padding with zeros on the left. |
|  | EXTS | W/L | $R d$ (sign extension) $\rightarrow$ Rd <br> Extends the lower 8 bits of a 16-bit register to word size, or the lower 16 bits of a 32-bit register to longword size, by extending the sign bit. |
|  | TAS | B | @ERd - 0, $1 \rightarrow$ (<bit 7> of @ERd)*2 <br> Tests memory contents, and sets the most significant bit (bit 7) to 1 . |
|  | MAC | - | $(E A s) \times(E A d)+\text { MAC } \rightarrow \text { MAC }$ <br> Performs signed multiplication on memory contents and adds the result to the multiply-accumulate register. The following operations can be performed: <br> 16 bits $\times 16$ bits +32 bits $\rightarrow 32$ bits, saturating <br> 16 bits $\times 16$ bits +42 bits $\rightarrow 42$ bits, non-saturating <br> Supported by H8S/2600 CPU only. |
|  | CLRMAC | - | $0 \rightarrow$ MAC |

Clears the multiply-accumulate register to zero.
Supported by H8S/2600 CPU only.

| LDMAC | L | $\mathrm{Rs} \rightarrow$ MAC, MAC $\rightarrow \mathrm{Rd}$ |
| :--- | :--- | :--- |
| STMAC |  | Transfers data between a general register and the |
|  | multiply-accumulate register. |  |

Supported by H8S/2600 CPU only.

| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| Logic operations | AND | B/W/L | $R d \wedge R s \rightarrow R d, R d \wedge \# I M M \rightarrow R d$ <br> Performs a logical AND operation on a general register and another general register or immediate data. |
|  | OR | B/W/L | $R d \vee R s \rightarrow R d, \quad R d \vee \# I M M \rightarrow R d$ <br> Performs a logical OR operation on a general register and another general register or immediate data. |
|  | XOR | B/W/L | $\mathrm{Rd} \oplus \mathrm{Rs} \rightarrow \mathrm{Rd}, \quad \mathrm{Rd} \oplus \# \mathrm{IMM} \rightarrow \mathrm{Rd}$ <br> Performs a logical exclusive OR operation on a general register and another general register or immediate data. |
|  | NOT | B/W/L | $\neg(\mathrm{Rd}) \rightarrow(\mathrm{Rd})$ <br> Takes the one's complement of general register contents. |
| Shift operations | SHAL SHAR | B/W/L | $\mathrm{Rd}(\text { shift }) \rightarrow \mathrm{Rd}$ <br> Performs an arithmetic shift on general register contents. <br> 1-bit or 2-bit shift is possible. |
|  | SHLL SHLR | B/W/L | $\mathrm{Rd}(\text { shift }) \rightarrow \mathrm{Rd}$ <br> Performs a logical shift on general register contents. 1-bit or 2-bit shift is possible. |
|  | ROTL ROTR | B/W/L | $\mathrm{Rd} \text { (rotate) } \rightarrow \mathrm{Rd}$ <br> Rotates general register contents. <br> 1-bit or 2-bit rotation is possible. |
|  | ROTXL ROTXR | B/W/L | $\mathrm{Rd} \text { (rotate) } \rightarrow \mathrm{Rd}$ <br> Rotates general register contents through the carry bit. 1-bit or 2-bit rotation is possible. |


| Type | Instruction | Size*1 | Function |
| :---: | :---: | :---: | :---: |
| Bit-manipulation instructions | BSET | B | $1 \rightarrow$ (<bit-No.> of <EAd>) <br> Sets a specified bit in a general register or memory operand to 1 . The bit number is specified by 3 -bit immediate data or the lower three bits of a general register. |
|  | BCLR | B | $0 \rightarrow(<\text { bit-No. }>\text { of }<E A d>)$ <br> Clears a specified bit in a general register or memory operand to 0 . The bit number is specified by 3 -bit immediate data or the lower three bits of a general register. |
|  | BNOT | B | $\neg$ (<bit-No.> of <EAd>) $\rightarrow$ (<bit-No.> of <EAd>) <br> Inverts a specified bit in a general register or memory operand. The bit number is specified by 3 -bit immediate data or the lower three bits of a general register. |
|  | BTST | B | $\neg(\text { <bit-No. }>\text { of }\langle E A d>) \rightarrow Z$ <br> Tests a specified bit in a general register or memory operand and sets or clears the Z flag accordingly. The bit number is specified by 3 -bit immediate data or the lower three bits of a general register. |
|  | BAND | B | $\mathrm{C} \wedge(<\text { bit-No.> of }<\mathrm{EAd}>) \rightarrow \mathrm{C}$ <br> ANDs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag. |
|  | BIAND | B | $\mathrm{C} \wedge \neg$ (<bit-No.> of $<\mathrm{EAd}>$ ) $\rightarrow \mathrm{C}$ <br> ANDs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. <br> The bit number is specified by 3 -bit immediate data. |
|  | BOR | B | $\mathrm{C} \vee(<\text { bit-No. }>\text { of }<\mathrm{EAd}>) \rightarrow \mathrm{C}$ <br> ORs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag. |
|  | BIOR | B | C $\vee \neg$ (<bit-No.> of $<$ EAd $>$ ) $\rightarrow$ C <br> ORs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. <br> The bit number is specified by 3 -bit immediate data. |


| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| Bit-manipulation instructions | BXOR | B | $\mathrm{C} \oplus(<\text { bit-No. }>\text { of }<\mathrm{EAd}>) \rightarrow \mathrm{C}$ <br> Exclusive-ORs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag. |
|  | BIXOR | B | $\mathrm{C} \oplus \neg(<\text { bit-No. }>\text { of }<\mathrm{EAd}>) \rightarrow \mathrm{C}$ <br> Exclusive-ORs the carry flag with the inverse of a specified bit in a general register or memory operand and stores the result in the carry flag. <br> The bit number is specified by 3-bit immediate data. |
|  | BLD | B | $(<\text { bit-No. }>\text { of }<E A d>) \rightarrow C$ <br> Transfers a specified bit in a general register or memory operand to the carry flag. |
|  | BILD | B | $\neg(<\text { bit-No. }>\text { of }<E A d>) \rightarrow C$ <br> Transfers the inverse of a specified bit in a general register or memory operand to the carry flag. <br> The bit number is specified by 3 -bit immediate data. |
|  | BST | B | $\mathrm{C} \rightarrow(<\text { bit-No. }>\text { of }<E A d>)$ <br> Transfers the carry flag value to a specified bit in a general register or memory operand. |
|  | BIST | B | $\neg \mathrm{C} \rightarrow$ (<bit-No.> of $<$ EAd $>$ ) <br> Transfers the inverse of the carry flag value to a specified bit in a general register or memory operand. <br> The bit number is specified by 3 -bit immediate data. |


| Type | Instruction | Size ${ }^{* 1}$ | Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Branch instructions | Bcc | - | Branches to a specified address if a specified condition is true. The branching conditions are listed below. |  |  |
|  |  |  | Mnemonic | Description | Condition |
|  |  |  | BRA(BT) | Always (true) | Always |
|  |  |  | BRN(BF) | Never (false) | Never |
|  |  |  | BHI | High | $C \vee Z=0$ |
|  |  |  | BLS | Low or same | $C \vee Z=1$ |
|  |  |  | BCC(BHS) | Carry clear (high or same) | $C=0$ |
|  |  |  | BCS(BLO) | Carry set (low) | $C=1$ |
|  |  |  | BNE | Not equal | $\mathrm{Z}=0$ |
|  |  |  | BEQ | Equal | $\mathrm{Z}=1$ |
|  |  |  | BVC | Overflow clear | $V=0$ |
|  |  |  | BVS | Overflow set | $\mathrm{V}=1$ |
|  |  |  | BPL | Plus | $\mathrm{N}=0$ |
|  |  |  | BMI | Minus | $\mathrm{N}=1$ |
|  |  |  | BGE | Greater or equal | $\mathrm{N} \oplus \mathrm{V}=0$ |
|  |  |  | BLT | Less than | $\mathrm{N} \oplus \mathrm{V}=1$ |
|  |  |  | BGT | Greater than | $\mathrm{Z} \vee(\mathrm{N} \oplus \mathrm{V})=0$ |
|  |  |  | BLE | Less or equal | $\mathrm{Z} \vee(\mathrm{N} \oplus \mathrm{V})=1$ |
|  | JMP | - | Branches unconditionally to a specified address. |  |  |
|  | BSR | - | Branches to a subroutine at a specified address. |  |  |
|  | JSR | - | Branches to a subroutine at a specified address. |  |  |
|  | RTS | - | Returns from a subroutine |  |  |


| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| System control instructions | TRAPA | - | Starts trap-instruction exception handling. |
|  | RTE | - | Returns from an exception-handling routine. |
|  | SLEEP | - | Causes a transition to a power-down state. |
|  | LDC | B/W | (EAs) $\rightarrow$ CCR, (EAs) $\rightarrow$ EXR |
|  |  |  | Moves the source operand contents or immediate data to CCR or EXR. Although CCR and EXR are 8-bit registers, word-size transfers are performed between them and memory. The upper 8 bits are valid. |
|  | STC | B/W | CCR $\rightarrow$ (EAd), EXR $\rightarrow$ (EAd) |
|  |  |  | Transfers CCR or EXR contents to a general register or memory. Although CCR and EXR are 8-bit registers, word-size transfers are performed between them and memory. The upper 8 bits are valid. |
|  | ANDC | B | CCR $\wedge$ \#IMM $\rightarrow$ CCR, EXR $\wedge$ \#IMM $\rightarrow$ EXR |
|  |  |  | Logically ANDs the CCR or EXR contents with immediate data. |
|  | ORC | B | CCR $v$ \#IMM $\rightarrow$ CCR, EXR $v$ \#IMM $\rightarrow$ EXR |
|  |  |  | Logically ORs the CCR or EXR contents with immediate data. |
|  | XORC | B | CCR $\oplus$ \#IMM $\rightarrow$ CCR, EXR $\oplus$ \#IMM $\rightarrow$ EXR |
|  |  |  | Logically exclusive-ORs the CCR or EXR contents with immediate data. |
|  | NOP | - | $\mathrm{PC}+2 \rightarrow \mathrm{PC}$ |
|  |  |  | Only increments the program counter. |


| Type | Instruction | Size ${ }^{* 1}$ | Function |
| :---: | :---: | :---: | :---: |
| Block data transfer instruction | EEPMOV.B | - | ```if R4L # 0 then Repeat @ER5+ }->\mathrm{ @ER6+ R4L-1 T R4L Until R4L = 0 else next;``` |
|  | EEPMOV.W | - | ```if R4 \not=0 then Repeat @ER5+ -> @ER6+ R4-1 }->\mathrm{ R4 Until R4 = 0 else next;``` |
|  |  |  | Transfers a data block according to parameters set in general registers R4L or R4, ER5, and ER6. |
|  |  |  | R4L or R4: size of block (bytes) <br> ER5: starting source address <br> ER6: starting destination address |
|  |  |  | Execution of the next instruction begins as soon as the transfer is completed. |

Notes: 1. Size refers to the operand size.
B: Byte
W: Word
L: Longword
2. Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction.

### 1.6.4 Basic Instruction Formats

The H8S/2600 or H8S/2000 instructions consist of 2-byte (1-word) units. An instruction consists of an operation field (op field), a register field (r field), an effective address extension (EA field), and a condition field (cc).

Operation Field: Indicates the function of the instruction, the addressing mode, and the operation to be carried out on the operand. The operation field always includes the first four bits of the instruction. Some instructions have two operation fields.

Register Field: Specifies a general register. Address registers are specified by 3 bits, data registers by 3 bits or 4 bits. Some instructions have two register fields. Some have no register field.

Effective Address Extension: Eight, 16, or 32 bits specifying immediate data, an absolute address, or a displacement.

Condition Field: Specifies the branching condition of Bcc instructions.
Figure 1.12 shows examples of instruction formats.
(1) Operation field only

| op |
| :---: |
| NOP, RTS, etc. |

(2) Operation field and register fields

| op | rn | rm |
| :---: | :---: | :---: |

(3) Operation field, register fields, and effective address extension

| op | rn | rm |
| :---: | :---: | :---: |
| EA (disp) |  |  |

(4) Operation field, effective address extension, and condition field

| op | cc | EA (disp) |
| :---: | :---: | :---: |

Figure 1.12 Instruction Formats

### 1.7 Addressing Modes and Effective Address Calculation

## (1) Addressing Modes

The CPUs support the eight addressing modes listed in table 1.4. Each instruction uses a subset of these addressing modes. Arithmetic and logic instructions can use the register direct and immediate modes. Data transfer instructions can use all addressing modes except program-counter relative and memory indirect. Bit manipulation instructions use register direct, register indirect, or absolute addressing mode to specify an operand, and register direct (BSET, BCLR, BNOT, and BTST instructions) or immediate (3-bit) addressing mode to specify a bit number in the operand.

## Table 1.4 Addressing Modes

| No. | Addressing Mode | Symbol |
| :--- | :--- | :--- |
| 1 | Register direct | Rn |
| 2 | Register indirect | @ERn |
| 3 | Register indirect with displacement | @(d:16,ERn)/@(d:32,ERn) |
| 4 | Register indirect with post-increment | @ERn+ |
|  | Register indirect with pre-decrement | @-ERn |
| 5 | Absolute address | @aa:8/@aa:16/@aa:24/@aa:32 |
| 6 | Immediate | \#xx:8/\#xx:16/\#xx:32 |
| 7 | Program-counter relative | @(d:8,PC)/@(d:16,PC) |
| 8 | Memory indirect | @ @aa:8 |

1. Register Direct-Rn: The register field of the instruction specifies an $8-, 16$-, or 32 -bit general register containing the operand. R 0 H to R 7 H and R 0 L to R 7 L can be specified as 8 -bit registers. R0 to R7 and E0 to E7 can be specified as 16-bit registers. ER0 to ER7 can be specified as 32-bit registers.
2. Register Indirect—@ERn: The register field of the instruction code specifies an address register ( ERn ) which contains the address of the operand in memory. If the address is a program instruction address, the lower 24 bits are valid and the upper 8 bits are all assumed to be $0\left(\mathrm{H}^{\prime} 00\right)$.
3. Register Indirect with Displacement — @ (d:16, ERn) or @(d:32, ERn): A 16-bit or 32-bit displacement contained in the instruction is added to an address register (ERn) specified by the register field of the instruction, and the sum gives the address of a memory operand. A 16-bit displacement is sign-extended when added.

## 4. Register Indirect with Post-Increment or Pre-Decrement—@ERn+ or @-ERn:

- Register indirect with post-increment—@ERn+

The register field of the instruction code specifies an address register (ERn) which contains the address of a memory operand. After the operand is accessed, 1,2 , or 4 is added to the address register contents and the sum is stored in the address register. The value added is 1 for byte access, 2 for word access, or 4 for longword access. For word or longword access, the register value should be even.

- Register indirect with pre-decrement-@-ERn The value 1,2 , or 4 is subtracted from an address register (ERn) specified by the register field in the instruction code, and the result becomes the address of a memory operand. The result is also stored in the address register. The value subtracted is 1 for byte access, 2 for word access, or 4 for longword access. For word or longword access, the register value should be even.

5. Absolute Address—@aa:8, @aa:16, @aa:24, or @aa:32: The instruction code contains the absolute address of a memory operand. The absolute address may be 8 bits long ( $@ a a: 8$ ), 16 bits long (@aa:16), 24 bits long (@aa:24), or 32 bits long (@aa:32).

To access data, the absolute address should be 8 bits (@aa:8), 16 bits (@aa:16), or 32 bits (@aa:32) long. For an 8 -bit absolute address, the upper 24 bits are all assumed to be 1
(H'FFFFFF). For a 16-bit absolute address the upper 16 bits are a sign extension. A 32-bit absolute address can access the entire address space.

A 24-bit absolute address (@aa:24) indicates the address of a program instruction. The upper 8 bits are all assumed to be $0\left(\mathrm{H}^{\prime} 00\right)$.

Table 1.5 indicates the accessible absolute address ranges.
Table 1.5 Absolute Address Access Ranges

| Absolute Address |  | Normal Mode | Advanced Mode |
| :---: | :---: | :---: | :---: |
| Data address | 8 bits (@aa:8) | H'FF00 to H'FFFF | H'FFFFFF00 to H'FFFFFFFF |
|  | 16 bits (@aa:16) | H'0000 to H'FFFF | H'00000000 to H'00007FFF, H'FFFF8000 to H'FFFFFFFFF |
|  | 32 bits (@aa:32) |  | H'00000000 to H'FFFFFFFF |
| Program instruction address | 24 bits (@aa:24) |  | H'00000000 to H'00FFFFFF |

For further details on the accessible range, refer to the relevant microcontroller hardware manual.
6. Immediate—\#xx:8, \#xx:16, or \#xx:32: The instruction contains 8-bit (\#xx:8), 16-bit (\#xx:16), or 32-bit (\#xx:32) immediate data as an operand.

The ADDS, SUBS, INC, and DEC instructions contain immediate data implicitly. Some bit manipulation instructions contain 3-bit immediate data in the instruction code, specifying a bit number. The TRAPA instruction contains 2-bit immediate data in its instruction code, specifying a vector address.
7. Program-Counter Relative-@(d:8, PC) or @(d:16, PC): This mode is used in the Bcc and BSR instructions. An 8 -bit or 16 -bit displacement contained in the instruction is sign-extended and added to the 24 -bit PC contents to generate a branch address. Only the lower 24 bits of this branch address are valid; the upper 8 bits are all assumed to be $0\left(\mathrm{H}^{\prime} 00\right)$. The PC value to which the displacement is added is the address of the first byte of the next instruction, so the possible branching range is -126 to +128 bytes ( -63 to +64 words) or -32766 to +32768 bytes ( -16383 to +16384 words) from the branch instruction. The resulting value should be an even number.
8. Memory Indirect - @ @aa:8: This mode can be used by the JMP and JSR instructions. The second byte of the instruction specifies a memory operand by an 8-bit absolute address. This memory operand contains a branch address. The upper bits of the absolute address are all assumed to be 0 , so the address range is 0 to 255 ( $\mathrm{H}^{\prime} 0000$ to $\mathrm{H}^{\prime} 00 \mathrm{FF}$ in normal mode, $\mathrm{H}^{\prime} 00000000$ to $\mathrm{H}^{\prime} 000000 \mathrm{FF}$ in advanced mode). In normal mode the memory operand is a word operand and the branch address is 16 bits long. In advanced mode the memory operand is a longword operand, the first byte of which is assumed to be all $0\left(\mathrm{H}^{\prime} 00\right)$.

Note that the first part of the address range is also the exception vector area. For further details refer to the relevant microcontroller hardware manual.


Figure 1.13 Branch Address Specification in Memory Indirect Mode

If an odd address is specified in word or longword memory access, or as a branch address, the least significant bit is regarded as 0 , causing data to be accessed or an instruction code to be fetched at the address preceding the specified address. (For further information, see section 1.5.2, Memory Data Formats.)

## (2) Effective Address Calculation

Table 1.6 indicates how effective addresses are calculated in each addressing mode. In normal mode the upper 8 bits of the effective address are ignored in order to generate a 16-bit address.

Table 1.6 Effective Address Calculation




## Section 2 Instruction Descriptions

### 2.1 Tables and Symbols

This section explains how to read the tables in section 2.2, describing each instruction. Note that the descriptions of some instructions extend over more than one page.

| [1] Mnemonic (Full Name) |  | [2] Type |
| :--- | :--- | :--- |
| [3] Operation |  |  |
| [6] Condition Code |  |  |
| [5] Opsembly-Language Format |  |  |

[7] Description
[8] Available Registers
[9] Operand Format and Number of States Required for Execution
[10] Notes
[1] Mnemonic (Full Name): Gives the full and mnemonic names of the instruction.
[2] Type: Indicates the type of instruction.
[3] Operation: Describes the instruction in symbolic notation. (See section 2.1.2, Operation.)
[4] Assembly-Language Format: Indicates the assembly-language format of the instruction. (See section 2.1.1, Assembler Format.)
[5] Operand Size: Indicates the available operand sizes.
[6] Condition Code: Indicates the effect of instruction execution on the flag bits in the CCR. (See section 2.1.3, Condition Code.)
[7] Description: Describes the operation of the instruction in detail.
[8] Available Registers: Indicates which registers can be specified in the register field of the instruction.
[9] Operand Format and Number of States Required for Execution: Shows the addressing modes and instruction format together with the number of states required for execution.
[10] Notes: Gives notes concerning execution of the instruction.

### 2.1.1 Assembly-Language Format



The operand size is byte (B), word (W), or longword (L). Some instructions are restricted to a limited set of operand sizes.

The symbol <EA> indicates that two or more addressing modes can be used. The H8S/2600 CPU supports the eight addressing modes listed next. Effective address calculation is described in section 1.7, Addressing Modes and Effective Address Calculation.

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

The suffixes $: 8,: 16,: 24$, and $: 32$ may be omitted. In particular, if the $: 8,: 16,: 24$, or $: 32$ designation is omitted in an absolute address or displacement, the assembler will optimize the length according to the value range. For details, refer to the H8S, H8/300 Series cross assembler user's manual.

Note: ":2" and ":3" in "\#xx (:2)" and "\#xx (:3)" indicate the specifiable bit length. Do not include (:2) or (:3) in the assembler notation.
Example: TRAPA \#3

### 2.1.2 Operation

The symbols used in the operation descriptions are defined as follows.

| Rd | General register (destination)* |
| :---: | :---: |
| Rs | General register (source)* |
| Rn | General register* |
| ERn | General register (32-bit register) |
| MAC | Multiply-accumulate register (32-bit register) |
| (EAd) | Destination operand |
| (EAs) | Source operand |
| EXR | Extended control register |
| CCR | Condition-code register |
| N | $N$ (negative) flag in CCR |
| Z | Z (zero) flag in CCR |
| V | $V$ (overflow) flag in CCR |
| C | C (carry) flag in CCR |
| PC | Program counter |
| SP | Stack pointer |
| \#IMM | Immediate data |
| disp | Displacement |
| + | Add |
| - | Subtract |
| $\times$ | Multiply |
| $\div$ | Divide |
| $\wedge$ | Logical AND |
| $v$ | Logical OR |
| $\oplus$ | Logical exclusive OR |
| $\rightarrow$ | Transfer from the operand on the left to the operand on the right, or transition from the state on the left to the state on the right |
| $\neg$ | Logical NOT (logical complement) |
| ( ) < > | Contents of effective address of the operand |
| $\begin{aligned} & \hline: 8 /: 16 / \\ & : 24 /: 32 \end{aligned}$ | 8-, 16-, 24-, or 32-bit length |

Note: * General registers include 8-bit registers (ROH to R7H and ROL to R7L), 16-bit registers (R0 to R7 and E0 to E7), and 32-bit registers (ER0 to ER7).

### 2.1.3 Condition Code

The symbols used in the condition-code description are defined as follows.

| Symbol | Meaning |
| :--- | :--- |
| $\uparrow$ | Changes according to the result of instruction execution |
| $*$ | Undetermined (no guaranteed value) |
| 0 | Always cleared to 0 |
| 1 | Always set to 1 |
| - | Not affected by execution of the instruction |
| $\Delta$ | Varies depending on conditions; see the notes |

For details on changes of the condition code, see section 2.8, Condition Code Modification.

### 2.1.4 Instruction Format

The symbols used in the instruction format descriptions are listed below.

| Symbol | Meaning |
| :--- | :--- |
| IMM | Immediate data (2, 3, 8, 16, or 32 bits) |
| abs | Absolute address (8, 16, 24, or 32 bits) |
| disp | Displacement (8, 16, or 32 bits) |
| rs, rd, rn | Register field (4 bits). The symbols rs, rd, and rn correspond to operand symbols <br> Rs, Rd, and Rn. |
| ers, erd, ern | Register field (3 bits). The symbols ers, erd, and ern correspond to operand <br> symbols ERs, ERd, and ERn. |

### 2.1.5 Register Specification

Address Register Specification: When a general register is used as an address register [@ERn, @(d:16, ERn), @(d:32, ERn), @ERn+, or @-ERn], the register is specified by a 3-bit register field (ers or erd).

Data Register Specification: A general register can be used as a 32-bit, 16-bit, or 8-bit data register.

When used as a 32 -bit register, it is specified by a 3-bit register field (ers, erd, or ern).
When used as a 16 -bit register, it is specified by a 4 -bit register field (rs, rd, or rn). The lower 3 bits specify the register number. The upper bit is set to 1 to specify an extended register (En) or cleared to 0 to specify a general register ( Rn ).

When used as an 8 -bit register, it is specified by a 4 -bit register field (rs, rd, or rn). The lower 3 bits specify the register number. The upper bit is set to 1 to specify a low register ( RnL ) or cleared to 0 to specify a high register ( RnH ). This is shown next.

Address Register 32-Bit Register

| Register <br> Field | General <br> Register |  | Register <br> Field |  | General <br> Register |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | Register <br> Field |  | General <br> Register |  |  |  |
| 000 | ER0 | 0000 | R0 | 0000 | R0H |  |
| 001 | ER1 | 0001 | $\cdot$ | R1 | $\cdot$ | 0001 |

### 2.1.6 Bit Data Access in Bit Manipulation Instructions

Bit data is accessed as the $n$-th bit $(\mathrm{n}=0,1,2,3, \ldots, 7)$ of a byte operand in a general register or memory. The bit number is given by 3-bit immediate data, or by the lower 3 bits of a general register value.

Example 1: To set bit 3 in R 2 H to 1


Example 2: To load bit 5 at address H'FFFF02 into the bit accumulator

BLD \#5, @H'FFFF02


The operand size and addressing mode are as indicated for register or memory operand data.

### 2.2 Instruction Descriptions

The instructions are described starting in section 2.2.1.
2.2.1 (1) ADD (B)

ADD (ADD Binary)
Add Binary

## Operation

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

## Assembly-Language Format

ADD. B <EAs>, Rd

## Operand Size

Byte

H: Set to 1 if there is a carry at bit 3; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a carry at bit 7 ; otherwise cleared to 0 .

## Description

This instruction adds the source operand to the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd .

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Immediate | ADD.B | \#xx:8, Rd | 8 | rd | IMM |  |  |  | 1 |
| Register direct | ADD.B | Rs, Rd | 0 | 8 | rs | rd |  |  | 1 |

## Notes

2.2.1 (2) ADD (W)

ADD (ADD Binary)
Add Binary

## Operation

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

## Assembly-Language Format

ADD.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}: \quad$ Set to 1 if there is a carry at bit 11 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C : Set to 1 if there is a carry at bit 15 ; otherwise cleared to 0 .

## Description

This instruction adds the source operand to the contents of a 16-bit register Rd (destination operand) and stores the result in the 16 -bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  |  |  |  |  |  |  |  | 2nd byte | 3rd byte | 4th byte |  |
| Immediate | ADD.W | \#xx:16, Rd | 7 | 9 | 1 | rd | IMM |  |  | 2 |  |  |  |  |  |  |
| Register direct | ADD.W | Rs, Rd | 0 | 9 | rs | rd |  |  | 1 |  |  |  |  |  |  |

## Notes

2.2.1 (3) ADD (L)

ADD (ADD Binary)
Add Binary

## Operation

$\mathrm{ERd}+(\mathrm{EAs}) \rightarrow \mathrm{ERd}$

## Assembly-Language Format

ADD.L <EAs>, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\downarrow$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: \quad$ Set to 1 if there is a carry at bit 27 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C : Set to 1 if there is a carry at bit 31 ; otherwise cleared to 0 .

## Description

This instruction adds the source operand to the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode <br> Immediate | Mnemonic <br> ADD.L | Operands <br> \#xx:32, ERd | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  |  | 3rd byte | 4th byte | 5th byte | 6th byte |  |
|  |  |  | 7 | A | 1 |  | erd |  |  |  |  |  |
| Register direct | ADD.L | ERs, ERd | 0 | A | 1 ers |  | erd |  |  |  |  | 1 |

## Notes

### 2.2.2 ADDS

ADDS (ADD with Sign extension)

## Operation

Rd $+1 \rightarrow$ ERd
$\mathrm{Rd}+2 \rightarrow$ ERd
$\mathrm{Rd}+4 \rightarrow$ ERd

## Assembly-Language Format

ADDS \#1,ERd
ADDS \#2, ERd
ADDS \#4, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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, 2, or 4 to the contents of a 32-bit register ERd (destination operand). Unlike the ADD instruction, it does not affect the condition code flags.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Register direct | ADDS | \#1, ERd | 0 | B | 0 | 0 | erd |  |  | 1 |
| Register direct | ADDS | \#2, ERd | 0 | B | 8 | 0 | erd |  |  | 1 |
| Register direct | ADDS | \#4, ERd | 0 | B | 9 | 0 | erd |  |  | 1 |

## Notes

### 2.2.3 ADDX

ADDX (ADD with eXtend carry)
Add with Carry

## Operation

$\mathrm{Rd}+(\mathrm{EAs})+\mathrm{C} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

ADDX <EAs>, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

H : Set to 1 if there is a carry at bit 3; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a carry at bit 7 ; otherwise cleared to 0 .

## Description

This instruction adds the source operand and carry flag to the contents of an 8-bit register Rd (destination operand) and stores the result in the 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Immediate | ADDX | \#xx:8, Rd | 9 | rd | IMM |  |  |  | 1 |
| Register direct | ADDX | Rs, Rd | 0 | E | rs | rd |  |  | 1 |

## Notes

2.2.4 (1) AND (B)

AND (AND logical)
Logical AND

## Operation

$R d \wedge(E A s) \rightarrow R d$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

AND. B <EAs>, Rd

## Operand Size

Byte
$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ANDs the source operand with the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | AND.B | \#xx:8, Rd | E | rd | IMM |  |  |  | 1 |
| Register direct | AND.B | Rs, Rd | 1 | 6 | rs | rd |  |  | 1 |

## Notes

2.2.4 (2) AND (W)

AND (AND logical)
Logical AND

## Operation

$R d \wedge(E A s) \rightarrow R d$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

## Assembly-Language Format

AND.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ANDs the source operand with the contents of a 16-bit register Rd (destination operand) and stores the result in the 16-bit register Rd .

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | AND.W | \#xx:16, Rd | 7 | 9 | 6 | rd | IMM | 2 |  |
| Register direct | AND.W | Rs, Rd | 6 | 6 | rs | rd |  |  | 1 |

## Notes

2.2.4 (3) AND (L)

AND (AND logical)
Logical AND

## Operation

$E R d \wedge(E A s) \rightarrow E R d$

## Assembly-Language Format

AND.L <EAs>, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |  |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ANDs the source operand with the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte | 6th byte |  |
| Immediate | AND.L | \#xx:32, ERd | 7 | A | 6 | 0 erd | IMM |  |  |  |  |  | 3 |
| Register direct | AND.L | ERs, ERd | 0 | 1 | F | 0 | 6 | 6 | 0 ers | 0 erd |  |  | 2 |

## Notes

2.2.5 (1) ANDC

ANDC (AND Control register)
Logical AND with CCR

## Operation

CCR $\wedge$ \#IMM $\rightarrow$ CCR

## Assembly-Language Format <br> ANDC \#xx:8, CCR

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Stores the corresponding bit of the result.
UI: Stores the corresponding bit of the result.
H: Stores the corresponding bit of the result.
U : Stores the corresponding bit of the result.
N : Stores the corresponding bit of the result.
Z: Stores the corresponding bit of the result.
V: Stores the corresponding bit of the result.
C: Stores the corresponding bit of the result.

## Description

This instruction ANDs the contents of the condition-code register (CCR) with immediate data and stores the result in the condition-code register. No interrupt requests, including NMI, are accepted immediately after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |
| Immediate | ANDC | $\# x x: 8, ~ C C R ~$ | 0 | 6 | IMM |  |  | 1 |

## Notes

### 2.2.5 (2) ANDC

ANDC (AND Control register)
Logical AND with EXR

## Operation

EXR $\wedge$ \#IMM $\rightarrow$ EXR

## Assembly-Language Format

ANDC \#xx:8,EXR

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

Byte

## Description

This instruction ANDs the contents of the extended control register (EXR) with immediate data and stores the result in the extended control register. No interrupt requests, including NMI, are accepted for three states after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte | IMM | 2 |  |

## Notes

### 2.2.6 BAND

BAND (Bit AND)
Bit Logical AND

## Operation

$\mathrm{C} \wedge(<$ bit No. $>$ of $\langle\mathrm{EAd}>) \rightarrow \mathrm{C}$

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

H : Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.

## Operand Size

Byte

## Description

This instruction ANDs a specified bit in the destination operand with the carry flag and stores the result in the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing | Mnemonic |  |  |  |  |  |  |  | Inst | uct | F |  |  |  |  |  |  |  | No. of |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 2nd |  |  |  | 4th |  |  |  | 6th b |  |  |  | 8th b |  | States |
| Register direct | BAND | \#xx:3, Rd | 7 | 6 | 0:IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BAND | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 6 | 0:IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BAND | \#xx:3, @aa:8 | 7 | E | abs |  | 7 | 6 | 0:IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BAND | \#xx:3, @aa:16 | 6 | A | 1 | 0 | abs |  |  |  | 7 | 6 | 0 IMM |  |  |  |  |  | 4 |
| Absolute address | BAND | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 6 | 0 IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.

[^0]
### 2.2.7 Bcc

Bcc (Branch conditionally)

## Operation

If condition is true, then

$$
\mathrm{PC}+\operatorname{disp} \rightarrow \mathrm{PC}
$$

else next;

## Assembly-Language Format

BCC disp


## Operand Size

## Condition Code


$\mathrm{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 condition specified in the condition field (cc) is true, a displacement is added to the program counter (PC) and execution branches to the resulting address. If the condition is false, the next instruction is executed. The PC value used in the address calculation is the starting address of the instruction immediately following the Bcc instruction. The displacement is a signed 8 -bit or 16-bit value. The branch destination address can be located in the range from -126 to +128 bytes or -32766 to +32768 bytes from the Bcc instruction.

| Mnemonic | Meaning | cc | Condition | Signed/Unsigned* |
| :--- | :--- | :---: | :--- | :--- |
| BRA (BT) | Always (true) | 0000 | True |  |
| BRN (BF) | Never (false) | 0001 | False |  |
| BHI | Hlgh | 0010 | $\mathrm{CvZ}=0$ | $\mathrm{X}>\mathrm{Y}$ (unsigned) |
| BLS | Low or Same | 0011 | $\mathrm{CvZ}=1$ | $\mathrm{X} \leq \mathrm{Y}$ (unsigned) |
| BCC (BHS) | Carry Clear (High or Same) | 0100 | $\mathrm{C}=0$ | $\mathrm{X} \geq \mathrm{Y}$ (unsigned) |
| BCS (BLO) | Carry Set (LOw) | 0101 | $\mathrm{C}=1$ | $\mathrm{X}<\mathrm{Y}$ (unsigned) |
| BNE | Not Equal | 0110 | $\mathrm{Z}=0$ | $\mathrm{X} \neq \mathrm{Y}$ (unsigned or signed) |
| BEQ | EQual | 0111 | $\mathrm{Z}=1$ | $\mathrm{X}=\mathrm{Y}$ (unsigned or signed) |
| BVC | oVerflow Clear | 1000 | $\mathrm{~V}=0$ |  |
| BVS | oVerflow Set | 1001 | $\mathrm{~V}=1$ |  |
| BPL | PLus | 1010 | $\mathrm{~N}=0$ |  |
| BMI | MInus | 1011 | $\mathrm{~N}=1$ |  |
| BGE | Greater or Equal | 1100 | $\mathrm{~N} \oplus \mathrm{~V}=0$ | $\mathrm{X} \geq \mathrm{Y}$ (signed) |
| BLT | Less Than | 1101 | $\mathrm{~N} \oplus \mathrm{~V}=1$ | $\mathrm{X}<\mathrm{Y}$ (signed) |
| BGT | Greater Than | 1110 | $\mathrm{Zv}(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{X}>\mathrm{Y}$ (signed) |
| BLE | Less or Equal | 1111 | $\mathrm{Zv}(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{X} \leq \mathrm{Y}$ (signed) |

Note: * If the immediately preceding instruction is a CMP instruction, X is the general register contents (destination operand) and Y is the source operand.

## Bec (Branch conditionally)

Conditional Branch
Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | $\begin{gathered} \hline \text { 2nd byte } \\ \hline \text { disp } \end{gathered}$ |  | 3rd byte | 4th byte |  |
| Program-counter relative | BRA (BT) | d:8 | 4 | 0 |  |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | disp  <br> 0 0 |  | disp |  | 3 |
| Program-counter relative | BRN (BF) | d:8 | 4 | 1 | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | 1 | 0 | disp |  | 3 |
| Program-counter relative | BHI | d:8 | 4 | 2 | disp |  | disp |  | 2 |
|  |  | d:16 | 5 | 8 | 2 | 0 |  |  | 3 |
| Program-counter relative | BLS | d:8 | 4 | 3 | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | 3 | 0 | disp |  | 3 |
| Program-counter relative | Bcc (BHS) | d:8 | 4 | 4 | disp |  | disp |  | 2 |
|  |  | d:16 | 5 | 8 | 4 | 0 |  |  | 3 |
| Program-counter relative | BCS (BLO) | d:8 | 4 | 5 | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | 5 | 0 | disp |  | 3 |
| Program-counter relative | BNE | d:8 | 4 | 6 | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | 6 | 0 | disp |  | 3 |
| Program-counter relative | BEQ | d:8 | 4 | 7 | disp |  | disp |  | 2 |
|  |  | d:16 | 5 | 8 | 7 | 0 |  |  | 3 |
| Program-counter relative | BVC | d:8 | 4 | 8 | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | 8 | 0 | disp |  | 3 |
| Program-counter relative | BVS | d:8 | 4 | 9 | disp |  | disp |  | 2 |
|  |  | d:16 | 5 | 8 | 9 | 0 |  |  | 3 |
| Program-counter relative | BPL | d:8 | 4 | A | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | A | 0 | disp |  | 3 |
| Program-counter relative | BMI | d:8 | 4 | B | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | B | 0 | disp |  | 3 |
| Program-counter relative | BGE | d:8 | 4 | C | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | C | 0 | disp |  | 3 |
| Program-counter relative | BLT | d:8 | 4 | D | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | D | 0 | disp |  | 3 |
| Program-counter relative | BGT | d:8 | 4 | E | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | E | 0 | disp |  | 3 |
| Program-counter relative | BLE | d:8 | 4 | F | disp |  |  |  | 2 |
|  |  | d:16 | 5 | 8 | F | 0 | disp |  | 3 |

## Notes

1. The branch destination address must be even.
2. In machine language BRA, BRN, BCC, and BCS are identical to BT, BF, BHS, and BLO, respectively.

### 2.2.8 BCLR

BCLR (Bit CLeaR)
Bit Clear

## Operation

$0 \rightarrow(<$ bit No.> of $<\mathrm{EAd}>)$

## Assembly-Language Format

BCLR \#xx:3, <EAd>
BCLR Rn, <EAd>

## Operand Size

Byte

## 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 register Rn. The specified bit is not tested. The condition-code flags are not altered.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Rn: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BCLR | \#xx:3, Rd | 7 | 2 | 0 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BCLR | \#xx:3, @ERd | 7 | D | 0 erd | 0 | 7 | 2 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BCLR | \#xx:3, @aa:8 | 7 | F | ab |  | 7 | 2 | 0 OIMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BCLR | \#xx:3, @aa:16 | 6 | A | 1 | 8 |  |  | bs |  | 7 | 2 | 0 IMM |  |  |  |  |  | 5 |
| Absolute address | BCLR | \#xx:3, @aa:32 | 6 | A | 3 | 8 |  |  |  |  |  |  |  |  | 7 | 2 | 0 :IMM | 0 | 6 |
| Register direct | BCLR | Rn, Rd | 6 | 2 | rn | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BCLR | Rn, @ERd | 7 | D | 0 erd | 0 | 6 | 2 | rn | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BCLR | Rn, @aa:8 | 7 | F | ab |  | 6 | 2 | rn | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BCLR | Rn, @aa:16 | 6 | A | 1 | 8 |  |  | bs |  | 6 | 2 | rn | 0 |  |  |  |  | 5 |
| Absolute address | BCLR | Rn, @aa:32 | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 6 | 2 | rn | 0 | 6 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.9 BIAND

BIAND (Bit Invert AND)
Bit Logical AND

## Operation

$\mathrm{C} \wedge[\neg(<$ bit No. $>$ of $<\mathrm{EAd}>)] \rightarrow \mathrm{C}$

## Assembly-Language Format

BIAND \#xx:3,<EAd>

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.
Operand Format and Number of States Required for Execution

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.10 BILD

BILD (Bit Invert LoaD)
Bit Load

## Operation

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

## Assembly-Language Format

BILD \#xx:3,<EAd>

## Operand Size

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

H : Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Loaded with the inverse of the specified bit.

Byte

## Description

This instruction loads the inverse of a specified bit from the destination operand into the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BILD | \#xx:3, Rd | 7 | 7 | 1 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BILD | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 7 | 1 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BILD | \#xx:3, @aa:8 | 7 | E | ab |  | 7 | 7 | 1 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BILD | \#xx:3, @aa:16 | 6 | A | 1 | 0 |  |  | bs |  | 7 | 7 | 1 IMM | 0 |  |  |  |  | 4 |
| Absolute address | BILD | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 7 | 1 IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.11 BIOR

BIOR (Bit Invert inclusive OR)
Bit Logical OR

## Operation

$\mathrm{C} \vee[\neg(<$ bit No. $>$ of $<\mathrm{EAd}>)] \rightarrow \mathrm{C}$

## Assembly-Language Format

BIOR \#xx:3,<EAd>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\imath$ |

H : Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.

## Operand Size

Byte

## Description

This instruction ORs the inverse of a specified bit in the destination operand with the carry flag and stores the result in the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing | Mnemonic |  |  |  |  |  |  |  | Inst | uct | F |  |  |  |  |  |  |  | No. of |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode* | Mnemonic | Operands |  |  | 2nd |  |  |  | 4th |  |  |  | 6th b |  |  |  | 8th |  | States |
| Register direct | BIOR | \#xx:3, Rd | 7 | 4 | 1 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BIOR | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 4 | 1:IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BIOR | \#xx:3, @aa:8 | 7 | E | abs |  | 7 | 4 | 1:IM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BIOR | \#xx:3, @aa:16 | 6 | A | 1 | 0 | abs |  |  |  | 7 | 4 | 1 IMM |  |  |  |  |  | 4 |
| Absolute address | BIOR | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 4 | 1:IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.12 BIST

BIST (Bit Invert STore)
Bit Store

## Operation

$\neg \mathrm{C} \rightarrow$ (<bit No. $>$ of $<\mathrm{EAd}>$ )

## Assembly-Language Format

BIST \#xx:3,<EAd>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

Byte

## Description

This instruction stores the inverse of the carry flag in a specified bit location in the destination operand. The bit number is specified by 3-bit immediate data. Other bits in the destination operand remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BIST | \#xx:3, Rd | 6 | 7 | 1 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BIST | \#xx:3, @ERd | 7 | D | 0 erd | 0 | 6 | 7 | 1 IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BIST | \#xx:3, @aa:8 | 7 | F | ab |  | 6 | 7 | 1 IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BIST | \#xx:3, @aa:16 | 6 | A | 1 | 8 |  |  | s |  | 6 | 7 | 1 IMM |  |  |  |  |  | 5 |
| Absolute address | BIST | \#xx:3, @aa:32 | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 6 | 7 | $1 \mathrm{IIMM}^{\text {a }}$ | 0 | 6 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.13 BIXOR

BIXOR (Bit Invert eXclusive OR)

## Operation

$\mathrm{C} \oplus[\neg(<$ bit No. $>$ of $\langle\mathrm{EAd}\rangle)] \rightarrow \mathrm{C}$

## Assembly-Language Format

BIXOR \#xx:3,<EAd>

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

$\mathrm{H}:$ Previous value remains unchanged.
N: Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.

## Description

This instruction exclusively ORs the inverse of a specified bit in the destination operand with the carry flag and stores the result in the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.14 BLD

BLD (Bit LoaD)
Bit Load

## Operation

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

## Assembly-Language Format

BLD \#xx:3,<EAd>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\mathfrak{\downarrow}$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Loaded from the specified bit.

## Operand Size

Byte

## Description

This instruction loads a specified bit from the destination operand into the carry flag. The bit number is specified by 3 -bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BLD | \#xx:3, Rd | 7 | 7 | OIMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BLD | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 7 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BLD | \#xx:3, @aa:8 | 7 | E | abs |  | 7 | 7 | OIMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BLD | \#xx:3, @aa:16 | 6 | A | 1 | 0 |  |  | bs |  | 7 | 7 | 0:IMM | 0 |  |  |  |  | 4 |
| Absolute address | BLD | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 7 | 0 IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.15 BNOT

BNOT (Bit NOT)
Bit NOT

## Operation

$\neg(<$ bit No. $>$ of $<$ EAd $>) \rightarrow$ (bit No. of $<\mathrm{EAd}>$ )

## Assembly-Language Format

BNOT \#xx:3,<EAd>
BNOT Rn, <EAd>

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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 inverts a specified bit in the destination operand. The bit number is specified by 3bit immediate data or by the lower 3 bits of an 8 -bit register Rn . The specified bit is not tested.
The condition code remains unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Rn: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BNOT | \#xx:3, Rd | 7 | 1 | OIMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BNOT | \#xx:3, @ERd | 7 | D | 0 erd | 0 | 7 | 1 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BNOT | \#xx:3, @aa:8 | 7 | F | ab |  | 7 | 1 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BNOT | \#xx:3, @aa:16 | 6 | A | 1 | 8 |  |  | s |  | 7 | 1 | 0 IMM | 0 |  |  |  |  | 5 |
| Absolute address | BNOT | \#xx:3, @aa:32 | 6 | A | 3 | 8 |  |  |  |  |  |  |  |  | 7 | 1 | OIMM | 0 | 6 |
| Register direct | BNOT | Rn, Rd | 6 | 1 | rn | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BNOT | Rn, @ERd | 7 | D | 0 erd | 0 | 6 | 1 | rn | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BNOT | Rn, @aa:8 | 7 | F | ab |  | 6 | 1 | rn | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BNOT | Rn, @aa:16 | 6 | A | 1 | 8 |  |  | s |  | 6 | 1 | rn | 0 |  |  |  |  | 5 |
| Absolute address | BNOT | Rn, @aa:32 | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 6 | 1 | rn | 0 | 6 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.16 BOR

BOR (Bit inclusive OR)
Bit Logical OR

## Operation

C $\vee(<$ bit No. $>$ of $<\mathrm{EAd}>) \rightarrow \mathrm{C}$

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

H : Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.

## Operand Size

Byte

## Description

This instruction ORs a specified bit in the destination operand with the carry flag and stores the result in the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing | Mnemonic |  |  |  |  |  |  |  | Inst | uct | F |  |  |  |  |  |  |  | . of |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode* | Mnemonic | ds |  |  | 2nd |  |  |  | 4th |  |  |  | 6th |  |  |  | 8th |  | States |
| Register direct | BOR | \#xx:3, Rd | 7 | 4 | 0 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BOR | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 4 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BOR | \#xx:3, @aa:8 | 7 | E | abs |  | 7 | 4 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BOR | \#xx:3, @aa:16 | 6 | A | 1 | 0 | abs |  |  |  | 7 | 4 | 0:IMM |  |  |  |  |  | 4 |
| Absolute address | BOR | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 4 | 0 IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.17 BSET

BSET (Bit SET)
Bit Set

## Operation

$1 \rightarrow(<$ bit No.> of <EAd>)

## Assembly-Language Format

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

## Operand Size

Byte

## 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 register Rn. The specified bit is not tested. The condition code flags are not altered.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Rn: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BSET | \#xx:3, Rd | 7 | 0 | 0 IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BSET | \#xx:3, @ERd | 7 | D | 0 erd | 0 | 7 | 0 | O:IMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BSET | \#xx:3, @aa:8 | 7 | F | ab |  | 7 | 0 | OIMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BSET | \#xx:3, @aa:16 | 6 | A | 1 | 8 |  |  | b |  | 7 | 0 | 0 IMM | 0 |  |  |  |  | 5 |
| Absolute address | BSET | \#xx:3, @aa:32 | 6 | A | 3 | 8 |  |  |  |  |  |  |  |  | 7 | 0 | 0 IMM | 0 | 6 |
| Register direct | BSET | Rn, Rd | 6 | 0 | rn | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BSET | Rn, @ERd | 7 | D | 0 erd | 0 | 6 | 0 |  | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BSET | Rn, @aa:8 | 7 | F | ab |  | 6 | 0 |  | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BSET | Rn, @aa:16 | 6 | A | 1 | 8 |  |  | b |  | 6 | 0 | rn | 0 |  |  |  |  | 5 |
| Absolute address | BSET | Rn, @aa:32 | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 6 | 0 | rn | 0 | 6 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.18 BSR

BSR (Branch to SubRoutine)
Branch to Subroutine

## Operation

PC $\rightarrow$ @-SP
$\mathrm{PC}+\operatorname{disp} \rightarrow \mathrm{PC}$

## Assembly-Language Format

BSR disp

Operand Size

Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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.
$\qquad$

## Description

This instruction branches to a subroutine at a specified address. It pushes the program counter (PC) value onto the stack as a restart address, then adds a specified displacement to the PC value and branches to the resulting address. The PC value pushed onto the stack is the address of the instruction following the BSR instruction. The displacement is a signed 8-bit or 16-bit value, so the possible branching range is -126 to +128 bytes or -32766 to +32768 bytes from the address of the BSR instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 2st byte | 2nd byte | 3rd byte | 4th byte | Normal | Advanced |  |
| Program-counter <br> relative | BSR | $\mathrm{d}: 8$ | 5 | 5 | disp |  |  | 3 | 4 |
|  |  | $\mathrm{~d}: 16$ | 5 | C | 0 | 0 | disp | 4 | 5 |

## Notes

The stack structure differs between normal mode and advanced mode. In normal mode only the lower 16 bits of the program counter are pushed onto the stack.

Ensure that the branch destination address is even.


### 2.2.19 BST

BST (Bit STore)
Bit Store

## Operation

$\mathrm{C} \rightarrow(<$ bit No. $>$ of $<\mathrm{EAd}>$ )

## Assembly-Language Format

BST \#xx:3,<EAd>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

Byte

## Description

This instruction stores the carry flag in a specified bit location in the destination operand. The bit number is specified by 3-bit immediate data.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BST | \#xx:3, Rd | 6 | 7 | 0:IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BST | \#xx:3, @ERd | 7 | D | 0 erd | 0 | 6 | 7 | 0 OIMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BST | \#xx:3, @aa:8 | 7 | F | ab |  | 6 | 7 | 0 OIMM | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | BST | \#xx:3, @aa:16 | 6 | A | 1 | 8 |  |  | bs |  | 6 | 7 | 0:IMM |  |  |  |  |  | 5 |
| Absolute address | BST | \#xx:3, @aa:32 | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 6 | 7 | 0:IMM | 0 | 6 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

### 2.2.20 BTST

BTST (Bit TeST)
Bit Test

## Operation

$\neg(<$ Bit No $>$ of $<$ EAd $>) \rightarrow \mathrm{Z}$

## Assembly-Language Format

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

## Operand Size

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | $\hat{\downarrow}$ | - | - |

H: Previous value remains unchanged.
$\mathrm{N}:$ Previous value remains unchanged.
Z: Set to 1 if the specified bit is zero; otherwise cleared to 0 .
V: Previous value remains unchanged.
C: Previous value remains unchanged.

Byte

## Description

This instruction tests a specified bit in the destination operand and sets or clears the zero flag according to the result. The bit number can be specified by 3-bit immediate data, or by the lower three bits of an 8 -bit register Rn. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Rn: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing Mode* | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |  |
| Register direct | BTST | \#xx:3, Rd | 7 | 3 | OIMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BTST | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 3 | OIMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BTST | \#xx:3, @aa:8 | 7 | E | ab |  | 7 | 3 | 0 OLMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BTST | \#xx:3, @aa:16 | 6 | A | 1 | 0 |  |  |  |  | 7 | 3 | 0 IMM |  |  |  |  |  | 4 |
| Absolute address | BTST | \#xx:3, @aa:32 | 6 | A | 3 | 0 |  |  |  |  |  |  |  |  | 7 | 3 | 0 IMM | 0 | 5 |
| Register direct | BTST | Rn, Rd | 6 | 3 |  | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BTST | Rn, @ERd | 7 | C | 0 erd | 0 | 6 | 3 | rn | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BTST | Rn, @aa:8 | 7 | E | ab |  | 6 | 3 |  | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BTST | Rn, @aa:16 | 6 | A | 1 | 0 |  |  | s |  | 6 | 3 |  | 0 |  |  |  |  | 4 |
| Absolute address | BTST | Rn, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 6 | 3 | rn | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.

### 2.2.21 BXOR

BXOR (Bit eXclusive OR)

## Operation

$\mathrm{C} \oplus(<$ bit No $>$ of $\langle\mathrm{EAd}\rangle) \rightarrow \mathrm{C}$

## Assembly-Language Format

BXOR \#xx:3,<EAd>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\downarrow$ |

H : Previous value remains unchanged.
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Stores the result of the operation.

## Operand Size

Byte

## Description

This instruction exclusively ORs a specified bit in the destination operand with the carry flag and stores the result in the carry flag. The bit number is specified by 3-bit immediate data. The destination operand contents remain unchanged.


## Available Registers

Rd: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing | Mnemonic |  |  |  |  |  |  |  | Inst | uct | For |  |  |  |  |  |  |  | No. of |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode* |  | erands |  |  | 2nd b |  |  |  | 4th |  |  |  | 6th b |  |  |  | 8th |  | States |
| Register direct | BXOR | \#xx:3, Rd | 7 | 5 | OIMM | rd |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| Register indirect | BXOR | \#xx:3, @ERd | 7 | C | 0 erd | 0 | 7 | 5 | 0 OIMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BXOR | \#xx:3, @aa:8 | 7 | E | abs |  | 7 | 5 | 0 IMM | 0 |  |  |  |  |  |  |  |  | 3 |
| Absolute address | BXOR | \#xx:3, @aa:16 | 6 | A | 1 | 0 | abs |  |  |  | 7 | 5 | 0 IMM | 0 |  |  |  |  | 4 |
| Absolute address | BXOR | \#xx:3, @aa:32 | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 5 | 0 IMM | 0 | 5 |

Note: * The addressing mode is the addressing mode of the destination operand <EAd>.
Notes
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.
2.2.22 CLRMAC

CLRMAC (CLeaR MAC register)
Initialize Multiply-Accumulate Register

## Operation

$0 \rightarrow \mathrm{MACH}, \mathrm{MACL}$

## Assembly-Language Format

CLRMAC

Operand Size

Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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.
$\qquad$

## Description

This instruction simultaneously clears registers MACH and MACL.
It is supported only by the H8S/2600 CPU .

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| - | CLRMAC | - | 0 | 1 | A | 0 |  |  |
| $2^{*}$ |  |  |  |  |  |  |  |  |

Note: * A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

## Notes

Execution of this instruction also clears the overflow flag in the multiplier to 0 .
2.2.23 (1) CMP (B)

CMP (CoMPare)
Compare

## Operation

Rd - (EAs), set/clear CCR

## Assembly-Language Format

CMP.B <EAs>, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

H: Set to 1 if there is a borrow at bit 3; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 7 ; otherwise cleared to 0 .

## Description

This instruction subtracts the source operand from the contents of an 8-bit register Rd (destination operand) and sets or clears the condition code bits according to the result. The contents of the 8-bit register Rd remain unchanged.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | }{States} |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | CMP.B | \#xx:8, Rd | A | rd | IMM |  |  | 1 |
| Register direct | CMP.B | Rs, Rd | 1 | C | rs | rd |  |  |

## Notes

2.2.23 (2) CMP (W)

CMP (CoMPare)
Compare

## Operation

Rd - (EAs), set/clear CCR

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\downarrow$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

## Assembly-Language Format

CMP.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}: \quad$ Set to 1 if there is a borrow at bit 11 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 15 ; otherwise cleared to 0 .

## Description

This instruction subtracts the source operand from the contents of a 16-bit register Rd (destination operand) and sets or clears the condition code bits according to the result. The contents of the 16bit register Rd remain unchanged.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Immediate | CMP.W | \#xx:16, Rd | 7 | 9 | 2 | rd |  |  | 2 |
| Register direct | CMP.W | Rs, Rd | 1 | D | rs | rd |  |  | 1 |

## Notes

### 2.2.23 (3) CMP (L)

CMP (CoMPare)
Compare

## Operation

ERd - (EAs), set/clear CCR

## Assembly-Language Format

CMP.L <EAs>, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: \quad$ Set to 1 if there is a borrow at bit 27 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 31 ; otherwise cleared to 0 .

## Description

This instruction subtracts the source operand from the contents of a 32-bit register ERd (destination operand) and sets or clears the condition code bits according to the result. The contents of the 32-bit register ERd remain unchanged.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte | 5th byte | 6th byte |  |
| Immediate | CMP.L | \#xx:32, ERd | 7 | A | 2 | 0 erd |  |  |  |  | 3 |
| Register direct | CMP.L | ERs, ERd | 1 | F | 1 ers | 0 erd |  |  |  |  | 1 |

## Notes

2.2.24 DAA

DAA (Decimal Adjust Add)
Decimal Adjust

## Operation

Rd (decimal adjust) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

DAA Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $*$ | - | $\imath$ | $\imath$ | $*$ | $\imath$ |

$\mathrm{H}: \quad$ Undetermined (no guaranteed value).
N : Set to 1 if the adjusted result is negative; otherwise cleared to 0 .
Z : Set to 1 if the adjusted result is zero; otherwise cleared to 0 .
V: Undetermined (no guaranteed value).
C: Set to 1 if there is a carry at bit 7 ; otherwise left unchanged.

## Description

Given that the result of an addition operation performed by an ADD.B or ADDX instruction on 4-bit BCD data is contained in an 8-bit register Rd and the carry and half-carry flags, the DAA instruction adjusts the contents of the 8 -bit register Rd (destination operand) by adding $\mathrm{H}^{\prime} 00, \mathrm{H}^{\prime} 06$, $\mathrm{H}^{\prime} 60$, or $\mathrm{H}^{\prime} 66$ according to the table below.

| C Flag <br> before <br> Adjustment | Upper 4 Bits <br> before <br> Adjustment | H Flag <br> before <br> Adjustment | Lower 4 Bits <br> before <br> Adjustment | Value <br> Added <br> (Hexadecimal) | C Flag <br> after <br> Adjustment |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 to 9 | 0 | 0 to 9 | 00 | 0 |
| 0 | 0 to 8 | 0 | A to F | 06 | 0 |
| 0 | 0 to 9 | 1 | 0 to 3 | 06 | 0 |
| 0 | A to F | 0 | 0 to 9 | 60 | 1 |
| 0 | 9 to F | 0 | A to F | 66 | 1 |
| 0 | A to F | 1 | 0 to 3 | 66 | 1 |
| 1 | 0 to 2 | 0 | 0 to 9 | 60 | 1 |
| 1 | 0 to 2 | 0 | A to F | 66 | 1 |
| 1 | 0 to 3 | 1 | 0 to 3 | 66 | 1 |

DAA (Decimal Adjust Add)
Decimal Adjust
Available Registers
Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Register direct | DAA | Rd | 0 | F | 0 | rd |  |  | 1 |

## Notes

Valid results (8-bit register Rd contents and $\mathrm{C}, \mathrm{V}, \mathrm{Z}, \mathrm{N}$, and H flags) are not assured if this instruction is executed under conditions other than those described above.

### 2.2.25 DAS

DAS (Decimal Adjust Subtract)
Decimal Adjust

## Operation

Rd (decimal adjust) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
DAS Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $*$ | - | $\downarrow$ | $\imath$ | $*$ | 0 |

H: Undetermined (no guaranteed value).
N : Set to 1 if the adjusted result is negative; otherwise cleared to 0 .
Z: Set to 1 if the adjusted result is zero; otherwise cleared to 0 .
V: Undetermined (no guaranteed value).
C: Previous value remains unchanged.

## Description

Given that the result of a subtraction operation performed by a SUB.B, SUBX.B, or NEG.B instruction on 4-bit BCD data is contained in an 8-bit register Rd and the carry and half-carry flags, the DAS instruction adjusts the contents of the 8-bit register Rd (destination operand) by adding $\mathrm{H}^{\prime} 00, \mathrm{H}^{\prime} \mathrm{FA}, \mathrm{H}^{\prime} \mathrm{A} 0$, or $\mathrm{H}^{\prime} 9 \mathrm{~A}$ according to the table below.

| C Flag <br> before <br> Adjustment | Upper 4 Bits <br> before <br> Adjustment | H Flag <br> before <br> Adjustment | Lower 4 Bits <br> before <br> Adjustment | Value <br> Added <br> (Hexadecimal) | C Flag <br> after <br> Adjustment |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 to 9 | 0 | 0 to 9 | 00 | 0 |
| 0 | 0 to 8 | 1 | 6 to F | FA | 0 |
| 1 | 7 to F | 0 | 0 to 9 | A0 | 1 |
| 1 | 6 to F | 1 | 6 to F | 9 A | 1 |

Available Registers
Rd: R0L to R7L, R0H to R7H

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | DAS | Rd | 1 | F | 0 | rd |  |  | 1 |

## Notes

Valid results (8-bit register Rd contents and $\mathrm{C}, \mathrm{V}, \mathrm{Z}, \mathrm{N}$, and H flags) are not assured if this instruction is executed under conditions other than those described above.
2.2.26 (1) DEC (B)

DEC (DECrement)
Decrement

## Operation

$\mathrm{Rd}-1 \rightarrow \mathrm{Rd}$

## Assembly-Language Format

DEC.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0.
C: Previous value remains unchanged.

## Description

This instruction decrements an 8-bit register Rd (destination operand) and stores the result in the 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | DEC.B | Rd | 1 | A | 0 | rd |  |  | 1 |

## Notes

An overflow is caused by the operation $\mathrm{H}^{\prime} 80-1 \rightarrow \mathrm{H}^{\prime} 7 \mathrm{~F}$.
2.2.26 (2) DEC (W)

DEC (DECrement)
Decrement

## Operation

$\mathrm{Rd}-1 \rightarrow \mathrm{Rd}$
$\mathrm{Rd}-2 \rightarrow \mathrm{Rd}$

## Assembly-Language Format

DEC.W \#1, Rd
DEC.W \#2, Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0.
C: Previous value remains unchanged.

## Description

This instruction subtracts the immediate value 1 or 2 from the contents of a 16 -bit register Rd (destination operand) and stores the result in the 16-bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | DEC.W | \#1, Rd | 1 | B | 5 | rd |  |  | 1 |
| Register direct | DEC.W | \#2, Rd | 1 | B | D | rd |  |  | 1 |

## Notes

An overflow is caused by the operations H'8000 - $1 \rightarrow \mathrm{H}^{\prime} 7 \mathrm{FFF}, \mathrm{H}^{\prime} 8000-2 \rightarrow \mathrm{H}^{\prime} 7 \mathrm{FFE}$, and H'8001 - $2 \rightarrow$ H'7FFF.
2.2.26 (3) DEC (L)

DEC (DECrement)
Decrement

## Operation

ERd - $1 \rightarrow$ ERd
ERd - $2 \rightarrow$ ERd

## Assembly-Language Format

DEC.L \#1, ERd
DEC.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction subtracts the immediate value 1 or 2 from the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |  |
| Register direct | DEC.L | \#1, ERd | 1 | B | 7 | 0 | erd |  |  | 1 |
| Register direct | DEC.L | \#2, ERd | 1 | B | F | 0 | erd |  |  | 1 |

## Notes

An overflow is caused by the operations H'80000000-1 $\rightarrow$ H'7FFFFFFF, H'80000000 - $2 \rightarrow$
$H^{\prime} 7 F F F F F F E$, and $\mathrm{H}^{\prime} 80000001-2 \rightarrow \mathrm{H}^{\prime} 7$ FFFFFFF.
2.2.27 (1) DIVXS (B)

DIVXS (DIVide eXtend as Signed)
Divide Signed

## Operation

$\mathrm{Rd} \div \mathrm{Rs} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

DIVXS.B Rs, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the quotient is negative; otherwise cleared to 0 .
Z: Set to 1 if the divisor is zero; otherwise cleared to 0.
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Description

This instruction divides the contents of a 16-bit register Rd (destination operand) by the contents of an 8-bit register Rs (source operand) and stores the result in the 16-bit register Rd. The division is signed. The operation performed is 16 bits $\div 8$ bits $\rightarrow 8$-bit quotient and 8 -bit remainder. The quotient is placed in the lower 8 bits of Rd . The remainder is placed in the upper 8 bits of Rd . The sign of the remainder matches the sign of the dividend.

| Rd | Rs |  |
| :---: | :---: | :---: | :---: |
| Dividend | Rd |  |
| 16 bits | $\rightarrow$Remainder Quotient <br> 8 bits 8 bits <br> 8  |  |

Valid results are not assured if division by zero is attempted or an overflow occurs.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |  |
|  | DIVXS.B | Rs, Rd | 0 | 1 | D | 0 | 5 | 1 | rs | rd |

## Notes

The N flag is set to 1 if the dividend and divisor have different signs, and cleared to 0 if they have the same sign. The N flag may therefore be set to 1 when the quotient is zero.
2.2.27 (2) DIVXS (W)

DIVXS (DIVide eXtend as Signed)
Divide Signed

## Operation

ERd $\div$ Rs $\rightarrow$ ERd

## Assembly-Language Format

DIVXS.W Rs,ERd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the quotient is negative; otherwise cleared to 0 .
Z: Set to 1 if the divisor is zero; otherwise cleared to 0.
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Description

This instruction divides the contents of a 32-bit register ERd (destination operand) by the contents of a 16-bit register Rs (source operand) and stores the result in the 32-bit register ERd. The division is signed. The operation performed is 32 bits $\div 16$ bits $\rightarrow 16$-bit quotient and 16-bit remainder. The quotient is placed in the lower 16 bits $(\mathrm{Rd})$ of the 32-bit register ERd. The remainder is placed in the upper 16 bits (Ed). The sign of the remainder matches the sign of the dividend.

| ERd | Rs |  | ERd |  |
| :---: | :---: | :---: | :---: | :---: |
| Dividend | $\rightarrow$Divisor   <br> 32 bits 16 bits 16 bits |  |  |  |

Valid results are not assured if division by zero is attempted or an overflow occurs.

## Available Registers

ERd: ER0 to ER7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |  |
| Register direct | DIVXS.W | Rs, ERd | 0 | 1 | $D$ | 0 | 5 | 3 | rs | 0 |

## Notes

The N flag is set to 1 if the dividend and divisor have different signs, and cleared to 0 if they have the same sign. The N flag may therefore be set to 1 when the quotient is zero.
2.2.28 (1) DIVXU (B)

DIVXU (DIVide eXtend as Unsigned)
Divide

## Operation

$\mathrm{Rd} \div \mathrm{Rs} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

DIVXU.B Rs, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

H : Previous value remains unchanged.
N : Set to 1 if the divisor is negative; otherwise cleared to 0 .
Z: Set to 1 if the divisor is zero; otherwise cleared to 0.
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Description

This instruction divides the contents of a 16-bit register Rd (destination operand) by the contents of an 8-bit register Rs (source operand) and stores the result in the 16-bit register Rd. The division is unsigned. The operation performed is 16 bits $\div 8$ bits $\rightarrow 8$-bit quotient and 8 -bit remainder. The quotient is placed in the lower 8 bits of Rd. The remainder is placed in the upper 8 bits of Rd.

| Rd | Rs |  |
| :---: | :---: | :---: | :---: |
| Dividend | $\rightarrow$Divisor   <br> 16 bits Remainder Quotient <br> 8 bits 8 bits  |  |

Valid results are not assured if division by zero is attempted or an overflow occurs.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0L to R7L, R0H to R7H

DIVXU (DIVide eXtend as Unsigned)
Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte | Stes |  |
| Register direct | DIVXU.B | Rs, Rd | 5 | 1 | rs | rd |  |  |

Notes
2.2.28 (2) DIVXU (W)

DIVXU (DIVide eXtend as Unsigned)
Divide

## Operation

ERd $\div$ Rs $\rightarrow$ ERd

## Assembly-Language Format

DIVXU.W Rs,ERd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

H : Previous value remains unchanged.
N : Set to 1 if the divisor is negative; otherwise cleared to 0 .
Z: Set to 1 if the divisor is zero; otherwise cleared to 0.
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Description

This instruction divides the contents of a 32-bit register ERd (destination operand) by the contents of a 16-bit register Rs (source register) and stores the result in the 32-bit register ERd. The division is unsigned. The operation performed is 32 bits $\div 16$ bits $\rightarrow 16$-bit quotient and 16-bit remainder. The quotient is placed in the lower 16 bits $(\mathrm{Rd})$ of the 32-bit register ERd. The remainder is placed in the upper 16 bits of (Ed).

| ERd | Rs |  | ERd |  |
| :---: | :---: | :---: | :---: | :---: |
| Dividend | $\rightarrow$Divisor   <br> 32 bits 16 bits 16 bits |  |  |  |

Valid results are not assured if division by zero is attempted or an overflow occurs.

## Available Registers

ERd: ER0 to ER7
Rs: R0 to R7, E0 to E7

DIVXU (DIVide eXtend as Unsigned)
Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | DIVXU.W | Rs, ERd | 5 | 3 | rs | erd |  |  |

Notes

### 2.2.29 (1) EEPMOV (B)

## Operation

if $\mathrm{R} 4 \mathrm{~L} \neq 0$ then
repeat @ER5+ $\rightarrow$ @ER6+ R4L-1 $\rightarrow$ R4L
until R4L $=0$
else next;

## Assembly-Language Format

EEPMOV.B

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

## Description

This instruction performs a block data transfer. It moves data from the memory location specified in ER5 to the memory location specified in ER6, increments ER5 and ER6, decrements R4L, and repeats these operations until R4L reaches zero. Execution then proceeds to the next instruction. The data transfer is performed a byte at a time, with R4L indicating the number of bytes to be transferred. The byte symbol in the assembly-language format designates the size of R4L (and limits the maximum number of bytes that can be transferred to 255). No interrupts are detected while the block transfer is in progress.

When the EEPMOV.B instruction ends, R4L contains 0 (zero), and ER5 and ER6 contain the last transfer address +1 .

## Operand Format and Number of States Required for Execution

| Addressing | M | Operands | Instruction Format |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode | Mnemonic |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |
| - | EEPMOV.B |  | 7 | B | 5 | C | 5 | 9 | 8 | F | $4+2 n^{*}$ |

Note: * n is the initial value of R4L. Although n bytes of data are transferred, $2(\mathrm{n}+1)$ data accesses are performed, requiring $2(n+1)$ states. $(n=0,1,2, \ldots, 255)$.

## Notes

This instruction first reads the memory locations indicated by ER5 and ER6, then carries out the block data transfer.

### 2.2.29 (2) EEPMOV (W)

EEPMOV (MOVe data to EEPROM)
Block Data Transfer

## Operation

if $\mathrm{R} 4 \neq 0$ then
repeat @ER5+ $\rightarrow$ @ER6+ R4-1 $\rightarrow$ R4
until R4 = 0
else next;

## Assembly-Language Format

EEPMOV.W

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

## Description

This instruction performs a block data transfer. It moves data from the memory location specified in ER5 to the memory location specified in ER6, increments ER5 and ER6, decrements R4, and repeats these operations until R4 reaches zero. Execution then proceeds to the next instruction. The data transfer is performed a byte at a time, with R4 indicating the number of bytes to be transferred. The word symbol in the assembly-language format designates the size of R4 (allowing a maximum 65535 bytes to be transferred). All interrupts are detected while the block transfer is in progress.

If no interrupt occurs while the EEPMOV.W instruction is executing, when the EEPMOV.W instruction ends, R4 contains 0 (zero), and ER5 and ER6 contain the last transfer address +1 .

If an interrupt occurs, interrupt exception handling begins after the current byte has been transferred. R4 indicates the number of bytes remaining to be transferred. ER5 and ER6 indicate the next transfer addresses. The program counter value pushed onto the stack in interrupt exception handling is the address of the next instruction after the EEPMOV.W instruction.

See the note on EEPMOV.W instruction and interrupt.

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |  |  |
| - | EEPMOV.W |  | 7 | B | D | 4 | 5 | 9 | 8 | F | $4+2 \mathrm{n}^{*}$ |

Note: * n is the initial value of R4. Although n bytes of data are transferred, $2(\mathrm{n}+1)$ data accesses are performed, requiring $2(n+1)$ states. $(n=0,1,2, \ldots, 65535)$.

## Notes

This instruction first reads memory at the addresses indicated by ER5 and ER6, then carries out the block data transfer.

## EEPMOV.W Instruction and Interrupt

If an interrupt request occurs while the EEPMOV.W instruction is being executed, interrupt exception handling is carried out after the current byte has been transferred. Register contents are then as follows:

ER5: address of the next byte to be transferred
ER6: destination address of the next byte
R4: number of bytes remaining to be transferred
The program counter value pushed on the stack in interrupt exception handling is the address of the next instruction after the EEPMOV.W instruction. Programs should be coded as follows to allow for interrupts during execution of the EEPMOV.W instruction.

## Example:

## L1: EEPMOV.W <br> MOV.W R4,R4 <br> BNE L1

Interrupt requests other than NMI are not accepted if they are masked in the CPU.
During execution of the EEPMOV.B instruction no interrupts are accepted, including NMI.

### 2.2.30 (1) EXTS (W)

EXTS (EXTend as Signed)

## Operation

$(<$ Bit $7>$ of Rd) $\rightarrow$ (<bits 15 to $8>$ of Rd)

## Assembly-Language Format

EXTS.W Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .

Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction copies the sign of the lower 8 bits in a 16-bit register Rd in the upward direction (copies Rd bit 7 to bits 15 to 8 ) to extend the data to signed word data.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | EXTS.W | Rd | 1 | 7 | D | rd |  |  | 1 |

## Notes

2.2.30 (2) EXTS (L)

EXTS (EXTend as Signed)
Sign Extension

## Operation

$(<$ Bit $15>$ of ERd) $\rightarrow$ (<bits 31 to $16>$ of ERd)

## Assembly-Language Format

EXTS.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction copies the sign of the lower 16 bits in a 32-bit register ERd in the upward direction (copies ERd bit 15 to bits 31 to 16) to extend the data to signed longword data.


## Available Registers

ERd: ER0 to ER7

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | EXTS.L | ERd | 1 | 7 | F | erd |  |  |

## Notes

2.2.31 (1) EXTU (W)

EXTU (EXTend as Unsigned)

## Operation

$0 \rightarrow$ (<bits 15 to $8>$ of Rd )

## Assembly-Language Format

EXTU.W Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\downarrow$ | 0 | - |  |

H : Previous value remains unchanged.
N : Always cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0.
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction extends the lower 8 bits in a 16-bit register Rd to word data by padding with zeros. That is, it clears the upper 8 bits of Rd (bits 15 to 8 ) to 0 .


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | EXTU.W | Rd | 1 | 7 | 5 | rd |  |  | 1 |

## Notes

2.2.31 (2) EXTU (L)

EXTU (EXTend as Unsigned)
Zero Extension

## Operation

$0 \rightarrow$ (<bits 31 to $16>$ of ERd)

## Assembly-Language Format

EXTU.L ERd

Operand Size
Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Always cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction extends the lower 16 bits (general register Rd) in a 32-bit register ERd to longword data by padding with zeros. That is, it clears the upper 16 bits of ERd (bits 31 to 16) to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | EXTU.L | ERd | 1 | 7 | 7 | erd |  |  | 1 |

## Notes

2.2.32 (1) INC (B)

INC (INCrement)

## Operation

$\mathrm{Rd}+1 \rightarrow \mathrm{Rd}$

## Assembly-Language Format

INC.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | $\imath$ | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0.
C: Previous value remains unchanged.

## Description

This instruction increments an 8-bit register Rd (destination operand) and stores the result in the 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | INC.B | Rd | 0 | A | 0 | rd |  |  | 1 |

## Notes

An overflow is caused by the operation $\mathrm{H}^{\prime} 7 \mathrm{~F}+1 \rightarrow \mathrm{H}^{\prime} 80$.
2.2.32 (2) INC (W)

INC (INCrement)
Increment

## Operation

$\mathrm{Rd}+1 \rightarrow \mathrm{Rd}$
$\mathrm{Rd}+2 \rightarrow \mathrm{Rd}$

## Assembly-Language Format

INC.W \#1,Rd
INC.W \#2, Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction adds the immediate value 1 or 2 to the contents of a 16-bit register Rd (destination operand) and stores the result in the 16-bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | INC.W | \#1, Rd | 0 | B | 5 | rd |  |  | 1 |
| Register direct | INC.W | \#2, Rd | 0 | $B$ | $D$ | rd |  |  | 1 |

## Notes

An overflow is caused by the operations $\mathrm{H}^{\prime} 7 \mathrm{FFF}+1 \rightarrow \mathrm{H}^{\prime} 8000$, $\mathrm{H}^{\prime} 7 \mathrm{FFF}+2 \rightarrow \mathrm{H}^{\prime} 8001$, and $\mathrm{H}^{\prime} 7 \mathrm{FFE}+2 \rightarrow \mathrm{H}^{\prime} 8000$.
2.2.32 (3) INC (L)

INC (INCrement)

## Operation

ERd $+1 \rightarrow$ ERd
ERd $+2 \rightarrow$ ERd

## Assembly-Language Format

INC.L \#1, ERd
INC.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | $\imath$ | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0.
C: Previous value remains unchanged.

## Description

This instruction adds the immediate value 1 or 2 to the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | INC.L | \#1, ERd | 0 | B | 7 | 0 | erd |  |  |
| Register direct | INC.L | \#2, ERd | 0 | B | F | 0 | erd |  |  |

## Notes

An overflow is caused by the operations H'7FFFFFFF $+1 \rightarrow \mathrm{H}^{\prime} 80000000$, H'7FFFFFFF $+2 \rightarrow$ $\mathrm{H}^{\prime} 80000001$, and $\mathrm{H}^{\prime} 7 \mathrm{FFFFFFE}+2 \rightarrow \mathrm{H}^{\prime} 80000000$.

### 2.2.33 JMP

JMP (JuMP)
Unconditional Branch

## Operation

Effective address $\rightarrow \mathrm{PC}$

## Assembly-Language Format

JMP <EA>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

## Description

This instruction branches unconditionally to a specified effective address.

## Available Registers

ERn: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte | Normal | Advanced |
| Register indirect | JMP | @ERn | 5 | 9 | 0 ern | 0 |  |  | 2 |  |
| Absolute address | JMP | @aa:24 | 5 | A | abs |  |  |  | 3 |  |
| Memory indirect | JMP | @ @aa:8 | 5 | B | ab |  |  |  | 4 | 5 |

## Notes

The structure of the branch address and the number of states required for execution differ between normal mode and advanced mode.

Ensure that the branch destination address is even.

### 2.2.34 JSR

JSR (Jump to SubRoutine)

## Operation

PC $\rightarrow$ @-SP
Effective address $\rightarrow$ PC

## Assembly-Language Format

JSR <EA>

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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.

## Operand Size

## Description

This instruction pushes the program counter onto the stack as a return address, then branches to a specified effective address. The program counter value pushed onto the stack is the address of the instruction following the JSR instruction.

## Available Registers

ERn: ER0 to ER7

## Operand Format and Number of States Required for Execution

| Addressing |  |  |  |  | Instr | uct | Format |  | No. | tates |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  | 2nd b |  | 3rd byte | 4th byte | Normal | Advanced |
| Register indirect | JSR | @ERn | 5 | D | 0 Oern | 0 |  |  | 3 | 4 |
| Absolute address | JSR | @aa:24 | 5 | E | abs |  |  |  | 4 | 5 |
| Memory indirect | JSR | @@aa:8 | 5 | F | abs |  |  |  | 4 | 6 |

## JSR (Jump to SubRoutine)

Jump to Subroutine

## Notes

The stack structure differs between normal mode and advanced mode. In normal mode only the lower 16 bits of the program counter are pushed onto the stack.

Ensure that the branch destination address is even.

2.2.35 (1) LDC (B)

LDC (LoaD to Control register)
Load CCR

## Operation

$<$ EAs $>\rightarrow$ CCR

## Assembly-Language Format

LDC.B <EAs>, CCR

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Loaded from the corresponding bit in the source operand.
H : Loaded from the corresponding bit in the source operand.
N : Loaded from the corresponding bit in the source operand.
Z: Loaded from the corresponding bit in the source operand.
V: Loaded from the corresponding bit in the source operand.
C: Loaded from the corresponding bit in the source operand.

## Description

This instruction loads the source operand contents into the condition-code register (CCR).
No interrupt requests, including NMI, are accepted immediately after execution of this instruction.

## Available Registers

Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Immediate | LDC.B | \#xx:8, CCR | 0 | 7 | IMM |  |  |  | 1 |
| Register direct | LDC.B | Rs, CCR | 0 | 3 | 0 | rs |  |  | 1 |

## Notes

2.2.35 (2) LDC (B)

LDC (LoaD to Control register)
Load EXR

## Operation

$<$ EAs> $\rightarrow$ EXR

## Assembly-Language Format

LDC.B <EAs>,EXR

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Previous value remains unchanged.
Z: Previous value remains unchanged.
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Operand Size

Byte

## Description

This instruction loads the source operand contents into the extended control register (EXR).
No interrupt requests, including NMI, are accepted for three states after execution of this instruction.

## Available Registers

Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Immediate | LDC.B | \#xx:8, EXR | 0 | 1 | 4 | 1 | 0 | 7 | IMM | 2 |
| Register direct | LDC.B | Rs, EXR | 0 | 3 | 1 | rs |  |  |  | 1 |

## Notes

2.2.35 (3) LDC (W)

LDC (LoaD to Control register)
Load CCR

Operation
(EAs) $\rightarrow$ CCR

Assembly-Language Format
LDC.W <EAs>, CCR

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Loaded from the corresponding bit in the source operand.
H: Loaded from the corresponding bit in the source operand.
N : Loaded from the corresponding bit in the source operand.
Z: Loaded from the corresponding bit in the source operand.
V: Loaded from the corresponding bit in the source operand.
C: Loaded from the corresponding bit in the source operand.

## Description

This instruction loads the source operand contents into the condition-code register (CCR).
Although CCR is a byte register, the source operand is word size. The contents of the even address are loaded into CCR.

No interrupt requests, including NMI, are accepted immediately after execution of this instruction.

## Available Registers

ERs: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte | 8th byte | 9th byte | 10th byte |  |
| Register indirect | LDC.W | @ERs, CCR | 0 | 1 | 4 | 0 | 6 | 9 | 0 ers | 0 |  |  |  |  |  |  |  |  | 3 |
| Register indirect with | LDC.W | @(d:16, ERs), CCR | 0 | 1 | 4 | 0 | 6 | F | 0 ers | 0 |  |  |  |  |  |  |  |  | 4 |
|  | LDC.W | @(d:32, ERs), CCR | 0 | 1 | 4 | 0 | 7 | 8 | 0 ers | 0 | 6 | B | 2 | 0 |  |  |  |  | 6 |
| Register indirect with postincrement | LDC.W | @ERs+, CCR | 0 | 1 | 4 | 0 | 6 | D | 0 ers | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | LDC.W | @aa:16, CCR | 0 | 1 | 4 | 0 | 6 | B | 0 | 0 | abs |  |  |  |  |  |  |  | 4 |
|  | LDC.W | @aa:32, CCR | 0 | 1 | 4 | 0 | 6 | B | 2 | 0 | abs |  |  |  |  |  |  |  | 5 |

Notes
2.2.39 (1) MOV (B)

MOV (MOVe data)

## Operation

$\mathrm{Rs} \rightarrow \mathrm{Rd}$

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

MOV.B Rs, Rd

## Operand Size

Byte

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers one byte of data from an 8-bit register Rs to an 8-bit register Rd, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rs: R0L to R7L, R0H to R7H
Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | MOV.B | Rs, Rd | 0 | C | rs | rd |  |  | 1 |

## Notes

2.2.39 (2) MOV (W)

MOV (MOVe data)
Move

## Operation

$\mathrm{Rs} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

MOV.W Rs, Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |  |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers one word of data from a 16-bit register Rs to a 16-bit register Rd, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | MOV.W | Rs, Rd | 0 | D | rs | rd |  |  | 1 |

## Notes

2.2.39 (3) MOV (L)

MOV (MOVe data)

## Operation

ERs $\rightarrow$ ERd

Assembly-Language Format
MOV.L ERs, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers one word of data from a 32 -bit register ERs to a 32 -bit register ERd, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

## Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  |  | 3rd byte | 4th byte |  |
| Register direct | MOV.L | ERs, ERd | 0 | F | 1 | ers 0 | 0 erd |  |  | 1 |

## Notes

2.2.39 (4) MOV (B)

MOV (MOVe data)
Move

## Operation

(EAs) $\rightarrow$ Rd

Assembly-Language Format
MOV.B <EAs>, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the source operand contents to an 8-bit register Rd, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rd: R0L to R7L, R0H to R7H
ERs: ER0 to ER7
Operand Format and Number of States Required for Execution

|  | - | $\sim$ | ल | $\llcorner$ | ल | ~ | ल | * |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\frac{0.0}{0}$ |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | $\begin{aligned} & \stackrel{\circ}{\sigma} \end{aligned}$ |
|  |  |  |  |  |  |  |  |  |
|  |  |  | $\frac{0}{0}$ |  |  |  | $\frac{\sim}{\sim}$ |  |
|  |  |  |  | $\varangle$ <br> $\omega$ |  |  |  |  |
|  |  | ㅁ | 믄 | $\bigcirc$ | 믄 | $\stackrel{\sim}{\infty}$ | 믄 | 끈 |
|  | $\geqq$ | $\frac{\omega}{\omega}$ | $\frac{\oplus}{\omega}$ | $\frac{\omega}{\omega}$ | $\frac{\omega}{\Phi}$ |  | $\bigcirc$ | N |
|  |  | 0 | - | - | $\bigcirc$ |  |  |  |
|  | 믄 | $\infty$ | ш | $\infty$ | 0 | 믄 | $\varangle$ | $<$ |
|  | น | $\bullet$ | $\bullet$ | N | $\omega$ | $\sim$ | $\bullet$ | $\bullet$ |
| 응 픙 응 |  |  |  |  |  |  |  |  |
|  | $\stackrel{\infty}{\stackrel{\infty}{\mathrm{O}}}$ | $\stackrel{\infty}{\text { D }}$ | $\stackrel{\infty}{\stackrel{\infty}{\gtrless}}$ | $\stackrel{\infty}{\text { Dì }}$ | $\stackrel{\infty}{\stackrel{\infty}{\gtrless}}$ | $\stackrel{\infty}{\stackrel{\infty}{\Sigma}}$ | $\begin{aligned} & \infty \\ & \stackrel{\infty}{\text { O}} \\ & \sum \end{aligned}$ | $\stackrel{\infty}{\text { ® }}$ |
|  |  |  |  |  |  |  |  |  |

Notes
The MOV.B @ER7+, Rd instruction should never be used, because it leaves an odd value in the stack pointer (ER7). For details refer to section 3.3 , Exception-Handling State, or to the relevant hardware manual.
For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.
2.2.39 (5) MOV (W)

MOV (MOVe data)
Move

## Operation

(EAs) $\rightarrow$ Rd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

MOV.W <EAs>, Rd

## Operand Size

Word

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the source operand contents to a 16-bit register Rd, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rd: R0 to R7, E0 to E7
ERs: ER0 to ER7
Operand Format and Number of States Required for Execution

|  | $\sim$ | N | $\cdots$ | $\llcorner$ | m | ल | + |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\frac{0.0}{0}$ |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  | $\begin{aligned} & \text { n } \\ & \text { n } \end{aligned}$ |
|  |  |  |  |  |  |  |  |
|  | $\sum_{\sum}^{\sum}$ |  | $\frac{0.0}{0}$ |  |  | $\begin{aligned} & \text { n } \\ & \text { م } \end{aligned}$ |  |
|  |  |  |  | $\oplus$ <br> $\omega$ |  |  |  |
|  | 믄 | ㅁ | ㅁ | $\bigcirc$ | ㅁ | 믄 | 민 |
|  | $\bigcirc$ | $\frac{\mathscr{\omega}}{\omega}$ | $\stackrel{\oplus}{\square}$ | $\frac{\infty}{\omega}$ | $\stackrel{(9}{ \pm}$ | $\bigcirc$ | $\sim$ |
|  |  | - | - | 0 | 0 |  |  |
|  | $\sigma$ | の | レ | $\infty$ | $\bigcirc$ | $\infty$ | $\infty$ |
|  | $\checkmark$ | $\bullet$ | $\omega$ | N | $\omega$ | $\omega$ | $\bullet$ |
| 응 픙 응 |  |  |  |  |  | $\begin{aligned} & \underset{\Upsilon}{\square} \\ & \dot{6} \\ & \dot{\widetilde{\sigma}} \\ & \text { (8) } \end{aligned}$ |  |
|  | $\stackrel{>}{3}$ | $\underset{\substack{0}}{3}$ | $\underset{\substack{0}}{3}$ | $\begin{aligned} & 3 \\ & \gg \\ & \sum \\ & \hline \end{aligned}$ | $\begin{aligned} & 3 \\ & \underset{\sum}{0} \end{aligned}$ | $\underset{\substack{0}}{>}$ | $\stackrel{3}{3}$ |
|  | $\begin{aligned} & \stackrel{0}{\stackrel{0}{0}} \\ & \stackrel{0}{0} \\ & \stackrel{0}{E} \\ & \underline{E} \end{aligned}$ |  |  |  |  |  |  |

[^1]2.2.39 (6) MOV (L)

MOV (MOVe data)

## Operation

(EAs) $\rightarrow$ ERd

## Assembly-Language Format

MOV.L <EAs>, ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the source operand contents to a specified 32-bit register (ERd), tests the transferred data, and sets condition-code flags according to the result. The first memory word located at the effective address is stored in extended register Ed. The next word is stored in general register Rd.


## Available Registers

ERs: ER0 to ER7
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

|  | の | * | $\sim$ | $\wedge$ | ๑ | $\llcorner$ | $\bullet$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\frac{0}{0}$ |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  | $\stackrel{\sim}{0}$ |
|  |  |  |  |  |  |  |  |
|  | $\sum_{\leqq}$ |  | $\frac{0.0}{0}$ |  |  | - |  |
|  |  |  | $\begin{gathered} \frac{0}{\omega} \\ 0 \\ \vdots \\ \frac{\omega}{0} \\ 0 \end{gathered}$ | $\begin{gathered} 0 \\ \cdots \frac{\infty}{\oplus} \\ \stackrel{\omega}{0} \end{gathered}$ |  | 뮹 $\cdots$ 0 0 | 믈 - $\sim$ |
|  |  | $\sigma$ | ᄂ | $\infty$ | - | $\infty$ | $\infty$ |
|  |  | $\bigcirc$ | $\bigcirc$ | $\wedge$ | $\bigcirc$ | $\odot$ | $\omega$ |
|  | $\frac{0}{\omega}$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | $<$ | $\checkmark$ | $\ulcorner$ | - | - | - | - |
|  | $\wedge$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  |  |  |  |  |  |  |  |
|  | $\stackrel{\perp}{\text { D }}$ | $\stackrel{\perp}{\text { D}}$ | $\stackrel{\perp}{\mathrm{O}}$ | $\stackrel{\perp}{\mathrm{B}}$ | $\stackrel{\perp}{\text { D }}$ | $\stackrel{\perp}{\text { D}}$ | $\stackrel{\text { B }}{\substack{\text { ® }}}$ |
|  |  |  |  |  |  |  |  |

[^2]2.2.39 (7) MOV (B)

MOV (MOVe data)
Move

## Operation

Rs $\rightarrow$ (EAd)

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

MOV.B Rs, <EAd>

## Operand Size

Byte

H : Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the contents of an 8-bit register Rs (source operand) to a destination location, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rs: R0L to R7L, R0H to R7H
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

|  | $\sim$ | $\cdots$ | $\llcorner$ | $\cdots$ | $\sim$ | ल | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\frac{0.0}{0}$ |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  | 毎 |
|  |  |  |  |  |  |  |  |
|  |  | $\frac{0.0}{0}$ | $\cong$ <br> $<$ |  |  | $\begin{aligned} & \infty \\ & \stackrel{0}{\sigma} \end{aligned}$ |  |
|  |  |  | $\varangle$ $\omega$ |  |  |  |  |
|  | $\varrho$ | $\varrho$ | $\bigcirc$ | $\varrho$ | $\begin{aligned} & \text { n } \\ & \text { त } \end{aligned}$ | $\varrho$ | $\varrho$ |
|  | $\frac{0}{0}$ | $\frac{\square}{0}$ | $\frac{\square}{0}$ | $\frac{\square}{0}$ |  | $\infty$ | < |
|  | - | - | - | - |  |  |  |
|  | $\infty$ | ш | $\infty$ | 0 | $\cdots$ | $\varangle$ | $<$ |
|  | $\bullet$ | $\bullet$ | N | $\omega$ | ल | $\bullet$ | $\bullet$ |
| 음 픙 O |  |  |  | $\begin{aligned} & \text { 므 } \\ & \text { I } \\ & \text { ®) } \\ & \dot{\sim} \end{aligned}$ | $\begin{aligned} & \propto \dot{\tilde{\sigma}} \\ & \dot{\tilde{\sigma}} \\ & \underset{8}{8} \\ & \dot{\sim} \end{aligned}$ |  |  |
| 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> 1 | $\stackrel{\infty}{\text { Di }}$ | $\stackrel{\infty}{\stackrel{\infty}{\Sigma}}$ | $\stackrel{\infty}{\stackrel{\infty}{\Sigma}}$ | $\stackrel{\infty}{\underset{\Sigma}{\infty}}$ | $\stackrel{\infty}{\stackrel{\infty}{\text { O}}}$ | $\stackrel{\infty}{\stackrel{\infty}{\Sigma}}$ | $\stackrel{\infty}{\text { ® }}$ |
|  |  |  |  |  |  |  |  |

[^3]2.2.39 (8) MOV (W)

MOV (MOVe data)
Move

## Operation

Rs $\rightarrow$ (EAd)

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

MOV.W Rs, <EAd>

## Operand Size

Word

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the contents of a 16 -bit register Rs (source operand) to a destination location, tests the transferred data, and sets condition-code flags according to the result.

## Available Registers

Rs: R0 to R7, E0 to E7
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte | 6th byte | 7th byte | 8th byte |  |
| Register indirect | MOV.W | Rs, @ERd | 6 | 9 | 1 erd | rs |  |  |  |  |  |  |  |  | 2 |
| Register indirect | MOV.W | $\begin{gathered} \text { Rs, } \\ \text { @(d:16, ERd) } \end{gathered}$ | 6 | F | 1 erd | rs | disp |  |  |  |  |  |  |  | 3 |
| displacement | MOV.W | $\begin{gathered} \text { Rs, } \\ \text { @(d:32, ERd) } \end{gathered}$ | 7 | 8 | 0 erd | 0 | 6 | B | A | rs | disp |  |  |  | 5 |
| Register indirect with predecrement | MOV.W | Rs, @-ERd | 6 | D | 1 erd | rs |  |  |  |  |  |  |  |  | 3 |
| Absolute address | MOV.W | Rs, @aa:16 | 6 | B | 8 | rs | abs |  |  |  |  |  |  |  | 3 |
|  | MOV.W | Rs, @aa:32 | 6 | B | A | rs | abs |  |  |  |  |  |  |  | 4 |

[^4]2.2.39 (9) MOV (L)

MOV (MOVe data)
Move

## Operation

ERs $\rightarrow($ EAd $)$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

MOV.L ERs, <EAd>

## Operand Size

Longword
$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the contents of a 32-bit register ERs (source operand) to a destination location, tests the transferred data, and sets condition-code flags according to the result. The extended register (Es) contents are stored at the first word indicated by the effective address. The general register (Rs) contents are stored at the next word.


## Available Registers

ERs: ER0 to ER7
ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte | 5th byte |  | 6th byte |  | 7th byte | 8th byte | 9th byte | 10th byte |  |
| Register indirect | MOV.L | ERs, @ERd | 0 | 1 | 0 | 0 | 6 | 9 | 1 erdo ers |  |  |  |  |  |  |  |  | 4 |
| Register | MOV.L | ERs, @ (d:16, ERd) | 0 | 1 | 0 | 0 | 6 | F | 1 erdom |  |  |  |  |  |  |  |  | 5 |
| ment | MOV.L | ERs, @ (d:32, ERd) | 0 | 1 | 0 | 0 | 7 | 8 | 0 erd 0 | 6 | B | A | 0 ors |  |  |  |  | 7 |
| Register indirect with predecrement | MOV.L | ERs, @-ERd | 0 | 1 | 0 | 0 | 6 | D | 1 erd: 0: ers |  |  |  |  |  |  |  |  | 5 |
| Absolute address | MOV.L | ERs, @aa:16 | 0 | 1 | 0 | 0 | 6 | B | 8 0 ers | abs |  |  |  |  |  |  |  | 5 |
|  | MOV.L | ERs, @aa:32 | 0 | 1 | 0 | 0 | 6 | B | A 0-ers | abs |  |  |  |  |  |  |  | 6 |

[^5]
### 2.2.40 MOVFPE

MOVFPE (MOVe From Peripheral with E clock)

## Operation

(EAs) $\rightarrow$ Rd
Synchronized with E clock

Assembly-Language Format
MOVFPE @aa:16,Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | - |

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers memory contents specified by a 16-bit absolute address to a general register Rd in synchronization with an E clock, tests the transferred data, and sets condition-code flags according to the result.

Note: Avoid using this instruction in microcontrollers without an E clock output pin, or in single-chip mode.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte | $*$ |  |
| Absolute address | MOVFPE | @aa:16, Rd | 6 | A | 4 | rd | abs |  |

Note: * For details, refer to the relevant microcontroller hardware manual.

## Notes

1. This instruction cannot be used with addressing modes other than the above, and cannot transfer word data or longword data.
2. The number of states required for execution is variable. For details, refer to the relevant microcontroller hardware manual.

### 2.2.41 MOVTPE

MOVTPE (MOVe To Peripheral with E clock)

## Operation

Rs $\rightarrow$ (EAd)
Synchronized with E clock

## Assembly-Language Format

movtre Rs, @aa:16

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction transfers the contents of a general register Rs (source operand) to a destination location specified by a 16 -bit absolute address in synchronization with an E clock, tests the transferred data, and sets condition-code flags according to the result.

Note: Avoid using this instruction in microcontrollers without an E clock output pin, or in single-chip mode.

## Available Registers

Rs: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte | $*$ |  |
| Absolute address | MOVTPE | Rs, @aa:16 | 6 | A | C | rs | abs |  |

Note: * For details, refer to the relevant microcontroller hardware manual.

## Notes

1. This instruction cannot be used with addressing modes other than the above, and cannot transfer word data or longword data.
2. The number of states required for execution is variable. For details, refer to the relevant microcontroller hardware manual.

### 2.2.42 (1) MULXS (B)

MULXS (MULtiply eXtend as Signed)
Multiply Signed

## Operation

Rd $\times$ Rs $\rightarrow$ Rd

## Assembly-Language Format

mULXS.B Rs, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

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

## Description

This instruction multiplies the lower 8 bits of a 16 -bit register Rd (destination operand) by the contents of an 8 -bit register Rs (source operand) as signed data and stores the result in the 16-bit register Rd. If Rd is one of general registers R0 to R7, Rs can be the upper part ( RdH ) or lower part (RdL) of Rd. The operation performed is 8 bits $\times 8$ bits $\rightarrow 16$ bits signed multiplication.

| Rd |  | $\times$ | Rs | $\rightarrow$ | Rd |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Don't care | Multiplicand |  | Multiplier |  | Product |
|  | bits |  | 8 bits |  | 16 bits |

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0L to R7L, R0H to R7H

## Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |
| Register direct | MULXS.B | Rs, Rd | 0 | 1 | C | 0 | 5 | 0 | rs | rd | 4* |

Note: * The number of states in the H8S/2000 CPU is 13.
A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

## Notes

2.2.42 (2) MULXS (W)

MULXS (MULtiply eXtend as Signed)

## Operation

ERd $\times$ Rs $\rightarrow$ ERd

## Assembly-Language Format

mULXS.W Rs, ERd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | - | - |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Previous value remains unchanged.
C: Previous value remains unchanged.

## Description

This instruction multiplies the lower 16 bits of a 32 -bit register ERd (destination operand) by the contents of a 16-bit register Rs (source operand) as signed data and stores the result in the 32-bit register ERd. Rs can be the upper part (Ed) or lower part (Rd) of ERd. The operation performed is 16 bits $\times 16$ bits $\rightarrow 32$ bits signed multiplication.
ERd

| Don't care | Multiplicand $\times$ |
| :--- | :--- |

16 bits
Rs

16 bits
32 bits

## Available Registers

ERd: ER0 to ER7
Rs: R0 to R7, E0 to E7

## Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |  |
| Register direct | MULXS.W | Rs, ERd | 0 | 1 | C | 0 | 5 | 2 | rs |  | erd | 5* |

Note: * The number of states in the H8S/2000 CPU is 21.
A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

## Notes

2.2.43 (1) MULXU (B)

MULXU (MULtiply eXtend as Unsigned)
Multiply

## Operation

Rd $\times$ Rs $\rightarrow$ Rd

## Assembly-Language Format

mULXU.B Rs, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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 multiplies the lower 8 bits of a 16-bit register Rd (destination operand) by the contents of an 8-bit register Rs (source operand) as unsigned data and stores the result in the 16-bit register Rd. If Rd is one of general registers R0 to R7, Rs can be the upper part ( RdH ) or lower part ( RdL ) of Rd. The operation performed is 8 bits $\times 8$ bits $\rightarrow 16$ bits unsigned multiplication.

| Rd |  | $\times$ | Rs |  | Rd |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Don't care | Multiplicand |  | Multiplier | $\rightarrow$ | Product |
| 8 bits |  |  | 8 bits |  | 16 bits |

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0L to R7L, R0H to R7H
Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | MULXU.B | Rs, Rd | 5 | 0 | rs | rd |  |  | $3^{*}$ |

Note: * The number of states in the H8S/2000 CPU is 12.
A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

## Notes

2.2.43 (2) MULXU (W)

MULXU (MULtiply eXtend as Unsigned)

## Operation

ERd $\times$ Rs $\rightarrow$ ERd

## Assembly-Language Format

mULXU.W Rs, ERd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

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 multiplies the lower 16 bits of a 32-bit register ERd (destination operand) by the contents of a 16-bit register Rs (source operand) as unsigned data and stores the result in the 32-bit register ERd. Rs can be the upper part (Ed) or lower part (Rd) of ERd. The operation performed is 16 bits $\times 16$ bits $\rightarrow 32$ bits unsigned multiplication.

ERd

| Don't care | Multiplicand |
| :---: | :---: |
| 16 bits |  |

16 bits

Rs


16 bits 32 bits

## Available Registers

ERd: ER0 to ER7
Rs: R0 to R7, E0 to E7
Operand Format and Number of States Required for Execution

| Add | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ode |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | MULXU.W | Rs, ERd | 5 | 2 | rs | 0 erd |  |  | 4* |

Note: * The number of states in the H8S/2000 CPU is 20.
A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

## Notes

### 2.2.44 (1) NEG (B)

NEG (NEGate)
Negate Binary Signed

## Operation

$0-\mathrm{Rd} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

NEG.B Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

H : Set to 1 if there is a borrow at bit 3; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 7 ; otherwise cleared to 0 .

## Description

This instruction takes the two's complement of the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd (subtracting the register contents from $\mathrm{H}^{\prime} 00$ ). If the original contents of Rd were $\mathrm{H}^{\prime} 80$, however, the result remains $\mathrm{H}^{\prime} 80$.

## Available Registers

Rd: R0L to R7L, R0H to R7H

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | NEG.B | Rd | 1 | 7 | 8 | rd |  |  |

## Notes

An overflow occurs if the original contents of Rd were H'80.
2.2.44 (2) NEG (W)

NEG (NEGate)
Negate Binary Signed

## Operation

$0-\mathrm{Rd} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

NEG.W Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: \quad$ Set to 1 if there is a borrow at bit 11 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 15 ; otherwise cleared to 0 .

## Description

This instruction takes the two's complement of the contents of a 16-bit register Rd (destination operand) and stores the result in the 16 -bit register Rd (subtracting the register contents from $\mathrm{H}^{\prime} 0000$ ). If the original contents of Rd were $\mathrm{H}^{\prime} 8000$, however, the result remains $\mathrm{H}^{\prime} 8000$.

## Available Registers

Rd : R0 to $\mathrm{R} 7, \mathrm{E} 0$ to E 7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | NEG.W | Rd | 1 | 7 | 9 | rd |  |  | 1 |

## Notes

An overflow occurs if the original contents of Rd were $\mathrm{H}^{\prime} 8000$.

### 2.2.44 (3) NEG (L)

NEG (NEGate)
Negate Binary Signed

## Operation

0 - ERd $\rightarrow$ ERd

## Assembly-Language Format

NEG.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: \quad$ Set to 1 if there is a borrow at bit 27 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 31 ; otherwise cleared to 0 .

## Description

This instruction takes the two's complement of the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd (subtracting the register contents from $\mathrm{H}^{\prime} 00000000$ ). If the original contents of ERd were $\mathrm{H}^{\prime} 80000000$, however, the result remains H'800000000.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | NEG.L | ERd | 1 | 7 | B | erd |  |  |

## Notes

An overflow occurs if the original contents of ERd were $\mathrm{H}^{\prime} 80000000$.

### 2.2.45 NOP

NOP (No OPeration)

## Operation

$\mathrm{PC}+2 \rightarrow \mathrm{PC}$

Assembly-Language Format
NOP

Operand Size

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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.
$\qquad$

## Description

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

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands |  |  |  | uct | Format |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| - | NOP |  | 0 | 0 | 0 | 0 |  |  | 1 |

## Notes

2.2.46 (1) NOT (B)

NOT (NOT = logical complement)
Logical Complement

## Operation

$\neg \mathrm{Rd} \rightarrow \mathrm{Rd}$

Assembly-Language Format
NOT.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |  |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction takes the one's complement of the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | NOT.B | Rd | 1 | 7 | 0 | rd |  |  | 1 |

## Notes

2.2.46(2) NOT (W)

NOT (NOT = logical complement)
Logical Complement

## Operation

$\neg \mathrm{Rd} \rightarrow \mathrm{Rd}$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

## Assembly-Language Format

NOT.W Rd

## Operand Size

Word

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction takes the one's complement of the contents of a 16-bit register Rd (destination operand) and stores the result in the 16 -bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | NOT.W | Rd | 1 | 7 | 1 | rd |  |  | 1 |

## Notes

2.2.46 (3) NOT (L)

NOT (NOT = logical complement)
Logical Complement

## Operation

$\neg$ ERd $\rightarrow$ ERd

## Assembly-Language Format

NOT.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction takes the one's complement of the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands |  |  |  | tructio | Format |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | NOT.L | ERd | 1 | 7 | 3 | 0 erd |  |  | 1 |

## Notes

2.2.47 (1) OR (B)

OR (inclusive OR logical)
Logical OR

## Operation

$R d \vee(E A s) \rightarrow R d$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

## Assembly-Language Format

OR.B <EAs>, Rd

## Operand Size

Byte

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ORs the source operand with the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | OR.B | \#xx:8, Rd | C | rd | IMM |  |  |  | 1 |
| Register direct | OR.B | Rs, Rd | 1 | 4 | rs | rd |  |  | 1 |

## Notes

2.2.47 (2) OR (W)

OR (inclusive OR logical)
Logical OR

## Operation

Rd $v$ (EAs) $\rightarrow$ Rd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

OR.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ORs the source operand with the contents of a 16-bit register Rd (destination operand) and stores the result in the 16-bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Immediate | OR.W | \#xx:16, Rd | 7 | 9 | 4 | rd |  |  | 2 |
| Register direct | OR.W | Rs, Rd | 6 | 4 | rs | rd |  |  | 1 |

## Notes

2.2.47 (3) OR (L)

OR (inclusive OR logical)
Logical OR

## Operation

ERd $v(E A s) \rightarrow$ ERd

Assembly-Language Format
OR.L <EAs>, ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction ORs the source operand with the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th | byte | 5th byte | 6th byte |  |
| Immediate | OR.L | \#xx:32, ERd | 7 | A | 4 | 0 erd | IMM |  |  |  |  |  | 3 |
| Register direct | OR.L | ERs, ERd | 0 | 1 | F | 0 | 6 | 4 | 0 ers | 0 erd |  |  | 2 |

## Notes

### 2.2.48 (1) ORC

ORC (inclusive OR Control register)
Logical OR with CCR

## Operation

CCR v \#IMM $\rightarrow$ CCR

## Assembly-Language Format

ORC \#xx:8,CCR

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Stores the corresponding bit of the result.
UI: Stores the corresponding bit of the result.
H : Stores the corresponding bit of the result.
U : Stores the corresponding bit of the result.
N : Stores the corresponding bit of the result.
Z : Stores the corresponding bit of the result.
V: Stores the corresponding bit of the result.
C: Stores the corresponding bit of the result.

## Description

This instruction ORs the contents of the condition-code register (CCR) with immediate data and stores the result in the condition-code register. No interrupt requests, including NMI, are accepted immediately after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | ORC | $\# x x: 8$, CCR | 0 | 4 | IMM |  |  | 1 |

## Notes

2.2.48(2) ORC

ORC (inclusive OR Control register)
Logical OR with EXR

## Operation

EXR $\vee$ \#IMM $\rightarrow$ EXR

## Assembly-Language Format <br> ORC \#xx:8,EXR

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

H : Stores the corresponding bit of the result.
N : Stores the corresponding bit of the result.
Z: Stores the corresponding bit of the result.
V: Stores the corresponding bit of the result.
C : Stores the corresponding bit of the result.

## Operand Size

Byte

## Description

This instruction ORs the contents of the extended control register (EXR) with immediate data and stores the result in the extended control register. No interrupt requests, including NMI, are accepted for three states after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  |  | IMM |
| Immediate | ORC | \#xx:8, EXR | 0 | 1 | 4 | 1 | 0 | 4 |  |  |

## Notes

2.2.49 (1) POP (W)

POP (POP data)
Pop Data from Stack

## Operation

$@ \mathrm{SP}+\rightarrow \mathrm{Rn}$

## Assembly-Language Format

POP.W Rn

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |  |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction restores data from the stack to a 16-bit general register Rn , tests the restored data, and sets condition-code flags according to the result.

## Available Registers

Rn: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands |  |  |  | uct | Format |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| - | POP.W | Rn | 6 | D | 7 | rn |  |  | 3 |

## Notes

POP.W Rn is identical to MOV.W @SP+, Rn.
2.2.49 (2) POP (L)

POP (POP data)
Pop Data from Stack

## Operation

@SP+ $\rightarrow$ ERn

Assembly-Language Format
POP.L ERn

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction restores data from the stack to a 32-bit general register ERn, tests the restored data, and sets condition-code flags according to the result.

## Available Registers

ERn: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |  |
| - | POP.L | ERn | 0 | 1 | 0 | 0 | 6 | D | 7 | 0 | ern | 5 |

## Notes

POP.LERn is identical to MOV.L@SP+, ERn.

### 2.2.50 (1) PUSH (W)

PUSH (PUSH data)
Push Data on Stack

## Operation

Rn $\rightarrow$-SP

## Assembly-Language Format

PUSH.W Rn

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

H: Previous value remains unchanged.
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .

Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction saves data from a 16-bit register Rn onto the stack, tests the saved data, and sets condition-code flags according to the result.

## Available Registers

Rn: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| - | PUSH.W | Rn | 6 | 6 | D | F | rn |  |

## Notes

1. PUSH.W Rn is identical to MOV.W Rn, @-SP.
2. When PUSH.W R7 or PUSH.W E7 is executed, the value saved on the stack is the R7 or E7 value after effective address calculation (after ER7 is decremented by 2).

### 2.2.50 (2) PUSH (L)

PUSH (PUSH data)
Push Data on Stack

## Operation

ERn $\rightarrow$ @-SP

## Assembly-Language Format

PUSH.L ERn

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the transferred data is negative; otherwise cleared to 0 .
Z: Set to 1 if the transferred data is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction pushes data from a 32-bit register ERn onto the stack, tests the saved data, and sets condition-code flags according to the result.

## Available Registers

ERn: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |
| - | PUSH.L | ERn | 0 | 1 | 0 | 0 | 6 | D |  | 0 Oem | 5 |

## Notes

1. PUSH.L ERn is identical to MOV.L ERn, @-SP.
2. When PUSH.L ER7 is executed, the value saved on the stack is the ER7 value after effective address calculation (after ER7 is decremented by 4).
2.2.51 (1) ROTL (B)

ROTL (ROTate Left)
Rotate

## Operation

Rd (left rotation) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTL.B Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 7.

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 7) is rotated to the least significant bit (bit 0), and also copied to the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTL.B | Rd | 1 | 2 | 8 | rd |  |  |

## Notes

2.2.51 (2) ROTL (B)

ROTL (ROTate Left)
Rotate

## Operation

Rd (left rotation) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTL.B \#2, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 6 .

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) two bits to the left.
The most significant two bits (bits 7 and 6) are rotated to the least significant two bits (bits 1 and 0 ), and bit 6 is also copied to the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTL.B | \#2, Rd | 1 | 2 | C | rd |  |  |

Notes
2.2.51 (3) ROTL (W)

ROTL (ROTate Left)
Rotate

## Operation

Rd (left rotation) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTL.W Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0.
V: Always cleared to 0 .
C: Receives the previous value in bit 15.

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 15) is rotated to the least significant bit (bit 0 ), and also copied to the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTL.W | Rd | 1 | 2 | 9 | rd |  |  |

Notes
2.2.51 (4) ROTL (W)

ROTL (ROTate Left)
Rotate

## Operation

Rd (left rotation) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTL.W \#2, Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 14.

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) two bits to the left. The most significant two bits (bits 15 and 14) are rotated to the least significant two bits (bits 1 and 0 ), and bit 14 is also copied to the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTL.W | \#2, Rd | 1 | 2 | D | rd |  |  |

Notes
2.2.51 (5) ROTL (L)

ROTL (ROTate Left)
Rotate

## Operation

ERd (left rotation) $\rightarrow$ ERd

## Assembly-Language Format

ROTL.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 31 .

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) one bit to the left.
The most significant bit (bit 31) is rotated to the least significant bit (bit 0), and also copied to the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTL.L | ERd | 1 | 2 | B | erd |  |  |

## Notes

2.2.51 (6) ROTL (L)

ROTL (ROTate Left)
Rotate

## Operation

ERd (left rotation) $\rightarrow$ ERd

Assembly-Language Format
ROTL.L \#2, ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 30 .

## Description

This instruction rotates the bits in a 32 -bit register ERd (destination operand) two bits to the left. The most significant two bits (bits 31 and 30 ) are rotated to the least significant two bits (bits 1 and 0 ), and bit 30 is also copied to the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | ROTL.L | \#2, ERd | 1 | 2 | F | erd |  |  | 1 |

Notes
2.2.52 (1) ROTR (B)

ROTR (ROTate Right)
Rotate

## Operation

Rd (right rotation) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTR.B Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) one bit to the right. The least significant bit (bit 0 ) is rotated to the most significant bit (bit 7), and also copied to the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTR.B | Rd | 1 | 3 | 8 | rd |  |  |

## Notes

2.2.52 (2) ROTR (B)

ROTR (ROTate Right)
Rotate

## Operation

Rd (right rotation) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTR.B \#2, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) two bits to the right. The least significant two bits (bits 1 and 0 ) are rotated to the most significant two bits (bits 7 and 6 ), and bit 1 is also copied to the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTR.B | \#2, Rd | 1 | 3 | C | rd |  |  |

Notes
2.2.52 (3) ROTR (W)

ROTR (ROTate Right)
Rotate

## Operation

Rd (right rotation) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTR.W Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) one bit to the right. The least significant bit (bit 0 ) is rotated to the most significant bit (bit 15), and also copied to the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTR.W | Rd | 1 | 3 | 9 | rd |  |  |

Notes
2.2.52 (4) ROTR (W)

ROTR (ROTate Right)
Rotate

## Operation

Rd (right rotation) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTR.W \#2, Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) two bits to the right.
The least significant two bits (bits 1 and 0 ) are rotated to the most significant two bits (bits 15 and $14)$, and bit 1 is also copied to the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTR.W | \#2, Rd | 1 | 3 | D | rd |  |  |

Notes
2.2.52 (5) ROTR (L)

ROTR (ROTate Right)
Rotate

## Operation

ERd (right rotation) $\rightarrow$ ERd

## Assembly-Language Format

ROTR.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) one bit to the right. The least significant bit (bit 0) is rotated to the most significant bit (bit 31), and also copied to the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTR.L | ERd | 1 | 3 | B | erd |  |  |

## Notes

2.2.52 (6) ROTR (L)

ROTR (ROTate Right)
Rotate

## Operation

ERd (right rotation) $\rightarrow$ ERd

## Assembly-Language Format

ROTR.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) two bits to the right.
The least significant two bits (bits 1 and 0 ) are rotated to the most significant two bits (bits 31 and 30 ), and bit 1 is also copied to the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | ROTR.L | \#2, ERd | 1 | 3 | F | erd |  |  | 1 |

Notes
2.2.53 (1) ROTXL (B)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

Rd (left rotation through carry flag) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTXL.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\hat{\imath}$ | 0 | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 7 .

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) one bit to the left through the carry flag. The carry flag is rotated into the least significant bit (bit 0 ). The most significant bit (bit 7) rotates into the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXL.B | Rd | 1 | 2 | 0 | rd |  |  |

## Notes

2.2.53 (2) ROTXL (B)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

Rd (left rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXL.B \#2, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 6 .

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) two bits to the left through the carry flag. The carry flag rotates into bit 1 , bit 7 rotates into bit 0 , and bit 6 rotates into the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXL.B | \#2, Rd | 1 | 2 | 4 | rd |  |  |

Notes
2.2.53 (3) ROTXL (W)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

Rd (left rotation through carry flag) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

ROTXL.W Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 15 .

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) one bit to the left through the carry flag. The carry flag is rotated into the least significant bit (bit 0 ). The most significant bit (bit 15) rotates into the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXL.W | Rd | 1 | 2 | 1 | rd |  |  |

## Notes

2.2.53 (4) ROTXL (W)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

Rd (left rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXL.W \#2,Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 14.

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) two bits to the left through the carry flag. The carry flag rotates into bit 1 , bit 15 rotates into bit 0 , and bit 14 rotates into the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXL.W | \#2, Rd | 1 | 2 | 5 | rd |  |  |

Notes
2.2.53 (5) ROTXL (L)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

ERd (left rotation through carry flag) $\rightarrow$ ERd

## Assembly-Language Format

ROTXL.L ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\hat{\imath}$ | 0 | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 31 .

## Description

This instruction rotates the bits in a 32 -bit register ERd (destination operand) one bit to the left through the carry flag. The carry flag is rotated into the least significant bit (bit 0 ). The most significant bit (bit 31) rotates into the carry flag.


## Available Registers

ERd: ER0 to ER7

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXL.L | ERd | 1 | 2 | 3 | erd |  |  |

## Notes

2.2.53 (6) ROTXL (L)

ROTXL (ROTate with eXtend carry Left)
Rotate through Carry

## Operation

ERd (left rotation through carry flag) $\rightarrow$ ERd

Assembly-Language Format
ROTXL.L \#2,ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 30 .

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) two bits to the left through the carry flag. The carry flag rotates into bit 1 , bit 31 rotates into bit 0 , and bit 30 rotates into into the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | ROTXL.L | \#2, ERd | 1 | 2 | 7 | 0 erd |  |  | 1 |

Notes
2.2.54 (1) ROTXR (B)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

Rd (right rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXR.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) one bit to the right through the carry flag. The carry flag is rotated into the most significant bit (bit 7). The least significant bit (bit 0) rotates into the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Rd | 1 | 1st byte | 2nd byte | 3rd byte |  |

## Notes

2.2.54 (2) ROTXR (B)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

Rd (right rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXR.B \#2, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in an 8-bit register Rd (destination operand) two bits to the right through the carry flag. The carry flag rotates into bit 6 , bit 0 rotates into bit 7 , and bit 1 rotates into the carry flag.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXR.B | \#2, Rd | 1 | 3 | 4 | rd |  |  |

Notes
2.2.54 (3) ROTXR (W)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

Rd (right rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXR.W Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\downarrow}$ | $\hat{\downarrow}$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) one bit to the right through the carry flag. The carry flag is rotated into the most significant bit (bit 15). The least significant bit (bit 0) rotates into the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXR.W | Rd | 1 | 3 | 1 | rd |  |  |

Notes
2.2.54 (4) ROTXR (W)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

Rd (right rotation through carry flag) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
ROTXR.W \#2,Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in a 16-bit register Rd (destination operand) two bits to the right through the carry flag. The carry flag rotates into bit 14 , bit 0 rotates into bit 15 , and bit 1 rotates into the carry flag.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXR.W | \#2, Rd | 1 | 3 | 5 | rd |  |  |

Notes
2.2.54 (5) ROTXR (L)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

ERd (right rotation through carry flag) $\rightarrow$ ERd

## Assembly-Language Format

ROTXR.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) one bit to the right through the carry flag. The carry flag is rotated into the most significant bit (bit 31). The least significant bit (bit 0) rotates into the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |
| Register direct | ROTXR.L | ERd | 1 | 3 | 3 | erd |  |  |

## Notes

2.2.54 (6) ROTXR (L)

ROTXR (ROTate with eXtend carry Right)
Rotate through Carry

## Operation

ERd (right rotation through carry flag) $\rightarrow$ ERd

Assembly-Language Format
ROTXR.L \#2,ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction rotates the bits in a 32-bit register ERd (destination operand) two bits to the right through the carry flag. The carry flag rotates into bit 30 , bit 0 rotates into bit 31 , and bit 1 rotates into the carry flag.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | ROTXR.L | \#2, ERd | 1 | 3 | 7 | 0 erd |  |  | 1 |

Notes

## Operation

- When EXR is invalid
@SP+ $\rightarrow$ CCR
@SP+ $\rightarrow$ PC
- When EXR is valid
@SP+ $\rightarrow$ EXR
@SP+ $\rightarrow$ CCR
@SP+ $\rightarrow$ PC


## Assembly-Language Format

RTE

## Operand Size

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Restored from the corresponding bit on the stack.
UI: Restored from the corresponding bit on the stack.
H: Restored from the corresponding bit on the stack.
U : Restored from the corresponding bit on the stack.
N : Restored from the corresponding bit on the stack.
Z: Restored from the corresponding bit on the stack.
V: Restored from the corresponding bit on the stack.
C: Restored from the corresponding bit on the stack.

## Description

This instruction returns from an exception-handling routine by restoring the EXR, 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. If the extended control regiser (EXR) is valid, it is also restored (and the existing EXR contents are lost).

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| - | RTE |  | 5 | 6 | 7 | 0 |  |  | $5^{*}$ |

Note: * Six states when EXR is valid.

RTE (ReTurn from Exception)
Return from Exception Handling

## Notes

The stack structure differs between normal mode and advanced mode.

2.2.56 RTS

RTS (ReTurn from Subroutine)
Return from Subroutine

## Operation

$@ \mathrm{SP}+\rightarrow \mathrm{PC}$

## Assembly-Language Format

RTS

Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

## Description

This instruction returns from a subroutine by restoring 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.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte | Normal | Advanced |  |
| - | RTS |  | 5 | 4 | 7 | 0 |  |  | 4 |
| 5 |  |  |  |  |  |  |  |  |  |

## Notes

The stack structure and number of states required for execution differ between normal mode and advanced mode. In normal mode, only the lower 16 bits of the program counter are restored.


2.2.57 (1) SHAL (B)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

Rd (left arithmetic shift) $\rightarrow \mathrm{Rd}$

## Condition Code

| I | UI |  | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |  |

Assembly-Language Format
SHAL.B Rd

## Operand Size

Byte
$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 7.

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 7) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


Available Registers
Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  |  |
| Register direct | SHAL.B |  | 1 | 0 | 8 | rd |  |  | 1 |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.57 (2) SHAL (B)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

Rd (left arithmetic shift) $\rightarrow$ Rd

Assembly-Language Format
SHAL.B \#2,Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 6 .

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) two bits to the left. Bit 6 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Register direct | SHAL.B | \#2, Rd | 1 | 0 | C | rd |  |  | 1 |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.57 (3) SHAL (W)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

Rd (left arithmetic shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHAL.W Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 15 .

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 15) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


Available Registers
Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Rd | 1 | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.57 (4) SHAL (W)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

Rd (left arithmetic shift) $\rightarrow$ Rd

Assembly-Language Format
SHAL.W \#2, Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 14.

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) two bits to the left. Bit 14 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHAL.W | \#2, Rd | 1 | 0 | D | rd |  |  | 1 |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.57 (5) SHAL (L)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

ERd (left arithmetic shift) $\rightarrow$ ERd

Assembly-Language Format
SHAL.L ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V : Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 31 .

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) one bit to the left. The most significant bit (bit 31) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ERd | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.57 (6) SHAL (L)

SHAL (SHift Arithmetic Left)
Shift Arithmetic

## Operation

ERd (left arithmetic shift) $\rightarrow$ ERd

Assembly-Language Format
SHAL.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Receives the previous value in bit 30 .

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) two bits to the left. Bit 30 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | \#2, ERd | 1 | 0 | 1st byte | 2nd byte |  | 4th byte |

## Notes

The SHAL instruction differs from the SHLL instruction in its effect on the overflow flag.
2.2.58 (1) SHAR (B)

SHAR (SHift Arithmetic Right)
Shift Arithmetic

## Operation

Rd (right arithmetic shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHAR.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) one bit to the right. Bit 0 shifts into the carry flag. Bit 7 shifts into itself. Since bit 7 remains unaltered, the sign does not change.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHAR.B | Rd | 1 | 1 | 8 | rd |  |  | 1 |

## Notes

2.2.58 (2) SHAR (B)

SHAR (SHift Arithmetic Right)
Shift Arithmetic

## Operation

Rd (right arithmetic shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHAR.B \#2,Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) two bits to the right. Bit 1 shifts into the carry flag. Bits 7 and 6 receive the previous value of bit 7 . Since bit 7 remains unaltered, the sign does not change.


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Register direct | SHAR.B | \#2, Rd | 1 | 1 | C | rd |  |  | 1 |

## Notes

2.2.58 (3) SHAR (W)

SHAR (SHift Arithmetic Right)

## Operation

Rd (right arithmetic shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHAR.W Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) one bit to the right. Bit 0 shifts into the carry flag. Bit 15 shifts into itself. Since bit 15 remains unaltered, the sign does not change.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHAR.W | Rd | 1 | 1 | 9 | rd |  |  | 1 |

## Notes

2.2.58 (4) SHAR (W)

SHAR (SHift Arithmetic Right)
Shift Arithmetic

## Operation

Rd (right arithmetic shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHAR.W \#2,Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) two bits to the right. Bit 1 shifts into the carry flag. Bits 15 and 14 receive the previous value of bit 15 . Since bit 15 remains unaltered, the sign does not change.


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | \#2, Rd | 1st byte | 2nd byte |  | 3rd byte |  |  |

## Notes

2.2.58 (5) SHAR (L)

SHAR (SHift Arithmetic Right)

## Operation

ERd (right arithmetic shift) $\rightarrow$ ERd

## Assembly-Language Format

SHAR.L ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in a 32 -bit register ERd (destination operand) one bit to the right. Bit 0 shifts into the carry flag. Bit 31 shifts into itself. Since bit 31 remains unaltered, the sign does not change.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ERd | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

2.2.58 (6) SHAR (L)

SHAR (SHift Arithmetic Right)
Shift Arithmetic

## Operation

ERd (right arithmetic shift) $\rightarrow$ ERd

## Assembly-Language Format

SHAR.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) two bits to the right. Bit 1 shifts into the carry flag. Bits 31 and 30 receive the previous value of bit 31 . Since bit 31 remains unaltered, the sign does not change.


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Register direct | SHAR.L | \#2, ERd | 1 | 1 | F | 0 | erd |  |  |

## Notes

2.2.59 (1) SHLL (B)

SHLL (SHift Logical Left)
Shift Logical

## Operation

Rd (left logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLL.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 7.

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 7) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


Available Registers
Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHLL.B | Rd | 1 | 0 | 0 | rd |  |  | 1 |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.59 (2) SHLL (B)

SHLL (SHift Logical Left)
Shift Logical

## Operation

Rd (left logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLL.B \#2,Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 6 .

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) two bits to the left. Bit 6 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHLL.B | \#2, Rd | 1 | 0 | 4 | rd |  |  | 1 |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.59 (3) SHLL (W)

SHLL (SHift Logical Left)
Shift Logical

## Operation

Rd (left logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLL.W Rd

## Operand Size

Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V : Always cleared to 0 .
C: Receives the previous value in bit 15 .

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) one bit to the left. The most significant bit (bit 15) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


Available Registers
Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Rd | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.59 (4) SHLL (W)

SHLL (SHift Logical Left)
Shift Logical

## Operation

Rd (left logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLL.W \#2,Rd

## Operand Size

Word

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 14.

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) two bits to the left. Bit 14 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHLL.W | \#2, Rd | 1 | 0 | 5 | rd |  |  | 1 |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.59 (5) SHLL (L)

SHLL (SHift Logical Left)
Shift Logical

## Operation

ERd (left logical shift) $\rightarrow$ ERd

Assembly-Language Format
SHLL.L ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 31.

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) one bit to the left. The most significant bit (bit 31) shifts into the carry flag. The least significant bit (bit 0 ) is cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ERd | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.59 (6) SHLL (L)

SHLL (SHift Logical Left)
Shift Logical

## Operation

ERd (left logical shift) $\rightarrow$ ERd

## Assembly-Language Format

SHLL.L \#2, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | $\imath$ |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 30 .

## Description

This instruction shifts the bits in a 32 -bit register ERd (destination operand) two bits to the left.
Bit 30 shifts into the carry flag. Bits 0 and 1 are cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | \#2, ERd | 1 | 0 | 1st byte | 2nd byte |  | 4th byte |

## Notes

The SHLL instruction differs from the SHAL instruction in its effect on the overflow flag.
2.2.60 (1) SHLR (B)

SHLR (SHift Logical Right)
Shift Logical

## Operation

$R d$ (right logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLR.B Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Always cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) one bit to the right. The least significant bit (bit 0 ) shifts into the carry flag. The most significant bit (bit 7) is cleared to 0 .


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | SHLR.B | Rd | 1 | 1 | 0 | rd |  |  | 1 |

## Notes

2.2.60 (2) SHLR (B)

## SHLR (SHift Logical Right)

Shift Logical

## Operation

Rd (right logical shift) $\rightarrow \mathrm{Rd}$

## Assembly-Language Format

SHLR.B \#2,Rd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Always cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0.
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction shifts the bits in an 8-bit register Rd (destination operand) two bits to the right. Bit 1 shifts into the carry flag. Bits 7 and 6 are cleared to 0 .


## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | SHLR.B | \#2, Rd | 1 | 1 | 4 | rd |  |  | 1 |

## Notes

2.2.60 (3) SHLR (W)

SHLR (SHift Logical Right)
Shift Logical

## Operation

$R d$ (right logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLR.W Rd

Operand Size
Word

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Always cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) one bit to the right. The least significant bit (bit 0 ) shifts into the carry flag. The most significant bit (bit 15 ) is cleared to 0 .


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | SHLR.W | Rd | 1 | 1 | 1 | rd |  |  | 1 |

## Notes

2.2.60 (4) SHLR (W)

SHLR (SHift Logical Right)
Shift Logical

## Operation

Rd (right logical shift) $\rightarrow \mathrm{Rd}$

Assembly-Language Format
SHLR.W \#2,Rd

## Condition Code

| I | UI |  | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\hat{\downarrow}$ | 0 | $\imath$ |  |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Always cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

## Description

This instruction shifts the bits in a 16-bit register Rd (destination operand) two bits to the right. Bit 1 shifts into the carry flag. Bits 15 and 14 are cleared to 0 .


## Available Registers

Rd: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 3rd byte | 4th byte |  |
| Register direct | SHLR.W | \#2, Rd | 1 | 1 | 5 | rd |  |  | 1 |

## Notes

2.2.60 (5) SHLR (L)

SHLR (SHift Logical Right)
Shift Logical

## Operation

ERd (right logical shift) $\rightarrow$ ERd

Assembly-Language Format
SHLR.L ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | $\imath$ |

H : Previous value remains unchanged.
N : Always cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 0 .

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) one bit to the right. The least significant bit (bit 0 ) shifts into the carry flag. The most significant bit (bit 31 ) is cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ERd | 1st byte | 2nd byte | 3rd byte | 4th byte |  |

## Notes

### 2.2.60 (6) SHLR (L)

## SHLR (SHift Logical Right)

Shift Logical

## Operation

ERd (right logical shift) $\rightarrow$ ERd

Assembly-Language Format
SHLR.L \#2, ERd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\imath$ | 0 | $\imath$ |

$\mathrm{H}: ~ P r e v i o u s ~ v a l u e ~ r e m a i n s ~ u n c h a n g e d . ~$
N : Always cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Receives the previous value in bit 1.

Longword

## Description

This instruction shifts the bits in a 32-bit register ERd (destination operand) two bits to the right.
Bit 1 shifts into the carry flag. Bits 31 and 30 are cleared to 0 .


## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | \#2, ERd | 1 | 1 | 7 | 1st byte |  | 3rd byte |
| 4th byte | erd |  |  | 1 |  |  |  |  |

## Notes

### 2.2.61 SLEEP

SLEEP (SLEEP)

## Operation

Program execution state $\rightarrow$ power-down mode

## Assembly-Language Format

SLEEP

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

## 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. When it receives an exception-handling request, the CPU exits the power-down mode and begins the exception-handling sequence. Interrupt requests other than NMI cannot end the powerdown mode if they are masked in the CPU.

## Available Registers

## Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| - | SLEEP |  | 0 | 1 | 8 | 0 |  |  | 2 |

## Notes

For information about power-down modes, see the relevant microcontroller hardware manual.
2.2.62 (1) STC (B)

STC (STore from Control register)

## Operation

CCR $\rightarrow$ Rd

## Assembly-Language Format <br> STC. B CCR, Rd

## Operand Size

Byte

## Description

This instruction copies the CCR contents to an 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | STC.B | CCR, Rd | 0 | 2 | 0 | rd |  |  | 1 |

## Notes

2.2.62 (2) STC (B)

STC (STore from Control register)

## Operation

EXR $\rightarrow$ Rd

Assembly-Language Format
STC.B EXR, Rd

Operand Size
Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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 copies the EXR contents to an 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | STC.B | EXR, Rd | 0 | 2 | 1 | rd |  |  | 1 |

## Notes

2.2.62 (3) STC (W)

STC (STore from Control register)
Store CCR

## Operation

$\mathrm{CCR} \rightarrow(\mathrm{EAd})$

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

Assembly-Language Format
STC.W CCR, <EAd>

## 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.
Word

## Description

This instruction copies the CCR contents to a destination location. Although CCR is a byte register, the destination operand is a word operand. The CCR contents are stored at the even address. Undetermined data is stored at the odd address.

## Available Registers

ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte | 8th byte | 9th byte | 10th byte |  |
| Register indirect | STC.W | CCR, @ERd | 0 | 1 | 4 | 0 | 6 | 9 | 1 erd | 0 |  |  |  |  |  |  |  |  | 3 |
| Register | STC.W | CCR, @(d:16, ERd) | 0 | 1 | 4 | 0 | 6 | F | 1 erd | 0 | disp |  |  |  |  |  |  |  | 4 |
| ment | STC.W | CCR, @ (d:32, ERd) | 0 | 1 | 4 | 0 | 7 | 8 | 0 erd | 0 | 6 | B | A | 0 | disp |  |  |  | 6 |
| Register indirect with predecrement | STC.W | CCR, @-ERd | 0 | 1 | 4 | 0 | 6 | D | 1 erd | 0 |  |  |  |  |  |  |  |  | 4 |
| Absolute address | STC.W | CCR, @aa:16 | 0 | 1 | 4 | 0 | 6 | B | 8 | 0 | abs |  |  |  |  |  |  |  | 4 |
|  | STC.W | CCR, @aa:32 | 0 | 1 | 4 | 0 | 6 | B | A | 0 | abs |  |  |  |  |  |  |  | 5 |

2.2.62 (4) STC (W)

STC (STore from Control register)

## Operation

$\mathrm{EXR} \rightarrow(\mathrm{EAd})$

Assembly-Language Format
STC.W EXR, <EAd>

## Operand Size

Word

## Description

This instruction copies the EXR contents to a destination location. Although EXR is a byte register, the destination operand is a word operand. The EXR contents are stored at the even address. Undetermined data is stored at the odd address.

## Available Registers

ERd: ER0 to ER7
Operand Format and Number of States Required for Execution

|  | ๓ | - | $\bullet$ | + | * | $\sim$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\frac{0.0}{0}$ |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  | $\stackrel{\sim}{0}$ |
|  |  |  |  |  |  |  |
|  |  | 응 | 0 <br>  <br> $<$ <br> $\infty$ <br>  |  | $\stackrel{\sim}{\sim}$ |  |
|  | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | $\stackrel{\rightharpoonup}{0}$ | $\stackrel{\text { o}}{0}$ | $\begin{aligned} & \frac{0}{0} \\ & 0 \\ & \hline \end{aligned}$ | $\stackrel{\text { D}}{0}$ | $\infty$ | < |
|  | $\sigma$ | น | $\infty$ | $\bigcirc$ | ๓ | $\infty$ |
|  | $\bullet$ | $\bullet$ | N | $\bigcirc$ | $\bigcirc$ | $\bullet$ |
|  | - | - | - | - | - | - |
|  | * | $\checkmark$ | $\checkmark$ | * | $\checkmark$ | $\checkmark$ |
|  | - | - | - | - | - |  |
|  | $\bigcirc$ | - | $\bigcirc$ | - | - | $\bigcirc$ |
|  | $\begin{aligned} & \text { 물 } \\ & \text { ® } \\ & \text { ® } \\ & \text { 주 } \end{aligned}$ |  |  |  |  |  |
|  | $\begin{aligned} & 3 \\ & \substack{3 \\ 6} \end{aligned}$ | $\begin{aligned} & 3 \\ & \substack{3 \\ \vdots} \end{aligned}$ | $\begin{aligned} & 3 \\ & \substack{3 \\ 6} \end{aligned}$ | $\begin{aligned} & 3 \\ & \substack{3 \\ 6} \end{aligned}$ | $\begin{aligned} & 3 \\ & 0 \\ & 6 \end{aligned}$ | 3 0 0 |
|  |  |  |  |  |  |  |

## Operation

ERn (register list) $\rightarrow$ @-SP

## Assembly-Language Format

STM.L <register list>, @-SP

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

Longword

## Description

This instruction saves a group of registers specified by a register list onto the stack. The registers are saved in ascending order of register number.

Two, three, or four registers can be saved by one STM instruction. The following ranges can be specified in the register list.

Two registers: ER0-ER1, ER2-ER3, ER4-ER5, or ER6-ER7
Three registers: ER0-ER2 or ER4-ER6
Four registers: ER0-ER3 or ER4-ER7

## Available Registers

ERn: ER0 to ER7

## Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |  |  |
| - | STM.L | $\begin{aligned} & \text { (ERn-ERn+1), } \\ & @-S P \end{aligned}$ | 0 | 1 | 1 | 0 | 6 | D | F | 10 | ern | 7 |
| - | STM.L | $\begin{aligned} & \text { (ERn-ERn+2), } \\ & \text { @-SP } \end{aligned}$ | 0 | 1 | 2 | 0 | 6 | D | F | 0 | ern | 9 |
| - | STM.L | $\begin{aligned} & \text { (ERn-ERn+3), } \\ & \text { @-SP } \end{aligned}$ | 0 | 1 | 3 | 0 | 6 | D | F | 0 | ern | 11 |

## Notes

When ER7 is saved, the value after effective address calculation (after ER7 is decremented by 4) is saved on the stack.

## Operation

MACH $\rightarrow$ ERd
or
MACL $\rightarrow$ ERd

## Assembly-Language Format

STMAC MAC register, ERd

## Operand Size

Longword

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\imath^{*}$ | $\imath^{*}$ | $\imath^{*}$ | - |

H: Previous value remains unchanged.
N : Set to 1 if a MAC instruction resulted in a negative MAC register value; otherwise cleared to 0 .
Z: Set to 1 if a MAC instruction resulted in a zero MAC register value; otherwise cleared to 0 .
V : Set to 1 if a MAC instruction resulted in an overflow; otherwise cleared to 0 .
C: Previous value remains unchanged.
Note: * Execution of this instruction copies the N, Z, and V flag values from the multiplier to the condition-code register (CCR). If the STMAC instruction is executed after a CLRMAC or LDMAC instruction with no intervening MAC instruction, the V flag will be 0 and the N and Z flags will have undetermined values.

## Description

This instruction moves the contents of a multiply-accumulate register (MACH or MACL) to a general register. If the transfer is from MACH, the upper 22 bits transferred to the general register are a sign extension.
This instruction is supported by the H8S/2600 CPU only.

## Available Registers

ERd: ER0 to ER7

## STMAC (STore from MAC register)

Store Data from MAC Register
Operand Format and Number of States Required for Execution

| Addressing | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ode |  |  | 1st byte |  | 2nd byte |  |  | 3rd byte | 4th byte |  |
| Register direct | STMAC | MACH, ERd | 0 | 2 | 2 | 0 | erd |  |  | 1* |
| Register direct | STMAC | MACL, ERd | 0 | 2 | 3 | 0 | erd |  |  | 1* |

Note: * A maximum of three additional states are required for execution of this instruction within three states after execution of a MAC instruction. For example, if there is a one-state instruction (such as NOP) between the MAC instruction and this instruction, this instruction will be two states longer.
The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

Notes
2.2.65 (1) SUB (B)

## SUB (SUBtract binary)

Subtract Binary

## Operation

$\mathrm{Rd}-\mathrm{Rs} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

SUB.B Rs, Rd

## Operand Size

Byte

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

H: Set to 1 if there is a borrow at bit 3; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 7; otherwise cleared to 0 .

## Description

This instruction subtracts the contents of an 8-bit register Rs (source operand) from the contents of an 8-bit register Rd (destination operand) and stores the result in the 8 -bit register Rd .

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | SUB.B | Rs, Rd | 1 | 8 | rs | rd |  |  | 1 |

## SUB (SUBtract binary)

## Notes

The SUB.B instruction can operate only on general registers. Immediate data can be subtracted from general register contents by using the SUBX instruction. Before executing SUBX \#xx:8, Rd, first set the Z flag to 1 and clear the C flag to 0 . The following coding examples can also be used to subtract nonzero immediate data \#IMM.
(1) ORC \#H'05, CCR

SUBX \#(IMM-1),Rd
(2) ADD \#(0-IMM), Rd

XORC \#H'01,CCR
2.2.65 (2) SUB (W)

## SUB (SUBtract binary)

Subtract Binary

## Operation

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

## Assembly-Language Format

SUB.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}: \quad$ Set to 1 if there is a borrow at bit 11 ; otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 15 ; otherwise cleared to 0 .

## Description

This instruction subtracts a source operand from the contents of a 16-bit register Rd (destination operand) and stores the result in the 16-bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte |  | 3rd byte | 4th byte |  |  |
| Immediate | SUB.W | \#xx:16, Rd | 7 | 9 | 3 | rd | IMM |  | 2 |
| Register direct | SUB.W | Rs, Rd | 1 | 9 | rs | rd |  |  | 1 |

## Notes

2.2.65 (3) SUB (L)

## SUB (SUBtract binary)

Subtract Binary

## Operation

ERd $-(E A s) \rightarrow$ ERd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\downarrow$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

## Assembly-Language Format

SUB.L <EAs>, ERd

## Operand Size

Longword
$\mathrm{H}: ~ S e t ~ t o ~ 1 ~ i f ~ t h e r e ~ i s ~ a ~ b o r r o w ~ a t ~ b i t ~ 27 ; ~$ otherwise cleared to 0 .
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Set to 1 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 31 ; otherwise cleared to 0 .

## Description

This instruction subtracts a source operand from the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  |  | 3rd byte | 4th byte | 5th byte | 6th byte |  |
| Immediate | SUB.L | \#xx:32, ERd | 7 | A | 3 | 0 | erd |  |  |  |  | 3 |
| Register direct | SUB.L | ERs, ERd | 1 | A | 1 ers |  | erd |  |  |  |  | 1 |

## Notes

## Operation

Rd - $1 \rightarrow$ ERd
Rd $-2 \rightarrow$ ERd
Rd - $4 \rightarrow$ ERd

## Assembly-Language Format

SUBS \#1,ERd
SUBS \#2, ERd
SUBS \#4, ERd

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

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.

## Operand Size

Longword

## Description

This instruction subtracts the immediate value 1,2, or 4 from the contents of a 32-bit register ERd (destination operand). Unlike the SUB instruction, it does not affect the condition-code flags.

## Available Registers

ERd: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | , |  | 3rd byte | 4th byte |  |
| Register direct | SUBS | \#1, ERd | 1 | B | 0 | 0 | erd |  |  | 1 |
| Register direct | SUBS | \#2, ERd | 1 | B | 8 | 0 | erd |  |  | 1 |
| Register direct | SUBS | \#4, ERd | 1 | B | 9 | : | erd |  |  | 1 |

## Notes

2.2.67 SUBX

SUBX (SUBtract with eXtend carry)
Subtract with Borrow

## Operation

$\mathrm{Rd}-(\mathrm{EAs})-\mathrm{C} \rightarrow \mathrm{Rd}$

## Assembly-Language Format

SUBX <EAs>, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\imath$ | - | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

$\mathrm{H}: ~$ Set to 1 if there is a borrow at bit 3; otherwise cleared to 0 .
N : Set to 1 if 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 if an overflow occurs; otherwise cleared to 0 .
C: Set to 1 if there is a borrow at bit 7; otherwise cleared to 0 .

## Description

This instruction subtracts the source operand and carry flag from the contents of an 8-bit register Rd (destination operand) and stores the result in the 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |  |
| Immediate | SUBX | \#xx:8, Rd | B | rd | IMM |  |  |  | 1 |
| Register direct | SUBX | Rs, Rd | 1 | E | rs | rd |  |  | 1 |

## Notes

## Operation

@ERd - $0 \rightarrow$ set/clear CCR
$1 \rightarrow$ (<bit $7>$ of @ERd)

## Assembly-Language Format

TAS @ERd

## Operand Size

Byte

## Condition Code

| I | UI |  | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\hat{\imath}$ | $\hat{\imath}$ | 0 | - |  |

H: Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction tests a memory operand by comparing it with zero, and sets the condition-code register according to the result. Then it sets the most significant bit (bit 7) of the operand to 1 .

## Available Registers

ERd: ER0, ER1, ER4, ER5

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  | 仡 |  |  |
| Register indirect | TAS | @ERd | 0 | 1 | E | 0 | 7 | B | 0 | erd | C | 4 |

## Notes

### 2.2.69 TRAPA

TRAPA (TRAP Always)
Trap Unconditionally

## Operation

- When EXR is invalid

PC $\rightarrow$-SP
CCR $\rightarrow$ @-SP
$<$ Vector> $\rightarrow$ PC

- When EXR is valid
$\mathrm{PC} \rightarrow$ @-SP
CCR $\rightarrow$ @-SP
EXR $\rightarrow$ @-SP
$<$ Vector $>\rightarrow$ PC


## Assembly-Language Format

TRAPA \#x:2

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $*$ | - | - | - | - | - | - |

I: Always set to 1 .
UI: See note.
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.

Note: * The UI bit is set to 1 when used as an interrupt mask bit, but retains its previous value when used as a user bit. For details, see the relevant microcontroller hardware manual.

## Operand Size

## Description

This instruction pushes the program counter (PC) and condition-code register (CCR) onto the stack, then sets the I bit to 1 . If the extended control register (EXR) is valid, EXR is also saved onto the stack, but bits I2 to I0 are not modified. Next execution branches to a new address given by the contents of the vector address corresponding to the specified vector number. The PC value pushed onto the stack is the starting address of the next instruction after the TRAPA instruction.

| \#x | Vector Address |  |
| :---: | :---: | :---: |
|  | Normal Mode | Advanced Mode |
| 0 | H'0010 to H'0011 | H'000020 to H'000023 |
| 1 | H'0012 to H'0013 | H'000024 to H'000027 |
| 2 | H'0014 to H'0015 | H'000028 to H'00002B |
| 3 | H'0016 to H'0017 | H'00002C to H'00002F |

TRAPA (TRAP Always)
Trap Unconditionally

## Operand Format and Number of States Required for Execution

| A | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  | 1st byte |  | 2nd byte |  | 3rd byte | 4th byte |  |
| Register direct | TRAPA | \#x:2 | 5 | 7 | 001MM | 0 |  |  | 7* |

Note: * Eight states when EXR is valid.

## Notes

The stack and vector structure differ between normal mode and advanced mode, and depending on whether EXR is valid or invalid.
2.2.70 (1) XOR (B)

XOR (eXclusive OR logical)
Exclusive Logical OR

## Operation

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

## Assembly-Language Format

XOR.B <EAs>, Rd

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction exclusively ORs the source operand with the contents of an 8-bit register Rd (destination operand) and stores the result in the 8-bit register Rd.

## Available Registers

Rd: R0L to R7L, R0H to R7H
Rs: R0L to R7L, R0H to R7H

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Immediate | XOR.B | \#xx:8, Rd | D | rd | IMM |  |  |  | 1 |
| Register direct | XOR.B | Rs, Rd | 1 | 5 | rs | rd |  |  | 1 |

## Notes

2.2.70 (2) XOR (W)

XOR (eXclusive OR logical)
Exclusive Logical OR

## Operation

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

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\imath$ | $\imath$ | 0 | - |

## Assembly-Language Format

XOR.W <EAs>, Rd

## Operand Size

Word
$\mathrm{H}:$ Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z: Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction exclusively ORs the source operand with the contents of a 16-bit register Rd (destination operand) and stores the result in the 16-bit register Rd.

## Available Registers

Rd: R0 to R7, E0 to E7
Rs: R0 to R7, E0 to E7

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte | 2nd byte | 3rd byte | 4th byte |  |  |  |
| Immediate | XOR.W | \#xx:16, Rd | 7 | 9 | 5 | rd | IMM |  | 2 |
| Register direct | XOR.W | Rs, Rd | 6 | 5 | rs | rd |  |  | 1 |

## Notes

2.2.70 (3) XOR (L)

XOR (eXclusive OR logical)
Exclusive Logical OR

## Operation

$\mathrm{ERd} \oplus(\mathrm{EAs}) \rightarrow \mathrm{ERd}$

## Assembly-Language Format

XOR.L <EAs>, ERd

## Operand Size

Longword

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\downarrow$ | $\imath$ | 0 | - |

H : Previous value remains unchanged.
N : Set to 1 if the result is negative; otherwise cleared to 0 .
Z : Set to 1 if the result is zero; otherwise cleared to 0 .
V: Always cleared to 0 .
C: Previous value remains unchanged.

## Description

This instruction exclusively ORs the source operand with the contents of a 32-bit register ERd (destination operand) and stores the result in the 32-bit register ERd.

## Available Registers

ERd: ER0 to ER7
ERs: ER0 to ER7

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte | 6th byte |  |
| Immediate | XOR.L | \#xx:32, ERd | 7 | A | 5 | 0 erd | IMM |  |  |  |  |  | 3 |
| Register direct | XOR.L | ERs, ERd | 0 | 1 | F | 0 | 6 | 5 | ers | 0 erd |  |  | 2 |

## Notes

2.2.71 (1) XORC

XORC (eXclusive OR Control register)
Exclusive Logical OR with CCR

## Operation

$\mathrm{CCR} \oplus \# \mathrm{IMM} \rightarrow \mathrm{CCR}$

## Assembly-Language Format

XORC \#xx:8,CCR

## Operand Size

Byte

Condition Code

| I | UI | H | U | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ | $\imath$ |

I: Stores the corresponding bit of the result.
UI: Stores the corresponding bit of the result.
H: Stores the corresponding bit of the result.
U : Stores the corresponding bit of the result.
N : Stores the corresponding bit of the result.
Z: Stores the corresponding bit of the result.
V: Stores the corresponding bit of the result.
C: Stores the corresponding bit of the result.

## Description

This instruction exclusively ORs the contents of the condition-code register (CCR) with immediate data and stores the result in the condition-code register. No interrupt requests, including NMI, are accepted immediately after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing <br> Mode | Mnemonic | Operands | Instruction Format |  |  |  |  | No. of <br> States |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte | 4th byte |  |
| Immediate | XORC | $\# x x: 8, ~ C C R ~$ | 0 | 5 | IMM |  |  | 1 |

## Notes

2.2.71 (2) XORC

XORC (eXclusive OR Control register)
Exclusive Logical OR with EXR

## Operation

EXR $\oplus$ \#IMM $\rightarrow$ EXR

## Assembly-Language Format

XORC \#xx:8,EXR

## Condition Code

| I | UI | H | U | N | Z | V | C |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

$\mathrm{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.

## Operand Size

Byte

## Description

This instruction exclusively ORs the contents of the extended control register (EXR) with immediate data and stores the result in the extended control register. No interrupt requests, including NMI, are accepted for three states after execution of this instruction.

Operand Format and Number of States Required for Execution

| Addressing Mode | Mnemonic | Operands | Instruction Format |  |  |  |  |  |  | No. of States |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  |
| Immediate | XORC | \#xx:8, EXR | 0 | 1 | 4 | 1 | 0 | 5 | IMM | 2 |

## Notes

### 2.3 Instruction Set

Table 2.1 Instruction Set


(2) Arithmetic Operation Instructions



(3) Logic Operation Instructions

(4) Shift Instructions


(5) Bit Manipulation Instructions




Section 2 Instruction Descriptions
(6) Branch Instructions


(7) System Control Instructions



Section 2 Instruction Descriptions
（8）Block Transfer Instructions

| Mnemonic |  | Size | Addressing Mode and Instruction Length（Bytes） |  |  |  |  |  |  |  |  | Operation | Condition Code |  |  |  |  |  | No．of States＊${ }^{* 1}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \times \\ & \times \\ & \text { * } \end{aligned}$ | $\underset{\sim}{¢}$ | $\begin{aligned} & \text { ᄃ } \\ & \text { ¢ } \\ & \text { ® } \end{aligned}$ |  |  | $\begin{aligned} & \text { ⿷匚 } \\ & \text { ©( } \end{aligned}$ | $\begin{aligned} & \text { O} \\ & \text { क्0 } \\ & \text { (8) } \end{aligned}$ | $\begin{aligned} & \text { ๔్ } \\ & \text { ®®) } \\ & \text { (8) } \end{aligned}$ | 1 |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 |  |  |  |  |  |  |  |  | H |  | N | Z | V | C | 2 | $\frac{3}{4}$ |  |  |
| EEPMOV | EEPMOV．B |  | － |  |  |  |  |  |  |  |  | 4 | $\begin{aligned} & \text { if R4L } \neq 0 \\ & \text { Repeat @ER5 }+\rightarrow \text { @ER6+ } \\ & \text { ER5 }+1 \rightarrow \text { ER5 } \\ & \text { ER6+1 }+ \text { ER6 } \\ & \text { R4L-1 } \rightarrow \text { R4L } \\ & \text { Until R4L=0 } \\ & \text { else next; } \\ & \hline \end{aligned}$ | － | － | － | － | － | － |  |  |
|  | EEPMOV．W |  | － |  |  |  |  |  |  |  |  | 4 | ```if \(\mathrm{R} 4 \neq 0\) Repeat @ER5+ \(\rightarrow\) @ER6+ ER5 \(+1 \rightarrow\) ER5 ER6+1 \(\rightarrow\) ER6 R4-1 \(\rightarrow 4\) Until R4=0 else next;``` | － | － | － | － | － | － |  |  |

[^6]
### 2.4 Instruction Code

Table 2.2 Instruction Codes


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  | 9th byte | 10th byte |
| Bcc | BCC d:16 (BHS d:16) | - | 5 | 8 | $4 \quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BCS d:8 (BLO d:8) | - | 4 | 5 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BCS d:16 (BLO d:16) | - | 5 | 8 | $5 \vdots 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BNE d:8 | - | 4 | 6 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BNE d:16 | - | 5 | 8 | $6 \quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BEQ d:8 | - | 4 | 7 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BEQ d:16 | - | 5 | 8 | $7 \quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BVC d:8 | - | 4 | 8 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BVC d:16 | - | 5 | 8 | 8 \ 0 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BVS d:8 | - | 4 | 9 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BVS d:16 | - | 5 | 8 | $9 \quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BPL d:8 | - | 4 | A | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BPL d:16 | - | 5 | 8 | A $\vdots 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BMI d:8 | - | 4 | B | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BMI d:16 | - | 5 | 8 | B $\vdots 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BGE d:8 | - | 4 | C | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BGE d:16 | - | 5 | 8 | C $\quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BLT d:8 | - | 4 | D | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BLT d:16 | - | 5 | 8 | D $\vdots 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BGT d:8 | - | 4 | E | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BGT d:16 | - | 5 | 8 | E $\quad 0$ | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BLE d:8 | - | 4 | F | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BLE d:16 | - | 5 | 8 | F 0 | disp |  |  |  |  |  |  |  |  |  |  |  |  |  |
| BCLR | BCLR \#xx:3,Rd | B | 7 | 2 | 0:IMM: rd |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BCLR \#xx:3,@ERd | B | 7 | D | 0 erd: 0 | 7 | 2 | IMM | 0 |  |  |  |  |  |  |  |  |  |  |
|  | BCLR \#xx:3,@aa:8 | B | 7 | F | abs | 7 | 2 | IMM |  |  |  |  |  |  |  |  |  |  |  |
|  | BCLR \#xx:3,@aa:16 | B | 6 | A | 1 \% 8 | abs |  |  |  | 7 | 2 | 0 :IMM |  |  |  |  |  |  |  |
|  | BCLR \#xx:3,@aa:32 | B | 6 | A | $3 \quad 8$ | abs |  |  |  |  |  |  |  | 7 | 2 | 0 :IMM |  |  |  |
|  | BCLR Rn,Rd | B | 6 | 2 | rn $\vdots$ rd |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BCLR Rn, @ERd | B | 7 | D | 0 : erd 0 | 6 | 2 | rn $\vdots$ | 0 |  |  |  |  |  |  |  |  |  |  |
|  | BCLR Rn, @aa:8 | B | 7 | F | abs | 6 | 2 | rn | 0 |  |  |  |  |  |  |  |  |  |  |
|  | BCLR Rn,@aa:16 | B | 6 | A | 1 ) 8 | abs |  |  |  | 6 | 2 | rn |  |  |  |  |  |  |  |
|  | BCLR Rn,@aa:32 | B | 6 | A | $3 \quad 8$ | abs |  |  |  |  |  |  |  | 6 | 2 | rn | 0 |  |  |


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte | 9th byte | 10th byte |
| BIAND | BIAND \#xx:3,Rd | B | 7 | 6 | 1 :IMM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BIAND \#xx:3, @ERd | B | 7 | C | 0 ! erd | 0 | 7 | 6 | 1:IMM: | 0 |  |  |  |  |  |  |  |  |  |
|  | BIAND \#xx:3, @aa:8 | B | 7 | E | ab |  | 7 | 6 | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BIAND \#xx:3, @aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  | 7 | 6 | 1 :IMM: |  |  |  |  |  |  |
|  | BIAND \#xx:3, @aa:32 | B | 6 | A | $3 \vdots$ | 0 | abs |  |  |  |  |  |  |  | 7 | 6 | $1: \mathrm{IMM} \mathbf{S} 0$ |  |  |
| BILD | BILD \#xx:3,Rd | B | 7 | 7 | 1 :IMM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BILD \#xx:3,@ERd | B | 7 | C | 0 ! erd | 0 | 7 | 7 | 1 IMM |  |  |  |  |  |  |  |  |  |  |
|  | BILD \#xx:3,@aa:8 | B | 7 | E | ab |  | 7 | 7 | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BILD \#xx:3,@aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  | 7 | 7 | 1 :IMM: | 0 |  |  |  |  |  |
|  | BILD \#xx:3, @aa:32 | B | 6 | A | $3 \vdots$ | 0 | abs |  |  |  |  |  |  |  | 7 | 7 | 1:IMM: 0 |  |  |
| BIOR | BIOR \#xx:3,Rd | B | 7 | 4 | 1 :IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BIOR \#xx:3,@ERd | B | 7 | C | 0 erd | 0 | 7 | 4 | 1 :IMM: | 0 |  |  |  |  |  |  |  |  |  |
|  | BIOR \#xx:3,@aa:8 | B | 7 | E | ab |  | 7 | 4 | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BIOR \#xx:3,@aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  | 7 | 4 | 1 ! MM : | 0 |  |  |  |  |  |
|  | BIOR \#xx:3,@aa:32 | B | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 4 | 1 I MM : 0 |  |  |
| BIST | BIST \#xx:3,Rd | B | 6 | 7 | 1 :IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BIST \#xx:3,@ERd | B | 7 | D | $0 \vdots$ erd | 0 | 6 |  | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BIST \#xx:3,@aa:8 | B | 7 | F | ab |  | 6 | 7 | 1 IMM: | 0 |  |  |  |  |  |  |  |  |  |
|  | BIST \#xx:3,@aa:16 | B | 6 | A | 1 | 8 | abs |  |  |  | 6 | 7 | 1 :IMM: | 0 |  |  |  |  |  |
|  | BIST \#xx:3, @aa:32 | B | 6 | A | $3 \vdots$ | 8 | abs |  |  |  |  |  |  |  | 6 | 7 | 1:IMM |  |  |
| BIXOR | BIXOR \#xx:3,Rd | B | 7 | 5 | 1 :IMM |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BIXOR \#xx:3,@ERd | B | 7 | C | 0 ; erd | 0 | 7 | 5 | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BIXOR \#xx:3,@aa:8 | B | 7 | E | ab |  | 7 | 5 | 1 IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BIXOR \#xx:3,@aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  | 7 | 5 | 1 :IMM: |  |  |  |  |  |  |
|  | BIXOR \#xx:3,@aa:32 | B | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 5 | 1:IMM |  |  |
| BLD | BLD \#xx:3,Rd | B | 7 | 7 | 0:IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BLD \#xx:3,@ERd | B | 7 | C | 0 erd | 0 | 7 | 7 | 0 :IMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BLD \#xx:3,@aa:8 | B | 7 | E | ab |  | 7 | 7 | 0 OIMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BLD \#xx:3,@aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  | 7 | 7 | 0 :IMM; | 0 |  |  |  |  |  |
|  | BLD \#xx:3,@aa:32 | B | 6 | A | 3 | 0 | abs |  |  |  |  |  |  |  | 7 | 7 | 0 IMM |  |  |
| BNOT | BNOT \#xx:3,Rd | B | 7 | 1 | 0 :IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BNOT \#xx:3,@ERd | B | 7 | D | 0 erd | 0 | 7 | 1 | 0 OIMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BNOT \#xx:3,@aa:8 | B | 7 | F | abs |  | 7 | 1 | 0 OIMM | 0 |  |  |  |  |  |  |  |  |  |
|  | BNOT \#xx:3,@aa:16 | B | 6 | A | 1 | 8 | abs |  |  |  | 7 | 1 | 0 | 0 |  |  |  |  |  |
|  | BNOT \#xx:3,@aa:32 | B | 6 | A | 3 | 8 | abs |  |  |  |  |  |  |  | 7 | 1 | 0:IMM |  |  |
|  | BNOT Rn,Rd | B | 6 | 1 | rn | rd |  |  |  |  |  |  |  |  |  |  |  |  |  |



| Instruction <br> BXOR | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte | 7th byte |  | 8th byte | 9th byte | 10th byte |
|  | BXOR \#xx:3,Rd | B | 7 | 5 | 0 : IMM | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | BXOR \#xx:3, @ERd | B | 7 | C | 0 erd | 0 | 7 | 5 | 0 :IMM |  |  |  |  |  |  |  |  |  |
|  | BXOR \#xx:3, @aa:8 | B | 7 | E | ab |  | 7 | 5 | 0 :IMM |  |  |  |  |  |  |  |  |  |
|  | BXOR \#xx:3,@aa:16 | B | 6 | A | 1 | 0 | abs |  |  |  |  | 5 | 0 :IMM |  |  |  |  |  |
|  | BXOR \#xx:3,@aa:32 | B | 6 | A | 3 | 0 | abs |  |  |  |  |  |  | 7 | 5 | 0 :IMM 0 |  |  |
| CLRMAC*1 | CLRMAC | - | 0 | 1 | A |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CMP | CMP.B \#xx:8,Rd | B | A | rd | IMM |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | CMP.B Rs, Rd | B | 1 | C | rs | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | CMP.W \#xx:16,Rd | W | 7 | 9 | 2 | rd | IMM |  |  |  |  |  |  |  |  |  |  |  |
|  | CMP.W Rd,Rd | W | 1 | D | rs | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | CMP.L \#xx:32,ERd | L | 7 | A | 2 | 0 : erd | IMM |  |  |  |  |  |  |  |  |  |  |  |
|  | CMP.L ERs,ERd | L | 1 | F | 1 ers | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |
| DAA | DAA Rd | B | 0 | F | 0 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
| DAS | DAS Rd | B | 1 | F | 0 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
| DEC | DEC.B Rd | B | 1 | A | 0 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | DEC.W \#1,Rd | W | 1 | B | 5 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | DEC.W \#2,Rd | W | 1 | B | D | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | DEC.L \#1,ERd | L | 1 | B | 7 | 0 ; erd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | DEC.L \#2,ERd | L | 1 | B |  | 0 erd |  |  |  |  |  |  |  |  |  |  |  |  |
| DIVXS | DIVXS.B Rs, Rd | B | 0 | 1 | D | 0 | 5 | 1 | rs | rd |  |  |  |  |  |  |  |  |
|  | DIVXS.W Rs,ERd | W | 0 | 1 | D | 0 | 5 | 3 | rs | 0 : erd |  |  |  |  |  |  |  |  |
| DIVXU | DIVXU.B Rs,Rd | B | 5 | 1 | rs | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | DIVXU.W Rs, ERd | W | 5 | 3 | rs | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |
| EEPMOV | EEPMOV.B | - | 7 | B | 5 | C | 5 | 9 | 8 | F |  |  |  |  |  |  |  |  |
|  | EEPMOV.W | - | 7 | B | D | 4 | 5 | 9 | 8 | F |  |  |  |  |  |  |  |  |
| EXTS | EXTS.W Rd | W | 1 | 7 | D | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | EXTS.L ERd | L | 1 | 7 | F | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |
| EXTU | EXTU.W Rd | W | 1 | 7 | 5 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | EXTU.L ERd | L | 1 | 7 | 7 | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |
| INC | INC.B Rd | B | 0 | A | 0 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | INC.W \#1,Rd | W | 0 | B | 5 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | INC.W \#2,Rd | W | 0 | B | D | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | INC.L \#1,ERd | L | 0 | B | 7 | 0 ; erd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | INC.L \#2,ERd | L | 0 | B | F | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |



| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte | 5th byte | 6th byte | 7th byte | 8th byte | 9th byte | 10th byte |
| MOV | MOV.B @ aa:32,Rd | B | 6 | A | 2 | rd | abs |  |  |  |  |  |  |  |  |
|  | MOV.B Rs, @ERd | B | 6 | 8 | 1 erd | rs |  |  |  |  |  |  |  |  |  |
|  | MOV.B Rs, @(d:16,ERd) | B | 6 | E | 1 erd | rs |  |  |  |  |  |  |  |  |  |
|  | MOV.B Rs,@(d:32,ERd) | B | 7 | 8 | $0 \vdots$ erd | 0 |  | A | A $\vdots$ rs | disp |  |  |  |  |  |
|  | MOV.B Rs, @-ERd | B | 6 | C | 1 erd | rs |  |  |  |  |  |  |  |  |  |
|  | MOV.B Rs, @aa:8 | B | 3 | rs | ab |  |  |  |  |  |  |  |  |  |  |
|  | MOV.B Rs, @aa:16 | B | 6 | A | 8 | rs |  |  | s |  |  |  |  |  |  |
|  | MOV.B Rs, @aa:32 | B | 6 | A | A | rs | abs |  |  |  |  |  |  |  |  |
|  | MOV.W \#xx:16,Rd | W | 7 | 9 | 0 | rd | IMM |  |  |  |  |  |  |  |  |
|  | MOV.W Rs,Rd | W | 0 | D | rs | rd |  |  |  |  |  |  |  |  |  |
|  | MOV.W @ERs,Rd | W | 6 | 9 | $0 \vdots$ ers | rd |  |  |  |  |  |  |  |  |  |
|  | MOV.W @(d:16,ERs),Rd | W | 6 | F | 0 ers | rd | disp |  |  |  |  |  |  |  |  |
|  | MOV.W @(d:32,ERs),Rd | W | 7 | 8 | 0 ers | 0 | 6 | B | $2 \vdots$ rd | disp |  |  |  |  |  |
|  | MOV.W @ERs+,Rd | W | 6 | D | 0 ers | rd |  |  |  |  |  |  |  |  |  |
|  | MOV.W @aa:16,Rd | W | 6 | B | 0 | rd |  |  | bs |  |  |  |  |  |  |
|  | MOV.W @aa:32,Rd | W | 6 | B | 2 | rd | abs |  |  |  |  |  |  |  |  |
|  | MOV.W Rs, @ERd | W | 6 | 9 | 1 erd | rs |  |  |  |  |  |  |  |  |  |
|  | MOV.W Rs, @ (d:16,ERd) | W | 6 | F | 1 erd | rs | disp |  |  |  |  |  |  |  |  |
|  | MOV.W Rs, @ (d:32,ERd) | W | 7 | 8 | 0 | 0 | 6 | B | A $\vdots$ rs | disp |  |  |  |  |  |
|  | MOV.W Rs, @-ERd | W | 6 | D | 1 erd | rs |  |  |  |  |  |  |  |  |  |
|  | MOV.W Rs, @aa:16 | W | 6 | B | 8 | rs |  |  | bs |  |  |  |  |  |  |
|  | MOV.W Rs, @aa:32 | W | 6 | B | A | rs | abs |  |  |  |  |  |  |  |  |
|  | MOV.L \#xx:32,Rd | L | 7 | A | 0 | 0 erd | IMM |  |  |  |  |  |  |  |  |
|  | MOV.L ERs, ERd | L | 0 | F | 1 | 0 erd |  |  |  |  |  |  |  |  |  |
|  | MOV.L @ERs,ERd | L | 0 | 1 | 0 | 0 | 6 | 9 | 0 ers:0 erd |  |  |  |  |  |  |
|  | MOV.L @ (d:16,ERs),ERd | L | 0 | 1 | 0 | 0 | 6 | F | 0 ers 0 erd | disp |  |  |  |  |  |
|  | MOV.L @ (d:32,ERs),ERd | L | 0 | 1 | 0 | 0 | 7 | 8 | 0 ers 0 | $6 \vdots$ B | $2 \div 0 ;$ erd | disp |  |  |  |
|  | MOV.L @ERs+,ERd | L | 0 | 1 | 0 | 0 | 6 | D | $0 \vdots$ ers 0 0 erd |  |  |  |  |  |  |
|  | MOV.L @ aa:16,ERd | L | 0 | 1 | 0 | 0 | 6 | B | 0 0 erd | abs |  |  |  |  |  |
|  | MOV.L @ aa:32,ERd | L | 0 | 1 | 0 | 0 | 6 | B | 2 0 erd | abs |  |  |  |  |  |
|  | MOV.L ERs, @ERd | L | 0 | 1 | 0 | 0 | 6 | 9 | 1 erd 0 ers |  |  |  |  |  |  |
|  | MOV.L ERs, @(d:16,ERd) | L | 0 | 1 | 0 | 0 | 6 | F | 1 erd 0 ers | disp |  |  |  |  |  |
|  | MOV.L ERs, @(d:32,ERd)*2 | L | 0 | 1 | 0 | 0 | 7 | 8 | 0 erd 0 | $6 \vdots$ B | A 0 0 ers | disp |  |  |  |
|  | MOV.L ERs, @-ERd | L | 0 | 1 | 0 | 0 | 6 | D | 1 erd 0 ers |  |  |  |  |  |  |
|  | MOV.L ERs, @aa:16 | L | 0 | 1 | 0 | 0 | 6 | B | 8 \% 0 | abs |  |  |  |  |  |
|  | MOV.L ERs, @aa:32 | L | 0 | 1 | 0 | 0 | 6 | B | A $0 \vdots$ ers | abs |  |  |  |  |  |


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | byte |  |  | 4th byte | 5th byte | 6th byte | 7th byte | 8th byte | 9th byte | 10th byte |
| MOVFPE | MOVFPE @aa:16,Rd | B | 6 | A | 4 | rd | abs |  |  |  |  |  |  |  |  |
| MOVTPE | MOVTPE Rs,@aa:16 | B | 6 | A | C | rs | abs |  |  |  |  |  |  |  |  |
| MULXS | MULXS.B Rs,Rd | B | 0 | 1 | C | 0 | 5 | 0 | rs $\vdots$ rd |  |  |  |  |  |  |
|  | MULXS.W Rs,ERd | W | 0 | 1 | C | 0 |  | 2 | rs 0 : erd |  |  |  |  |  |  |
| MULXU | MULXU.B Rs,Rd | B | 5 | 0 | rs | rd |  |  |  |  |  |  |  |  |  |
|  | MULXU.W Rs,ERd | W | 5 | 2 | rs | 0; erd |  |  |  |  |  |  |  |  |  |
| NEG | NEG.B Rd | B | 1 | 7 | 8 | rd |  |  |  |  |  |  |  |  |  |
|  | NEG.W Rd | W | 1 | 7 | 9 | rd |  |  |  |  |  |  |  |  |  |
|  | NEG.L ERd | L | 1 | 7 | B | 0 : erd |  |  |  |  |  |  |  |  |  |
| NOP | NOP | - | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |
| NOT | NOT.B Rd | B | 1 | 7 | 0 | rd |  |  |  |  |  |  |  |  |  |
|  | NOT.W Rd | W | 1 | 7 |  | rd |  |  |  |  |  |  |  |  |  |
|  | NOT.L ERd | L | 1 | 7 |  | 0; erd |  |  |  |  |  |  |  |  |  |
| OR | OR.B \#xx:8,Rd | B | C | rd |  |  |  |  |  |  |  |  |  |  |  |
|  | OR.B Rs,Rd | B | 1 | 4 | rs | rd |  |  |  |  |  |  |  |  |  |
|  | OR.W \#xx:16,Rd | W | 7 | 9 | 4 | rd | IMM |  |  |  |  |  |  |  |  |
|  | OR.W Rs, Rd | W | 6 | 4 | rs | rd |  |  |  |  |  |  |  |  |  |
|  | OR.L \#xx:32,ERd | L | 7 | A | 4 | 0: erd | IMM |  |  |  |  |  |  |  |  |
|  | OR.L ERs,ERd | L | 0 | 1 | F | 0 | 6 | 4 | $0 \vdots$ ers $0 \vdots$ erd |  |  |  |  |  |  |
| ORC | ORC \#xx:8,CCR | B | 0 | 4 | IMM |  |  |  |  |  |  |  |  |  |  |
|  | ORC \#xx:8,EXR | B | 0 | 1 | 4 | 1 | 0 | 4 | IMM |  |  |  |  |  |  |
| POP | POP.W Rn | W | 6 | D | 7 | rn |  |  |  |  |  |  |  |  |  |
|  | POP.L ERn | L | 0 | 1 | 0 | 0 | 6 | D | $7 \quad 0 \vdots$ ern |  |  |  |  |  |  |
| PUSH | PUSH.W Rn | W | 6 | D | F | rn |  |  |  |  |  |  |  |  |  |
|  | PUSH.L ERn | L | 0 | 1 | 0 | 0 |  | D | F $\quad 0 \vdots$ ern |  |  |  |  |  |  |
| ROTL | ROTL.B Rd | B | 1 | 2 | 8 | rd |  |  |  |  |  |  |  |  |  |
|  | ROTL.B \#2,Rd | B | 1 | 2 | C | rd |  |  |  |  |  |  |  |  |  |
|  | ROTL.W Rd | W | 1 | 2 | 9 | rd |  |  |  |  |  |  |  |  |  |
|  | ROTL.W \#2,Rd | W | 1 | 2 | D | rd |  |  |  |  |  |  |  |  |  |
|  | ROTL.L ERd | L | 1 | 2 | B | 0; erd |  |  |  |  |  |  |  |  |  |
|  | ROTL.L \#2,ERd | L | 1 | 2 | F | 0 : erd |  |  |  |  |  |  |  |  |  |
| ROTR | ROTR.B Rd | B | 1 | 3 | 8 | rd |  |  |  |  |  |  |  |  |  |
|  | ROTR.B \#2,Rd | B | 1 | 3 | C | rd |  |  |  |  |  |  |  |  |  |
|  | ROTR.W Rd | W | 1 | 3 | 9 | rd |  |  |  |  |  |  |  |  |  |
|  | ROTR.W \#2,Rd | W | 1 | 3 | D | rd |  |  |  |  |  |  |  |  |  |


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | yte |  | byte | 3rd byte | 4th byte | 5th byte | 6th byte | 7th byte | 8th byte | 9th byte | 10th byte |
| ROTR | ROTR.L ERd | L | 1 | 3 | B | 0 erd |  |  |  |  |  |  |  |  |
|  | ROTR.L \#2,ERd | L | 1 | 3 |  | 0 erd |  |  |  |  |  |  |  |  |
| ROTXL | ROTXL.B Rd | B | 1 | 2 |  |  |  |  |  |  |  |  |  |  |
|  | ROTXL.B \#2,Rd | B | 1 | 2 | 4 | ! rd |  |  |  |  |  |  |  |  |
|  | ROTXL.W Rd | W | 1 | 2 | 1 | \% rd |  |  |  |  |  |  |  |  |
|  | ROTXL.W \#2,Rd | W | 1 | 2 | 5 | \% rd |  |  |  |  |  |  |  |  |
|  | ROTXL.L ERd | L | 1 | 2 |  | 0: erd |  |  |  |  |  |  |  |  |
|  | ROTXL.L \#2,ERd | L | 1 | 2 | 7 | 0 erd |  |  |  |  |  |  |  |  |
| ROTXR | ROTXR.B Rd | B | 1 | 3 | 0 | rd |  |  |  |  |  |  |  |  |
|  | ROTXR.B \#2,Rd | B | 1 | 3 | 4 | rd |  |  |  |  |  |  |  |  |
|  | ROTXR.W Rd | W | 1 | 3 | 1 | rd |  |  |  |  |  |  |  |  |
|  | ROTXR.W \#2,Rd | W | 1 | 3 |  | rd |  |  |  |  |  |  |  |  |
|  | ROTXR.L ERd | L | 1 | 3 |  | 0 erd |  |  |  |  |  |  |  |  |
|  | ROTXR.L \#2,ERd | L | 1 | 3 |  | $0 \vdots$ erd |  |  |  |  |  |  |  |  |
| RTE | RTE | - | 5 | 6 | 7 | 0 |  |  |  |  |  |  |  |  |
| RTS | RTS | - | 5 | 4 | 7 | 0 |  |  |  |  |  |  |  |  |
| SHAL | SHAL.B Rd | B | 1 | 0 | 8 | \% rd |  |  |  |  |  |  |  |  |
|  | SHAL.B \#2,Rd | B | 1 | 0 | C | ! rd |  |  |  |  |  |  |  |  |
|  | SHAL.W Rd | W | 1 | 0 | 9 | \% rd |  |  |  |  |  |  |  |  |
|  | SHAL.W \#2,Rd | W | 1 | 0 | D | rd |  |  |  |  |  |  |  |  |
|  | SHAL.L ERd | L | 1 | 0 | B | 0 : erd |  |  |  |  |  |  |  |  |
|  | SHAL.L \#2,ERd | L | 1 | 0 | F | 0 erd |  |  |  |  |  |  |  |  |
| SHAR | SHAR.B Rd | B | 1 | 1 | 8 | rd |  |  |  |  |  |  |  |  |
|  | SHAR.B \#2,Rd | B | 1 | 1 | C | \% rd |  |  |  |  |  |  |  |  |
|  | SHAR.W Rd | W | 1 | 1 | 9 | \% rd |  |  |  |  |  |  |  |  |
|  | SHAR.W \#2,Rd | W | 1 | 1 | D | ! rd |  |  |  |  |  |  |  |  |
|  | SHAR.L ERd | L | 1 | 1 | B | 0; erd |  |  |  |  |  |  |  |  |
|  | SHAR.L \#2,ERd | L | 1 | 1 |  | 0 erd |  |  |  |  |  |  |  |  |
| SHLL | SHLL.B Rd | B | 1 | 0 | 0 | \% rd |  |  |  |  |  |  |  |  |
|  | SHLL.B \#2,Rd | B | 1 | 0 | 4 | rd |  |  |  |  |  |  |  |  |
|  | SHLL.W Rd | W | 1 | 0 | 1 | \% rd |  |  |  |  |  |  |  |  |
|  | SHLL.W \#2,Rd | W | 1 | 0 | 5 | ! rd |  |  |  |  |  |  |  |  |
|  | SHLL.L ERd | L | 1 | 0 | 3 | 0 erd |  |  |  |  |  |  |  |  |
|  | SHLL.L \#2,ERd | L | 1 | 0 | 7 | 0 erd |  |  |  |  |  |  |  |  |
| SHLR | SHLR.B Rd | B | 1 | 1 | 0 | $\vdots \mathrm{rd}$ |  |  |  |  |  |  |  |  |
|  | SHLR.B \#2,Rd | B | 1 | 1 | 4 | rd |  |  |  |  |  |  |  |  |


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte | 8th byte | 9th byte | 10th byte |
| SHLR | SHLR.W Rd | W | 1 | 1 | 1 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SHLR.W \#2,Rd | W | 1 | 1 |  | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SHLR.L ERd | L | 1 | 1 |  | 0; erd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SHLR.L \#2,ERd | L | 1 | 1 |  | 0 : erd |  |  |  |  |  |  |  |  |  |  |  |  |
| SLEEP | SLEEP | - | 0 | 1 | 8 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |
| STC | STC.B CCR,Rd | B | 0 | 2 | 0 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | STC.B EXR,Rd | B | 0 | 2 | 1 | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | STC.W CCR,@ERd | W | 0 | 1 | 4 | 0 | 6 | 9 | 1 !erd | 0 |  |  |  |  |  |  |  |  |
|  | STC.W EXR,@ERd | W | 0 | 1 | 4 | 1 | 6 | 9 | 1 !erd | 0 |  |  |  |  |  |  |  |  |
|  | STC.W CCR,@(d:16,ERd) | W | 0 | 1 | 4 | 0 | 6 | F | 1 !erd | 0 | disp |  |  |  |  |  |  |  |
|  | STC.W EXR,@(d:16,ERd) | W | 0 | 1 | 4 | 1 | 6 | F | 1 erd | 0 | disp |  |  |  |  |  |  |  |
|  | STC.W CCR, @ (d:32,ERd) | W | 0 | 1 | 4 | 0 | 7 | 8 | 0 erd | 0 | 6 | B | A | 0 | disp |  |  |  |
|  | STC.W EXR,@(d:32,ERd) | W | 0 | 1 | 4 | 1 | 7 | 8 | 0 erd | 0 | 6 | B | A | 0 | disp |  |  |  |
|  | STC.W CCR,@-ERd | W | 0 | 1 | 4 | 0 | 6 | D | 1 !erd | 0 |  |  |  |  |  |  |  |  |
|  | STC.W EXR, @-ERd | W | 0 | 1 | 4 | 1 | 6 | D | 1 erd | 0 |  |  |  |  |  |  |  |  |
|  | STC.W CCR,@aa:16 | W | 0 | 1 | 4 | 0 | 6 | B | 8 | 0 | abs |  |  |  |  |  |  |  |
|  | STC.W EXR,@aa:16 | W | 0 | 1 | 4 | 1 | 6 | B | 8 | 0 | abs |  |  |  |  |  |  |  |
|  | STC.W CCR,@aa:32 | W | 0 | 1 | 4 | 0 | 6 | B | A | 0 | abs |  |  |  |  |  |  |  |
|  | STC.W EXR,@aa:32 | W | 0 | 1 | 4 | 1 | 6 | B | A | 0 | abs |  |  |  |  |  |  |  |
| STM | STM.L (ERn-ERn+1),@-SP | L | 0 | 1 | 1 | 0 | 6 | D |  | 0 |  |  |  |  |  |  |  |  |
|  | STM.L (ERn-ERn+2), @-SP | L | 0 | 1 | 2 | 0 | 6 | D | F | 0 ern |  |  |  |  |  |  |  |  |
|  | STM.L (ERn-ERn+3),@-SP | L | 0 | 1 | 3 | 0 | 6 | D |  | $0 \vdots$ ern |  |  |  |  |  |  |  |  |
| STMAC*1 | STMAC MACH,ERd | L | 0 | 2 | 2 | 0: ers |  |  |  |  |  |  |  |  |  |  |  |  |
|  | STMAC MACL,ERd | L | 0 | 2 | 3 | 0\% ers |  |  |  |  |  |  |  |  |  |  |  |  |
| SUB | SUB.B Rs, Rd | B | 1 | 8 | rs | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SUB.W \#xx:16,Rd | W | 7 | 9 | 3 | rd | IMM |  |  |  |  |  |  |  |  |  |  |  |
|  | SUB.W Rs,Rd | W | 1 | 9 | rs | rd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SUB.L \#xx:32,ERd | L | 7 | A | 3 | 0\% erd | IMM |  |  |  |  |  |  |  |  |  |  |  |
|  | SUB.L ERs,ERd | L | 1 | A | 1 | 0 erd |  |  |  |  |  |  |  |  |  |  |  |  |
| SUBS | SUBS \#1,ERd | L | 1 | B |  | 0; erd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SUBS \#2,ERd | L | 1 | B | 8 | 0: erd |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SUBS \#4,ERd | L | 1 | B | 9 | 0; erd |  |  |  |  |  |  |  |  |  |  |  |  |
| SUBX | SUBX \#xx:8,Rd | B | B | rd | IMM |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | SUBX Rs, Rd | B | 1 | E | rs : | rd |  |  |  |  |  |  |  |  |  |  |  |  |
| TAS | TAS @ERd*3 | B | 0 | 1 | E | 0 | 7 | B | 0 : erd | C |  |  |  |  |  |  |  |  |
| TRAPA | TRAPA \#x:2 | - | 5 | 7 | 00: IMM | 0 |  |  |  |  |  |  |  |  |  |  |  |  |


| Instruction | Mnemonic | Size | Instruction Format |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | byte |  |  | 4th byte | 5th byte | 6th byte | 7th byte | 8th byte | 9th byte | 10th byte |
| XOR | XOR.B \#xx:8,Rd | B | D | rd |  | MM |  |  |  |  |  |  |  |  |  |
|  | XOR.B Rs, Rd | B | 1 | 5 |  | $\vdots \mathrm{rd}$ |  |  |  |  |  |  |  |  |  |
|  | XOR.W \#xx:16,Rd | W | 7 | 9 | 5 | $\vdots \mathrm{rd}$ |  |  | M |  |  |  |  |  |  |
|  | XOR.W Rs,Rd | W | 6 | 5 |  | ! rd |  |  |  |  |  |  |  |  |  |
|  | XOR.L \#xx:32,ERd | L | 7 | A |  | 0: erd |  |  | IM |  |  |  |  |  |  |
|  | XOR.LERs,ERd | L | 0 | 1 | F | 0 | 6 | 5 | 0 ers : 0\% erd |  |  |  |  |  |  |
| XORC | XORC \#xx:8,CCR | B | 0 | 5 |  | MM |  |  |  |  |  |  |  |  |  |
|  | XORC \#xx:8,EXR | B | 0 | 1 | 4 | 1 | 0 | 5 | IMM |  |  |  |  |  |  |
| Notes: 1. These instructions are supported by the H8S/2600 CPU only. <br> 2. Bit 7 of the 4th byte of the MOV.L ERs, @(d:32,ERd) instruction can be either 1 or 0 . <br> 3. Only register ERO, ER1, ER4, or ER5 should be used when using the TAS instruction. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Legend: |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| IMM: <br> abs: <br> disp: <br> rs, rd, rn: | Immediate data (2, 3, 8, 16, or 32 bits) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Absolute address (8, 16, 24, or 32 bits) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Displacement (8, 16, or 32 bits) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | Register field (4 bits specifying an 8-bit or 16-bit register. The symbols rs, rd, and rn correspond to operand symbols Rs, Rd, and Rn.) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ers, erd, ern, erm: Register field (3 bits specifying an address register or 32-bit register. The symbols ers, erd, ern, and erm correspond to oper symbols ERs, ERd, ERn, and ERm.) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| The register fields specify general registers as follows. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Address Register 32-Bit Register |  |  | 16-Bit Register |  |  |  |  |  | 8-Bit Register |  |  |  |  |  |  |
| Register Field | General Register | Register Field |  |  | General Register |  |  |  | Register Field | General Register |  |  |  |  |  |
| 000 | ER0 | 0000 |  |  | R0 |  |  |  | 0000 | ROH |  |  |  |  |  |
| 001 | ER1 | 0001 |  |  | R1 |  |  |  | 0001 | R1H |  |  |  |  |  |
|  | : | : |  |  | : |  |  |  | . | : |  |  |  |  |  |
| 111 | ER7 | $\begin{aligned} & 0111 \\ & 1000 \\ & 1001 \end{aligned}$ |  |  | R7 |  |  |  | 0111 | R7H |  |  |  |  |  |
|  |  |  |  |  | E0 |  |  |  | 1000 | ROL |  |  |  |  |  |
|  |  |  |  |  | E. |  |  |  | 1001 | R11 |  |  |  |  |  |
|  |  |  | : |  | $\vdots$ |  |  |  | . | : |  |  |  |  |  |
|  |  |  | 1111 |  | E7 |  |  |  | 1111 | R7L |  |  |  |  |  |

### 2.5 Operation Code Map

Table 2.3 shows an operation code map.
Table 2.3 Operation Code Map (1)

Operation Code: | 1st byte |  | 2nd byte |  |
| :---: | :---: | :---: | :---: |
| AH | AL | BH | BL |

Instruction when most significant bit of BH is 0 .
Operation Code:
Note: * These instructions are supported by the H8S/2600 CPU only.

Table 2.3 Operation Code Map (2)

Note: * These instructions are supported by the H8S/2600 CPU only.

## Table 2.3 Operation Code Map (3)

| Operation Code: | 1st byte |  | 2nd byte |  |  | 3rd byte |  | 4th byte |  |  |  |  | Instruction when most significant bit of DH is 0 . Instruction when most significant bit of DH is 1 . |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | AH | AL | BH | BL |  | CH | CL | DH | DL |  |  |  |  |  |  |  |  |  |
| $\text { AHALBHBLCH } \quad \text { CL }$ | 0 | 1 | 2 |  | 3 |  | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| $01 \mathrm{C05}$ | MULXS |  | MULXS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01D05 |  | DIVXS |  |  | DIVXS |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01 F06 |  |  |  |  |  |  | OR | XOR | AND |  |  |  |  |  |  |  |  |  |
| $7 \mathrm{CrO6}{ }^{* 1}$ |  |  |  |  | BTST |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $7 \mathrm{Cr} 07^{* 1}$ |  |  |  |  | BTST |  | BOR | $\frac{\text { BXOR }}{\text { BIXOR }}$ | $\underbrace{\text { BAND }}_{\text {BIAND }}$ | BLD BILD |  |  |  |  |  |  |  |  |
| 7Dr06*1 | BSET | BNOT | BCLR |  |  |  |  |  |  | $\begin{array}{ll} \text { BST } & \\ \hline \text { BIST } \end{array}$ |  |  |  |  |  |  |  |  |
| 7Dr07*1 | BSET | BNOT | BCLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7Eaa6*2 |  |  |  |  | BTST |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7Eaa7*2 |  |  |  |  | BTST |  | BOR | $\frac{\mathrm{BXOR}}{\mathrm{BIXOR}}$ | $\underbrace{\text { BAND }}_{\text {BIAND }}$ | $\text { BLD } \text { BILD }$ |  |  |  |  |  |  |  |  |
| 7Faa6*2 | BSET | BNOT | BCLR |  |  |  |  |  |  | $\begin{array}{\|cc\|} \hline \text { BST } & \\ \hline \end{array}$ |  |  |  |  |  |  |  |  |
| 7Faa7* ${ }^{\text {2 }}$ | BSET | BNOT | BCLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

[^7]Table 2.3 Operation Code Map (4)

| Operation Code: | 1st byte |  | 2nd byte |  |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | AH | AL | BH | BL |  | CH | CL | DH | DL | EH | EL |  |  | FL |  |
| Instruction when most significant bit of FH is 0 . Instruction when most significant bit of FH is 1 . |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| \| EL | 0 | 1 | 2 |  | 3 |  | 4 | 5 | 6 | 7 |  | 8 |  | 9 |  |  |  |  |  |  | A | B | C | D | E | F |
| 6A10aaaa6* |  |  |  |  | BTST |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6A10aaaa** |  |  |  |  |  |  | $\text { BOR } \mathrm{BIOR}$ | $\frac{\text { BXOR }}{\text { BIXOR }}$ | BAND BIAND | $\mathrm{B}_{\mathrm{B}}^{\mathrm{BLD}}$ |  |  |  |  |  |  |  |  |  |  |
| 6A18aaaa6* | BSET | BNOT | BCLR |  |  |  |  |  |  | $\mathrm{BST}_{\mathrm{B}}$ |  |  |  |  |  |  |  |  |  |  |
| 6A18aaaa7* |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| Operation Code: | 1st byte |  | 2nd byte |  | 3rd byte |  | 4th byte |  | 5th byte |  | 6th byte |  | 7th byte |  | 8th byte |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | AH | AL | BH | BL | CH | CL | DH | DL | EH | EL | FH | FL | GH | GL | HH | HL |


Note: * The letters "aa" indicate an absolute address field.

### 2.6 Number of States Required for Instruction Execution

The tables in this section can be used to calculate the number of states required for instruction execution by the CPU. Table 2.5 indicates the number of instruction fetch, data read/write, and other cycles occurring in each instruction. Table 2.4 indicates the number of states required for each cycle, depending on its size. The number of states required for each cycle depends on the product. See the hardware manual named for the relevant product for details. The number of states required for execution of an instruction can be calculated from these two tables as follows:

Execution states $=I \times S_{I}+J \times S_{J}+K \times S_{K}+L \times S_{L}+M \times S_{M}+N \times S_{N}$
Examples: Advanced mode, program code and stack located in external memory, on-chip supporting modules accessed in two states with 8-bit bus width, external devices accessed in three states with one wait state and 16-bit bus width.

1. BSET \#0, @FFFFC7:8

From table 2.5:

$$
\mathrm{I}=\mathrm{L}=2, \quad \mathrm{~J}=\mathrm{K}=\mathrm{M}=\mathrm{N}=0
$$

From table 2.4:

$$
\mathrm{S}_{\mathrm{I}}=4, \quad \mathrm{~S}_{\mathrm{L}}=2
$$

Number of states required for execution $=2 \times 4+2 \times 2=12$
2. JSR @ @ 30

From table 2.5:

$$
\mathrm{I}=\mathrm{J}=\mathrm{K}=2, \quad \mathrm{~L}=\mathrm{M}=\mathrm{N}=0
$$

From table 2.4:

$$
\mathrm{S}_{\mathrm{I}}=\mathrm{S}_{\mathrm{J}}=\mathrm{S}_{\mathrm{K}}=4
$$

Number of states required for execution $=2 \times 4+2 \times 4+2 \times 4=24$

Table 2.4 Number of States per Cycle
Access Conditions

| Cycle |  | On-Chip Memory | On-Chip Supporting Module |  | External Device |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 8-Bit Bus |  | 16-Bit Bus |  |
|  |  |  | $\begin{aligned} & \hline 8 \text {-Bit } \\ & \text { Bus } \end{aligned}$ | $\begin{aligned} & \text { 16-Bit } \\ & \text { Bus } \end{aligned}$ | 2-State Access | 3-State Access | 2-State Access | 3-State Access |
| Instruction fetch | S | 1 | 2 n | n | 4 | $6+2 m$ | 2 | $3+\mathrm{m}^{*}$ |
| Branch address read | S |  |  |  |  |  |  |  |
| Stack operation | $\mathrm{S}_{\mathrm{K}}$ |  |  |  |  |  |  |  |
| Byte data access | $\mathrm{S}_{\mathrm{L}}$ |  | n |  | 2 | $3+m$ |  |  |
| Word data access | $\mathrm{S}_{\text {M }}$ |  | 2 n |  | 4 | $6+2 m$ |  |  |
| Internal operation | $\mathrm{S}_{\mathrm{N}}$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Note: * For the MOVFPE and MOVTPE instructions, refer to the relevant microcontroller hardware manual.
Legend:
m: Number of wait states inserted into external device access
n : Number of states required for access to an on-chip supporting module. For the specific number, refer to the relevant microcontroller hardware manual.

Table 2.5 Number of Cycles in Instruction Execution

|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| ADD | ADD.B \#xx:8,Rd | 1 |  |  |  |  |  |
|  | ADD.B Rs,Rd | 1 |  |  |  |  |  |
|  | ADD.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | ADD.W Rs,Rd | 1 |  |  |  |  |  |
|  | ADD.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | ADD.L ERs,ERd | 1 |  |  |  |  |  |
| ADDS | ADDS \#1/2/4,ERd | 1 |  |  |  |  |  |
| ADDX | ADDX \#xx:8,Rd | 1 |  |  |  |  |  |
|  | ADDX Rs,Rd | 1 |  |  |  |  |  |
| AND | AND.B \#xx:8,Rd | 1 |  |  |  |  |  |
|  | AND.B Rs,Rd | 1 |  |  |  |  |  |
|  | AND.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | AND.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | AND.L ERs,ERd | 2 |  |  |  |  |  |
| ANDC | ANDC \#xx:8,CCR | 1 |  |  |  |  |  |
|  | ANDC \#xx:8,EXR | 2 |  |  |  |  |  |
| BAND | BAND \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BAND \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BAND \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BAND \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BAND \#xx:3,@aa:32 | 4 |  |  | 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 |  |  |  |  |  |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| Bcc | BLE d:8 | 2 |  |  |  |  |  |
|  | BRA d:16 (BT d:16) | 2 |  |  |  |  | 1 |
|  | BRN d:16 (BF d:16) | 2 |  |  |  |  | 1 |
|  | BHI d:16 | 2 |  |  |  |  | 1 |
|  | BLS d:16 | 2 |  |  |  |  | 1 |
|  | BCC d:16 (BHS d:16) | 2 |  |  |  |  | 1 |
|  | BCS d:16 (BLO d:16) | 2 |  |  |  |  | 1 |
|  | BNE d:16 | 2 |  |  |  |  | 1 |
|  | BEQ d:16 | 2 |  |  |  |  | 1 |
|  | BVC d:16 | 2 |  |  |  |  | 1 |
|  | BVS d:16 | 2 |  |  |  |  | 1 |
|  | BPL d:16 | 2 |  |  |  |  | 1 |
|  | BMI d:16 | 2 |  |  |  |  | 1 |
|  | BGE d:16 | 2 |  |  |  |  | 1 |
|  | BLT d:16 | 2 |  |  |  |  | 1 |
|  | BGT d:16 | 2 |  |  |  |  | 1 |
|  | BLE d:16 | 2 |  |  |  |  | 1 |
| BCLR | BCLR \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BCLR \#xx:3,@ERd | 2 |  |  | 2 |  |  |
|  | BCLR \#xx:3, @aa:8 | 2 |  |  | 2 |  |  |
|  | BCLR \#xx:3, @aa:16 | 3 |  |  | 2 |  |  |
|  | BCLR \#xx:3, @aa:32 | 4 |  |  | 2 |  |  |
|  | BCLR Rn,Rd | 1 |  |  |  |  |  |
|  | BCLR Rn, @ERd | 2 |  |  | 2 |  |  |
|  | BCLR Rn, @aa:8 | 2 |  |  | 2 |  |  |
|  | BCLR Rn, @aa:16 | 3 |  |  | 2 |  |  |
|  | BCLR Rn, @aa:32 | 4 |  |  | 2 |  |  |
| BIAND | BIAND \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BIAND \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BIAND \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BIAND \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BIAND \#xx:3,@aa:32 | 4 |  |  | 1 |  |  |
| BILD | BILD \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BILD \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BILD \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BILD \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BILD \#xx:3,@aa:32 | 4 |  |  | 1 |  |  |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| BIOR | BIOR \#xx:8,Rd | 1 |  |  |  |  |  |
|  | BIOR \#xx:8,@ERd | 2 |  |  | 1 |  |  |
|  | BIOR \#xx:8, @aa:8 | 2 |  |  | 1 |  |  |
|  | BIOR \#xx:8, @aa:16 | 3 |  |  | 1 |  |  |
|  | BIOR \#xx:8, @aa:32 | 4 |  |  | 1 |  |  |
| BIST | BIST \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BIST \#xx:3,@ERd | 2 |  |  | 2 |  |  |
|  | BIST \#xx:3,@aa:8 | 2 |  |  | 2 |  |  |
|  | BIST \#xx:3,@aa:16 | 3 |  |  | 2 |  |  |
|  | BIST \#xx:3,@aa:32 | 4 |  |  | 2 |  |  |
| BIXOR | BIXOR \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BIXOR \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BIXOR \#xx:3, @aa:8 | 2 |  |  | 1 |  |  |
|  | BIXOR \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BIXOR \#xx:3,@aa:32 | 4 |  |  | 1 |  |  |
| BLD | BLD \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BLD \#xx:3, @ERd | 2 |  |  | 1 |  |  |
|  | BLD \#xx:3, @aa:8 | 2 |  |  | 1 |  |  |
|  | BLD \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BLD \#xx:3, @aa:32 | 4 |  |  | 1 |  |  |
| BNOT | BNOT \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BNOT \#xx:3,@ERd | 2 |  |  | 2 |  |  |
|  | BNOT \#xx:3,@aa:8 | 2 |  |  | 2 |  |  |
|  | BNOT \#xx:3,@aa:16 | 3 |  |  | 2 |  |  |
|  | BNOT \#xx:3,@aa:32 | 4 |  |  | 2 |  |  |
|  | BNOT Rn,Rd | 1 |  |  |  |  |  |
|  | BNOT Rn, @ERd | 2 |  |  | 2 |  |  |
|  | BNOT Rn, @aa:8 | 2 |  |  | 2 |  |  |
|  | BNOT Rn, @aa:16 | 3 |  |  | 2 |  |  |
|  | BNOT Rn, @aa:32 | 4 |  |  | 2 |  |  |
| BOR | BOR \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BOR \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BOR \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BOR \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BOR \#xx:3,@aa:32 | 4 |  |  | 1 |  |  |
| BSET | BSET \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BSET \#xx:3,@ERd | 2 |  |  | 2 |  |  |
|  | BSET \#xx:3, @aa:8 | 2 |  |  | 2 |  |  |

Rev. 4.00 Feb 24, 2006 page 282 of 322
REJ09B0139-0400

|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| BSET | BSET \#xx:3, @aa:16 | 3 |  |  | 2 |  |  |
|  | BSET \#xx:3, @aa:32 | 4 |  |  | 2 |  |  |
|  | BSET Rn,Rd | 1 |  |  |  |  |  |
|  | BSET Rn, @ERd | 2 |  |  | 2 |  |  |
|  | BSET Rn, @aa:8 | 2 |  |  | 2 |  |  |
|  | BSET Rn, @aa:16 | 3 |  |  | 2 |  |  |
|  | BSET Rn, @aa:32 | 4 |  |  | 2 |  |  |
| BSR | BSR d:8 Normal | 2 |  | 1 |  |  |  |
|  | Advanced | 2 |  | 2 |  |  |  |
|  | BSR d:16 Normal | 2 |  | 1 | - |  | 1 |
|  | Advanced | 2 |  | 2 |  |  | 1 |
| BST | BST \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BST \#xx:3,@ERd | 2 |  |  | 2 |  |  |
|  | BST \#xx:3,@aa:8 | 2 |  |  | 2 |  |  |
|  | BST \#xx:3,@aa:16 | 3 |  |  | 2 |  |  |
|  | BST \#xx:3, @aa:32 | 4 |  |  | 2 |  |  |
| BTST | BTST \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BTST \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BTST \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BTST \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BTST \#xx:3, @aa:32 | 4 |  |  | 1 |  |  |
|  | BTST Rn,Rd | 1 |  |  |  |  |  |
|  | BTST Rn, @ ERd | 2 |  |  | 1 |  |  |
|  | BTST Rn, @aa:8 | 2 |  |  | 1 |  |  |
|  | BTST Rn, @aa:16 | 3 |  |  | 1 |  |  |
|  | BTST Rn, @aa:32 | 4 |  |  | 1 |  |  |
| BXOR | BXOR \#xx:3,Rd | 1 |  |  |  |  |  |
|  | BXOR \#xx:3,@ERd | 2 |  |  | 1 |  |  |
|  | BXOR \#xx:3,@aa:8 | 2 |  |  | 1 |  |  |
|  | BXOR \#xx:3,@aa:16 | 3 |  |  | 1 |  |  |
|  | BXOR \#xx:3,@aa:32 | 4 |  |  | 1 |  |  |
| CLRMAC*5 | CLRMAC | 1 |  |  |  |  | $1^{* 3 * 6}$ |
| CMP | CMP.B \#xx:8,Rd | 1 |  |  |  |  |  |
|  | CMP.B Rs,Rd | 1 |  |  |  |  |  |
|  | CMP.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | CMP.W Rs,Rd | 1 |  |  |  |  |  |
|  | CMP.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | CMP.L ERs,ERd | 1 |  |  |  |  |  |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| DAA | DAA Rd | 1 |  |  |  |  |  |
| DAS | DAS Rd | 1 |  |  |  |  |  |
| DEC | DEC.B Rd | 1 |  |  |  |  |  |
|  | DEC.W \#1/2,Rd | 1 |  |  |  |  |  |
|  | DEC.L \#1/2,ERd | 1 |  |  |  |  |  |
| DIVXS | DIVXS.B Rs,Rd | 2 |  |  |  |  | 11 |
|  | DIVXS.W Rs,ERd | 2 |  |  |  |  | 19 |
| DIVXU | DIVXU.B Rs,Rd | 1 |  |  |  |  | 11 |
|  | DIVXU.W Rs,ERd | 1 |  |  |  |  | 19 |
| EEPMOV | EEPMOV.B | 2 |  |  | $2 \mathrm{n}+2^{* 1}$ |  |  |
|  | EEPMOV.W | 2 |  |  | $2 \mathrm{n}+2^{* 1}$ |  |  |
| EXTS | EXTS.W Rd | 1 |  |  |  |  |  |
|  | EXTS.L ERd | 1 |  |  |  |  |  |
| EXTU | EXTU.W Rd | 1 |  |  |  |  |  |
|  | EXTU.L ERd | 1 |  |  |  |  |  |
| INC | INC.B Rd | 1 |  |  |  |  |  |
|  | INC.W \#1/2,Rd | 1 |  |  |  |  |  |
|  | INC.L \#1/2,ERd | 1 |  |  |  |  |  |
| JMP | JMP @ERn | 2 |  |  |  |  |  |
|  | JMP @ aa:24 | 2 |  |  |  |  | 1 |
|  | JMP @ @aa:8 Normal | 2 | 1 |  |  |  | 1 |
|  | Advanced | 2 | 2 |  |  |  | 1 |
| JSR | JSR @ERn Normal | 2 |  | 1 |  |  |  |
|  | Advanced | 2 |  | 2 |  |  |  |
|  | JSR @aa:24 Normal | 2 |  | 1 |  |  | 1 |
|  | Advanced | 2 |  | 2 |  |  | 1 |
|  | JSR @ @aa:8 Normal | 2 | 1 | 1 |  |  |  |
|  | Advanced | 2 | 2 | 2 |  |  |  |
| LDC | LDC \#xx:8,CCR | 1 |  |  |  |  |  |
|  | LDC \#xx:8,EXR | 2 |  |  |  |  |  |
|  | LDC Rs,CCR | 1 |  |  |  |  |  |
|  | LDC Rs,EXR | 1 |  |  |  |  |  |
|  | LDC @ERs,CCR | 2 |  |  |  | 1 |  |
|  | LDC @ERs,EXR | 2 |  |  |  | 1 |  |
|  | LDC @(d:16,ERs),CCR | 3 |  |  |  | 1 |  |
|  | LDC @ (d:16,ERs),EXR | 3 |  |  |  | 1 |  |
|  | LDC @ (d:32,ERs),CCR | 5 |  |  |  | 1 |  |
|  | LDC @(d:32,ERs),EXR | 5 |  |  |  | 1 |  |

Rev. 4.00 Feb 24, 2006 page 284 of 322
REJ09B0139-0400

|  |  | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data <br> Access | Word Data <br> Access | Internal <br> Operation |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | Fetch |  |  |  |  |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| MOV | MOV.W Rs, @ (d:16,ERd) | 2 |  |  |  | 1 |  |
|  | MOV.W Rs, @ (d:32,ERd) | 4 |  |  |  | 1 |  |
|  | MOV.W Rs,@-ERd | 1 |  |  |  | 1 | 1 |
|  | MOV.W Rs,@aa:16 | 2 |  |  |  | 1 |  |
|  | MOV.W Rs, @aa:32 | 3 |  |  |  | 1 |  |
|  | MOV.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | MOV.L ERs,ERd | 1 |  |  |  |  |  |
|  | MOV.L @ERs,ERd | 2 |  |  |  | 2 |  |
|  | MOV.L @ (d:16,ERs),ERd | 3 |  |  |  | 2 |  |
|  | MOV.L @ (d:32,ERs),ERd | 5 |  |  |  | 2 |  |
|  | MOV.L @ERs+,ERd | 2 |  |  |  | 2 | 1 |
|  | MOV.L @aa:16,ERd | 3 |  |  |  | 2 |  |
|  | MOV.L @aa:32,ERd | 4 |  |  |  | 2 |  |
|  | MOV.L ERs, @ERd | 2 |  |  |  | 2 |  |
|  | MOV.L ERs, @ (d:16,ERd) | 3 |  |  |  | 2 |  |
|  | MOV.L ERs, @ (d:32,ERd) | 5 |  |  |  | 2 |  |
|  | MOV.L ERs, @-ERd | 2 |  |  |  | 2 | 1 |
|  | MOV.L ERs, @aa:16 | 3 |  |  |  | 2 |  |
|  | MOV.L ERs, @aa:32 | 4 |  |  |  | 2 |  |
| MOVFPE | MOVFPE @:aa:16,Rd | 2 |  |  | $1^{* 2}$ |  |  |
| MOVTPE | MOVTPE Rs, @:aa:16 | 2 |  |  | $1^{* 2}$ |  |  |
| MULXS | MULXS.B Rs,Rd H8S/2600 | 2 |  |  |  |  | $2^{* 3 * 6}$ |
|  | H8S/2000 | 2 |  |  |  |  | 11 |
|  | MULXS.W Rs,ERd H8S/2600 | 2 |  |  |  |  | $3^{* 3 * 6}$ |
|  | H8S/2000 | 2 |  |  |  |  | 19 |
| MULXU | MULXU.B Rs,Rd H8S/2600 | 1 |  |  |  |  | $2^{* 3 * 6}$ |
|  | H8S/2000 | 1 |  |  |  |  | 11 |
|  | MULXU.W Rs,ERd H8S/2600 | 1 |  |  |  |  | $3^{* 3 * 6}$ |
|  | H8S/2000 | 1 |  |  |  |  | 19 |
| NEG | NEG.B Rd | 1 |  |  |  |  |  |
|  | NEG.W Rd | 1 |  |  |  |  |  |
|  | NEG.L ERd | 1 |  |  |  |  |  |
| NOP | NOP | 1 |  |  |  |  |  |
| NOT | NOT.B Rd | 1 |  |  |  |  |  |
|  | NOT.W Rd | 1 |  |  |  |  |  |
|  | NOT.L ERd | 1 |  |  |  |  |  |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| OR | OR.B \#xx:8,Rd | 1 |  |  |  |  |  |
|  | OR.B Rs, Rd | 1 |  |  |  |  |  |
|  | OR.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | OR.W Rs,Rd | 1 |  |  |  |  |  |
|  | OR.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | OR.L ERs,ERd | 2 |  |  |  |  |  |
| ORC | ORC \#xx:8,CCR | 1 |  |  |  |  |  |
|  | ORC \#xx:8,EXR | 2 |  |  |  |  |  |
| POP | POP.W Rn | 1 |  |  |  | 1 | 1 |
|  | POP.L ERn | 2 |  |  |  | 2 | 1 |
| PUSH | PUSH.W Rn | 1 |  |  |  | 1 | 1 |
|  | PUSH.L ERn | 2 |  |  |  | 2 | 1 |
| ROTL | ROTL.B Rd | 1 |  |  |  |  |  |
|  | ROTL.B \#2,Rd | 1 |  |  |  |  |  |
|  | ROTL.W Rd | 1 |  |  |  |  |  |
|  | ROTL.W \#2,Rd | 1 |  |  |  |  |  |
|  | ROTL.L ERd | 1 |  |  |  |  |  |
|  | ROTL.L \#2,ERd | 1 |  |  |  |  |  |
| ROTR | ROTR.B Rd | 1 |  |  |  |  |  |
|  | ROTR.B \#2,Rd | 1 |  |  |  |  |  |
|  | ROTR.W Rd | 1 |  |  |  |  |  |
|  | ROTR.W \#2,Rd | 1 |  |  |  |  |  |
|  | ROTR.L ERd | 1 |  |  |  |  |  |
|  | ROTR.L \#2,ERd | 1 |  |  |  |  |  |
| ROTXL | ROTXL.B Rd | 1 |  |  |  |  |  |
|  | ROTXL.B \#2,Rd | 1 |  |  |  |  |  |
|  | ROTXL.W Rd | 1 |  |  |  |  |  |
|  | ROTXL.W \#2,Rd | 1 |  |  |  |  |  |
|  | ROTXL.L ERd | 1 |  |  |  |  |  |
|  | ROTXL.L \#2,ERd | 1 |  |  |  |  |  |
| ROTXR | ROTXR.B Rd | 1 |  |  |  |  |  |
|  | ROTXR.B \#2,Rd | 1 |  |  |  |  |  |
|  | ROTXR.W Rd | 1 |  |  |  |  |  |
|  | ROTXR.W \#2,Rd | 1 |  |  |  |  |  |
|  | ROTXR.L ERd | 1 |  |  |  |  |  |
|  | ROTXR.L \#2,ERd | 1 |  |  |  |  |  |
| RTE | RTE | 2 |  | $2 / 3^{* 1}$ |  |  | 1 |
| RTS | RTS Normal | 2 |  | 1 |  |  | 1 |
|  | Advanced | 2 |  | 2 |  |  | 1 |


|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| SHAL | SHAL.B Rd | 1 |  |  |  |  |  |
|  | SHAL.B \#2,Rd | 1 |  |  |  |  |  |
|  | SHAL.W Rd | 1 |  |  |  |  |  |
|  | SHAL.W \#2,Rd | 1 |  |  |  |  |  |
|  | SHAL.L ERd | 1 |  |  |  |  |  |
|  | SHAL.L \#2,ERd | 1 |  |  |  |  |  |
| SHAR | SHAR.B Rd | 1 |  |  |  |  |  |
|  | SHAR.B \#2,Rd | 1 |  |  |  |  |  |
|  | SHAR.W Rd | 1 |  |  |  |  |  |
|  | SHAR.W \#2,Rd | 1 |  |  |  |  |  |
|  | SHAR.L ERd | 1 |  |  |  |  |  |
|  | SHAR.L \#2,ERd | 1 |  |  |  |  |  |
| SHLL | SHLL.B Rd | 1 |  |  |  |  |  |
|  | SHLL.B \#2,Rd | 1 |  |  |  |  |  |
|  | SHLL.W Rd | 1 |  |  |  |  |  |
|  | SHLL.W \#2,Rd | 1 |  |  |  |  |  |
|  | SHLL.L ERd | 1 |  |  |  |  |  |
|  | SHLL.L \#2,ERd | 1 |  |  |  |  |  |
| SHLR | SHLR.B Rd | 1 |  |  |  |  |  |
|  | SHLR.B \#2,Rd | 1 |  |  |  |  |  |
|  | SHLR.W Rd | 1 |  |  |  |  |  |
|  | SHLR.W \#2,Rd | 1 |  |  |  |  |  |
|  | SHLR.L ERd | 1 |  |  |  |  |  |
|  | SHLR.L \#2,ERd | 1 |  |  |  |  |  |
| SLEEP | SLEEP | 1 |  |  |  |  | 1 |
| STC | STC.B CCR,Rd | 1 |  |  |  |  |  |
|  | STC.B EXR,Rd | 1 |  |  |  |  |  |
|  | STC.W CCR, @ERd | 2 |  |  |  | 1 |  |
|  | STC.W EXR, @ERd | 2 |  |  |  | 1 |  |
|  | STC.W CCR, @(d:16,ERd) | 3 |  |  |  | 1 |  |
|  | STC.W EXR, @ (d:16,ERd) | 3 |  |  |  | 1 |  |
|  | STC.W CCR, @(d:32,ERd) | 5 |  |  |  | 1 |  |
|  | STC.W EXR, @ (d:32,ERd) | 5 |  |  |  | 1 |  |
|  | STC.W CCR, @-ERd | 2 |  |  |  | 1 | 1 |
|  | STC.W EXR, @-ERd | 2 |  |  |  | 1 | 1 |
|  | STC.W CCR, @aa:16 | 3 |  |  |  | 1 |  |
|  | STC.W EXR, @aa:16 | 3 |  |  |  | 1 |  |
|  | STC.W CCR,@aa:32 | 4 |  |  |  | 1 |  |
|  | STC.W EXR, @aa:32 | 4 |  |  |  | 1 |  |

Rev. 4.00 Feb 24, 2006 page 288 of 322
REJ09B0139-0400

|  |  | Instruction Fetch | Branch <br> Address <br> Read | Stack <br> Operation | Byte Data Access | Word Data Access | Internal Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Mnemonic | I | J | K | L | M | N |
| STM | STM.L (ERn-ERn+1), @-SP | 2 |  | 4 |  |  | 1 |
|  | STM.L(ERn-ERn+2), @-SP | 2 |  | 6 |  |  | 1 |
|  | STM.L(ERn-ERn+3),@-SP | 2 |  | 8 |  |  | 1 |
| STMAC*5 | STMAC MACH,ERd | 1 |  |  |  |  | 0*3 |
|  | STMAC MACL,ERd | 1 |  |  |  |  | $0^{* 3 * 6}$ |
| SUB | SUB.B Rs,Rd | 1 |  |  |  |  |  |
|  | SUB.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | SUB.W Rs,Rd | 1 |  |  |  |  |  |
|  | SUB.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | SUB.L ERs,ERd | 1 |  |  |  |  |  |
| SUBS | SUBS \#1/2/4,ERd | 1 |  |  |  |  |  |
| SUBX | SUBX \#xx:8,Rd | 1 |  |  |  |  |  |
|  | SUBX Rs,Rd | 1 |  |  |  |  |  |
| TAS | TAS @ERd*4 | 2 |  |  | 2 |  |  |
| TRAPA | TRAPA \#x:2 | 2 | 1 | 2/3*1 |  |  | 2 |
|  |  | 2 | 2 | $2 / 3{ }^{* 1}$ |  |  | 2 |
| XOR | XOR.B \#xx:8,Rd | 1 |  |  |  |  |  |
|  | XOR.B Rs,Rd | 1 |  |  |  |  |  |
|  | XOR.W \#xx:16,Rd | 2 |  |  |  |  |  |
|  | XOR.W Rs,Rd | 1 |  |  |  |  |  |
|  | XOR.L \#xx:32,ERd | 3 |  |  |  |  |  |
|  | XOR.L ERs,ERd | 2 |  |  |  |  |  |
| XORC | XORC \#xx:8,CCR | 1 |  |  |  |  |  |
| XORC | XORC \#xx:8,EXR | 2 |  |  |  |  |  |

Notes: 1. 2 when EXR is invalid, 3 when EXR is valid.
2. 5 for concatenated execution, 4 otherwise.
3. An internal operation may require between 0 and 3 additional states, depending on the preceding instruction.
4. Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction.
5. These instructions are supported by the H8S/2600 CPU only.
6. The number of states may differ depending on the product. For details, refer to the relevant microcontroller hardware manual of the product in question.

### 2.7 Bus States During Instruction Execution

Table 2.6 indicates the types of cycles that occur during instruction execution by the CPU. See table 2.4 for the number of states per cycle.

How to Read the Table:


Legend

| $R: B$ | Byte-size read |
| :--- | :--- |
| R:W | Word-size read |
| W:B | Byte-size write |
| W:W | Word-size write |
| 2nd | Address of 2nd word (3rd and 4th bytes) |
| 3rd | Address of 3rd word (5th and 6th bytes) |
| 4th | Address of 4th word (7th and 8th bytes) |
| 5 th | Address of 5th word (9th and 10th bytes) |
| NEXT | Address of next instruction |
| EA | Effective address |
| VEC | Vector address |

Table 2.6 Instruction Execution Cycles


| Instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BLE d:8 | R:W NEXT | R:W EA |  |  |  |  |  |  |  |
| BRA d:16 (BT d:16) | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BRN d:16 (BF d:16) | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BHI d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BLS d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BCC d:16 (BHS d:16) | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BCS d:16 (BLO d:16) | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BNE d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BEQ d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BVC d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BVS d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BPL d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BMI d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BGE d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BLT d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BGT d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BLE d:16 | R:W 2nd | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| BCLR \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BCLR \#xx:3, @ERd | R:W 2nd | R:BEA | R:W NEXT | W:B EA |  |  |  |  |  |
| BCLR \#xx:3,@aa:8 | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BCLR \#xx:3, @aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |


| Instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BCLR \#xx:3,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BCLR Rn,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BCLR Rn, @ERd | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BCLR Rn, @aa:8 | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BCLR Rn, @aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BCLR Rn, @aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BIAND \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BIAND \#xx:3,@ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIAND \#xx:3, @aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIAND \#xx:3,@aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BIAND \#xx:3, @aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BILD \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BILD \#xx:3,@ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BILD \#xx:3,@aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BILD \#xx:3,@aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BILD \#xx:3,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BIOR \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BIOR \#xx:3,@ ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIOR \#xx:3,@ aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIOR \#xx:3,@ aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BIOR \#xx:3,@ aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BIST \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BIST \#xx:3,@ERd | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BIST \#xx:3,@aa:8 | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BIST \#xx:3,@aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BIST \#xx:3,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BIXOR \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BIXOR \#xx:3,@ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIXOR \#xx:3, @aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BIXOR \#xx:3, @aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BIXOR \#xx:3, @aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BLD \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BLD \#xx:3, @ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BLD \#xx:3, @aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BLD \#xx:3, @aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BLD \#xx:3, @aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BNOT \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |


| Instruction |  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BNOT \#xx:3,@ERd |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BNOT \#xx:3,@aa:8 |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BNOT \#xx:3,@aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BNOT \#xx:3,@aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BNOT Rn,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BNOT Rn, @ERd |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BNOT Rn, @aa:8 |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BNOT Rn,@aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BNOT Rn, @aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BOR \#xx:3,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BOR \#xx:3, @ERd |  | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BOR \#xx:3, @aa:8 |  | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BOR \#xx:3,@aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BOR \#xx:3, @aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BSET \#xx:3,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BSET \#xx:3,@ERd |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BSET \#xx:3,@aa:8 |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BSET \#xx:3, @aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BSET \#xx:3, @aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BSET Rn,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BSET Rn, @ERd |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BSET Rn, @aa:8 |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BSET Rn, @aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BSET Rn, @aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BSR d:8 | Normal | R:W NEXT | R:W EA | W:W stack |  |  |  |  |  |  |
|  | Advanced | R:W NEXT | R:W EA | W:W stack (H) | W:W stack (L) |  |  |  |  |  |
| BSR d:16 | Normal | R:W 2nd | Internal operation, 1 state | R:W EA | W:W stack |  |  |  |  |  |
|  | Advanced | R:W 2nd | Internal operation, 1 state | R:W EA | W:W stack (H) | W:W stack (L) |  |  |  |  |
| BST \#xx:3,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BST \#xx:3, @ERd |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BST \#xx:3, @aa:8 |  | R:W 2nd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |  |
| BST \#xx:3,@aa:16 |  | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT | W:B EA |  |  |  |  |
| BST \#xx:3,@aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT | W:B EA |  |  |  |
| BTST \#xx:3,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| BTST \#xx:3,@ERd |  | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |


| Instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BTST \#xx:3,@aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BTST \#xx:3,@aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BTST \#xx:3,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BTST Rn,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BTST Rn, @ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BTST Rn, @aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BTST Rn, @aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BTST Rn, @aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| BXOR \#xx:3,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| BXOR \#xx:3,@ERd | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BXOR \#xx:3,@aa:8 | R:W 2nd | R:B EA | R:W NEXT |  |  |  |  |  |  |
| BXOR \#xx:3,@aa:16 | R:W 2nd | R:W 3rd | R:B EA | R:W NEXT |  |  |  |  |  |
| BXOR \#xx:3,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:B EA | R:W NEXT |  |  |  |  |
| CLRMAC* | R:W NEXT | Internal operation, 1 state*9 |  |  |  |  |  |  |  |
| CMP.B \#xx:8,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| CMP.B Rs, Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| CMP.W \#xx:16,Rd | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| CMP.W Rs,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| CMP.L \#xx:32,ERd | R:W 2nd | R:W 3rd | R:W NEXT |  |  |  |  |  |  |
| CMP.L ERs, ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| DAA Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| DAS Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| DEC.B Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| DEC.W \#1/2,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| DEC.L \#1/2,ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| DIVXS.B Rs,Rd | R:W 2nd | R:W NEXT | Internal ope | 11 states |  |  |  |  |  |
| DIVXS.W Rs,ERd | R:W 2nd | R:W NEXT | Internal ope | 19 states |  |  |  |  |  |
| DIVXU.B Rs,Rd | R:W NEXT | Internal operation, | 11 states |  |  |  |  |  |  |
| DIVXU.W Rs,ERd | R:W NEXT | Internal operation, | 19 states |  |  |  |  |  |  |
| EEPMOV.B | R:W 2nd | R:BEAs *1 | R:B EAd ${ }^{1}$ | R:BEAs *2 | W:B EAd *2 | R:W NEXT |  |  |  |
| EEPMOV.W | R:W 2nd | R:BEAs *1 | R:B EAd*1 | R:BEAs *2 | W:B EAd *2 | R:W NEXT |  |  |  |
| EXTS.W Rd | R:W NEXT |  |  | $\longleftarrow$ Rep | n times*3 |  |  |  |  |
| EXTS.L ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| EXTU.W Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| EXTU.L ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| INC.B Rd | R:W NEXT |  |  |  |  |  |  |  |  |


| Instruction |  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC.W \#1/2,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| INC.L \#1/2,ERd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| JMP @ERn |  | R:W NEXT | R:W EA |  |  |  |  |  |  |  |
| JMP @aa:24 |  | R:W 2nd | Internal operation, 1 state | R:W EA |  |  |  |  |  |  |
| JMP @ @aa:8 | Normal | R:W NEXT | R:W aa:8 | Internal operation, 1 state | R:W EA |  |  |  |  |  |
|  | Advanced | R:W NEXT | R:W aa:8 (H) | R:W aa:8 (L) | Internal operation, 1 state | R:W EA |  |  |  |  |
| JSR @ERn | Normal | R:W NEXT | R:W EA | W:W stack |  |  |  |  |  |  |
|  | Advanced | R:W NEXT | R:W EA | W:W stack (H) | W:W stack (L) |  |  |  |  |  |
| JSR @aa:24 | Normal | R:W 2nd | Internal operation, 1 state | R:W EA | W:W stack |  |  |  |  |  |
|  | Advanced | R:W 2nd | Internal operation, 1 state | R:W EA | W:W stack (H) | W:W stack (L) |  |  |  |  |
| JSR @ @aa:8 | Normal | R:W NEXT | R:W aa:8 | W:W stack | R:W EA |  |  |  |  |  |
|  | Advanced | R:W NEXT | R:W aa:8 (H) | R:W aa:8 (L) | W:W stack (H) | W:W stack (L) | R:W EA |  |  |  |
| LDC \#xx:8,CCR |  | R:W NEXT |  |  |  |  |  |  |  |  |
| LDC \#xx:8,EXR |  | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| LDC Rs,CCR |  | R:W NEXT |  |  |  |  |  |  |  |  |
| LDC Rs,EXR |  | R:W NEXT |  |  |  |  |  |  |  |  |
| LDC @ERs,CCR |  | R:W 2nd | R:W NEXT | R:W EA |  |  |  |  |  |  |
| LDC @ERs,EXR |  | R:W 2nd | R:W NEXT | R:W EA |  |  |  |  |  |  |
| LDC @(d:16,ERs),CCR |  | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA |  |  |  |  |  |
| LDC @(d:16,ERs),EXR |  | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA |  |  |  |  |  |
| LDC @(d:32,ERs),CCR |  | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | R:W EA |  |  |  |
| LDC @(d:32,ERs),EXR |  | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | R:W EA |  |  |  |
| LDC @ERs+,CCR |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W EA |  |  |  |  |  |
| LDC @ERs+,EXR |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W EA |  |  |  |  |  |
| LDC @aa:16,CCR |  | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA |  |  |  |  |  |
| LDC @aa:16,EXR |  | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA |  |  |  |  |  |
| LDC @aa:32,CCR |  | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | R:W EA |  |  |  |  |
| LDC @aa:32,EXR |  | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | R:W EA |  |  |  |  |
| LDM.L @SP+,(ERn-ERn+1) |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W stack (H)*3 | R:W stack (L)*3 |  |  |  |  |


| Instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LDM.L @SP+,(ERn-ERn+2) | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W stack (H)*3 | R:W stack (L)*3 |  |  |  |  |
| LDM.L @SP+,(ERn-ERn+3) | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W stack (H)*3 | R:W stack (L)*3 |  |  |  |  |
| LDMAC ERs,MACH*11 | R:W NEXT | Internal operation, 1 state*9 |  | $\longleftarrow$ Repeate | n times*3$\longrightarrow$ |  |  |  |  |
| LDMAC ERs,MACL*11 | R:W NEXT | Internal operation 1 state*9 |  |  |  |  |  |  |  |
| MAC @ERn+,@ERm+*11 | R:W 2nd | R:W NEXT | R:W EAn | R:W EAm |  |  |  |  |  |
| MOV.B \#xx:8,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| MOV.B Rs,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| MOV.B @ERs,Rd | R:W NEXT | R:B EA |  |  |  |  |  |  |  |
| MOV.B @ (d:16,ERs),Rd | R:W 2nd | R:W NEXT | R:B EA |  |  |  |  |  |  |
| MOV.B @ (d:32,ERs),Rd | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | R:B EA |  |  |  |  |
| MOV.B @ERs+,Rd | R:W NEXT | Internal operation 1 state | R:B EA |  |  |  |  |  |  |
| MOV.B @aa:8,Rd | R:W NEXT | R:B EA |  |  |  |  |  |  |  |
| MOV.B @aa:16,Rd | R:W 2nd | R:W NEXT | R:B EA |  |  |  |  |  |  |
| MOV.B @ aa:32,Rd | R:W 2nd | R:W 3rd | R:W NEXT | R:B EA |  |  |  |  |  |
| MOV.B Rs, @ERd | R:W NEXT | W:B EA |  |  |  |  |  |  |  |
| MOV.B Rs, @ (d:16,ERd) | R:W 2nd | R:W NEXT | W:B EA |  |  |  |  |  |  |
| MOV.B Rs, @(d:32,ERd) | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | W:B EA |  |  |  |  |
| MOV.B Rs, @-ERd | R:W NEXT | Internal operation 1 state | W:B EA |  |  |  |  |  |  |
| MOV.B Rs, @aa:8 | R:W NEXT | W:B EA |  |  |  |  |  |  |  |
| MOV.B Rs,@aa:16 | R:W 2nd | R:W NEXT | W:B EA |  |  |  |  |  |  |
| MOV.B Rs, @aa:32 | R:W 2nd | R:W 3rd | R:W NEXT | W:B EA |  |  |  |  |  |
| MOV.W \#xx:16,Rd | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| MOV.W Rs,Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| MOV.W @ERs,Rd | R:W NEXT | R:W EA |  |  |  |  |  |  |  |
| MOV.W @(d:16,ERs),Rd | R:W 2nd | R:W NEXT | R:W EA |  |  |  |  |  |  |
| MOV.W @(d:32,ERs),Rd | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | R:W EA |  |  |  |  |
| MOV.W @ERs+, Rd | R:W NEXT | Internal operation 1 state | R:W EA |  |  |  |  |  |  |
| MOV.W @aa:16,Rd | R:W 2nd | R:W NEXT | R:W EA |  |  |  |  |  |  |
| MOV.W @aa:32,Rd | R:W 2nd | R:W 3rd | R:W NEXT | R:B EA |  |  |  |  |  |
| MOV.W Rs, @ERd | R:W NEXT | W:W EA |  |  |  |  |  |  |  |


| Instruction | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOV.W Rs, @(d:16,ERd) | R:W 2nd | R:W NEXT | W:W EA |  |  |  |  |  |  |
| MOV.W Rs, @(d:32,ERd) | R:W 2nd | R:W 3rd | R:E 4th | R:W NEXT | W:W EA |  |  |  |  |
| MOV.W Rs, @aa:16 | R:W 2nd | R:W NEXT | W:W EA |  |  |  |  |  |  |
| MOV.W Rs, @aa:32 | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA |  |  |  |  |  |
| MOV.W Rs, @-ERd | R:W NEXT | Internal operation, 1 state | W:W EA |  |  |  |  |  |  |
| MOV.L \#xx:32,ERd | R:W 2nd | R:W 3rd | R:W NEXT |  |  |  |  |  |  |
| MOV.L ERs,ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| MOV.L @ERs,ERd | R:W 2nd | R:W NEXT | R:W EA | R:W EA+2 |  |  |  |  |  |
| MOV.L @ (d:16,ERs),ERd | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA | R:W EA+2 |  |  |  |  |
| MOV.L @ (d:32,ERs),ERd | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | R:W EA | R:W EA+2 |  |  |
| MOV.L @ ERs+,ERd | R:W 2nd | R:W NEXT | Internal operation, 1 state | R:W EA | R:W EA+2 |  |  |  |  |
| MOV.L @ aa:16,ERd | R:W 2nd | R:W 3rd | R:W NEXT | R:W EA | R:W EA+2 |  |  |  |  |
| MOV.L @ aa:32,ERd | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | R:W EA | R:W EA+2 |  |  |  |
| MOV.L ERs, @ERd | R:W 2nd | R:W NEXT | W:W EA | W:W EA+2 |  |  |  |  |  |
| MOV.L ERs, @ (d:16,ERd) | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA | W:W EA+2 |  |  |  |  |
| MOV.L ERs, @ (d:32,ERd) | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | W:W EA | W:W EA+2 |  |  |
| MOV.L ERs, @-ERd | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W EA | W:W EA+2 |  |  |  |  |
| MOV.L ERs,@aa:16 | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA | W:W EA+2 |  |  |  |  |
| MOV.L ERs,@aa:32 | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | W:W EA | W:W EA+2 |  |  |  |
| MOVFPE @aa:16,Rd | R:W 2nd | R:W NEXT | R:W * 4 EA |  |  |  |  |  |  |
| MOVTPE Rs,@aa:16 | R:W 2nd | R:W NEXT | W:B *4 EA |  |  |  |  |  |  |
| MULXS.B Rs,Rd H8S/2600 | R:W 2nd | R:W NEXT | Internal operation, | 2 states*9 |  |  |  |  |  |
| H8S/2000 | R:W 2nd | R:W NEXT | Internal operation, | 11 states |  |  |  |  |  |
| MULXS.W Rs,ERd H8S/2600 | R:W 2nd | R:W NEXT | Internal operation, | 3 states*9 |  |  |  |  |  |
| H8S/2000 | R:W 2nd | R:W NEXT | Internal operation, | 19 states |  |  |  |  |  |
| MULXU.B Rs, Rd H8S/2600 | R:W NEXT | Internal operation, | 2 states*9 |  |  |  |  |  |  |
| H8S/2000 | R:W NEXT | Internal operation, | 11 states |  |  |  |  |  |  |
| MULXU.W Rs,ERd H8S/2600 | R:W NEXT | Internal operation, | 3 states*9 |  |  |  |  |  |  |
| H8S/2000 | R:W NEXT | Internal operation, | 19 states |  |  |  |  |  |  |
| NEG.B Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| NEG.W Rd | R:W NEXT |  |  |  |  |  |  |  |  |
| NEG.L ERd | R:W NEXT |  |  |  |  |  |  |  |  |
| NOP | R:W NEXT |  |  |  |  |  |  |  |  |
| NOT.B Rd | R:W NEXT |  |  |  |  |  |  |  |  |




| Instruction |  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STC EXR,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| STC CCR,@ERd |  | R:W 2nd | R:W NEXT | W:W EA |  |  |  |  |  |  |
| STC EXR,@ERd |  | R:W 2nd | R:W NEXT | W:W EA |  |  |  |  |  |  |
| STC CCR,@(d:16,ERd) |  | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA |  |  |  |  |  |
| STC EXR, @ (d:16,ERd) |  | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA |  |  |  |  |  |
| STC CCR,@(d:32,ERd) |  | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | W:W EA |  |  |  |
| STC EXR,@(d:32,ERd) |  | R:W 2nd | R:W 3rd | R:W 4th | R:W 5th | R:W NEXT | W:W EA |  |  |  |
| STC CCR,@-ERd |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W EA |  |  |  |  |  |
| STC EXR,@-ERd |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W EA |  |  |  |  |  |
| STC CCR,@aa:16 |  | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA |  |  |  |  |  |
| STC EXR,@aa:16 |  | R:W 2nd | R:W 3rd | R:W NEXT | W:W EA |  |  |  |  |  |
| STC CCR,@aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | W:W EA |  |  |  |  |
| STC EXR,@aa:32 |  | R:W 2nd | R:W 3rd | R:W 4th | R:W NEXT | W:W EA |  |  |  |  |
| STM.L(ERn-ERn+1),@-SP |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W stack (H)*3 | W:W stack (L)*3 |  |  |  |  |
| STM.L(ERn-ERn+2),@-SP |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W stack (H)*3 | W:W stack (L)*3 |  |  |  |  |
| STM.L(ERn-ERn+3),@-SP |  | R:W 2nd | R:W NEXT | Internal operation, 1 state | W:W stack (H)*3 | W:W stack (L)*3 |  |  |  |  |
| STMAC MACH,ERd*11 |  | R:W NEXT | *9 |  | «_ Repeated | times*3 $\longrightarrow$ |  |  |  |  |
| STMAC MACL,ERd* ${ }^{\text {11 }}$ |  | R:W NEXT | *9 |  |  |  |  |  |  |  |
| SUB.B Rs, Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| SUB.W \#xx:16,Rd |  | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| SUB.W Rs,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| SUB.L \#xx:32,ERd |  | R:W 2nd | R:W 3rd | R:W NEXT |  |  |  |  |  |  |
| SUB.L ERs,ERd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| SUBS \#1/2/4,ERd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| SUBX \#xx:8,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| SUBX Rs,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| TAS @ ERd ${ }^{* 10}$ |  | R:W 2nd | R:W NEXT | R:B EA | W:B EA |  |  |  |  |  |
| TRAPA \#x:2 | Normal | R:W NEXT | Internal operation, 1 state | W:W stack (L) | W:W stack (H) | W:W stack (EXR) | R:W VEC | Internal operation, 1 state | R:W *8 |  |
|  | Advanced | R:W NEXT | Internal operation, 1 state | W:W stack (L) | W:W stack (H) | W:W stack (EXR) | R:W VEC | R:W VEC+2 | Internal operation 1 state | R:W *8 |
| XOR.B \#xx8,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |


| Instruction |  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XOR.B Rs,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| XOR.W \#xx:16,Rd |  | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| XOR.W Rs,Rd |  | R:W NEXT |  |  |  |  |  |  |  |  |
| XOR.L \#xx:32,ERd |  | R:W 2nd | R:W 3rd | R:W NEXT |  |  |  |  |  |  |
| XOR.L ERs,ERd |  | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| XORC \#xx:8,CCR |  | R:W NEXT |  |  |  |  |  |  |  |  |
| XORC \#xx:8,EXR |  | R:W 2nd | R:W NEXT |  |  |  |  |  |  |  |
| Reset exception handling | Normal | R:W VEC | Internal operation, 1 state | R:W *6 |  |  |  |  |  |  |
|  | Advanced | R:W VEC | R:W VEC+2 | Internal operation, 1 state | R:W *6 |  |  |  |  |  |
| Interrupt exception handling | Normal | R:W *7 | Internal operation, 1 state | W:W stack (L) | W:W stack (H) | W:W stack (EXR) | R:W VEC | Internal operation, 1 state | R:W *8 |  |
|  | Advanced | R:W *7 | Internal operation, 1 state | W:W stack (L) | W:W stack (H) | W:W stack (EXR) | R:W:M VEC | R:W VEC+2 | Internal operation 1 state | R:W *8 |

[^8]
### 2.8 Condition Code Modification

This section indicates the effect of each CPU instruction on the condition code. The notation used in the table is defined below.
$m=\left\{\begin{array}{l}31 \text { for longword operands } \\ 15 \text { for word operands } \\ 7 \text { for byte operands }\end{array}\right.$
Si The i-th bit of the source operand
Di The i-th bit of the destination operand
$\mathrm{Ri} \quad$ The i-th bit of the result

Dn The specified bit in the destination operand

- Not affected
$\downarrow \quad$ Modified according to the result of the instruction (see definition)
$0 \quad$ Always cleared to 0
1 Always set to 1
* Undetermined (no guaranteed value)

Z' Z flag before instruction execution
$C^{\prime} \quad$ C flag before instruction execution

## Table 2.7 Condition Code Modification

| Instruction | H | N | Z | v | C | Definition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\downarrow$ | $\downarrow$ | $\begin{aligned} & \mathrm{H}=\mathrm{Sm}-4 \cdot \mathrm{Dm}-4+\mathrm{Dm}-4 \cdot \overline{\mathrm{Rm}-4}+\mathrm{Sm}-4 \cdot \overline{\mathrm{Rm}-4} \\ & \mathrm{~N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots . . \overline{\mathrm{RO}} \\ & \mathrm{~V}=\mathrm{Sm} \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\overline{\mathrm{Sm}} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \mathrm{Dm}+\mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Rm}} \end{aligned}$ |
| ADDS | - | - | - | - | - |  |
| ADDX | $\uparrow$ | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\downarrow$ | $\begin{aligned} & \mathrm{H}=\mathrm{Sm}-4 \cdot \mathrm{Dm}-4+\mathrm{Dm}-4 \cdot \overline{\mathrm{Rm}-4}+\mathrm{Sm}-4 \cdot \overline{\mathrm{Rm}-4} \\ & \mathrm{~N}=\mathrm{Rm} \\ & \mathrm{Z}=\mathrm{Z} \cdot \overline{\mathrm{Rm}} \cdot \ldots \ldots . \overline{\mathrm{Ro}} \\ & \mathrm{~V}=\mathrm{Sm} \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\overline{\mathrm{Sm}} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \mathrm{Dm}+\mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Rm}} \end{aligned}$ |
| AND | - | $\uparrow$ | $\downarrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots . . \overline{\mathrm{Ro}} \end{aligned}$ |
| ANDC | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\downarrow$ | $\downarrow$ | Stores the corresponding bits of the result. <br> No flags change when the operand is EXR. |
| BAND | - | - | - | - | $\downarrow$ | $\mathrm{C}=\mathrm{C}^{\prime} \cdot \mathrm{Dn}$ |
| Bcc | - | - | - | - | - |  |
| BCLR | - | - | - | - | - |  |
| BIAND | - | - | - | - | $\uparrow$ | $\mathrm{C}=\mathrm{C}^{\prime} \cdot \overline{\mathrm{Dn}}$ |
| BILD | - | - | - | - | $\uparrow$ | $\mathrm{C}=\overline{\mathrm{Dn}}$ |
| BIOR | - | - | - | - | $\downarrow$ | $\mathrm{C}=\mathrm{C}^{\prime}+\overline{\mathrm{Dn}}$ |
| BIST | - | - | - | - | - |  |
| BIXOR | - | - | - | - | $\uparrow$ | $\mathrm{C}=\mathrm{C}^{\prime} \cdot \mathrm{Dn}+\overline{\mathrm{C}^{\prime}} \cdot \overline{\mathrm{Dn}}$ |
| BLD | - | - | - | - | $\uparrow$ | $\mathrm{C}=\mathrm{Dn}$ |
| BNOT | - | - | - | - | - |  |
| BOR | - | - | - | - | $\downarrow$ | $\mathrm{C}=\mathrm{C}^{\prime}+\mathrm{Dn}$ |
| BSET | - | - | - | - | - |  |
| BSR | - | - | - | - | - |  |
| BST | - | - | - | - | - |  |
| BTST | - | - | $\uparrow$ | - | - | $\mathrm{Z}=\overline{\mathrm{D}} \mathrm{n}$ |
| BXOR | - | - | - | - | $\downarrow$ | $\mathrm{C}=\mathrm{C}^{\prime} \cdot \overline{\mathrm{Dn}}+\overline{\mathrm{C}^{\prime}} \cdot \mathrm{Dn}$ |
| CLRMAC* | - | - | - | - | - |  |
| CMP | $\uparrow$ | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\downarrow$ | $\begin{aligned} & \mathrm{H}=\mathrm{Sm}-4 \cdot \overline{\mathrm{Dm}-4}+\overline{\mathrm{Dm}-4} \cdot \mathrm{Rm}-4+\mathrm{Sm}-4 \cdot \mathrm{Rm}-4 \\ & \mathrm{~N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \cdot \overline{\mathrm{R0}} \\ & \mathrm{~V}=\overline{\mathrm{Sm}} \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\overline{\mathrm{Dm}} \cdot \mathrm{Rm}+\mathrm{Sm} \cdot \mathrm{Rm} \end{aligned}$ |


| Instruction | H | N | Z | V | C | Definition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DAA | * | $\downarrow$ | $\uparrow$ | * | $\uparrow$ | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \overline{\mathrm{RO}} \end{aligned}$ <br> C: decimal arithmetic carry |
| DAS | * | $\downarrow$ | $\downarrow$ | * | $\uparrow$ | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \cdot \overline{\mathrm{RO}} \end{aligned}$ <br> C: decimal arithmetic borrow |
| DEC | - | $\uparrow$ | $\uparrow$ | $\uparrow$ | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \cdot \overline{\mathrm{RO}} \\ & \mathrm{~V}=\mathrm{Dm} \cdot \overline{\mathrm{Rm}} \end{aligned}$ |
| DIVXS | - | $\uparrow$ | $\downarrow$ | - | - | $\begin{aligned} & \mathrm{N}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\overline{\mathrm{Sm}} \cdot \mathrm{Dm} \\ & \mathrm{Z}=\overline{\mathrm{Sm}} \cdot \overline{\mathrm{Sm}-1} \cdot \ldots . . . \overline{\mathrm{SO}} \end{aligned}$ |
| DIVXU | - | $\uparrow$ | $\downarrow$ | - | - | $\begin{aligned} & \mathrm{N}=\mathrm{Sm} \\ & \mathrm{Z}=\overline{\mathrm{Sm}} \cdot \overline{\mathrm{Sm}-1} \cdot \ldots . . . \overline{\mathrm{SO}} \end{aligned}$ |
| EEPMOV | - | - | - | - | - |  |
| EXTS | - | $\downarrow$ | $\uparrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots \cdot \overline{\mathrm{RO}} \end{aligned}$ |
| EXTU | - | 0 | $\uparrow$ | 0 | - | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{Ro}}$ |
| INC | - | $\uparrow$ | $\downarrow$ | $\uparrow$ | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \cdot \overline{\mathrm{RO}} \\ & \mathrm{~V}=\overline{\mathrm{Dm}} \cdot \mathrm{Rm} \end{aligned}$ |
| JMP | - | - | - | - | - |  |
| JSR | - | - | - | - | - |  |
| LDC | $\uparrow$ | $\uparrow$ | $\downarrow$ | $\downarrow$ | $\uparrow$ | Stores the corresponding bits of the result. <br> No flags change when the operand is EXR. |
| LDM | - | - | - | - | - |  |
| LDMAC* | - | - | - | - | - |  |
| MAC* | - | - | - | - | - |  |
| MOV | - | $\downarrow$ | $\downarrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots . \overline{\mathrm{RO}} \end{aligned}$ |
| MOVFPE | - | $\uparrow$ | $\downarrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \overline{\mathrm{RO}} \end{aligned}$ |
| MOVTPE | - | $\uparrow$ | $\imath$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \overline{\mathrm{RO}} \end{aligned}$ |
| MULXS | - | $\uparrow$ | $\uparrow$ | - | - | $\begin{aligned} & \mathrm{N}=\mathrm{R} 2 \mathrm{~m} \\ & \mathrm{Z}=\overline{\mathrm{R} 2 \mathrm{~m}} \cdot \overline{\mathrm{R} 2 \mathrm{~m}-1} \cdot \ldots \ldots . \overline{\mathrm{RO}} \end{aligned}$ |


| Instruction | H | N | Z | V | C | Definition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MULXU | - | - | - | - | - |  |
| NEG | $\downarrow$ | $\downarrow$ | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\mathrm{H}=\mathrm{Dm}-4+\mathrm{Rm}-4$ |
|  |  |  |  |  |  | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
|  |  |  |  |  |  | $\mathrm{V}=\mathrm{Dm} \cdot \mathrm{Rm}$ |
|  |  |  |  |  |  | $C=D m+R m$ |
| NOP | - | - | - | - | - |  |
| NOT | - | $\downarrow$ | $\downarrow$ | 0 | - | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
| OR | - | $\uparrow$ | $\downarrow$ | 0 | - | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
| ORC | $\uparrow$ | $\imath$ | $\downarrow$ | $\uparrow$ | $\uparrow$ | Stores the corresponding bits of the result. |
|  |  |  |  |  |  | No flags change when the operand is EXR. |
| POP | - | $\downarrow$ | $\uparrow$ | 0 | - | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
| PUSH |  | $\downarrow$ | $\uparrow$ | 0 | - | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
| ROTL | - | $\downarrow$ | $\uparrow$ | 0 | $\uparrow$ | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots . . \overline{\mathrm{RO}}$ |
|  |  |  |  |  |  | $\mathrm{C}=\mathrm{Dm}$ (1-bit shift) or C = Dm-1 (2-bit shift) |
| ROTR | - | $\uparrow$ | $\uparrow$ | 0 | $\uparrow$ | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
|  |  |  |  |  |  | $\mathrm{C}=\mathrm{D} 0$ (1-bit shift) or $\mathrm{C}=\mathrm{D} 1$ (2-bit shift) |
| ROTXL | - | $\uparrow$ | $\uparrow$ | 0 | $\uparrow$ | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
|  |  |  |  |  |  | $\mathrm{C}=\mathrm{Dm}$ (1-bit shift) or $\mathrm{C}=\mathrm{Dm}$-1 (2-bit shift) |
| ROTXR | - | $\downarrow$ | $\uparrow$ | 0 | $\uparrow$ | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{RO}}$ |
|  |  |  |  |  |  | $\mathrm{C}=\mathrm{D} 0$ (1-bit shift) or C = D1 (2-bit shift) |
| RTE | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\uparrow$ | $\uparrow$ | Stores the corresponding bits of the result. |
| RTS | - | - | - | - | - |  |
| SHAL | - | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\uparrow$ | $\mathrm{N}=\mathrm{Rm}$ |
|  |  |  |  |  |  | $\mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . . \overline{\mathrm{Ro}}$ |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  | $\mathrm{C}=\mathrm{Dm}$ (1-bit shift) or $\mathrm{C}=\mathrm{Dm}-1$ (2-bit shift) |


| Instruction | H | N | Z | v | C | Definition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SHAR | - | $\downarrow$ | $\downarrow$ | 0 | $\downarrow$ | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot . . . . . \cdot \overline{\mathrm{RO}} \\ & \mathrm{C}=\mathrm{D} 0 \text { (1-bit shift) or } \mathrm{C}=\mathrm{D} 1 \text { (2-bit shift) } \end{aligned}$ |
| SHLL | - | $\uparrow$ | $\uparrow$ | 0 | $\downarrow$ | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots \cdot \overline{\mathrm{RO}} \\ & \mathrm{C}=\operatorname{Dm}(1 \text {-bit shift) or } \mathrm{C}=\mathrm{Dm}-1 \text { (2-bit shift) } \end{aligned}$ |
| SHLR | - | 0 | $\uparrow$ | 0 | $\uparrow$ | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \overline{\mathrm{RO}} \\ & \mathrm{C}=\mathrm{D} 0(1 \text {-bit shift) or } \mathrm{C}=\mathrm{D} 1 \text { (2-bit shift) } \end{aligned}$ |
| SLEEP | - | - | - | - | - |  |
| STC | - | - | - | - | - |  |
| STM | - | - | - | - | - |  |
| STMAC* | - | $\uparrow$ | $\uparrow$ | $\uparrow$ | - | $\mathrm{N}=1$ if MAC instruction resulted in negative value in MAC register <br> $Z=1$ if MAC instruction resulted in zero value in MAC register <br> $\mathrm{V}=1$ if MAC instruction resulted in overflow |
| SUB | $\uparrow$ | $\downarrow$ | $\uparrow$ | $\downarrow$ | $\downarrow$ | $\begin{aligned} & \mathrm{H}=\mathrm{Sm}-4 \cdot \overline{\mathrm{Dm}-4}+\overline{\mathrm{Dm}-4} \cdot \mathrm{Rm}-4+\mathrm{Sm}-4 \cdot \mathrm{Rm}-4 \\ & \mathrm{~N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots \ldots . \overline{\mathrm{Ro}} \\ & \mathrm{~V}=\overline{\mathrm{Sm}} \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\overline{\mathrm{Dm}} \cdot \mathrm{Rm}+\mathrm{Sm} \cdot \mathrm{Rm} \end{aligned}$ |
| SUBS | - | - | - | - | - |  |
| SUBX | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\downarrow$ | $\begin{aligned} & \mathrm{H}=\mathrm{Sm}-4 \cdot \overline{\mathrm{Dm}-4}+\overline{\mathrm{Dm}-4} \cdot \mathrm{Rm}-4+\mathrm{Sm}-4 \cdot \mathrm{Rm}-4 \\ & \mathrm{~N}=\mathrm{Rm} \\ & \mathrm{Z}=\mathrm{Z}^{\prime} \cdot \overline{\mathrm{Rm}} \cdot \ldots \ldots . . \overline{\mathrm{Ro}} \\ & \mathrm{~V}=\overline{\mathrm{Sm}} \cdot \mathrm{Dm} \cdot \overline{\mathrm{Rm}}+\mathrm{Sm} \cdot \overline{\mathrm{Dm}} \cdot \mathrm{Rm} \\ & \mathrm{C}=\mathrm{Sm} \cdot \overline{\mathrm{Dm}}+\overline{\mathrm{Dm}} \cdot \mathrm{Rm}+\mathrm{Sm} \cdot \mathrm{Rm} \end{aligned}$ |
| TAS | - | $\uparrow$ | $\uparrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Dm} \\ & \mathrm{Z}=\overline{\mathrm{Dm}} \cdot \overline{\mathrm{Dm}-1} \cdot \ldots \ldots . . \overline{\mathrm{D} 0} \end{aligned}$ |
| TRAPA | - | - | - | - | - |  |
| XOR | - | $\uparrow$ | $\downarrow$ | 0 | - | $\begin{aligned} & \mathrm{N}=\mathrm{Rm} \\ & \mathrm{Z}=\overline{\mathrm{Rm}} \cdot \overline{\mathrm{Rm}-1} \cdot \ldots . . . \cdot \overline{\mathrm{RO}} \end{aligned}$ |
| XORC | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\uparrow$ | $\downarrow$ | Stores the corresponding bits of the result. <br> No flags change when the operand is EXR. |

Note: * These instructions are supported by the H8S/2600 CPU only.


[^0]:    Notes
    For the @aa:8/@aa:16 access range, refer to the relevant microcontroller hardware manual.

[^1]:    Notes

    1. The source operand $<$ EAs $>$ must be located at an even address.
    2. In machine language, MOV.W @ER7+, Rd is identical to POP.W Rd.
[^2]:    Notes

    1. The source operand <EAs> must be located at an even address.
    2. In machine language, MOV.L @R7+, ERd is identical to POP.L ERd.
[^3]:    Notes

    1. The MOV.B Rs, @-ER7 instruction should never be used, because it leaves an odd value in the stack pointer (ER7). For details refer to section 3.3, Exception-Handling State, or to the relevant hardware manual.
    2. Execution of MOV.B RnL, @-ERn or MOV.B RnH, @-ERn first decrements ERn by one, then transfers the designated part ( RnL or RnH ) of the resulting ERn value.
[^4]:    Notes

    1. The destination operand $<\mathrm{EAd}>$ must be located at an even address. 2. In machine language, MOV.W Rs, @-ER7 is identical to PUSH.W Rs.
    2. When MOV.W Rn, @-ERn is executed, the transferred value comes from (value of ERn before execution) - 2 .
[^5]:    Notes

    1. The destination operand $<\mathrm{EAd}>$ must be located at an even address. In machine language, MOV.L ERs, @-ER7 is identical to PUSH.L ERs.
    2. When MOV.L ERn, @-ERn is executed, the transferred value is (value of ERn before execution) - 4 .
[^6]:    Notes：1．The number of states is the number of states required for execution when the instruction and its operands are located in on－chip memory． n is the initial setting of R4L or R4．

    Seven states for saving or restoring two registers，nine states for three registers，or eleven states for four registers． One additional state is required for execution immediately after a MULXU，MULXS，or STMAC instruction．Also，a maximum of three additional states are required for execution of a MULXU instruction within three states after execution of a MAC instruction．For example，if there is a one－state instruction （such as NOP）between a MAC instruction and a MULXU instruction，the MULXU instruction will be two states longer．

    For example，if there is a one－state instruction（such as NOP）between a MAC instruction and a MULXS instruction，the MULXS instruction will be one state longer．

    6．A maximum of three additional states are required for execution of one of these instructions within three states after execution of a MAC instruction． For example，if there is a one－state instruction（such as NOP）between a MAC instruction and one of these instructions，that instruction will be two states longer．

    Values in parentheses（ ）are for the H8S／2000 CPU．Values in square brackets［ ］apply to interrupt control modes 2 and 3.
    Only register ER0，ER1，ER4，or ER5 should be used when using the TAS instruction．
    The number of states may differ depending on the product．For details，refer to the relevant microcontroller hardware manual of the product in question．
    The number of states required for execution of an instruction that transfers data in synchronization with the E clock is variable．
    Set to 1 when a carry or borrow occurs at bit 11；otherwise cleared to 0 ．
    Set to 1 when a carry or borrow occurs at bit 27；otherwise cleared
    Set to 1 when the divisor is negative；otherwise cleared to 0 ．
    MAC instruction results are indicated in the flags when the STMAC instruction is executed．
    One additional state is required for execution when EXR is valid．
    －ヘ ๗－
    ம்
    Set to 1 when the divisor is zero；otherwise cleared to 0

[^7]:    Notes: 1. The letter "r" indicates a register field.
    2. The letters "aa" indicate an absolute address field.

[^8]:    Notes: 1. EAs is the contents of ER5. EAd is the contents of ER6.
    2. EAs is the contents of ER5. EAd is the contents of ER6. Both registers are incremented by 1 after execution of the instruction. $n$ is the initial value of R4L or R4. If $n=0$, these bus cycles are not executed.
    3. Repeated two times to save or restore two registers, three times for three registers, or four times for four registers. For the number of states required for byte-size read or write, refer to the relevant microcontroller hardware manual. Start address after return.

    Start address of the program.
    Prefetch address, equal to two plus the PC value pushed onto the stack. In recovery from sleep mode or software standby mode the read operation is replaced by an internal operation.

    Start address of the interrupt-handling routine.
    9. An internal operation may require between 0 and 3 additional states, depending on the preceding instruction. 10. Only register ER0, ER1, ER4, or ER5 should be used when using the TAS instruction. 11. These instructions are supported by the $\mathrm{H} 8 \mathrm{~S} / 2600 \mathrm{CPU}$ only.

