## 2.6.3 Table of Instructions Classified by Function

Table 2-3 summarizes the instructions in each functional category. The notation used in table 2-3 is defined below.

## **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              | V (overflow) flag in CCR                       |  |  |  |
| С              | C (carry) flag in CCR                          |  |  |  |
| PC             | Program counter                                |  |  |  |
| SP             | Stack pointer                                  |  |  |  |
| #IMM           | Immediate data                                 |  |  |  |
| disp           | Displacement                                   |  |  |  |
| +              | Addition                                       |  |  |  |
| _              | Subtraction                                    |  |  |  |
| ×              | Multiplication                                 |  |  |  |
| ÷              | Division                                       |  |  |  |
| ^              | Logical AND                                    |  |  |  |
| <u></u>        | Logical OR                                     |  |  |  |
| $lue{\oplus}$  | Logical exclusive OR                           |  |  |  |
| $\rightarrow$  | Move                                           |  |  |  |
| 7              | 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 to R7, E0 to E7), and 32-bit registers (ER0 to ER7).

**Table 2-3** Instructions Classified by Function

| Туре                  | Instruction  | Size*1 | Function                                                                                                                                                                                                                                                               |  |
|-----------------------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data transfer         | MOV          | B/W/L  | (EAs) → Rd, Rs → (Ead) Moves data between two general registers or between a general register and memory, or moves immediate data to a general register.                                                                                                               |  |
|                       | MOVFPE       | В      | Cannot be used in the H8S/2633 Series.                                                                                                                                                                                                                                 |  |
|                       | MOVTPE       | В      | Cannot be used in the H8S/2633 Series.                                                                                                                                                                                                                                 |  |
|                       | 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$<br>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+ → 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.                                                                                                                                                                             |  |
| Arithmetic operations | ADD<br>SUB   | B/W/L  | Rd ± Rs → Rd, Rd ± #IMM → Rd 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.) |  |
|                       | ADDX<br>SUBX | В      | Rd $\pm$ Rs $\pm$ C $\rightarrow$ Rd, Rd $\pm$ #IMM $\pm$ C $\rightarrow$ Rd<br>Performs addition or subtraction with carry or borrow on<br>byte data in two general registers, or on immediate data<br>and data in a general register.                                |  |
|                       | INC<br>DEC   | B/W/L  | Rd $\pm$ 1 $\rightarrow$ Rd, Rd $\pm$ 2 $\rightarrow$ Rd<br>Increments or decrements a general register by 1 or 2.<br>(Byte operands can be incremented or decremented by 1 only.)                                                                                     |  |
|                       | ADDS<br>SUBS | L      | Rd $\pm$ 1 $\rightarrow$ Rd, Rd $\pm$ 2 $\rightarrow$ Rd, Rd $\pm$ 4 $\rightarrow$ Rd<br>Adds or subtracts the value 1, 2, or 4 to or from data in a 32-bit register.                                                                                                  |  |
|                       | DAA<br>DAS   | В      | Rd decimal adjust → Rd Decimal-adjusts an addition or subtraction result in a general register by referring to the CCR to produce 4-bit BCD data.                                                                                                                      |  |

| Туре                  | Instruction       | Size*1 | Function                                                                                                                                                                                                                                                                                   |
|-----------------------|-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Arithmetic operations | MULXU             | B/W    | $Rd \times Rs \rightarrow 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    | $Rd \times Rs \rightarrow 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    | Rd $\div$ Rs $\to$ Rd<br>Performs unsigned division on data in two general<br>registers: either 16 bits $\div$ 8 bits $\to$ 8-bit quotient and 8-bit<br>remainder or 32 bits $\div$ 16 bits $\to$ 16-bit quotient and 16-<br>bit remainder.                                                |
|                       | DIVXS             | B/W    | Rd $\div$ Rs $\to$ Rd<br>Performs signed division on data in two general<br>registers: either 16 bits $\div$ 8 bits $\to$ 8-bit quotient and 8-bit<br>remainder or 32 bits $\div$ 16 bits $\to$ 16-bit quotient and 16-<br>bit remainder.                                                  |
|                       | CMP               | B/W/L  | Rd – Rs, Rd – #IMM 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-Rd \rightarrow Rd$ Takes the two's complement (arithmetic complement) of data in a general register.                                                                                                                                                                                    |
|                       | EXTU              | W/L    | Rd (zero extension) → Rd 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    | Rd (sign extension) → Rd 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* <sup>2</sup> | В      | @ERd $-0$ , 1 $\rightarrow$ ( <bit 7=""> of @Erd) Tests memory contents, and sets the most significant bit (bit 7) to 1.</bit>                                                                                                                                                             |
|                       | MAC               |        | (EAs) × (EAd) + MAC → MAC  Performs signed multiplication on memory contents and adds the result to the multiply-accumulate register. The following operations can be performed:  16 bits × 16 bits + 32 bits → 32 bits, saturating  16 bits × 16 bits + 42 bits → 42 bits, non-saturating |

| Туре                                 | Instruction    | Size*1 | Function                                                                                                                                                                                                                                           |
|--------------------------------------|----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Arithmetic operations                | CLRMAC         | _      | $0 \rightarrow \text{MAC}$ Clears the multiply-accumulate register to zero.                                                                                                                                                                        |
|                                      | LDMAC<br>STMAC | L      | Rs 	o MAC, $MAC 	o RdTransfers data between a general register and a multiply-accumulate register.$                                                                                                                                                |
| Logic operations                     | AND            | B/W/L  | $Rd \wedge Rs \rightarrow Rd$ , $Rd \wedge \#IMM \rightarrow Rd$<br>Performs a logical AND operation on a general register and another general register or immediate data.                                                                         |
|                                      | OR             | B/W/L  | Rd ∨ Rs → Rd, Rd ∨ #IMM → Rd Performs a logical OR operation on a general register and another general register or immediate data.                                                                                                                 |
|                                      | XOR            | B/W/L  | $Rd \oplus Rs \rightarrow Rd$ , $Rd \oplus \#IMM \rightarrow Rd$<br>Performs a logical exclusive OR operation on a general register and another general register or immediate data.                                                                |
|                                      | NOT            | B/W/L  | ¬ (Rd) → (Rd) Takes the one's complement of general register contents.                                                                                                                                                                             |
| Shift operations                     | SHAL<br>SHAR   | B/W/L  | Rd (shift) → Rd Performs an arithmetic shift on general register contents. 1-bit or 2-bit shift is possible.                                                                                                                                       |
|                                      | SHLL<br>SHLR   | B/W/L  | Rd (shift) → Rd Performs a logical shift on general register contents. 1-bit or 2-bit shift is possible.                                                                                                                                           |
|                                      | ROTL<br>ROTR   | B/W/L  | Rd (rotate) → Rd<br>Rotates general register contents.<br>1-bit or 2-bit rotation is possible.                                                                                                                                                     |
|                                      | ROTXL<br>ROTXR | B/W/L  | Rd (rotate) → Rd Rotates general register contents through the carry flag. 1-bit or 2-bit rotation is possible.                                                                                                                                    |
| Bit-<br>manipulation<br>instructions | BSET           | В      | 1 → ( <bit-no.> of <ead>) 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.</ead></bit-no.>                                    |
|                                      | BCLR           | В      | 0 → ( <bit-no.> of <ead>) 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.</ead></bit-no.>                                  |
|                                      | BNOT           | В      | ¬ ( <bit-no.> of <ead>) → (<bit-no.> of <ead>) 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.</ead></bit-no.></ead></bit-no.> |

| Туре                          | Instruction | Size*1 | Function                                                                                                                                                                                                                                                                              |
|-------------------------------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit-manipulation instructions | BTST        | В      | ¬ ( <bit-no.> of <ead>) <math>\rightarrow</math> Z 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.</ead></bit-no.>        |
|                               | BAND        | В      | $C \land (\text{sbit-No.}) \to 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       | В      | $C \land \neg$ ( <bit-no.> of <ead>) <math>\rightarrow C</math><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.</ead></bit-no.> |
|                               | BOR         | В      | $C \lor (\text{sbit-No.} \gt \text{of } \text{}) \to C$ ORs the carry flag with a specified bit in a general register or memory operand and stores the result in the carry flag.                                                                                                      |
|                               | BIOR        | В      | $C \lor \neg$ ( <bit-no.> of <ead>) <math>\to C</math><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.</ead></bit-no.>           |
|                               | BXOR        | В      | $C \oplus (\text{sit-No.}) \to 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       | В      | C ⊕ ¬ ( <bit-no.> of <ead>) → C 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.  The bit number is specified by 3-bit immediate data.</ead></bit-no.>                               |
|                               | BLD         | В      | ( <bit-no.> of <ead>) <math>\rightarrow</math> C Transfers a specified bit in a general register or memory operand to the carry flag.</ead></bit-no.>                                                                                                                                 |
|                               | BILD        | В      | ¬ ( <bit-no.> of <ead>) → C Transfers the inverse of a specified bit in a general register or memory operand to the carry flag. The bit number is specified by 3-bit immediate data.</ead></bit-no.>                                                                                  |

| manipulation        | BST   | В | C \ ( <bit-no> 0</bit-no>                                                                                                                                                                                                    | 4 .ΓΛ.J. \                    |                      |
|---------------------|-------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------|
|                     |       |   | $C \rightarrow \text{( of )}$ Transfers the carry flag value to a specified bit in a general register or memory operand.                                                                                                     |                               |                      |
|                     | BIST  | В | $\neg$ C $\rightarrow$ ( <bit-no.> of <ead>)  Transfers the inverse of the carry flag value to a specified bit in a general register or memory operand. The bit number is specified by 3-bit immediate data.</ead></bit-no.> |                               |                      |
| 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 ∨ Z = 1            |
|                     |       |   | BCC(BHS)                                                                                                                                                                                                                     | Carry clear<br>(high or same) | C = 0                |
|                     |       |   | BCS(BLO)                                                                                                                                                                                                                     | Carry set (low)               | C = 1                |
|                     |       |   | BNE                                                                                                                                                                                                                          | Not equal                     | Z = 0                |
|                     |       |   | BEQ                                                                                                                                                                                                                          | Equal                         | Z = 1                |
|                     |       |   | BVC                                                                                                                                                                                                                          | Overflow clear                | V = 0                |
|                     |       |   | BVS                                                                                                                                                                                                                          | Overflow set                  | V = 1                |
|                     |       |   | BPL                                                                                                                                                                                                                          | Plus                          | N = 0                |
|                     |       |   | BMI                                                                                                                                                                                                                          | Minus                         | N = 1                |
|                     |       |   | BGE                                                                                                                                                                                                                          | Greater or equal              | N ⊕ V = 0            |
|                     |       |   | BLT                                                                                                                                                                                                                          | Less than                     | N ⊕ V = 1            |
|                     |       |   | BGT                                                                                                                                                                                                                          | Greater than                  | $Z\vee(N\oplus V)=0$ |
|                     |       |   | BLE                                                                                                                                                                                                                          | Less or equal                 | $Z\lor(N\oplus V)=1$ |
|                     | JMP   |   | Branches uncond                                                                                                                                                                                                              | ditionally to a specified a   | address.             |
|                     | BSR   |   | Branches to a subroutine at a specified address.                                                                                                                                                                             |                               |                      |
|                     | JSR   |   | Branches to a subroutine at a specified address.                                                                                                                                                                             |                               |                      |
|                     | RTS   | _ | Returns from a subroutine                                                                                                                                                                                                    |                               |                      |
| System control      | TRAPA |   | Starts trap-instruction exception handling.                                                                                                                                                                                  |                               |                      |
| instructions        | RTE   |   | Returns from an exception-handling routine.                                                                                                                                                                                  |                               |                      |
|                     | SLEEP | _ | Causes a transition                                                                                                                                                                                                          | on to a power-down sta        | te.                  |

| Туре                            | Instruction       | Size*1 | Function                                                                                                                                                                                                                                                      |
|---------------------------------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| System control instructions     | LDC               | B/W    | (EAs) → CCR, (EAs) → 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)$<br>Transfers CCR or EXR contents to a general register or<br>memory. Although CCR and EXR are 8-bit registers,<br>word-size transfers are performed between them and<br>memory. The upper 8 bits are valid. |
|                                 | ANDC              | В      | CCR $\land$ #IMM $\rightarrow$ CCR, EXR $\land$ #IMM $\rightarrow$ EXR Logically ANDs the CCR or EXR contents with immediate data.                                                                                                                            |
|                                 | ORC               | В      | CCR $\vee$ #IMM $\rightarrow$ CCR, EXR $\vee$ #IMM $\rightarrow$ EXR Logically ORs the CCR or EXR contents with immediate data.                                                                                                                               |
|                                 | XORC              | В      | CCR $\oplus$ #IMM $\rightarrow$ CCR, EXR $\oplus$ #IMM $\rightarrow$ EXR Logically exclusive-ORs the CCR or EXR contents with immediate data.                                                                                                                 |
|                                 | NOP               |        | $PC + 2 \rightarrow PC$ Only increments the program counter.                                                                                                                                                                                                  |
| Block data transfer instruction | EEPMOV.B          | _      | if R4L $\neq$ 0 then Repeat @ER5+ $\rightarrow$ @ER6+ R4L-1 $\rightarrow$ R4L Until R4L = 0 else next;                                                                                                                                                        |
|                                 | EEPMOV.W          | _      | if R4 $\neq$ 0 then Repeat @ER5+ $\rightarrow$ @ER6+ R4-1 $\rightarrow$ 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) ER5: starting source address ER6: starting destination address                                                                                                                                                               |
|                                 | o refers to the c |        | 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

 $<sup>^{*}2</sup>$  When using the TAS instruction, use register ER0, ER1, ER4, or ER5.